@directive-run/core 1.5.0 → 1.6.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.
Files changed (63) hide show
  1. package/dist/adapter-utils.cjs +1 -1
  2. package/dist/adapter-utils.d.cts +1 -1
  3. package/dist/adapter-utils.d.ts +1 -1
  4. package/dist/adapter-utils.js +1 -1
  5. package/dist/chunk-EOLY64E6.cjs +3 -0
  6. package/dist/chunk-EOLY64E6.cjs.map +1 -0
  7. package/dist/chunk-K3KVGWLP.cjs +3 -0
  8. package/dist/chunk-K3KVGWLP.cjs.map +1 -0
  9. package/dist/chunk-OVNPYGYJ.js +3 -0
  10. package/dist/chunk-OVNPYGYJ.js.map +1 -0
  11. package/dist/chunk-QOK7CHOW.js +16 -0
  12. package/dist/chunk-QOK7CHOW.js.map +1 -0
  13. package/dist/chunk-T4ZO4IYL.cjs +16 -0
  14. package/dist/chunk-T4ZO4IYL.cjs.map +1 -0
  15. package/dist/chunk-T6IJUWYR.js +3 -0
  16. package/dist/chunk-T6IJUWYR.js.map +1 -0
  17. package/dist/{helpers-h9PR2JSJ.d.ts → helpers-BwAThjnJ.d.ts} +1 -1
  18. package/dist/{helpers-B1MiHave.d.cts → helpers-CG27mEGG.d.cts} +1 -1
  19. package/dist/index.cjs +4 -1
  20. package/dist/index.cjs.map +1 -1
  21. package/dist/index.d.cts +236 -6
  22. package/dist/index.d.ts +236 -6
  23. package/dist/index.js +4 -1
  24. package/dist/index.js.map +1 -1
  25. package/dist/internals.cjs +1 -1
  26. package/dist/internals.d.cts +41 -5
  27. package/dist/internals.d.ts +41 -5
  28. package/dist/internals.js +1 -1
  29. package/dist/plugins/index.cjs +1 -1
  30. package/dist/plugins/index.cjs.map +1 -1
  31. package/dist/plugins/index.d.cts +1 -1
  32. package/dist/plugins/index.d.ts +1 -1
  33. package/dist/plugins/index.js +1 -1
  34. package/dist/plugins/index.js.map +1 -1
  35. package/dist/{plugins-Bakr7js6.d.ts → plugins-DvrsPhzx.d.cts} +124 -21
  36. package/dist/{plugins-Bakr7js6.d.cts → plugins-DvrsPhzx.d.ts} +124 -21
  37. package/dist/system-5BSCMT63.cjs +2 -0
  38. package/dist/{system-CK3SHMXZ.cjs.map → system-5BSCMT63.cjs.map} +1 -1
  39. package/dist/system-DMJ6XEJ7.js +2 -0
  40. package/dist/{system-744ZPPES.js.map → system-DMJ6XEJ7.js.map} +1 -1
  41. package/dist/testing.cjs +1 -1
  42. package/dist/testing.d.cts +1 -1
  43. package/dist/testing.d.ts +1 -1
  44. package/dist/testing.js +1 -1
  45. package/dist/worker.cjs +1 -1
  46. package/dist/worker.d.cts +1 -1
  47. package/dist/worker.d.ts +1 -1
  48. package/dist/worker.js +1 -1
  49. package/package.json +1 -1
  50. package/dist/chunk-HAF5JCET.js +0 -16
  51. package/dist/chunk-HAF5JCET.js.map +0 -1
  52. package/dist/chunk-M5KZXNZX.js +0 -3
  53. package/dist/chunk-M5KZXNZX.js.map +0 -1
  54. package/dist/chunk-PGUTGWUI.cjs +0 -3
  55. package/dist/chunk-PGUTGWUI.cjs.map +0 -1
  56. package/dist/chunk-SQVKCJHE.cjs +0 -16
  57. package/dist/chunk-SQVKCJHE.cjs.map +0 -1
  58. package/dist/chunk-YCCQ73C6.js +0 -3
  59. package/dist/chunk-YCCQ73C6.js.map +0 -1
  60. package/dist/chunk-ZHS3EW2Z.cjs +0 -3
  61. package/dist/chunk-ZHS3EW2Z.cjs.map +0 -1
  62. package/dist/system-744ZPPES.js +0 -2
  63. package/dist/system-CK3SHMXZ.cjs +0 -2
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkS3CFYDIB_cjs=require('./chunk-S3CFYDIB.cjs'),chunkZHS3EW2Z_cjs=require('./chunk-ZHS3EW2Z.cjs');function w(n){let e=n.inspect();return {isSettled:n.isSettled,unmet:e.unmet,inflight:e.inflight,isWorking:e.unmet.length>0||e.inflight.length>0,hasUnmet:e.unmet.length>0,hasInflight:e.inflight.length>0}}function S(n,e){let r=null,t=null,s=0;return {throttled:((...i)=>{let o=Date.now(),l=o-s;l>=e?(s=o,n(...i)):(t=i,r||(r=setTimeout(()=>{r=null,s=Date.now(),t&&(n(...t),t=null);},e-l)));}),cleanup:()=>{r&&(clearTimeout(r),r=null),t=null;}}}function x(n,e){if(chunkS3CFYDIB_cjs.a&&e==null)throw new Error(`[Directive] ${n}() requires a system instance as the first argument. Received ${e}.`)}function R(n,e){return Object.is(n,e)}function T(n){let e=n.history;if(!e)return null;let r=e.snapshots.map(t=>({id:t.id,timestamp:t.timestamp,trigger:t.trigger}));return {canGoBack:e.currentIndex>0,canGoForward:e.currentIndex<e.snapshots.length-1,currentIndex:e.currentIndex,totalSnapshots:e.snapshots.length,snapshots:r,getSnapshotFacts:t=>{let s=e.snapshots.find(a=>a.id===t);return s?s.facts:null},goTo:t=>e.goTo(t),goBack:t=>e.goBack(t),goForward:t=>e.goForward(t),replay:()=>e.replay(),exportSession:()=>e.export(),importSession:t=>e.import(t),beginChangeset:t=>e.beginChangeset(t),endChangeset:()=>e.endChangeset(),isPaused:e.isPaused,pause:()=>e.pause(),resume:()=>e.resume()}}function I(n,e){let r={};for(let t of e)r[t]=n.facts.$store.get(t);return r}function C(n,e,r){let t=[],s=new Proxy({},{get(i,o){if(typeof o=="string")return e.has(o)?(t.push(o),n.read(o)):n.facts.$store.get(o)},has(i,o){return typeof o!="string"?false:e.has(o)||n.facts.$store.has(o)},ownKeys(){let i=Object.keys(n.facts.$store.toObject()),o=new Set(i);for(let l of e)o.add(l);return [...o]},getOwnPropertyDescriptor(){return {configurable:true,enumerable:true,writable:true}}}),{value:a,deps:u}=chunkS3CFYDIB_cjs.i(()=>r(s));return {value:a,factKeys:Array.from(u),deriveKeys:t}}function P(n,e,r,t){let s=e.length!==n.length||e.some((u,i)=>u!==n[i]),a=t.length!==r.length||t.some((u,i)=>u!==r[i]);return s||a}function q(n,e){if(!n)return {...e};let r="data"in n&&typeof n.data=="object"&&n.data!==null?n.data:n;return {...e,...r}}Object.defineProperty(exports,"createCallbackPlugin",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.d}});Object.defineProperty(exports,"getBridgeFact",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.c}});Object.defineProperty(exports,"requirementGuard",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.e}});Object.defineProperty(exports,"requirementGuardMultiple",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.f}});Object.defineProperty(exports,"setBridgeFact",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.b}});Object.defineProperty(exports,"shallowEqual",{enumerable:true,get:function(){return chunkZHS3EW2Z_cjs.d}});exports.assertSystem=x;exports.buildHistoryState=T;exports.computeInspectState=w;exports.createThrottle=S;exports.defaultEquality=R;exports.depsChanged=P;exports.mergeHydrationFacts=q;exports.pickFacts=I;exports.runTrackedSelector=C;//# sourceMappingURL=adapter-utils.cjs.map
1
+ 'use strict';var chunkS3CFYDIB_cjs=require('./chunk-S3CFYDIB.cjs'),chunkEOLY64E6_cjs=require('./chunk-EOLY64E6.cjs');function w(n){let e=n.inspect();return {isSettled:n.isSettled,unmet:e.unmet,inflight:e.inflight,isWorking:e.unmet.length>0||e.inflight.length>0,hasUnmet:e.unmet.length>0,hasInflight:e.inflight.length>0}}function S(n,e){let r=null,t=null,s=0;return {throttled:((...i)=>{let o=Date.now(),l=o-s;l>=e?(s=o,n(...i)):(t=i,r||(r=setTimeout(()=>{r=null,s=Date.now(),t&&(n(...t),t=null);},e-l)));}),cleanup:()=>{r&&(clearTimeout(r),r=null),t=null;}}}function x(n,e){if(chunkS3CFYDIB_cjs.a&&e==null)throw new Error(`[Directive] ${n}() requires a system instance as the first argument. Received ${e}.`)}function R(n,e){return Object.is(n,e)}function T(n){let e=n.history;if(!e)return null;let r=e.snapshots.map(t=>({id:t.id,timestamp:t.timestamp,trigger:t.trigger}));return {canGoBack:e.currentIndex>0,canGoForward:e.currentIndex<e.snapshots.length-1,currentIndex:e.currentIndex,totalSnapshots:e.snapshots.length,snapshots:r,getSnapshotFacts:t=>{let s=e.snapshots.find(a=>a.id===t);return s?s.facts:null},goTo:t=>e.goTo(t),goBack:t=>e.goBack(t),goForward:t=>e.goForward(t),replay:()=>e.replay(),exportSession:()=>e.export(),importSession:t=>e.import(t),beginChangeset:t=>e.beginChangeset(t),endChangeset:()=>e.endChangeset(),isPaused:e.isPaused,pause:()=>e.pause(),resume:()=>e.resume()}}function I(n,e){let r={};for(let t of e)r[t]=n.facts.$store.get(t);return r}function C(n,e,r){let t=[],s=new Proxy({},{get(i,o){if(typeof o=="string")return e.has(o)?(t.push(o),n.read(o)):n.facts.$store.get(o)},has(i,o){return typeof o!="string"?false:e.has(o)||n.facts.$store.has(o)},ownKeys(){let i=Object.keys(n.facts.$store.toObject()),o=new Set(i);for(let l of e)o.add(l);return [...o]},getOwnPropertyDescriptor(){return {configurable:true,enumerable:true,writable:true}}}),{value:a,deps:u}=chunkS3CFYDIB_cjs.i(()=>r(s));return {value:a,factKeys:Array.from(u),deriveKeys:t}}function P(n,e,r,t){let s=e.length!==n.length||e.some((u,i)=>u!==n[i]),a=t.length!==r.length||t.some((u,i)=>u!==r[i]);return s||a}function q(n,e){if(!n)return {...e};let r="data"in n&&typeof n.data=="object"&&n.data!==null?n.data:n;return {...e,...r}}Object.defineProperty(exports,"createCallbackPlugin",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.d}});Object.defineProperty(exports,"getBridgeFact",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.c}});Object.defineProperty(exports,"requirementGuard",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.e}});Object.defineProperty(exports,"requirementGuardMultiple",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.f}});Object.defineProperty(exports,"setBridgeFact",{enumerable:true,get:function(){return chunkS3CFYDIB_cjs.b}});Object.defineProperty(exports,"shallowEqual",{enumerable:true,get:function(){return chunkEOLY64E6_cjs.f}});exports.assertSystem=x;exports.buildHistoryState=T;exports.computeInspectState=w;exports.createThrottle=S;exports.defaultEquality=R;exports.depsChanged=P;exports.mergeHydrationFacts=q;exports.pickFacts=I;exports.runTrackedSelector=C;//# sourceMappingURL=adapter-utils.cjs.map
2
2
  //# sourceMappingURL=adapter-utils.cjs.map
@@ -1,4 +1,4 @@
1
- import { r as Requirement, o as Plugin, a as Facts, a8 as Schema, H as HistoryAPI, ac as SystemInspection, J as HistoryState } from './plugins-Bakr7js6.cjs';
1
+ import { s as Requirement, p as Plugin, b as Facts, a8 as Schema, H as HistoryAPI, ac as SystemInspection, J as HistoryState } from './plugins-DvrsPhzx.cjs';
2
2
  export { s as shallowEqual } from './utils-BnQajqPu.cjs';
3
3
 
4
4
  /**
@@ -1,4 +1,4 @@
1
- import { r as Requirement, o as Plugin, a as Facts, a8 as Schema, H as HistoryAPI, ac as SystemInspection, J as HistoryState } from './plugins-Bakr7js6.js';
1
+ import { s as Requirement, p as Plugin, b as Facts, a8 as Schema, H as HistoryAPI, ac as SystemInspection, J as HistoryState } from './plugins-DvrsPhzx.js';
2
2
  export { s as shallowEqual } from './utils-BnQajqPu.js';
3
3
 
4
4
  /**
@@ -1,2 +1,2 @@
1
- import {a,i}from'./chunk-EH2Q754B.js';export{d as createCallbackPlugin,c as getBridgeFact,e as requirementGuard,f as requirementGuardMultiple,b as setBridgeFact}from'./chunk-EH2Q754B.js';export{d as shallowEqual}from'./chunk-M5KZXNZX.js';function w(n){let e=n.inspect();return {isSettled:n.isSettled,unmet:e.unmet,inflight:e.inflight,isWorking:e.unmet.length>0||e.inflight.length>0,hasUnmet:e.unmet.length>0,hasInflight:e.inflight.length>0}}function S(n,e){let r=null,t=null,s=0;return {throttled:((...i)=>{let o=Date.now(),l=o-s;l>=e?(s=o,n(...i)):(t=i,r||(r=setTimeout(()=>{r=null,s=Date.now(),t&&(n(...t),t=null);},e-l)));}),cleanup:()=>{r&&(clearTimeout(r),r=null),t=null;}}}function x(n,e){if(a&&e==null)throw new Error(`[Directive] ${n}() requires a system instance as the first argument. Received ${e}.`)}function R(n,e){return Object.is(n,e)}function T(n){let e=n.history;if(!e)return null;let r=e.snapshots.map(t=>({id:t.id,timestamp:t.timestamp,trigger:t.trigger}));return {canGoBack:e.currentIndex>0,canGoForward:e.currentIndex<e.snapshots.length-1,currentIndex:e.currentIndex,totalSnapshots:e.snapshots.length,snapshots:r,getSnapshotFacts:t=>{let s=e.snapshots.find(a=>a.id===t);return s?s.facts:null},goTo:t=>e.goTo(t),goBack:t=>e.goBack(t),goForward:t=>e.goForward(t),replay:()=>e.replay(),exportSession:()=>e.export(),importSession:t=>e.import(t),beginChangeset:t=>e.beginChangeset(t),endChangeset:()=>e.endChangeset(),isPaused:e.isPaused,pause:()=>e.pause(),resume:()=>e.resume()}}function I(n,e){let r={};for(let t of e)r[t]=n.facts.$store.get(t);return r}function C(n,e,r){let t=[],s=new Proxy({},{get(i,o){if(typeof o=="string")return e.has(o)?(t.push(o),n.read(o)):n.facts.$store.get(o)},has(i,o){return typeof o!="string"?false:e.has(o)||n.facts.$store.has(o)},ownKeys(){let i=Object.keys(n.facts.$store.toObject()),o=new Set(i);for(let l of e)o.add(l);return [...o]},getOwnPropertyDescriptor(){return {configurable:true,enumerable:true,writable:true}}}),{value:a,deps:u}=i(()=>r(s));return {value:a,factKeys:Array.from(u),deriveKeys:t}}function P(n,e,r,t){let s=e.length!==n.length||e.some((u,i)=>u!==n[i]),a=t.length!==r.length||t.some((u,i)=>u!==r[i]);return s||a}function q(n,e){if(!n)return {...e};let r="data"in n&&typeof n.data=="object"&&n.data!==null?n.data:n;return {...e,...r}}export{x as assertSystem,T as buildHistoryState,w as computeInspectState,S as createThrottle,R as defaultEquality,P as depsChanged,q as mergeHydrationFacts,I as pickFacts,C as runTrackedSelector};//# sourceMappingURL=adapter-utils.js.map
1
+ import {a,i}from'./chunk-EH2Q754B.js';export{d as createCallbackPlugin,c as getBridgeFact,e as requirementGuard,f as requirementGuardMultiple,b as setBridgeFact}from'./chunk-EH2Q754B.js';export{f as shallowEqual}from'./chunk-T6IJUWYR.js';function w(n){let e=n.inspect();return {isSettled:n.isSettled,unmet:e.unmet,inflight:e.inflight,isWorking:e.unmet.length>0||e.inflight.length>0,hasUnmet:e.unmet.length>0,hasInflight:e.inflight.length>0}}function S(n,e){let r=null,t=null,s=0;return {throttled:((...i)=>{let o=Date.now(),l=o-s;l>=e?(s=o,n(...i)):(t=i,r||(r=setTimeout(()=>{r=null,s=Date.now(),t&&(n(...t),t=null);},e-l)));}),cleanup:()=>{r&&(clearTimeout(r),r=null),t=null;}}}function x(n,e){if(a&&e==null)throw new Error(`[Directive] ${n}() requires a system instance as the first argument. Received ${e}.`)}function R(n,e){return Object.is(n,e)}function T(n){let e=n.history;if(!e)return null;let r=e.snapshots.map(t=>({id:t.id,timestamp:t.timestamp,trigger:t.trigger}));return {canGoBack:e.currentIndex>0,canGoForward:e.currentIndex<e.snapshots.length-1,currentIndex:e.currentIndex,totalSnapshots:e.snapshots.length,snapshots:r,getSnapshotFacts:t=>{let s=e.snapshots.find(a=>a.id===t);return s?s.facts:null},goTo:t=>e.goTo(t),goBack:t=>e.goBack(t),goForward:t=>e.goForward(t),replay:()=>e.replay(),exportSession:()=>e.export(),importSession:t=>e.import(t),beginChangeset:t=>e.beginChangeset(t),endChangeset:()=>e.endChangeset(),isPaused:e.isPaused,pause:()=>e.pause(),resume:()=>e.resume()}}function I(n,e){let r={};for(let t of e)r[t]=n.facts.$store.get(t);return r}function C(n,e,r){let t=[],s=new Proxy({},{get(i,o){if(typeof o=="string")return e.has(o)?(t.push(o),n.read(o)):n.facts.$store.get(o)},has(i,o){return typeof o!="string"?false:e.has(o)||n.facts.$store.has(o)},ownKeys(){let i=Object.keys(n.facts.$store.toObject()),o=new Set(i);for(let l of e)o.add(l);return [...o]},getOwnPropertyDescriptor(){return {configurable:true,enumerable:true,writable:true}}}),{value:a,deps:u}=i(()=>r(s));return {value:a,factKeys:Array.from(u),deriveKeys:t}}function P(n,e,r,t){let s=e.length!==n.length||e.some((u,i)=>u!==n[i]),a=t.length!==r.length||t.some((u,i)=>u!==r[i]);return s||a}function q(n,e){if(!n)return {...e};let r="data"in n&&typeof n.data=="object"&&n.data!==null?n.data:n;return {...e,...r}}export{x as assertSystem,T as buildHistoryState,w as computeInspectState,S as createThrottle,R as defaultEquality,P as depsChanged,q as mergeHydrationFacts,I as pickFacts,C as runTrackedSelector};//# sourceMappingURL=adapter-utils.js.map
2
2
  //# sourceMappingURL=adapter-utils.js.map
@@ -0,0 +1,3 @@
1
+ 'use strict';function m(n,o=new WeakSet){if(n===null||typeof n!="object")return n;let r=n;if(o.has(r)||Object.isFrozen(r))return n;if(o.add(r),Array.isArray(r))for(let s of r)m(s,o);else for(let s of Object.keys(r))m(r[s],o);return Object.freeze(r),n}function b(n){return m(n)}function S(n,o,r){return (...s)=>{try{return r(...s)}catch(u){throw u instanceof Error&&u.message.startsWith("[Directive] ")?new Error(`[Directive] ${n} '${o}': ${u.message.slice(12)}`,{cause:u}):u}}}async function A(n,o,r){let s,u=new Promise((g,d)=>{s=setTimeout(()=>d(new Error(r)),o);});try{return await Promise.race([n,u])}finally{clearTimeout(s);}}function k(n,o=50){let r=new WeakSet;function s(t){if(t===null)return "null";if(t===void 0)return "undefined";let e=typeof t;if(e==="string")return JSON.stringify(t);if(e==="number"||e==="boolean")return String(t);if(e==="function")return '"[function]"';if(e==="symbol")return '"[symbol]"'}function u(t,e){if(r.has(t))return '"[circular]"';r.add(t);let i=e();return r.delete(t),i}function g(t,e){return u(t,()=>`[${t.map(i=>c(i,e+1)).join(",")}]`)}function d(t,e){return u(t,()=>`{${Object.keys(t).sort().map(f=>`${JSON.stringify(f)}:${c(t[f],e+1)}`).join(",")}}`)}function c(t,e){if(e>o)return '"[max depth exceeded]"';if(typeof t=="bigint")return `${t.toString()}n`;let i=s(t);if(i!==void 0)return i;if(t instanceof Date)return `D:${t.toISOString()}`;if(t instanceof RegExp)return `R:${t.source}:${t.flags}`;if(t instanceof Map){let a=[...t.entries()].sort();return `M:${c(a,e+1)}`}if(t instanceof Set){let a=[...t].sort();return `S:${c(a,e+1)}`}return Array.isArray(t)?g(t,e):typeof t=="object"?d(t,e):'"[unknown]"'}return c(n,0)}function x(n,o=50){let r=new Set(["__proto__","constructor","prototype"]),s=new WeakSet;function u(t,e){if(s.has(t))return true;s.add(t);let i=e();return s.delete(t),i}function g(t,e){for(let i of t)if(!c(i,e+1))return false;return true}function d(t,e){for(let i of Object.keys(t))if(r.has(i)||!c(t[i],e+1))return false;return true}function c(t,e){if(e>o)return false;if(t==null||typeof t!="object")return true;let i=t;return Array.isArray(i)?u(i,()=>g(i,e)):u(i,()=>d(i,e))}return c(n,0)}function T(n,o){if(n===o)return true;if(!n||!o)return false;let r=Object.keys(n),s=Object.keys(o);if(r.length!==s.length)return false;for(let u of r)if(n[u]!==o[u])return false;return true}function D(n){let o=k(n),r=5381;for(let s=0;s<o.length;s++)r=(r<<5)+r^o.charCodeAt(s);return (r>>>0).toString(16)}function h(n,o=Date.now()){return n.expiresAt!==void 0&&o>n.expiresAt}function E(n,o=Date.now()){if(!n||typeof n!="object")throw new Error("[Directive] Invalid snapshot: expected an object with 'data' and 'createdAt' properties.");if(!("data"in n))throw new Error("[Directive] Invalid snapshot: missing required 'data' property.");if(!("createdAt"in n)||typeof n.createdAt!="number")throw new Error("[Directive] Invalid snapshot: missing or invalid 'createdAt' property (expected number).");if(h(n,o)){let r=new Date(n.expiresAt).toISOString();throw new Error(`[Directive] Snapshot expired at ${r}. Obtain a fresh snapshot from the source.`)}return n.data}function $(n,o){let r=[];function s(e,i,a,f){r.push({path:e,oldValue:i,newValue:a,type:f});}function u(e,i,a){return e==null?(i!=null&&s(a,e,i,"added"),true):i==null?(s(a,e,i,"removed"),true):false}function g(e,i,a){if(e.length!==i.length){s(a,e,i,"changed");return}for(let f=0;f<e.length;f++)c(e[f],i[f],`${a}[${f}]`);}function d(e,i,a){let f=new Set([...Object.keys(e),...Object.keys(i)]);for(let y of f){let p=a?`${a}.${y}`:y;y in e?y in i?c(e[y],i[y],p):s(p,e[y],void 0,"removed"):s(p,void 0,i[y],"added");}}function c(e,i,a){if(!u(e,i,a)){if(typeof e!="object"||typeof i!="object"){Object.is(e,i)||s(a,e,i,"changed");return}if(Array.isArray(e)&&Array.isArray(i)){g(e,i,a);return}d(e,i,a);}}c(n.data,o.data,"");let t=n.version!==o.version&&(n.version!==void 0||o.version!==void 0);return {identical:r.length===0,changes:r,versionChanged:t,oldVersion:n.version,newVersion:o.version}}function R(n){return "signature"in n&&typeof n.signature=="string"}async function P(n,o){let r=k({data:n.data,createdAt:n.createdAt,expiresAt:n.expiresAt,version:n.version,metadata:n.metadata}),s=await l(r,o);return {...n,signature:s,algorithm:"hmac-sha256"}}async function C(n,o){if(!n.signature||n.algorithm!=="hmac-sha256")return false;let r=k({data:n.data,createdAt:n.createdAt,expiresAt:n.expiresAt,version:n.version,metadata:n.metadata}),s=await l(r,o);return w(n.signature,s)}async function l(n,o){let r=typeof o=="string"?new TextEncoder().encode(o):o,s={name:"HMAC",hash:{name:"SHA-256"}},u=await crypto.subtle.importKey("raw",r,s,false,["sign"]),g=new TextEncoder().encode(n),d=await crypto.subtle.sign("HMAC",u,g);return Array.from(new Uint8Array(d)).map(c=>c.toString(16).padStart(2,"0")).join("")}function w(n,o){if(n.length!==o.length)return false;let r=0;for(let s=0;s<n.length;s++)r|=n.charCodeAt(s)^o.charCodeAt(s);return r===0}function v(n,o=500){try{let r=JSON.stringify(n,(s,u)=>typeof u=="bigint"?`${u}n`:u,2);return r?r.length<=o?r:`${r.slice(0,o)}
2
+ ... (truncated, ${r.length} chars total)`:"[undefined]"}catch{return "[unserializable]"}}exports.a=b;exports.b=S;exports.c=A;exports.d=k;exports.e=x;exports.f=T;exports.g=D;exports.h=h;exports.i=E;exports.j=$;exports.k=R;exports.l=P;exports.m=C;exports.n=v;//# sourceMappingURL=chunk-EOLY64E6.cjs.map
3
+ //# sourceMappingURL=chunk-EOLY64E6.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/utils.ts"],"names":["deepFreeze","value","seen","obj","item","key","freezeSpec","spec","attributeError","category","id","fn","args","e","withTimeout","promise","ms","errorMessage","timeoutId","timeoutPromise","_","reject","stableStringify","maxDepth","stringifyPrimitive","val","type","withCircularGuard","result","stringifyArray","depth","v","stringify","stringifyObject","k","primitive","entries","items","isPrototypeSafe","dangerousKeys","objVal","checkArray","arr","check","checkObject","shallowEqual","a","b","keysA","keysB","hashObject","str","hash","i","isSnapshotExpired","snapshot","now","validateSnapshot","expiredAt","diffSnapshots","oldSnapshot","newSnapshot","changes","pushChange","path","oldValue","newValue","compareNullish","oldObj","newObj","compareArrays","oldArr","newArr","compare","compareObjects","oldRecord","newRecord","allKeys","childPath","versionChanged","isSignedSnapshot","signSnapshot","secret","payload","signature","hmacSha256","verifySnapshotSignature","signedSnapshot","expectedSignature","timingSafeEqual","message","secretBytes","algorithm","messageBytes","safeStringify","data","maxLen","_key"],"mappings":"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","file":"chunk-EOLY64E6.cjs","sourcesContent":["/**\n * Shared utilities for Directive\n */\n\n// ============================================================================\n// Deep freeze\n// ============================================================================\n\n/**\n * Recursively `Object.freeze` an object including nested objects, arrays, and\n * array elements. Uses a `WeakSet` to handle cycles. Skips primitives and\n * already-frozen values to avoid wasted work.\n *\n * Used at definition-registration sites (constraints, derivations, effects,\n * events, prefixed specs) so post-registration mutation of a nested operand\n * cannot silently change the compiled closure's behavior. Prefer\n * {@link freezeSpec} at registration sites — it documents the convention.\n */\nexport function deepFreeze<T>(\n value: T,\n seen: WeakSet<object> = new WeakSet(),\n): T {\n if (value === null || typeof value !== \"object\") {\n return value;\n }\n const obj = value as unknown as object;\n if (seen.has(obj) || Object.isFrozen(obj)) {\n return value;\n }\n seen.add(obj);\n\n if (Array.isArray(obj)) {\n for (const item of obj) {\n deepFreeze(item, seen);\n }\n } else {\n for (const key of Object.keys(obj)) {\n deepFreeze((obj as Record<string, unknown>)[key], seen);\n }\n }\n\n Object.freeze(obj);\n return value;\n}\n\n/**\n * Freeze a definition spec at registration. Centralizes the deepFreeze\n * convention so a new definition arm cannot forget it — every constraint,\n * derivation, effect, event, and prefixed-spec registration funnels through\n * this single helper.\n *\n * @param spec - The definition spec to freeze (mutated in place, returned)\n * @returns The same `spec` value, now deeply frozen\n *\n * @example\n * ```ts\n * // At registration time, freeze user-supplied specs so post-registration\n * // mutation cannot silently change the compiled closure's behavior.\n * const spec = freezeSpec(userPredicate);\n * memoizePredicate(spec);\n * ```\n */\nexport function freezeSpec<T>(spec: T): T {\n return deepFreeze(spec);\n}\n\n/**\n * Wrap a synthesized definition function so a `[Directive]`-prefixed error\n * thrown from inside it is re-thrown with the owning definition's category +\n * id injected, and the original error preserved as `cause`. Non-`[Directive]`\n * errors (user code, native) pass through untouched.\n *\n * Centralizes the owner-attribution wrap shared by the data-form `when`\n * (constraints), `on` (effects), and `compute` (derivations) closures — a\n * `[Directive]`-prefixed throw (e.g. `$matches: string`) is re-pointed at the\n * owning definition so the stack trace blames user config, not the runtime.\n *\n * @param category - The owning definition kind, used in the re-thrown message.\n * @param id - The owning definition's id.\n * @param fn - The synthesized function to wrap.\n * @returns A function with identical signature that re-attributes Directive errors.\n */\nexport function attributeError<A extends unknown[], R>(\n category: \"constraint\" | \"effect\" | \"derivation\",\n id: string,\n fn: (...args: A) => R,\n): (...args: A) => R {\n // Synchronous by design: the wrapped definition functions (memoized\n // predicate `when`/`on` closures, template closures) always return\n // synchronously. A `try/catch` only re-attributes a synchronous throw — an\n // async-returning fn's rejected promise would escape un-re-attributed.\n return (...args: A): R => {\n try {\n return fn(...args);\n } catch (e) {\n if (e instanceof Error && e.message.startsWith(\"[Directive] \")) {\n throw new Error(\n `[Directive] ${category} '${id}': ${e.message.slice(\"[Directive] \".length)}`,\n { cause: e },\n );\n }\n throw e;\n }\n };\n}\n\n/**\n * Execute a promise with a timeout, properly cleaning up the timer.\n * Used by both constraints and resolvers for timeout handling.\n *\n * @param promise - The promise to wrap with a timeout\n * @param ms - Timeout duration in milliseconds\n * @param errorMessage - Error message if timeout occurs\n * @returns The promise result\n * @throws Error if timeout is exceeded\n */\nexport async function withTimeout<T>(\n promise: Promise<T>,\n ms: number,\n errorMessage: string,\n): Promise<T> {\n let timeoutId: ReturnType<typeof setTimeout>;\n\n const timeoutPromise = new Promise<never>((_, reject) => {\n timeoutId = setTimeout(() => reject(new Error(errorMessage)), ms);\n });\n\n try {\n return await Promise.race([promise, timeoutPromise]);\n } finally {\n clearTimeout(timeoutId!);\n }\n}\n\n/**\n * Normalize an error to an Error instance.\n * Ensures consistent error handling throughout the library.\n *\n * @param error - The error to normalize (can be anything)\n * @returns An Error instance\n */\nexport function normalizeError(error: unknown): Error {\n if (error instanceof Error) {\n return error;\n }\n return new Error(String(error));\n}\n\n/**\n * Create a stable JSON string with sorted keys.\n * Handles circular references and deeply nested objects safely.\n *\n * @param value - The value to stringify\n * @param maxDepth - Maximum nesting depth (default: 50)\n * @returns A stable JSON string\n */\nexport function stableStringify(value: unknown, maxDepth = 50): string {\n const seen = new WeakSet();\n\n /** Stringify a primitive value (null, undefined, string, number, boolean, function, symbol). */\n function stringifyPrimitive(val: unknown): string | undefined {\n if (val === null) return \"null\";\n if (val === undefined) return \"undefined\";\n\n const type = typeof val;\n if (type === \"string\") return JSON.stringify(val);\n if (type === \"number\" || type === \"boolean\") return String(val);\n if (type === \"function\") return '\"[function]\"';\n if (type === \"symbol\") return '\"[symbol]\"';\n\n return undefined;\n }\n\n /** Guard against circular references using a seen-set, then delegate to fn. */\n function withCircularGuard(obj: object, fn: () => string): string {\n if (seen.has(obj)) {\n return '\"[circular]\"';\n }\n seen.add(obj);\n const result = fn();\n seen.delete(obj);\n\n return result;\n }\n\n /** Stringify an array with circular reference protection. */\n function stringifyArray(val: unknown[], depth: number): string {\n return withCircularGuard(\n val,\n () => `[${val.map((v) => stringify(v, depth + 1)).join(\",\")}]`,\n );\n }\n\n /** Stringify an object with sorted keys and circular reference protection. */\n function stringifyObject(\n obj: Record<string, unknown>,\n depth: number,\n ): string {\n return withCircularGuard(obj, () => {\n const keys = Object.keys(obj).sort();\n const pairs = keys.map(\n (k) => `${JSON.stringify(k)}:${stringify(obj[k], depth + 1)}`,\n );\n\n return `{${pairs.join(\",\")}}`;\n });\n }\n\n /** Recursively stringify a value with depth limit and circular detection. */\n function stringify(val: unknown, depth: number): string {\n if (depth > maxDepth) {\n return '\"[max depth exceeded]\"';\n }\n\n // BigInt is not JSON-serializable; encode with a trailing 'n' to remain\n // distinct from numeric strings.\n if (typeof val === \"bigint\") {\n return `${val.toString()}n`;\n }\n\n const primitive = stringifyPrimitive(val);\n if (primitive !== undefined) {\n return primitive;\n }\n\n // Typed-value branches: each prefix is bare (no outer quotes) so it can\n // never collide with a JSON-encoded string. `JSON.stringify(\"D:...\")`\n // emits `\"D:...\"` (the wrapping quotes ARE part of the output string),\n // whereas the Date branch emits `D:...` (no quotes). Distinct outputs.\n if (val instanceof Date) {\n return `D:${val.toISOString()}`;\n }\n if (val instanceof RegExp) {\n return `R:${val.source}:${val.flags}`;\n }\n if (val instanceof Map) {\n const entries = [...val.entries()].sort();\n return `M:${stringify(entries, depth + 1)}`;\n }\n if (val instanceof Set) {\n const items = [...val].sort();\n return `S:${stringify(items, depth + 1)}`;\n }\n\n if (Array.isArray(val)) {\n return stringifyArray(val, depth);\n }\n\n if (typeof val === \"object\") {\n return stringifyObject(val as Record<string, unknown>, depth);\n }\n\n return '\"[unknown]\"';\n }\n\n return stringify(value, 0);\n}\n\n/**\n * Check for prototype pollution in an object, including nested objects.\n * Returns true if the object is safe, false if dangerous keys are found.\n *\n * @param obj - The object to check\n * @param maxDepth - Maximum nesting depth to check (default: 50)\n * @returns True if safe, false if dangerous keys found\n */\nexport function isPrototypeSafe(obj: unknown, maxDepth = 50): boolean {\n const dangerousKeys = new Set([\"__proto__\", \"constructor\", \"prototype\"]);\n const seen = new WeakSet();\n\n /** Guard against circular references using a seen-set, then delegate to fn. */\n function withCircularGuard(objVal: object, fn: () => boolean): boolean {\n if (seen.has(objVal)) return true;\n seen.add(objVal);\n const result = fn();\n seen.delete(objVal);\n\n return result;\n }\n\n /** Check array elements for prototype pollution keys. */\n function checkArray(arr: unknown[], depth: number): boolean {\n for (const item of arr) {\n if (!check(item, depth + 1)) {\n return false;\n }\n }\n\n return true;\n }\n\n /** Check object keys and values for prototype pollution. */\n function checkObject(\n objVal: Record<string, unknown>,\n depth: number,\n ): boolean {\n for (const key of Object.keys(objVal)) {\n if (dangerousKeys.has(key)) {\n return false;\n }\n if (!check(objVal[key], depth + 1)) {\n return false;\n }\n }\n\n return true;\n }\n\n /** Recursively check a value tree for dangerous prototype keys. */\n function check(val: unknown, depth: number): boolean {\n if (depth > maxDepth) return false; // Fail safe at max depth - don't assume safety\n if (val === null || val === undefined) return true;\n if (typeof val !== \"object\") return true;\n\n const objVal = val as Record<string, unknown>;\n\n if (Array.isArray(objVal)) {\n return withCircularGuard(objVal, () => checkArray(objVal, depth));\n }\n\n return withCircularGuard(objVal, () => checkObject(objVal, depth));\n }\n\n return check(obj, 0);\n}\n\n/**\n * Shallow equality comparison for objects.\n * Used by React hooks to avoid unnecessary re-renders.\n *\n * @param a - First object\n * @param b - Second object\n * @returns True if objects are shallowly equal\n */\nexport function shallowEqual<T extends Record<string, unknown>>(\n a: T,\n b: T,\n): boolean {\n if (a === b) return true;\n if (!a || !b) return false;\n\n const keysA = Object.keys(a);\n const keysB = Object.keys(b);\n\n if (keysA.length !== keysB.length) return false;\n\n for (const key of keysA) {\n if (a[key] !== b[key]) return false;\n }\n\n return true;\n}\n\n/**\n * Generate a simple hash string from an object.\n * Uses djb2 algorithm on the stable stringified value.\n *\n * **Limitations:**\n * - 32-bit hash output means collision probability increases with data set size\n * (birthday paradox: ~50% collision chance at ~77,000 distinct values)\n * - Suitable for: cache invalidation, change detection, deduplication of small sets\n * - NOT suitable for: cryptographic use, security-sensitive operations, large-scale deduplication\n *\n * For security-sensitive use cases requiring stronger collision resistance,\n * consider using a cryptographic hash like SHA-256.\n *\n * @param value - The value to hash\n * @returns A hex hash string (8 characters, 32 bits)\n */\nexport function hashObject(value: unknown): string {\n const str = stableStringify(value);\n let hash = 5381;\n for (let i = 0; i < str.length; i++) {\n hash = ((hash << 5) + hash) ^ str.charCodeAt(i);\n }\n // Convert to unsigned 32-bit and then to hex\n return (hash >>> 0).toString(16);\n}\n\n// ============================================================================\n// Distributable Snapshot Utilities\n// ============================================================================\n\n/**\n * Distributable snapshot type for type-safe helper functions.\n */\nexport interface DistributableSnapshotLike<T = Record<string, unknown>> {\n data: T;\n createdAt: number;\n expiresAt?: number;\n version?: string;\n metadata?: Record<string, unknown>;\n}\n\n/**\n * Check if a distributable snapshot has expired.\n * Returns false if the snapshot has no expiresAt field.\n *\n * @example\n * ```typescript\n * const snapshot = system.getDistributableSnapshot({ ttlSeconds: 3600 });\n * // ... later ...\n * if (isSnapshotExpired(snapshot)) {\n * // Refresh the snapshot\n * }\n * ```\n *\n * @param snapshot - The snapshot to check\n * @param now - Optional current timestamp (defaults to Date.now())\n * @returns True if the snapshot has expired, false otherwise\n */\nexport function isSnapshotExpired<T>(\n snapshot: DistributableSnapshotLike<T>,\n now: number = Date.now(),\n): boolean {\n return snapshot.expiresAt !== undefined && now > snapshot.expiresAt;\n}\n\n/**\n * Validate a distributable snapshot and return its data.\n * Throws if the snapshot is malformed or has expired.\n *\n * @example\n * ```typescript\n * const cached = JSON.parse(await redis.get(`entitlements:${userId}`));\n * try {\n * const data = validateSnapshot(cached);\n * // Use data.canUseFeature, etc.\n * } catch (e) {\n * // Snapshot invalid or expired, refresh it\n * }\n * ```\n *\n * @example Using custom timestamp for testing\n * ```typescript\n * const snapshot = { data: { test: true }, createdAt: 1000, expiresAt: 2000 };\n * validateSnapshot(snapshot, 1500); // Returns { test: true }\n * validateSnapshot(snapshot, 2500); // Throws: Snapshot expired\n * ```\n *\n * @param snapshot - The snapshot to validate\n * @param now - Optional current timestamp (defaults to Date.now())\n * @returns The snapshot data if valid\n * @throws Error if the snapshot is malformed or has expired\n */\nexport function validateSnapshot<T>(\n snapshot: DistributableSnapshotLike<T>,\n now: number = Date.now(),\n): T {\n // Structural validation\n if (!snapshot || typeof snapshot !== \"object\") {\n throw new Error(\n \"[Directive] Invalid snapshot: expected an object with 'data' and 'createdAt' properties.\",\n );\n }\n if (!(\"data\" in snapshot)) {\n throw new Error(\n \"[Directive] Invalid snapshot: missing required 'data' property.\",\n );\n }\n if (!(\"createdAt\" in snapshot) || typeof snapshot.createdAt !== \"number\") {\n throw new Error(\n \"[Directive] Invalid snapshot: missing or invalid 'createdAt' property (expected number).\",\n );\n }\n\n // Expiration validation\n if (isSnapshotExpired(snapshot, now)) {\n const expiredAt = new Date(snapshot.expiresAt!).toISOString();\n throw new Error(\n `[Directive] Snapshot expired at ${expiredAt}. Obtain a fresh snapshot from the source.`,\n );\n }\n return snapshot.data;\n}\n\n/**\n * Diff result for a single changed value.\n */\nexport interface SnapshotDiffEntry {\n /** The key path that changed (e.g., \"canUseApi\" or \"limits.apiCalls\") */\n path: string;\n /** The value in the old snapshot */\n oldValue: unknown;\n /** The value in the new snapshot */\n newValue: unknown;\n /** Type of change: \"added\", \"removed\", or \"changed\" */\n type: \"added\" | \"removed\" | \"changed\";\n}\n\n/**\n * Result of diffing two snapshots.\n */\nexport interface SnapshotDiff {\n /** Whether the snapshots are identical */\n identical: boolean;\n /** List of changes between snapshots */\n changes: SnapshotDiffEntry[];\n /** Whether the version changed (if both have versions) */\n versionChanged: boolean;\n /** Old version (if available) */\n oldVersion?: string;\n /** New version (if available) */\n newVersion?: string;\n}\n\n/**\n * Compare two distributable snapshots and return the differences.\n * Useful for debugging, audit logs, and webhook payloads.\n *\n * @example\n * ```typescript\n * const oldSnapshot = system.getDistributableSnapshot({ includeVersion: true });\n * system.dispatch({ type: \"upgradePlan\", plan: \"pro\" });\n * const newSnapshot = system.getDistributableSnapshot({ includeVersion: true });\n *\n * const diff = diffSnapshots(oldSnapshot, newSnapshot);\n * if (!diff.identical) {\n * console.log(\"Changes:\", diff.changes);\n * // [{ path: \"canUseApi\", oldValue: false, newValue: true, type: \"changed\" }]\n * }\n * ```\n *\n * @param oldSnapshot - The previous snapshot\n * @param newSnapshot - The new snapshot\n * @returns A diff result with all changes\n */\nexport function diffSnapshots<T = Record<string, unknown>>(\n oldSnapshot: DistributableSnapshotLike<T>,\n newSnapshot: DistributableSnapshotLike<T>,\n): SnapshotDiff {\n const changes: SnapshotDiffEntry[] = [];\n\n /** Push a change entry to the diff results. */\n function pushChange(\n path: string,\n oldValue: unknown,\n newValue: unknown,\n type: SnapshotDiffEntry[\"type\"],\n ): void {\n changes.push({ path, oldValue, newValue, type });\n }\n\n /** Handle null/undefined comparison cases. Returns true if fully handled. */\n function compareNullish(\n oldObj: unknown,\n newObj: unknown,\n path: string,\n ): boolean {\n if (oldObj === null || oldObj === undefined) {\n if (newObj !== null && newObj !== undefined) {\n pushChange(path, oldObj, newObj, \"added\");\n }\n\n return true;\n }\n if (newObj === null || newObj === undefined) {\n pushChange(path, oldObj, newObj, \"removed\");\n\n return true;\n }\n\n return false;\n }\n\n /** Compare two arrays element by element, recursing into each. */\n function compareArrays(\n oldArr: unknown[],\n newArr: unknown[],\n path: string,\n ): void {\n if (oldArr.length !== newArr.length) {\n pushChange(path, oldArr, newArr, \"changed\");\n\n return;\n }\n for (let i = 0; i < oldArr.length; i++) {\n compare(oldArr[i], newArr[i], `${path}[${i}]`);\n }\n }\n\n /** Compare two objects by key union, detecting added/removed/changed. */\n function compareObjects(\n oldRecord: Record<string, unknown>,\n newRecord: Record<string, unknown>,\n path: string,\n ): void {\n const allKeys = new Set([\n ...Object.keys(oldRecord),\n ...Object.keys(newRecord),\n ]);\n\n for (const key of allKeys) {\n const childPath = path ? `${path}.${key}` : key;\n if (!(key in oldRecord)) {\n pushChange(childPath, undefined, newRecord[key], \"added\");\n } else if (!(key in newRecord)) {\n pushChange(childPath, oldRecord[key], undefined, \"removed\");\n } else {\n compare(oldRecord[key], newRecord[key], childPath);\n }\n }\n }\n\n /** Recursively compare two values and record differences. */\n function compare(oldObj: unknown, newObj: unknown, path: string): void {\n if (compareNullish(oldObj, newObj, path)) {\n return;\n }\n\n // Handle primitives\n if (typeof oldObj !== \"object\" || typeof newObj !== \"object\") {\n if (!Object.is(oldObj, newObj)) {\n pushChange(path, oldObj, newObj, \"changed\");\n }\n\n return;\n }\n\n // Handle arrays\n if (Array.isArray(oldObj) && Array.isArray(newObj)) {\n compareArrays(oldObj, newObj, path);\n\n return;\n }\n\n // Handle objects\n compareObjects(\n oldObj as Record<string, unknown>,\n newObj as Record<string, unknown>,\n path,\n );\n }\n\n // Compare data\n compare(oldSnapshot.data, newSnapshot.data, \"\");\n\n // Check version change\n const versionChanged =\n oldSnapshot.version !== newSnapshot.version &&\n (oldSnapshot.version !== undefined || newSnapshot.version !== undefined);\n\n return {\n identical: changes.length === 0,\n changes,\n versionChanged,\n oldVersion: oldSnapshot.version,\n newVersion: newSnapshot.version,\n };\n}\n\n// ============================================================================\n// Snapshot Signing (HMAC)\n// ============================================================================\n\n/**\n * A signed distributable snapshot.\n * Contains the original snapshot plus a cryptographic signature.\n */\nexport interface SignedSnapshot<T = Record<string, unknown>>\n extends DistributableSnapshotLike<T> {\n /** HMAC-SHA256 signature in hex format */\n signature: string;\n /** Signing algorithm used */\n algorithm: \"hmac-sha256\";\n}\n\n/**\n * Check if a snapshot is signed.\n *\n * @param snapshot - The snapshot to check\n * @returns True if the snapshot has a signature\n */\nexport function isSignedSnapshot<T>(\n snapshot: DistributableSnapshotLike<T> | SignedSnapshot<T>,\n): snapshot is SignedSnapshot<T> {\n return \"signature\" in snapshot && typeof snapshot.signature === \"string\";\n}\n\n/**\n * Sign a distributable snapshot using HMAC-SHA256.\n * Creates a tamper-proof signature that can be verified later.\n *\n * **Security Notes:**\n * - Use a cryptographically random secret of at least 32 bytes\n * - Store the secret securely (environment variable, secrets manager)\n * - Never expose the secret to clients\n * - The signature covers all snapshot fields for integrity\n *\n * @example\n * ```typescript\n * const snapshot = system.getDistributableSnapshot({\n * includeDerivations: ['canUseFeature', 'limits'],\n * ttlSeconds: 3600,\n * });\n *\n * // Sign the snapshot (server-side only)\n * const signed = await signSnapshot(snapshot, process.env.SNAPSHOT_SECRET);\n *\n * // Store in JWT, Redis, or send to client\n * const jwt = createJWT({ snapshot: signed });\n *\n * // Later, verify the signature\n * const isValid = await verifySnapshotSignature(signed, process.env.SNAPSHOT_SECRET);\n * if (!isValid) {\n * throw new Error('Snapshot has been tampered with');\n * }\n * ```\n *\n * @param snapshot - The snapshot to sign\n * @param secret - The HMAC secret (string or Uint8Array)\n * @returns A signed snapshot with the signature attached\n */\nexport async function signSnapshot<T>(\n snapshot: DistributableSnapshotLike<T>,\n secret: string | Uint8Array,\n): Promise<SignedSnapshot<T>> {\n // Create a canonical representation for signing\n const payload = stableStringify({\n data: snapshot.data,\n createdAt: snapshot.createdAt,\n expiresAt: snapshot.expiresAt,\n version: snapshot.version,\n metadata: snapshot.metadata,\n });\n\n const signature = await hmacSha256(payload, secret);\n\n return {\n ...snapshot,\n signature,\n algorithm: \"hmac-sha256\",\n };\n}\n\n/**\n * Verify the signature of a signed snapshot.\n * Returns true if the signature is valid, false otherwise.\n *\n * **Important:** Always verify signatures before trusting snapshot data,\n * especially if the snapshot was received from an untrusted source (client, cache).\n *\n * @example\n * ```typescript\n * // Receive signed snapshot from client or cache\n * const snapshot = JSON.parse(cachedData);\n *\n * // Verify before using\n * const isValid = await verifySnapshotSignature(snapshot, process.env.SNAPSHOT_SECRET);\n * if (!isValid) {\n * throw new Error('Invalid snapshot signature - possible tampering');\n * }\n *\n * // Now safe to use snapshot.data\n * if (snapshot.data.canUseFeature.api) {\n * // Grant access\n * }\n * ```\n *\n * @param signedSnapshot - The signed snapshot to verify\n * @param secret - The HMAC secret (must match the signing secret)\n * @returns True if signature is valid, false otherwise\n */\nexport async function verifySnapshotSignature<T>(\n signedSnapshot: SignedSnapshot<T>,\n secret: string | Uint8Array,\n): Promise<boolean> {\n if (!signedSnapshot.signature || signedSnapshot.algorithm !== \"hmac-sha256\") {\n return false;\n }\n\n // Recreate the canonical payload (same as signing)\n const payload = stableStringify({\n data: signedSnapshot.data,\n createdAt: signedSnapshot.createdAt,\n expiresAt: signedSnapshot.expiresAt,\n version: signedSnapshot.version,\n metadata: signedSnapshot.metadata,\n });\n\n const expectedSignature = await hmacSha256(payload, secret);\n\n // Use timing-safe comparison\n return timingSafeEqual(signedSnapshot.signature, expectedSignature);\n}\n\n/**\n * Create HMAC-SHA256 signature of a message.\n * Uses Web Crypto API for cross-platform support (Node.js, browsers, Deno, Bun).\n */\nasync function hmacSha256(\n message: string,\n secret: string | Uint8Array,\n): Promise<string> {\n // Convert secret to Uint8Array if string\n const secretBytes: Uint8Array =\n typeof secret === \"string\" ? new TextEncoder().encode(secret) : secret;\n\n // Import key for HMAC\n const algorithm: HmacImportParams = {\n name: \"HMAC\",\n hash: { name: \"SHA-256\" },\n };\n const key = await crypto.subtle.importKey(\n \"raw\",\n secretBytes as unknown as ArrayBuffer,\n algorithm,\n false,\n [\"sign\"],\n );\n\n // Sign the message\n const messageBytes = new TextEncoder().encode(message);\n const signature = await crypto.subtle.sign(\"HMAC\", key, messageBytes);\n\n // Convert to hex string\n return Array.from(new Uint8Array(signature))\n .map((b) => b.toString(16).padStart(2, \"0\"))\n .join(\"\");\n}\n\n/**\n * Timing-safe string comparison to prevent timing attacks.\n * Both strings should be the same length (hex signatures from same algorithm).\n */\nfunction timingSafeEqual(a: string, b: string): boolean {\n if (a.length !== b.length) {\n return false;\n }\n\n let result = 0;\n for (let i = 0; i < a.length; i++) {\n result |= a.charCodeAt(i) ^ b.charCodeAt(i);\n }\n return result === 0;\n}\n\n/**\n * Safely stringify any value for display. Handles circular references,\n * BigInt, throwing toJSON, and optional truncation.\n *\n * This is the canonical implementation – all packages should import this\n * instead of maintaining local copies.\n */\nexport function safeStringify(data: unknown, maxLen = 500): string {\n try {\n const str = JSON.stringify(\n data,\n (_key, value) => {\n if (typeof value === \"bigint\") {\n return `${value}n`;\n }\n\n return value;\n },\n 2,\n );\n if (!str) {\n return \"[undefined]\";\n }\n if (str.length <= maxLen) {\n return str;\n }\n\n return `${str.slice(0, maxLen)}\\n... (truncated, ${str.length} chars total)`;\n } catch {\n return \"[unserializable]\";\n }\n}\n"]}
@@ -0,0 +1,3 @@
1
+ 'use strict';var chunkS3CFYDIB_cjs=require('./chunk-S3CFYDIB.cjs'),chunkEOLY64E6_cjs=require('./chunk-EOLY64E6.cjs');var $e=new Set(["$eq","$ne","$in","$nin","$exists","$gt","$gte","$lt","$lte","$between","$matches","$startsWith","$endsWith","$contains","$changed"]),en=new Set(["$all","$any","$not"]);var Be=64;function me(r){return typeof r!="object"||r===null||Array.isArray(r)?false:!(r instanceof Date)&&!(r instanceof RegExp)}function _e(r){if(typeof r!="object"||r===null||Array.isArray(r))return false;let t=Object.getPrototypeOf(r);return t===Object.prototype||t===null}function Xe(r){if(!me(r))return false;let t=0,c=false;for(let l of Object.keys(r)){if(l.startsWith("$"))c=true,$e.has(l)||ye(`predicate: unknown operator "${l}" \u2014 looks like a typo. Known operators: ${[...$e].join(", ")}`);else if(c||t===0)return false;t++;}return c?t>0:false}function ot(r){return r===null?false:Array.isArray(r)?r.every(t=>_e(t)&&"fact"in t&&"op"in t):_e(r)}function Pe(r,t,c="",l=new WeakSet,s=0){if(s>Be){chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] predicate depth limit (${Be}) exceeded \u2014 flatten the predicate or split it into multiple constraints. If this is unexpected, check for a cyclic spec object.`),t.bail?.("depth");return}if(Array.isArray(r)){r.forEach((d,h)=>{if(!me(d))return;let C=d;if(typeof C.fact=="string"&&typeof C.op=="string"){let S=c?`${c}[${h}]`:`[${h}]`;t.operator?.(c?`${c}.${C.fact}`:C.fact,C.op,C.value,`${S}.value`);}});return}if(!me(r))return;if(l.has(r)){chunkS3CFYDIB_cjs.a&&console.warn("[Directive] walkPredicate: cyclic predicate spec"),t.bail?.("cycle");return}l.add(r);let o=r;for(let d of ["$all","$any","$not"])if(d in o){if(t.combinator?.(d)===false)return;let C=d==="$not"?[o.$not]:o[d]??[];for(let S of C)Pe(S,t,c,l,s+1);return}for(let d of Object.keys(o)){let h=c?`${c}.${d}`:d;if(d.startsWith("$")){t.strayOperatorKey?.(d,h);continue}let C=o[d];if(Xe(C)){let S=C;for(let N of Object.keys(S))t.operator?.(h,N,S[N],`${h}.${N}`);continue}if(_e(C)){if(t.nested?.(d)===false)continue;Pe(C,t,h,l,s+1);continue}t.literal?.(h,C);}}function st(r){if(!_e(r))return false;let t=false;return Pe(r,{operator(){t=true;},literal(){t=true;},combinator(){t=true;},strayOperatorKey(){t=true;},bail(){t=true;}}),!t}function Ze(r){return me(r)&&Object.hasOwn(r,"$template")&&typeof r.$template=="string"}function sn(r,t=""){function c(s,o,d,h){if(typeof s=="bigint")throw new Error(`[Directive] validatePredicate: bigint operand at "${o}" is not JSON-serializable (JSON.stringify throws on bigint).`);if(s instanceof Set)throw new Error(`[Directive] validatePredicate: Set operand at "${o}" is not JSON-serializable (serializes to {} and loses all members).`);if(s instanceof Map)throw new Error(`[Directive] validatePredicate: Map operand at "${o}" is not JSON-serializable (serializes to {} and loses all entries).`);if(s instanceof RegExp)throw new Error(`[Directive] validatePredicate: RegExp operand at "${o}" is not JSON-serializable (a regex lost to JSON.parse becomes {}). Only a direct $matches operand may be a RegExp.`);if(!(s===null||typeof s!="object")&&!(h>Be)&&!d.has(s)){if(d.add(s),Array.isArray(s)){s.forEach((C,S)=>{c(C,`${o}[${S}]`,d,h+1);});return}for(let C of Object.keys(s))c(s[C],o?`${o}.${C}`:C,d,h+1);}}function l(s,o,d){if(typeof s=="bigint")throw new Error(`[Directive] validatePredicate: bigint operand at "${d}" is not JSON-serializable (JSON.stringify throws on bigint).`);if(s instanceof Set)throw new Error(`[Directive] validatePredicate: Set operand at "${d}" is not JSON-serializable (serializes to {} and loses all members).`);if(s instanceof Map)throw new Error(`[Directive] validatePredicate: Map operand at "${d}" is not JSON-serializable (serializes to {} and loses all entries).`);if(o==="$matches"&&!(s instanceof RegExp))throw new Error(`[Directive] validatePredicate: $matches operand at "${d}" must be a RegExp; got ${s===null?"null":typeof s}. A regex lost to JSON.parse becomes {} \u2014 reify with new RegExp(pattern, flags) before installing.`);if(Array.isArray(s))s.forEach((h,C)=>{c(h,`${d}[${C}]`,new WeakSet,1);});else if(_e(s))for(let h of Object.keys(s))c(s[h],`${d}.${h}`,new WeakSet,1);}if(r instanceof Set)throw new Error(`[Directive] validatePredicate: Set operand${t?` at "${t}"`:""} is not JSON-serializable (serializes to {} and loses all members).`);if(r instanceof Map)throw new Error(`[Directive] validatePredicate: Map operand${t?` at "${t}"`:""} is not JSON-serializable (serializes to {} and loses all entries).`);Pe(r,{operator(s,o,d,h){l(d,o,t?`${t}.${h}`:h);},literal(s,o){l(o,"",t?`${t}.${s}`:s);}});}function It(){return {ids:new WeakMap,next:{v:1},pairs:new Set}}function rt(r,t){let c=r.ids.get(t);return c===void 0&&(c=r.next.v++,r.ids.set(t,c)),c}function pe(r,t,c){if(Object.is(r,t))return true;if(r instanceof Date&&t instanceof Date)return r.getTime()===t.getTime();if(typeof r!="object"||typeof t!="object"||r===null||t===null)return false;let l=c??It(),s=`${rt(l,r)}:${rt(l,t)}`;if(l.pairs.has(s))return true;if(l.pairs.add(s),Array.isArray(r)||Array.isArray(t))return !Array.isArray(r)||!Array.isArray(t)||r.length!==t.length?false:r.every((h,C)=>pe(h,t[C],l));if(r instanceof Set||t instanceof Set){if(!(r instanceof Set)||!(t instanceof Set)||r.size!==t.size)return false;let h=[...t];return [...r].every(C=>h.some(S=>pe(C,S,l)))}if(r instanceof Map||t instanceof Map){if(!(r instanceof Map)||!(t instanceof Map)||r.size!==t.size)return false;let h=[...t.entries()],C=new Array(h.length).fill(false);for(let[S,N]of r){let B=false;for(let U=0;U<h.length;U++){if(C[U])continue;let[K,O]=h[U];if(pe(S,K,l)&&pe(N,O,l)){C[U]=true,B=true;break}}if(!B)return false}return true}let o=Object.keys(r),d=Object.keys(t);return o.length!==d.length?false:o.every(h=>Object.hasOwn(t,h)&&pe(r[h],t[h],l))}function Ve(r){if(r instanceof Date)return r.getTime();if(typeof r=="number"||typeof r=="bigint"||typeof r=="string")return r}function Je(r,t,c){let l=Ve(t),s=Ve(c);if(l===void 0||s===void 0||typeof l!=typeof s)return false;switch(r){case "$gt":return l>s;case "$gte":return l>=s;case "$lt":return l<s;case "$lte":return l<=s;default:return false}}function He(r,t,c,l){switch(r){case "$eq":return pe(t,c);case "$ne":return !pe(t,c);case "$in":return Array.isArray(c)&&c.some(s=>pe(t,s));case "$nin":return Array.isArray(c)&&!c.some(s=>pe(t,s));case "$exists":return c===(t!==void 0);case "$changed":return !pe(t,l);case "$gt":case "$gte":case "$lt":case "$lte":return Je(r,t,c);case "$between":{if(!Array.isArray(c)||c.length!==2)return false;let s=Ve(c[0]),o=Ve(c[1]);return s!==void 0&&o!==void 0&&typeof s==typeof o&&s>o?(ye("$between: reversed pair \u2014 [min, max] required"),false):Je("$gte",t,c[0])&&Je("$lte",t,c[1])}case "$matches":{if(!(c instanceof RegExp))throw new Error("[Directive] $matches: operand must be a RegExp (string operands are no longer accepted; pass /pattern/flags directly).");return typeof t!="string"?false:c.test(t)}case "$startsWith":return typeof t!="string"?false:t.startsWith(String(c));case "$endsWith":return typeof t!="string"?false:t.endsWith(String(c));case "$contains":return typeof t=="string"?t.includes(String(c)):Array.isArray(t)?t.some(s=>pe(s,c)):t instanceof Set?t.has(c):false;default:return false}}function ye(r){chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] ${r}`);}function Tt(r,t,c,l){if(Xe(r)){let s=Object.keys(r);s.length>1&&ye(`predicate: operator object has ${s.length} operators (${s.join(", ")}) \u2014 write the array form or $all instead. The runtime ANDs them as a best-effort fallback.`);for(let o of s)if(!He(o,t,r[o],c))return false;return true}return me(r)?We(r,me(t)?t:Object.create(null),me(c)?c:void 0,l+1):pe(t,r)}function We(r,t,c,l=0){if(l>Be)return ye(`predicate depth limit (${Be}) exceeded \u2014 flatten the predicate or split it into multiple constraints. If this is unexpected, check for a cyclic spec object.`),false;if(Array.isArray(r))return r.every(s=>{if(!me(s))return false;let{fact:o,op:d,value:h}=s;return He(d,t?.[o],h,c?.[o])});if(!me(r))return !!r;if("$all"in r)return r.$all.every(s=>We(s,t,c,l+1));if("$any"in r)return r.$any.some(s=>We(s,t,c,l+1));if("$not"in r)return !We(r.$not,t,c,l+1);for(let s of Object.keys(r)){if($e.has(s))return ye(`predicate: operator "${s}" mixed with fact keys \u2014 wrap operators in a per-fact object`),false;if(!Tt(r[s],t?.[s],c?.[s],l))return false}return true}function Le(r,t,c,l=""){let s=[];if(Array.isArray(r)){for(let o of r){if(!me(o))continue;let{fact:d,op:h,value:C}=o,S=t?.[d];s.push({path:l+d,op:h,expected:C,actual:S,pass:He(h,S,C,c?.[d])});}return s}if(!me(r))return s;for(let o of ["$all","$any","$not"])if(o in r){let d=o==="$not"?[r.$not]:r[o],h=[];for(let N of d)h.push(...Le(N,t,c,l));let C=h.filter(N=>N.pass).length,S;return o==="$all"?S=h.length===0||C===h.length:o==="$any"?S=h.length>0&&C>0:S=!h.every(N=>N.pass),s.push({path:l||o,op:o,expected:d.length,actual:C,pass:S,children:h}),s}for(let o of Object.keys(r)){if($e.has(o))continue;let d=r[o],h=t?.[o],C=l+o;if(Xe(d))for(let S of Object.keys(d))s.push({path:C,op:S,expected:d[S],actual:h,pass:He(S,h,d[S],c?.[o])});else me(d)?s.push(...Le(d,me(h)?h:Object.create(null),me(c?.[o])?c?.[o]:void 0,`${C}.`)):s.push({path:C,op:"$eq",expected:d,actual:h,pass:pe(h,d)});}return s}var it=new WeakMap;function Ie(r){if(r===null||typeof r!="object")throw new Error(`[Directive] memoizePredicate: predicate must be a plain object or array; got ${typeof r}`);let t=it.get(r);if(t)return t;let c=(l,s)=>We(r,l,s);return it.set(r,c),c}function at(r,t=""){let c=new Set;return Pe(r,{operator(l){c.add(t+l);},literal(l){c.add(t+l);},strayOperatorKey(l){$e.has(l)||ye(`extractDeps: unknown operator "${l}" \u2014 skipping. Known operators: ${[...$e].join(", ")}`);}}),c}var ct=/^[A-Za-z_][A-Za-z0-9_]*$/;function jt(r){return typeof r=="symbol"||r==null?"":String(r)}function At(r,t){return typeof r=="symbol"?(ye("template: cannot interpolate a symbol value \u2014 using empty string"),""):r===void 0?(ye(`template: ${t?`key "${t}" is `:""}undefined \u2014 using empty string`),""):r===null?(ye(`template: ${t?`key "${t}" is `:""}null \u2014 using empty string`),""):String(r)}function Ge(r,t){let c=r.$template,l="",s=0;for(;s<c.length;){if(c[s]==="$"&&c[s+1]==="$"&&c[s+2]==="{"){l+="${",s+=3;continue}if(c[s]==="$"&&c[s+1]==="{"){let o=c.indexOf("}",s+2);if(o===-1){ye(`template: unterminated "\${" in ${JSON.stringify(c)}`),l+=c.slice(s);break}let d=c.slice(s+2,o);if(!ct.test(d))ye(`template: invalid placeholder "\${${d}}" \u2014 not an identifier`);else {let h=t!=null&&Object.hasOwn(t,d),C=h?t[d]:void 0;h?l+=At(C,d):(ye(`template: unknown key "${d}"`),l+=jt(C));}s=o+1;continue}l+=c[s],s++;}return l}function an(r){let t=new Set,c=r.$template,l=0;for(;l<c.length;){if(c[l]==="$"&&c[l+1]==="$"&&c[l+2]==="{"){l+=3;continue}if(c[l]==="$"&&c[l+1]==="{"){let s=c.indexOf("}",l+2);if(s===-1)break;let o=c.slice(l+2,s);ct.test(o)&&t.add(o),l=s+1;continue}l++;}return t}function lt(r,t){return r.map(c=>chunkEOLY64E6_cjs.d(t?.[c])).join("|")}function ft(r,t,c){let l=r.$set,s=c??{};for(let o of Object.keys(l)){let d=l[o];if(Ze(d))t[o]=Ge(d,s);else if(me(d)&&Object.hasOwn(d,"$ref")&&typeof d.$ref=="string"){let h=d.$ref;Object.hasOwn(s,h)||ye(`applyPatch: $ref "${h}" is missing from event payload \u2014 assigning undefined to fact "${o}"`),t[o]=s[h];}else t[o]=d;}}var Te=class extends Error{constructor(c,l,s,o,d=true){super(c);this.source=l;this.sourceId=s;this.context=o;this.recoverable=d;this.name="DirectiveError";}};function Ft(){return {create(r){return r}}}function Kt(){return {create(r){return r}}}function Wt(r){return r}function Bt(r){return r}function un(r){return r._mode==="single"}function dn(r){return r._mode==="namespaced"}function de(r){if(!r)return;let t=Object.assign(Object.create(null),r);return Array.isArray(t.tags)&&Object.freeze(t.tags),Object.freeze(t)}function mn(r){return typeof r=="object"&&r!==null&&Object.hasOwn(r,"compute")&&typeof r.compute=="function"}function _t(r){return typeof r=="boolean"?{enabled:r,maxSnapshots:100}:{enabled:true,maxSnapshots:r.maxSnapshots??100}}function ut(r){let{historyOption:t,facts:c,store:l,onSnapshot:s,onHistoryChange:o}=r,{enabled:d,maxSnapshots:h}=_t(t),C=[],S=-1,N=1,B=false,U=false,K=[],O=null,F=-1;function q(){return l.toObject()}function A(){let z=q();try{return structuredClone(z)}catch{try{return JSON.parse(JSON.stringify(z))}catch{return {...z}}}}function Y(z){if(!chunkEOLY64E6_cjs.e(z)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}l.batch(()=>{for(let[V,te]of Object.entries(z)){if(V==="__proto__"||V==="constructor"||V==="prototype"){console.warn(`[Directive] Skipping dangerous key "${V}" during fact restoration`);continue}c[V]=te;}});}return {get isEnabled(){return d},get isRestoring(){return U},get isPaused(){return B},get snapshots(){return [...C]},get currentIndex(){return S},takeSnapshot(z){if(!d||B)return {id:-1,timestamp:Date.now(),facts:{},trigger:z};let V={id:N++,timestamp:Date.now(),facts:A(),trigger:z};for(S<C.length-1&&C.splice(S+1),C.push(V),S=C.length-1;C.length>h;)C.shift(),S--;return s?.(V),V},restore(z){if(d){B=true,U=true;try{Y(z.facts);}finally{B=false,U=false;}}},goBack(z=1){if(!d||C.length===0)return;let V=S,te=S,ne=K.find(p=>S>p.startIndex&&S<=p.endIndex);if(ne)te=ne.startIndex;else if(K.find(u=>S===u.startIndex)){let u=K.find(R=>R.endIndex<S&&S-R.endIndex<=z);te=u?u.startIndex:Math.max(0,S-z);}else te=Math.max(0,S-z);if(V===te)return;S=te;let m=C[S];m&&(this.restore(m),o?.(V,te));},goForward(z=1){if(!d||C.length===0)return;let V=S,te=S,ne=K.find(p=>S>=p.startIndex&&S<p.endIndex);if(ne?te=ne.endIndex:te=Math.min(C.length-1,S+z),V===te)return;S=te;let m=C[S];m&&(this.restore(m),o?.(V,te));},goTo(z){if(!d)return;let V=C.findIndex(m=>m.id===z);if(V===-1){console.warn(`[Directive] Snapshot ${z} not found`);return}let te=S;S=V;let ne=C[S];ne&&(this.restore(ne),o?.(te,V));},replay(){if(!d||C.length===0)return;S=0;let z=C[0];z&&this.restore(z);},export(){return JSON.stringify({version:1,snapshots:C,currentIndex:S})},import(z){if(d)try{let V=JSON.parse(z);if(typeof V!="object"||V===null)throw new Error("[Directive] Invalid history data: expected object");if(V.version!==1)throw new Error(`[Directive] Unsupported history export version: ${V.version}`);if(!Array.isArray(V.snapshots))throw new Error("[Directive] Invalid history data: snapshots must be an array");if(typeof V.currentIndex!="number")throw new Error("Invalid history data: currentIndex must be a number");for(let ne of V.snapshots){if(typeof ne!="object"||ne===null)throw new Error("[Directive] Invalid snapshot: expected object");if(typeof ne.id!="number"||typeof ne.timestamp!="number"||typeof ne.trigger!="string"||typeof ne.facts!="object")throw new Error("Invalid snapshot structure");if(!chunkEOLY64E6_cjs.e(ne.facts))throw new Error("[Directive] Invalid fact data: potential prototype pollution detected in nested objects")}C.length=0,C.push(...V.snapshots),S=V.currentIndex;let te=C[S];te&&this.restore(te);}catch(V){console.error("[Directive] Failed to import history data:",V);}},beginChangeset(z){d&&(O=z,F=S);},endChangeset(){!d||O===null||(S>F&&K.push({label:O,startIndex:F,endIndex:S}),O=null,F=-1);},pause(){B=true;},resume(){B=false;}}}function dt(){let r={id:-1,timestamp:0,facts:{},trigger:""};return {isEnabled:false,isRestoring:false,isPaused:false,snapshots:[],currentIndex:-1,takeSnapshot:()=>r,restore:()=>{},goBack:()=>{},goForward:()=>{},goTo:()=>{},replay:()=>{},export:()=>"{}",import:()=>{},beginChangeset:()=>{},endChangeset:()=>{},pause:()=>{},resume:()=>{}}}var gt=new WeakMap;function zt(r,t){if(t)return t(r);let c=gt.get(r);if(c!==void 0)return c;let{type:l,...s}=r,o=chunkEOLY64E6_cjs.d(s),d=`${l}:${o}`;return gt.set(r,d),d}function Qe(r,t,c){return {requirement:r,id:zt(r,c),fromConstraint:t}}function wn(r){return t=>({type:r,...t})}function Dn(r,t){return r.type===t}function kn(r){return t=>t.type===r}var Me=class r{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 r;for(let c of this.map.values())t.add(c);return t}diff(t){let c=[],l=[];for(let s of this.map.values())t.has(s.id)||c.push(s);for(let s of t.map.values())this.map.has(s.id)||l.push(s);return {added:c,removed:l}}};var Nt=5e3;function mt(r){let{definitions:t,facts:c,requirementKeys:l={},defaultTimeout:s=Nt,onEvaluate:o,onError:d}=r,h=new Map;function C(n,a){if(!a||typeof a.when=="function")return;let v=a.when;if(chunkS3CFYDIB_cjs.a&&(a.async&&console.warn(`[Directive] constraint "${n}": data \`when\` is always sync; \`async: true\` will be ignored`),a.deps&&console.warn(`[Directive] constraint "${n}": data \`when\` cannot be combined with explicit \`deps\` \u2014 deps are tracked automatically`)),a.deps&&(a.deps=void 0),S(v))throw new Error(`[Directive] constraint "${n}": $changed is effects-only \u2014 constraint when has no prev snapshot. Move the change-detection to an effect, or use a boolean derivation as a synthetic prev.`);if(v===null||typeof v!="object")throw new Error(`[Directive] memoizePredicate: predicate must be a plain object or array; got ${typeof v}`);chunkS3CFYDIB_cjs.a&&st(v)&&console.warn(`[Directive] constraint '${n}': data spec has no operators, combinators, or clauses \u2014 looks like a config object passed by mistake. Either pass a predicate like { phase: 'red' } or a function.`),chunkEOLY64E6_cjs.a(v);let E=Ie(v);a.when=chunkEOLY64E6_cjs.b("constraint",n,P=>E(P)),h.set(n,v),a.async&&(a.async=false);}function S(n){let a=false;return Pe(n,{operator(v,E){E==="$changed"&&(a=true);},strayOperatorKey(v){v==="$changed"&&(a=true);}}),a}for(let n of Object.keys(t))C(n,t[n]);let N=new Map,B=new Set,U=new Set,K=new Map,O=new Map,F=new Set,q=new Map,A=new Map,Y=false,se=new Set,z=new Set,V=new Map,te=[],ne=new Map;function m(n,a){t[n]&&(V.has(n)||V.set(n,new Set),V.get(n).add(a));}function p(){V.clear();for(let[n,a]of Object.entries(t))if(a.after)for(let v of a.after)m(v,n);}function u(n,a,v,E,P){if(v.has(n))return;if(E.has(n)){let ae=a.indexOf(n),ce=[...a.slice(ae),n].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${ce}. Remove one of the \`after\` dependencies to break the cycle.`)}E.add(n),a.push(n);let Q=t[n];if(Q?.after)for(let ae of Q.after)t[ae]&&u(ae,a,v,E,P);a.pop(),E.delete(n),v.add(n),P.push(n);}function R(){let n=new Set,a=new Set,v=[];for(let E of Object.keys(t))u(E,[],n,a,v);te=v,ne=new Map(te.map((E,P)=>[E,P]));}R(),p();function j(){for(let[n,a]of Object.entries(t))if(a.after)for(let v of a.after)t[v]||console.warn(`[Directive] Constraint "${n}" references unknown constraint "${v}" in \`after\`. This dependency will be ignored. Check for typos or ensure the constraint exists.`);}chunkS3CFYDIB_cjs.a&&j();function Z(n,a){return a.async!==void 0?a.async:!!U.has(n)}function re(n){let a=t[n];if(!a)throw new Error(`[Directive] Unknown constraint: ${n}`);let v=Z(n,a);v&&U.add(n);let E={id:n,priority:a.priority??0,isAsync:v,lastResult:null,isEvaluating:false,error:null,lastResolvedAt:null,after:a.after??[],hitCount:0,lastActiveAt:null};return N.set(n,E),E}function le(n){return N.get(n)??re(n)}function be(n,a){if(n.size!==a.size||n.size===0)return false;for(let v of a)if(!n.has(v))return false;return true}function D(n,a){for(let v of a){let E=O.get(v);E&&(E.delete(n),E.size===0&&O.delete(v));}}function f(n,a){for(let v of a)O.has(v)||O.set(v,new Set),O.get(v).add(n);}function x(n){let a=K.get(n);a&&(D(n,a),K.delete(n));}function T(n){V.delete(n);for(let a of V.values())a.delete(n);}function H(n,a){let v=K.get(n)??new Set;be(v,a)||(D(n,v),f(n,a),K.set(n,a));}function ee(n,a){let v=a.when;if(a.deps)return q.set(n,new Set(a.deps)),v(c);let E=chunkS3CFYDIB_cjs.i(()=>v(c));return q.set(n,E.deps),E.value}function ue(n,a,v){a.lastResult=v,v&&(a.hitCount++,a.lastActiveAt=Date.now()),a.isEvaluating=false,o?.(n,v);}function ve(n,a,v){a.error=v instanceof Error?v:new Error(String(v)),a.lastResult=false,a.isEvaluating=false,d?.(n,v);}function he(n,a,v){return U.add(n),a.isAsync=true,chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] Constraint "${n}" returned a Promise but was not marked as async. Add \`async: true\` to the constraint definition to avoid this warning and improve performance.`),v.then(E=>(ue(n,a,E),E)).catch(E=>(ve(n,a,E),false))}function Re(n){let a=t[n];if(!a)return false;let v=le(n);v.isEvaluating=true,v.error=null;try{let E=ee(n,a);return E instanceof Promise?he(n,v,E):(ue(n,v,E),E)}catch(E){return ve(n,v,E),false}}async function we(n){let a=t[n];if(!a)return false;let v=le(n),E=a.timeout??s;if(v.isEvaluating=true,v.error=null,a.deps?.length){let P=new Set(a.deps);H(n,P),q.set(n,P);}try{let P=a.when(c),Q=await chunkEOLY64E6_cjs.c(P,E,`Constraint "${n}" timed out after ${E}ms`);return v.lastResult=Q,Q&&(v.hitCount++,v.lastActiveAt=Date.now()),v.isEvaluating=!1,o?.(n,Q),Q}catch(P){return v.error=P instanceof Error?P:new Error(String(P)),v.lastResult=false,v.isEvaluating=false,d?.(n,P),false}}let Ee=10;function Oe(n,a){if(n==null)return [];if(Array.isArray(n)){let v=n.filter(E=>E!=null);return chunkS3CFYDIB_cjs.a&&v.length>Ee&&a&&console.warn(`[Directive] Constraint "${a}" produced ${v.length} requirements. Consider splitting into multiple constraints for better performance.`),v}return [n]}function De(n){let a=t[n];if(!a)return {requirements:[],deps:new Set};let v=a.require;if(typeof v=="function"){let{value:P,deps:Q}=chunkS3CFYDIB_cjs.i(()=>v(c));return {requirements:Oe(P,n),deps:Q}}return {requirements:Oe(v,n),deps:new Set}}function W(n,a){if(a.size===0)return;let v=K.get(n)??new Set;for(let E of a)v.add(E);f(n,a),K.set(n,v);}let oe=null;function ge(){return oe||(oe=Object.keys(t).sort((n,a)=>{let v=le(n),P=le(a).priority-v.priority;if(P!==0)return P;let Q=ne.get(n)??0,ae=ne.get(a)??0;return Q-ae})),oe}for(let n of Object.keys(t))re(n);function xe(n){for(let[a,v]of Object.entries(n))v.async&&!v.deps&&console.warn(`[Directive] Async constraint "${a}" has no \`deps\` declared. Auto-tracking cannot work across async boundaries. Add \`deps: ["key1", "key2"]\` to enable dependency tracking.`);}chunkS3CFYDIB_cjs.a&&xe(t);function je(n){return !t[n]||B.has(n)||z.has(n)?true:se.has(n)}function y(n){let a=N.get(n);if(!a||a.after.length===0)return true;for(let v of a.after)if(!je(v))return false;return true}function b(n){let a=q.get(n);a!==void 0&&H(n,a),z.add(n),A.set(n,[]);}function w(n,a,v){if(a!==void 0){let E=new Set(a);for(let P of v)E.add(P);H(n,E);}else W(n,v);}function I(n,a,v){if(a.length===0){A.set(n,[]);return}let E=a.map(P=>Qe(P,n,l[P.type]));for(let P of E)v.add(P);A.set(n,E);}function L(n,a){for(let v of n)a.add(v);}function e(n,a,v){if(B.has(n))return;if(!a){b(n);return}z.delete(n);let E=q.get(n),P,Q;try{let ae=De(n);P=ae.requirements,Q=ae.deps;}catch(ae){d?.(n,ae),b(n);return}w(n,E,Q),I(n,P,v);}function i(n,a){let v=[],E=[];for(let P of n){if(y(P)){E.push(P);continue}v.push(P);let Q=A.get(P);Q&&L(Q,a);}return {blocked:v,ready:E}}function g(n,a){let v=[];for(let E of n){let P=Re(E);if(P instanceof Promise){v.push({id:E,promise:P});continue}e(E,P,a);}return v}async function M(n,a){let v=await Promise.all(n.map(async({id:E,promise:P})=>({id:E,active:await P})));for(let{id:E,active:P}of v)e(E,P,a);}async function k(n,a){let{blocked:v,ready:E}=i(n,a);if(E.length===0)return v;let P=[],Q=[];for(let ce of E)le(ce).isAsync?Q.push(ce):P.push(ce);let ae=g(P,a);if(ae.length>0&&await M(ae,a),Q.length>0){let ce=Q.map(Se=>({id:Se,promise:we(Se)}));await M(ce,a);}return v}function $(n,a){for(let v of n){let E=O.get(v);if(E)for(let P of E)B.has(P)||a.add(P);}}function _(n){for(let a of F)B.has(a)||n.add(a);F.clear();}function X(n){let a=new Set;return $(n,a),_(a),a}function G(n,a,v){for(let E of n){if(a.has(E))continue;let P=A.get(E);P&&L(P,v);}}return {async evaluate(n){let a=new Me;z.clear();let v=ge(),E=B.size===0?v:v.filter(ce=>!B.has(ce)),P;if(!Y||!n||n.size===0)P=E,Y=true;else {let ce=X(n);P=[...ce],G(E,ce,a);}let Q=P,ae=P.length+1;for(;Q.length>0&&ae>0;){let ce=Q.length;if(Q=await k(Q,a),Q.length===ce)break;ae--;}return a.all()},getState(n){return N.get(n)},getDependencies(n){return K.get(n)},getAllStates(){return [...N.values()]},disable(n){if(!N.has(n)){console.warn(`[Directive] constraints.disable("${n}") \u2014 no such constraint`);return}B.add(n),oe=null,A.delete(n),x(n),q.delete(n);},enable(n){if(!N.has(n)){console.warn(`[Directive] constraints.enable("${n}") \u2014 no such constraint`);return}B.delete(n),oe=null,F.add(n);},isDisabled(n){return B.has(n)},invalidate(n){let a=O.get(n);if(a)for(let v of a)F.add(v);},markResolved(n){se.add(n);let a=N.get(n);a&&(a.lastResolvedAt=Date.now());let v=V.get(n);if(v)for(let E of v)F.add(E);},isResolved(n){return se.has(n)},registerDefinitions(n){let a=false;for(let[v,E]of Object.entries(n))t[v]=E,C(v,t[v]),re(v),F.add(v),E.after?.length&&(a=true);oe=null,a&&R(),p();},assignDefinition(n,a){if(!t[n])throw new Error(`[Directive] Cannot assign constraint "${n}" \u2014 it does not exist. Use register() to create it.`);t[n]=a,h.delete(n),C(n,t[n]),re(n),F.add(n),oe=null,R(),p();},unregisterDefinition(n){t[n]&&(delete t[n],N.delete(n),B.delete(n),U.delete(n),F.delete(n),z.delete(n),se.delete(n),A.delete(n),q.delete(n),x(n),T(n),oe=null,R(),p());},async callOne(n,a){if(!t[n])throw new Error(`[Directive] Cannot call constraint "${n}" \u2014 it does not exist.`);if(B.has(n))return [];let E=le(n),P;if(E.isAsync)P=await we(n);else {let ce=Re(n);P=ce instanceof Promise?await ce:ce;}if(!P)return [];let{requirements:Q}=De(n);if(Q.length===0)return [];let ae=[];for(let ce of Q){let Se=a?{...ce,...a}:ce;ae.push(Qe(Se,n,l[Se.type]));}return ae},setRequirementKey(n,a){l[n]=a;},removeRequirementKey(n){delete l[n];},getWhenSpec(n){return h.get(n)},explainWhen(n){let a=h.get(n);if(a)return Le(a,c)}}}function pt(r){let{definitions:t,facts:c,onCompute:l,onInvalidate:s,onError:o}=r,d=3,h=new Map;function C(D,f){if(typeof f!="object"||f===null||!Object.hasOwn(f,"compute"))return;let x=f,T=x.compute,H;if(typeof T=="function")H=T;else if(Ze(T))chunkEOLY64E6_cjs.a(T),H=ee=>Ge(T,ee);else if(typeof T=="object"&&T!==null){chunkEOLY64E6_cjs.a(T);let ee=Ie(T);H=chunkEOLY64E6_cjs.b("derivation",D,ue=>ee(ue));}else if(T!==void 0)throw new Error(`[Directive] memoizePredicate: predicate must be a plain object or array; got ${typeof T}`);if(H){t[D]=H;let ee=de(x.meta);ee&&h.set(D,ee);}}for(let[D,f]of Object.entries(t))C(D,f);let S=new Map,N=new Map,B=new Map,U=new Map,K=0,O=new Set,F=false,q=100,A;function Y(D,f){let x=S.has(D)?U:B,T=x.get(D);T?.delete(f),T&&T.size===0&&x.delete(D);}function se(D,f){let x=t[D]?U:B,T=x.get(D);T||(T=new Set,x.set(D,T)),T.add(f);}function z(D){let f=S.get(D);if(f)for(let x of f.dependencies)Y(x,D);}function V(D){let f=U.get(D);if(f){K++;try{for(let x of f)le(x);}finally{K--;}U.delete(D);}}function te(D){delete t[D],S.delete(D),N.delete(D),O.delete(D),h.delete(D);}function ne(D){if(!t[D])throw new Error(`[Directive] Unknown derivation: ${D}`);let x={id:D,compute:()=>p(D),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false,stableRunCount:0,depsStable:false};return S.set(D,x),x}function m(D){return S.get(D)??ne(D)}function p(D){let f=m(D),x=t[D];if(!x)throw new Error(`[Directive] Unknown derivation: ${D}`);if(f.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${D}`);f.isComputing=true;try{let T=f.cachedValue,H,ee;if(f.depsStable&&f.dependencies.size>0)H=x(c,A),ee=f.dependencies;else {let ue=chunkS3CFYDIB_cjs.i(()=>x(c,A));H=ue.value,ee=ue.deps,f.dependencies.size>0&&u(ee,f.dependencies)?(f.stableRunCount++,f.stableRunCount>=d&&(f.depsStable=!0)):f.stableRunCount=0;}return f.cachedValue=H,f.isStale=!1,R(D,ee),l&&l(D,H,T,[...ee]),H}catch(T){throw o?.(D,T),T}finally{f.isComputing=false;}}function u(D,f){if(D.size!==f.size)return false;for(let x of f)if(!D.has(x))return false;return true}function R(D,f){let x=m(D),T=x.dependencies;if(!u(T,f)){for(let H of T)Y(H,D);for(let H of f)se(H,D);x.dependencies=f;}}function j(D){for(let f of D){let x=N.get(f);if(x)for(let T of x)T();}}function Z(){if(!(K>0||F)){F=true;try{let D=0;for(;O.size>0;){if(++D>q){let x=[...O];throw O.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${q} iterations. Remaining: ${x.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let f=[...O];O.clear(),j(f);}}finally{F=false;}}}function re(D,f){let x=U.get(D);if(x)for(let T of x)f.push(T);}function le(D,f=new Set){let x=[D];for(;x.length>0;){let T=x.pop();if(f.has(T))continue;f.add(T);let H=S.get(T);!H||H.isStale||(H.isStale=true,H.depsStable=false,H.stableRunCount=0,s?.(T),O.add(T),re(T,x));}}return A=new Proxy({},{get(D,f){if(typeof f=="symbol"||chunkS3CFYDIB_cjs.l.has(f)||!t[f])return;chunkS3CFYDIB_cjs.k(f);let x=m(f);return x.isStale&&p(f),x.cachedValue},set(){return false},deleteProperty(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),{get(D){let f=m(D);return f.isStale&&p(D),f.cachedValue},isStale(D){return S.get(D)?.isStale??true},invalidate(D){let f=B.get(D);if(!f)return;K++;let x=new Set;try{for(let T of f)le(T,x);}finally{K--,Z();}},invalidateMany(D){K++;let f=new Set;try{for(let x of D){let T=B.get(x);if(T)for(let H of T)le(H,f);}}finally{K--,Z();}},invalidateAll(){K++;try{for(let D of S.values())D.isStale||(D.isStale=!0,D.depsStable=!1,D.stableRunCount=0,O.add(D.id));}finally{K--,Z();}},subscribe(D,f){for(let x of D){let T=x;N.has(T)||N.set(T,new Set),N.get(T).add(f);}return ()=>{for(let x of D){let T=x,H=N.get(T);H?.delete(f),H&&H.size===0&&N.delete(T);}}},getProxy(){return A},getDependencies(D){return m(D).dependencies},registerDefinitions(D){for(let[f,x]of Object.entries(D))typeof x=="function"?t[f]=x:C(f,x),ne(f);},assignDefinition(D,f){if(!t[D])throw new Error(`[Directive] Cannot assign derivation "${D}" \u2014 it does not exist. Use register() to create it.`);typeof f=="function"?(t[D]=f,h.delete(D)):(h.delete(D),C(D,f));let x=S.get(D);x&&(x.isStale=true,x.depsStable=false,x.stableRunCount=0,O.add(D)),Z();},unregisterDefinition(D){t[D]&&(z(D),V(D),te(D),Z());},getMeta(D){return h.get(D)},callOne(D){if(!t[D])throw new Error(`[Directive] Cannot call derivation "${D}" \u2014 it does not exist.`);return p(D)}}}var Vt=3;function yt(r){let{definitions:t,facts:c,store:l,onRun:s,onError:o}=r,d=new Map,h=null,C=false,S=new Map;function N(m){let p=t[m];if(!p)throw new Error(`[Directive] Unknown effect: ${m}`);S.delete(m);let u=null,R=false;if(p.deps)u=new Set(p.deps),R=true;else if(p.on!==void 0){if(!ot(p.on))throw new Error(`[Directive] effect on must be a FactPredicate spec; got ${typeof p.on}`);if(p.on===null||typeof p.on!="object")throw new Error(`[Directive] memoizePredicate: predicate must be a plain object or array; got ${typeof p.on}`);chunkEOLY64E6_cjs.a(p.on),u=at(p.on),R=true;let Z=Ie(p.on);S.set(m,chunkEOLY64E6_cjs.b("effect",m,(re,le)=>Z(re,le)));}let j={id:m,enabled:true,hasExplicitDeps:R,dependencies:u,cleanup:null,stableRunCount:0,depsStable:false};return d.set(m,j),j}function B(m){return d.get(m)??N(m)}function U(){return l.toObject()}function K(m){m.depsStable=false,m.stableRunCount=0;}function O(m,p){for(let u of m)if(p.has(u))return true;return false}function F(m,p){let u=B(m);if(!u.enabled)return false;if(u.dependencies){if(!O(u.dependencies,p))return false;u.depsStable&&K(u);let R=S.get(m);if(R){let j=U();return R(j,h??void 0)}return true}return true}function q(m){if(m.cleanup){try{m.cleanup();}catch(p){o?.(m.id,p),console.error(`[Directive] Effect "${m.id}" cleanup threw an error:`,p);}m.cleanup=null;}}function A(m,p){if(typeof p=="function")if(C)try{p();}catch(u){o?.(m.id,u),console.error(`[Directive] Effect "${m.id}" cleanup threw an error:`,u);}else m.cleanup=p;}async function Y(m,p){let u;if(l.batch(()=>{u=p.run(c,h);}),u instanceof Promise){let R=await u;A(m,R);}else A(m,u);}function se(m,p){if(m.size!==p.size)return false;for(let u of p)if(!m.has(u))return false;return true}function z(m,p){if(!(m.dependencies&&se(m.dependencies,p))){K(m);return}m.stableRunCount++,m.stableRunCount>=Vt&&(m.depsStable=true);}async function V(m,p){if(m.depsStable&&m.dependencies){await Y(m,p);return}let u,R=chunkS3CFYDIB_cjs.i(()=>(l.batch(()=>{u=p.run(c,h);}),u)),j=R.deps,Z=R.value;Z instanceof Promise&&(Z=await Z),A(m,Z),z(m,j),m.dependencies=j.size>0?j:null;}async function te(m){let p=B(m),u=t[m];if(!(!p.enabled||!u)){q(p),s?.(m,p.dependencies?[...p.dependencies]:[]);try{p.hasExplicitDeps?await Y(p,u):await V(p,u);}catch(R){o?.(m,R),console.error(`[Directive] Effect "${m}" threw an error:`,R),p.hasExplicitDeps||K(p);}}}for(let m of Object.keys(t))N(m);return {async runEffects(m){let p=[];for(let u of Object.keys(t))F(u,m)&&p.push(u);await Promise.all(p.map(te)),h=U();},async runAll(){let m=Object.keys(t);await Promise.all(m.map(p=>{let u=B(p);return u.enabled?(K(u),te(p)):Promise.resolve()})),h=U();},disable(m){let p=B(m);p.enabled=false;},enable(m){let p=B(m);p.enabled=true;},isEnabled(m){return B(m).enabled},cleanupAll(){C=true;for(let m of d.values())q(m);},registerDefinitions(m){for(let[p,u]of Object.entries(m))t[p]=u,N(p);},assignDefinition(m,p){if(!t[m])throw new Error(`[Directive] Cannot assign effect "${m}" \u2014 it does not exist. Use register() to create it.`);let u=d.get(m);u&&q(u),t[m]=p,N(m);},unregisterDefinition(m){if(!t[m])return;let p=d.get(m);p&&q(p),delete t[m],d.delete(m),S.delete(m);},async callOne(m){let p=t[m];if(!p)throw new Error(`[Directive] Cannot call effect "${m}" \u2014 it does not exist.`);let u=B(m);if(u.enabled){q(u),s?.(m,u.dependencies?[...u.dependencies]:[]);try{let R;if(l.batch(()=>{R=p.run(c,h);}),R instanceof Promise){let j=await R;A(u,j);}else A(u,R);}catch(R){o?.(m,R),console.error(`[Directive] Effect "${m}" threw an error:`,R);}}}}}function Ht(r={}){let{delayMs:t=1e3,maxRetries:c=3,backoffMultiplier:l=2,maxDelayMs:s=3e4}=r,o=new Map;function d(h){let C=t*l**(h-1);return Math.min(C,s)}return {scheduleRetry(h,C,S,N,B){if(N>c)return null;let U=d(N),K={source:h,sourceId:C,context:S,attempt:N,nextRetryTime:Date.now()+U,callback:B};return o.set(C,K),K},getPendingRetries(){return Array.from(o.values())},processDueRetries(){let h=Date.now(),C=[];for(let[S,N]of o)N.nextRetryTime<=h&&(C.push(N),o.delete(S));return C},cancelRetry(h){o.delete(h);},clearAll(){o.clear();}}}var Lt={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};function vt(r={}){let{config:t={},onError:c,onRecovery:l}=r,s=[],o=100,d=Ht(t.retryLater),h=new Map,C=1e3;function S(O,F,q,A){if(q instanceof Te)return q;let Y=q instanceof Error?q.message:String(q),se=O!=="system";return new Te(Y,O,F,A,se)}function N(O,F,q){let A=(()=>{switch(O){case "constraint":return t.onConstraintError;case "resolver":return t.onResolverError;case "effect":return t.onEffectError;case "derivation":return t.onDerivationError;default:return}})();if(typeof A=="function"){try{let Y=A(q,F);if(typeof Y=="string")return Y}catch(Y){console.error("[Directive] Error in error handler callback:",Y);}return "skip"}return typeof A=="string"?A:Lt[O]}function B(O){s.push(O),s.length>o&&s.shift();try{c?.(O);}catch(F){console.error("[Directive] Error in onError callback:",F);}try{t.onError?.(O);}catch(F){console.error("[Directive] Error in config.onError callback:",F);}}function U(O,F,q){let A=(h.get(F)??0)+1;if(h.set(F,A),h.size>C){let se=h.keys().next().value;se!==void 0&&h.delete(se);}return d.scheduleRetry(O,F,q,A)?"retry-later":(h.delete(F),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${O} "${F}" exceeded max retry-later attempts. Skipping.`),"skip")}return {handleError(O,F,q,A){let Y=S(O,F,q,A);B(Y);let se=N(O,F,q instanceof Error?q:new Error(String(q)));se==="retry-later"&&(se=U(O,F,A));try{l?.(Y,se);}catch(z){console.error("[Directive] Error in onRecovery callback:",z);}if(se==="throw")throw Y;return se},getLastError(){return s[s.length-1]??null},getAllErrors(){return [...s]},clearErrors(){s.length=0;},getRetryLaterManager(){return d},processDueRetries(){return d.processDueRetries()},clearRetryAttempts(O){h.delete(O),d.cancelRetry(O);}}}function Ut(r,t=100){try{return JSON.stringify(r)?.slice(0,t)??String(r)}catch{return "[circular or non-serializable]"}}function Jt(r){let{schema:t,onChange:c,onBatch:l}=r,o=Object.keys(t).length===0,d=r.validate??chunkS3CFYDIB_cjs.a,h=r.strictKeys??(chunkS3CFYDIB_cjs.a&&!o),C=r.redactErrors??false,S=new Map,N=new Set,B=new Map,U=new Set,K=0,O=[],F=new Set,q=false,A=[],Y=100;function se(f){return f!==null&&typeof f=="object"&&"safeParse"in f&&typeof f.safeParse=="function"&&"_def"in f&&"parse"in f&&typeof f.parse=="function"}function z(f){let x=f;if(x._typeName)return x._typeName;if(se(f)){let T=f._def;if(T?.typeName)return T.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function V(f){return C?"[redacted]":Ut(f)}function te(f){return f===null?"null":Array.isArray(f)?"array":typeof f}function ne(f,x,T){let H=T.safeParse(x);if(H.success)return;let ee=te(x),ue=V(x),ve=H.error?.message??H.error?.issues?.[0]?.message??"Validation failed",he=z(T);throw new Error(`[Directive] Validation failed for "${f}": expected ${he}, got ${ee} ${ue}. ${ve}`)}function m(f){if(typeof f._lastFailedIndex=="number"&&f._lastFailedIndex>=0){let x=` (element at index ${f._lastFailedIndex} failed)`;return f._lastFailedIndex=-1,x}return ""}function p(f,x,T){let H=T._validators;if(!H||!Array.isArray(H)||H.length===0)return;let ee=T._typeName??"unknown";for(let ue=0;ue<H.length;ue++){let ve=H[ue];if(typeof ve!="function"||ve(x))continue;let he=te(x),Re=V(x),we=m(T),Ee=ue===0?"":` (validator ${ue+1} failed)`;throw new Error(`[Directive] Validation failed for "${f}": expected ${ee}, got ${he} ${Re}${Ee}${we}`)}}function u(f){if(h)throw new Error(`[Directive] Unknown fact key: "${f}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${f}"`);}function R(f,x){if(!d)return;let T=t[f];if(!T){u(f);return}if(se(T)){ne(f,x,T);return}p(f,x,T);}function j(f){B.get(f)?.forEach(x=>x());}function Z(){U.forEach(f=>f());}function re(f,x,T){if(q){A.push({key:f,value:x,prev:T});return}q=true;try{c?.(f,x,T),j(f),Z(),le(". A listener is repeatedly mutating facts that re-trigger notifications");}finally{q=false;}}function le(f){let x=0;for(;A.length>0;){if(++x>Y)throw A.length=0,new Error(`[Directive] Infinite notification loop detected after ${Y} iterations${f}.`);let T=[...A];A.length=0;for(let H of T)c?.(H.key,H.value,H.prev),j(H.key);Z();}}function be(){if(!(K>0)){if(l&&O.length>0&&l([...O]),F.size>0){q=true;try{for(let f of F)j(f);Z(),le(" during flush");}finally{q=false;}}O.length=0,F.clear();}}let D={get(f){return chunkS3CFYDIB_cjs.k(f),S.get(f)},has(f){return chunkS3CFYDIB_cjs.k(f),S.has(f)},set(f,x){chunkS3CFYDIB_cjs.a&&R(f,x);let T=S.get(f);Object.is(T,x)||(S.set(f,x),N.add(f),K>0?(O.push({key:f,value:x,prev:T,type:"set"}),F.add(f)):re(f,x,T));},delete(f){let x=S.get(f);S.delete(f),N.delete(f),K>0?(O.push({key:f,value:void 0,prev:x,type:"delete"}),F.add(f)):re(f,void 0,x);},batch(f){K++;try{f();}finally{K--,be();}},subscribe(f,x){for(let T of f){let H=T;B.has(H)||B.set(H,new Set),B.get(H).add(x);}return ()=>{for(let T of f){let H=B.get(T);H&&(H.delete(x),H.size===0&&B.delete(T));}}},subscribeAll(f){return U.add(f),()=>U.delete(f)},toObject(){let f={};for(let x of N)S.has(x)&&(f[x]=S.get(x));return f}};return D.destroy=()=>{B.clear(),U.clear();},D.registerKeys=f=>{for(let x of Object.keys(f))chunkS3CFYDIB_cjs.l.has(x)||(t[x]=f[x],N.add(x));},D}var Ye=new WeakMap;function ht(r,t,c=t){return new Proxy(r,{get(l,s){if(typeof s=="string"&&chunkS3CFYDIB_cjs.l.has(s))return;if(s===Symbol.for("nodejs.util.inspect.custom"))return ()=>l;let o=Reflect.get(l,s);if(typeof s=="symbol"||typeof o!="object"||o===null)return o;if(Ye.has(o))return Ye.get(o);let d=ht(o,t,`${c}.${String(s)}`);return Ye.set(o,d),d},set(l,s,o){return typeof s!="symbol"&&console.warn(`[Directive] Nested mutation on "facts.${c}.${String(s)}" will not trigger reactivity. Use: facts.${t} = { ...facts.${t}, ... }`),Reflect.set(l,s,o)}})}function Xt(r,t){let c=()=>({get:s=>chunkS3CFYDIB_cjs.j(()=>r.get(s)),has:s=>chunkS3CFYDIB_cjs.j(()=>r.has(s))});return new Proxy({},{get(s,o){if(typeof o=="symbol")return o===Symbol.for("nodejs.util.inspect.custom")?()=>chunkS3CFYDIB_cjs.j(()=>r.toObject()):void 0;if(chunkS3CFYDIB_cjs.l.has(o))return;if(o==="$store")return r;if(o==="$snapshot")return c;let d=r.get(o);return chunkS3CFYDIB_cjs.a&&d!==null&&typeof d=="object"?ht(d,o):d},set(s,o,d){if(typeof o=="symbol"||o==="$store"||o==="$snapshot"||chunkS3CFYDIB_cjs.l.has(o))return false;if(chunkS3CFYDIB_cjs.a){let h=chunkS3CFYDIB_cjs.m(d);h&&chunkS3CFYDIB_cjs.n(o,h);}return r.set(o,d),true},deleteProperty(s,o){return typeof o=="symbol"||o==="$store"||o==="$snapshot"||chunkS3CFYDIB_cjs.l.has(o)?false:(r.delete(o),true)},has(s,o){return o==="$store"||o==="$snapshot"?true:typeof o=="symbol"||chunkS3CFYDIB_cjs.l.has(o)?false:r.has(o)},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(s,o){if(!(typeof o=="string"&&chunkS3CFYDIB_cjs.l.has(o)))return o==="$store"||o==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function St(r){let t=Jt(r),c=Xt(t,r.schema);return {store:t,facts:c}}function bt(){let r=[];function t(o){if(o)try{return o()}catch(d){console.error("[Directive] Plugin error:",d);return}}async function c(o){if(o)try{return await o()}catch(d){console.error("[Directive] Plugin error:",d);return}}function l(o){return (...d)=>{for(let h of r)t(()=>h[o]?.(...d));}}return {register(o){r.some(d=>d.name===o.name)&&(console.warn(`[Directive] Plugin "${o.name}" is already registered, replacing...`),this.unregister(o.name)),r.push(o);},unregister(o){let d=r.findIndex(h=>h.name===o);d!==-1&&r.splice(d,1);},getPlugins(){return [...r]},async emitInit(o){for(let d of r)await c(()=>d.onInit?.(o));},emitStart:l("onStart"),emitStop:l("onStop"),emitDestroy:l("onDestroy"),emitFactSet:l("onFactSet"),emitFactDelete:l("onFactDelete"),emitFactsBatch:l("onFactsBatch"),emitDerivationCompute:l("onDerivationCompute"),emitDerivationInvalidate:l("onDerivationInvalidate"),emitReconcileStart:l("onReconcileStart"),emitReconcileEnd:l("onReconcileEnd"),emitConstraintEvaluate:l("onConstraintEvaluate"),emitConstraintError:l("onConstraintError"),emitRequirementCreated:l("onRequirementCreated"),emitRequirementMet:l("onRequirementMet"),emitRequirementCanceled:l("onRequirementCanceled"),emitResolverStart:l("onResolverStart"),emitResolverComplete:l("onResolverComplete"),emitResolverError:l("onResolverError"),emitResolverRetry:l("onResolverRetry"),emitResolverCancel:l("onResolverCancel"),emitResolverWriteRejected:l("onResolverWriteRejected"),emitEffectRun:l("onEffectRun"),emitEffectError:l("onEffectError"),emitSnapshot:l("onSnapshot"),emitHistoryNavigate:l("onHistoryNavigate"),emitError:l("onError"),emitErrorRecovery:l("onErrorRecovery"),emitDefinitionRegister:l("onDefinitionRegister"),emitDefinitionAssign:l("onDefinitionAssign"),emitDefinitionUnregister:l("onDefinitionUnregister"),emitDefinitionCall:l("onDefinitionCall"),emitTraceComplete:l("onTraceComplete")}}var Rt={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},wt={enabled:false,windowMs:50};function Zt(r,t){if(!t||t==="none")return r;if(t==="full")return Math.floor(Math.random()*r);if(t==="equal"){let c=r/2;return Math.floor(c+Math.random()*c)}if(typeof t=="object"&&"maxMs"in t){let c=Number.isFinite(t.maxMs)&&t.maxMs>0?t.maxMs:0;return r+Math.floor(Math.random()*c)}return r}function Gt(r,t){let{backoff:c,initialDelay:l=100,maxDelay:s=3e4}=r,o;switch(c){case "none":o=l;break;case "linear":o=l*t;break;case "exponential":o=l*2**(t-1);break;default:o=l;}let d=Math.min(o,s),h=Zt(d,r.jitter);return Math.max(1,h)}function Qt(r){if(chunkS3CFYDIB_cjs.a)for(let[t,c]of Object.entries(r)){if(!c.resolve&&!c.resolveBatch&&!c.resolveBatchWithResults)throw new Error(`[Directive] Resolver "${t}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(!(!c.batch?.enabled||c.resolveBatch||c.resolveBatchWithResults))if(c.resolve)console.warn(`[Directive] Resolver "${t}" has batch.enabled but no resolveBatch(). Falling back to individual resolve() calls. Add resolveBatch() for true bulk operations.`);else throw new Error(`[Directive] Resolver "${t}" has batch.enabled=true but no resolve(), resolveBatch(), or resolveBatchWithResults() method.`)}}function Dt(r){let{definitions:t,facts:c,store:l,getConstraintBinding:s,onStart:o,onComplete:d,onError:h,onRetry:C,onCancel:S,onClobber:N,onClobberSuppressed:B,onResolutionComplete:U,onRequeue:K}=r;Qt(t);let O=new Map,F=new Map,q=1e3,A=new Map,Y=new Map,se=1e3;function z(){if(F.size>q){let y=F.size-q,b=F.keys();for(let w=0;w<y;w++){let I=b.next().value;I&&F.delete(I);}}}function V(y){return typeof y=="object"&&y!==null&&"requirement"in y&&typeof y.requirement=="string"}function te(y){return typeof y=="object"&&y!==null&&"requirement"in y&&typeof y.requirement=="function"}function ne(y,b){return V(y)?b.type===y.requirement:te(y)?y.requirement(b):false}function m(y,b){let w=Y.get(y);if(!w)return null;Y.delete(y),Y.set(y,w);for(let I of w){let L=t[I];if(L&&ne(L,b))return I}return null}function p(y,b){if(!Y.has(y)){if(Y.size>=se){let w=Y.keys().next().value;w!==void 0&&Y.delete(w);}Y.set(y,new Set);}Y.get(y).add(b);}function u(y){let b=y.type,w=m(b,y);if(w)return w;for(let[I,L]of Object.entries(t))if(ne(L,y))return p(b,I),I;return null}function R(y){if(!s||!y||!y.fromConstraint)return null;let b=s(y.fromConstraint);return !b||b.fields.length===0?null:b}function j(y,b,w,I,L){let e=c,i=new Set(y.fields),g=10,M=0,k=false,$=new Map;for(let G of i){let J=w?w[G]:e[G];$.set(G,J);}let _=new Set;function X(G){return _.has(G)?false:Object.is(e[G],$.get(G))?true:(_.add(G),M++,M<=g?I&&I(G,$.get(G),e[G]):k||(k=true,L&&L(M-g)),b.abort(),false)}return new Proxy(c,{get(G,J,n){return Reflect.get(c,J,n)},set(G,J,n,a){if(typeof J!="string"||!i.has(J))return Reflect.set(c,J,n);if(!X(J))return true;let v=$.get(J);$.set(J,n);let E=Reflect.set(c,J,n);return E||$.set(J,v),E},deleteProperty(G,J){if(typeof J!="string"||!i.has(J))return Reflect.deleteProperty(c,J);if(!X(J))return true;let n=$.get(J);$.set(J,void 0);let a=Reflect.deleteProperty(c,J);return a||$.set(J,n),a},has(G,J){return Reflect.has(c,J)},ownKeys(){return Reflect.ownKeys(c)},getOwnPropertyDescriptor(G,J){return Reflect.getOwnPropertyDescriptor(c,J)}})}function Z(y,b,w,I,L,e){return {facts:w&&I?j(w,I,L,N&&e?(k,$,_)=>{let{resolverId:X,requirements:G}=e;for(let J of G)N(X,J,k,$,_);}:void 0,B&&e?k=>{let{resolverId:$,requirements:_}=e;for(let X of _)B($,X,k);}:void 0):c,signal:y,snapshot:()=>c.$snapshot(),requeue:()=>{if(K)for(let k of b)K(k);}}}async function re(y,b,w,I){let L=y instanceof Error?y:new Error(String(y));if(I.signal.aborted)return {action:"abort",error:L};if(w.shouldRetry&&!w.shouldRetry(L,b))return {action:"break",error:L};if(b<w.attempts){if(I.signal.aborted)return {action:"abort",error:L};let e=Gt(w,b);if(await new Promise(i=>{let g=setTimeout(i,e),M=()=>{clearTimeout(g),i();};I.signal.addEventListener("abort",M,{once:true});}),I.signal.aborted)return {action:"abort",error:L}}return {action:"continue",error:L}}async function le(y,b,w,I,L,e){if(!y.resolve)return;let i=R(w),g;l.batch(()=>{g=y.resolve(w.requirement,Z(I,[w.id],i,L,e,{resolverId:b,requirements:[w]}));});let M=y.timeout;if(M&&M>0){await chunkEOLY64E6_cjs.c(g,M,`Resolver "${b}" timed out after ${M}ms`);return}await g;}function be(y,b,w){let I=Date.now()-w;F.set(b.id,{state:"success",requirementId:b.id,completedAt:Date.now(),duration:I}),z(),d?.(y,b,I);}function D(y,b,w,I){F.set(b.id,{state:"error",requirementId:b.id,error:w,failedAt:Date.now(),attempts:I}),z(),h?.(y,b,w);}function f(y,b,w){let I=O.get(y);I&&(I.attempt=b,I.status={state:"running",requirementId:y,startedAt:w,attempt:b});}async function x(y,b,w,I,L){let e=await re(y,b,w,I);return e.action==="continue"&&b<w.attempts&&L(b+1),{lastError:e.error,shouldContinue:e.action==="continue"}}async function T(y,b,w,I){let L=t[y];if(!L)return;let e={...Rt,...L.retry},i=null,g=O.get(b.id)?.startedAt??Date.now();for(let M=1;M<=e.attempts;M++){if(w.signal.aborted)return;f(b.id,M,g);try{await le(L,y,b,w.signal,w,I),be(y,b,g);return}catch(k){let $=await x(k,M,e,w,_=>C?.(y,b,_));if(i=$.lastError,!$.shouldContinue)break}}D(y,b,i,e.attempts);}async function H(y,b,w){return b&&b>0?chunkEOLY64E6_cjs.c(y,b,w):y}async function ee(y,b,w,I,L,e,i,g){let M;l.batch(()=>{M=y.resolveBatchWithResults(I,L);});let k=await H(M,e,`Batch resolver "${b}" timed out after ${e}ms`);if(k.length!==w.length)throw new Error(`[Directive] Batch resolver "${b}" returned ${k.length} results but expected ${w.length}. Results array must match input order.`);let $=false;for(let _=0;_<w.length;_++){let X=w[_],G=k[_];if(G.success){be(b,X,i);continue}$=true;let J=G.error??new Error("Batch item failed");F.set(X.id,{state:"error",requirementId:X.id,error:J,failedAt:Date.now(),attempts:g}),h?.(b,X,J);}return !$||w.some((_,X)=>k[X]?.success)?"done":"retry"}async function ue(y,b,w,I,L,e,i){let g;l.batch(()=>{g=y.resolveBatch(I,L);}),await H(g,e,`Batch resolver "${b}" timed out after ${e}ms`);for(let M of w)be(b,M,i);}function ve(y,b,w,I){for(let L of b)D(y,L,w,I);}async function he(y,b){await Promise.all(b.map(w=>{let I=new AbortController;return T(y,w,I)}));}async function Re(y,b,w,I,L,e,i,g,M){let k=null;if(w.length>0){let X=w[0];w.every(J=>J.fromConstraint===X.fromConstraint)&&(k=R(X));}let $=Z(I,w.map(X=>X.id),k,L,M,{resolverId:b,requirements:w}),_=w.map(X=>X.requirement);return y.resolveBatchWithResults?ee(y,b,w,_,$,e,i,g):(await ue(y,b,w,_,$,e,i),"done")}function we(y,b,w){for(let I of b)C?.(y,I,w);}async function Ee(y,b,w,I,L,e){let i=new AbortController,g=Date.now(),M=null;for(let k=1;k<=I.attempts;k++){if(i.signal.aborted)return null;try{if(await Re(y,b,w,i.signal,i,L,g,k,e)==="done")return null}catch($){let _=await x($,k,I,i,X=>we(b,w,X));if(M=_.lastError,!_.shouldContinue)break}}return M}async function Oe(y,b,w){let I=t[y];if(!I)return;if(!I.resolveBatch&&!I.resolveBatchWithResults){await he(y,b);return}let L={...Rt,...I.retry},i={...wt,...I.batch}.timeoutMs??I.timeout,g=await Ee(I,y,b,L,i,w);g&&ve(y,b,g,L.attempts);}let De=1e4;function W(y){y.timer&&(clearTimeout(y.timer),y.timer=null);}function oe(y){return A.has(y)||A.set(y,{resolverId:y,requirements:[],baselines:[],timer:null}),A.get(y)}function ge(y,b,w){let I=t[y];if(!I)return;let L={...wt,...I.batch},e=oe(y),i=L.maxSize||De;if(e.requirements.length>=i&&(W(e),xe(y)),e.requirements.push(b),e.baselines.push(w),L.maxSize&&e.requirements.length>=L.maxSize){W(e),xe(y);return}W(e),e.timer=setTimeout(()=>{xe(y);},L.windowMs);}function xe(y){let b=A.get(y);if(!b||b.requirements.length===0)return;let w=[...b.requirements],I;for(let L=b.baselines.length-1;L>=0;L--){let e=b.baselines[L];if(e!==void 0){I=e;break}}b.requirements=[],b.baselines=[],b.timer=null,Oe(y,w,I).then(()=>{U?.();});}return {resolve(y,b){if(O.has(y.id))return;let w=u(y.requirement);if(!w){chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] No resolver found for requirement type "${y.requirement.type}" (id: ${y.id})`);return}let I=t[w];if(!I)return;if(I.batch?.enabled){ge(w,y,b?.factsBaseline);return}let L=new AbortController,e=Date.now(),i={requirementId:y.id,resolverId:w,controller:L,startedAt:e,attempt:1,status:{state:"pending",requirementId:y.id,startedAt:e},originalRequirement:y};O.set(y.id,i),o?.(w,y),T(w,y,L,b?.factsBaseline).finally(()=>{O.delete(y.id)&&U?.();});},cancel(y){let b=O.get(y);if(b){b.controller.abort(),O.delete(y),F.set(y,{state:"canceled",requirementId:y,canceledAt:Date.now()}),z(),S?.(b.resolverId,b.originalRequirement);return}for(let w of A.values()){let I=w.requirements.findIndex(L=>L.id===y);if(I!==-1){let[L]=w.requirements.splice(I,1);w.baselines.splice(I,1),F.set(y,{state:"canceled",requirementId:y,canceledAt:Date.now()}),z(),L&&S?.(w.resolverId,L);return}}},detach(y){O.delete(y);},cancelAll(){let y=[...O.keys()];for(let b of y)this.cancel(b);for(let b of A.values()){b.timer&&clearTimeout(b.timer);for(let w of b.requirements)F.set(w.id,{state:"canceled",requirementId:w.id,canceledAt:Date.now()}),S?.(b.resolverId,w);}A.clear(),z();},getStatus(y){let b=O.get(y);if(b)return b.status;let w=F.get(y);return w||{state:"idle"}},getInflight(){return [...O.keys()]},getInflightInfo(){return [...O.values()].map(y=>({id:y.requirementId,resolverId:y.resolverId,startedAt:y.startedAt}))},getInflightCount(){return O.size},isResolving(y){return O.has(y)},processBatches(){for(let y of A.keys())xe(y);},hasPendingBatches(){for(let y of A.values())if(y.requirements.length>0)return true;return false},registerDefinitions(y){for(let[b,w]of Object.entries(y))t[b]=w;Y.clear();},assignDefinition(y,b){if(!t[y])throw new Error(`[Directive] Cannot assign resolver "${y}" \u2014 it does not exist. Use register() to create it.`);t[y]=b,Y.clear();},unregisterDefinition(y){if(!t[y])return;for(let[w,I]of O)I.resolverId===y&&(I.controller.abort(),O.delete(w),F.set(w,{state:"canceled",requirementId:w,canceledAt:Date.now()}),S?.(y,I.originalRequirement));let b=A.get(y);if(b){b.timer&&clearTimeout(b.timer);for(let w of b.requirements)F.set(w.id,{state:"canceled",requirementId:w.id,canceledAt:Date.now()}),S?.(y,w);A.delete(y);}delete t[y],Y.clear(),z();},async callOne(y,b){let w=t[y];if(!w)throw new Error(`[Directive] Cannot call resolver "${y}" \u2014 it does not exist.`);let I=new AbortController,L=Z(I.signal,[]);if(w.resolve){let e;l.batch(()=>{e=w.resolve(b,L);}),await e;}},destroy(){this.cancelAll(),F.clear(),Y.clear();}}}function kt(r){let{mergedDerive:t,getDerivation:c,definitions:l}=r,s={register:(o,d)=>l.register("derivation",o,d),assign:(o,d)=>l.assign("derivation",o,d),unregister:o=>l.unregister("derivation",o),call:o=>l.call("derivation",o),isDynamic:o=>l.isDynamic("derivation",o),listDynamic:()=>l.listDynamic("derivation")};return new Proxy({},{get(o,d){if(typeof d!="symbol"&&!chunkS3CFYDIB_cjs.l.has(d)){if(d in s)return s[d];if(d in t)return c(d)}},has(o,d){return typeof d=="symbol"||chunkS3CFYDIB_cjs.l.has(d)?false:d in t||d in s},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(o,d){if(typeof d!="symbol"&&!chunkS3CFYDIB_cjs.l.has(d)&&(d in t||d in s))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function Et(r){let{mergedEvents:t,dispatchEvent:c}=r;return new Proxy({},{get(l,s){if(typeof s!="symbol"&&!chunkS3CFYDIB_cjs.l.has(s))return o=>{c(s,o);}},has(l,s){return typeof s=="symbol"||chunkS3CFYDIB_cjs.l.has(s)?false:s in t},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(l,s){if(typeof s!="symbol"&&!chunkS3CFYDIB_cjs.l.has(s)&&s in t)return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}var Yt=new Set(["register","assign","unregister","call","isDynamic","listDynamic"]);function xt(r){let{mergedConstraints:t,mergedResolvers:c,mergedDerive:l,mergedEffects:s,constraintsManager:o,resolversManager:d,derivationsManager:h,effectsManager:C,pluginManager:S,getState:N,scheduleReconcile:B,maxDeferredRegistrations:U}=r,K={constraints:new Set,resolvers:new Set,derivations:new Set,effects:new Set},O={constraints:new Map,resolvers:new Map,derivations:new Map,effects:new Map},F=[];function q(m){if(Yt.has(m))throw new Error(`[Directive] Derivation ID "${m}" conflicts with a reserved derive method name.`)}let A={constraint:{label:"Constraint",mergedMap:t,manager:o,dynamicSet:K.constraints,originalsMap:O.constraints,reconciles:true},resolver:{label:"Resolver",mergedMap:c,manager:d,dynamicSet:K.resolvers,originalsMap:O.resolvers,reconciles:true},derivation:{label:"Derivation",mergedMap:l,manager:h,dynamicSet:K.derivations,originalsMap:O.derivations,reconciles:false,validateId:q},effect:{label:"Effect",mergedMap:s,manager:C,dynamicSet:K.effects,originalsMap:O.effects,reconciles:false}};function Y(m){if(typeof m!="string"||m.length===0)throw new Error(`[Directive] Definition ID must be a non-empty string. Received: ${String(m)}`);if(chunkS3CFYDIB_cjs.l.has(m))throw new Error(`[Directive] Security: Definition ID "${m}" is a blocked property.`);if(m.includes("::"))throw new Error(`[Directive] Definition ID "${m}" cannot contain "::". This separator is reserved for namespacing.`)}function se(m,p,u){let R=A[m];if(R.validateId?.(p),p in R.mergedMap)throw new Error(`[Directive] ${R.label} "${p}" already exists. Use assign() to override.`);if(m!=="derivation"){let j=u;j.meta&&(j.meta=de(j.meta));}R.mergedMap[p]=u,R.manager.registerDefinitions({[p]:u}),R.dynamicSet.add(p),S.emitDefinitionRegister(m,p,u),R.reconciles&&B();}function z(m,p,u){let R=A[m];if(R.validateId?.(p),!(p in R.mergedMap))throw new Error(`[Directive] ${R.label} "${p}" does not exist. Use register() to create it.`);if(m!=="derivation"){let Z=u;Z.meta&&(Z.meta=de(Z.meta));}let j=R.mergedMap[p];R.manager.assignDefinition(p,u),R.originalsMap.set(p,j),R.mergedMap[p]=u,S.emitDefinitionAssign(m,p,u,j),R.reconciles&&B();}function V(m,p){let u=A[m];if(!u.dynamicSet.has(p)){chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] Cannot unregister static ${m} "${p}". Only dynamically registered ${m}s can be removed.`);return}u.manager.unregisterDefinition(p),delete u.mergedMap[p],u.dynamicSet.delete(p),u.originalsMap.delete(p),S.emitDefinitionUnregister(m,p),u.reconciles&&B();}function te(){if(F.length===0)return;let m=F.splice(0);for(let p of m)try{switch(p.op){case "register":se(p.type,p.id,p.def);break;case "assign":z(p.type,p.id,p.def);break;case "unregister":V(p.type,p.id);break}}catch(u){chunkS3CFYDIB_cjs.a&&console.error(`[Directive] Error in deferred ${p.op} for ${p.type} "${p.id}":`,u);}}function ne(m,p,u,R){let{isDestroyed:j,isReconciling:Z}=N();if(j)throw new Error(`[Directive] Cannot ${m} ${p} "${u}" on a destroyed system.`);if(Y(u),Z){if(F.length>=U)throw new Error(`[Directive] Too many deferred registrations (max ${U}). Avoid calling register/assign/unregister in resolver or effect callbacks during reconciliation.`);m==="unregister"?F.push({op:m,type:p,id:u}):F.push({op:m,type:p,id:u,def:R});return}switch(m){case "register":se(p,u,R);break;case "assign":z(p,u,R);break;case "unregister":V(p,u);break}}return {register(m,p,u){ne("register",m,p,u);},assign(m,p,u){ne("assign",m,p,u);},unregister(m,p){ne("unregister",m,p);},call(m,p,u){let{isDestroyed:R}=N();if(R)throw new Error(`[Directive] Cannot call ${m} "${p}" on a destroyed system.`);switch(Y(p),S.emitDefinitionCall(m,p,u),m){case "constraint":return o.callOne(p,u);case "resolver":return d.callOne(p,u);case "derivation":return h.callOne(p);case "effect":return C.callOne(p)}},isDynamic(m,p){switch(m){case "constraint":return K.constraints.has(p);case "resolver":return K.resolvers.has(p);case "derivation":return K.derivations.has(p);case "effect":return K.effects.has(p)}},listDynamic(m){switch(m){case "constraint":return [...K.constraints];case "resolver":return [...K.resolvers];case "derivation":return [...K.derivations];case "effect":return [...K.effects]}},flushDeferred:te,getOriginal(m,p){let R={constraint:O.constraints,resolver:O.resolvers,derivation:O.derivations,effect:O.effects}[m];if(R)return R.get(p)},restoreOriginal(m,p){let R={constraint:O.constraints,resolver:O.resolvers,derivation:O.derivations,effect:O.effects}[m];if(!R||!R.has(p))return false;let j=R.get(p);return ne("assign",m,p,j),R.delete(p),true},destroy(){F.length=0,K.constraints.clear(),K.resolvers.clear(),K.derivations.clear(),K.effects.clear(),O.constraints.clear(),O.resolvers.clear(),O.derivations.clear(),O.effects.clear();}}}function Mt(r){let{traceConfig:t,pluginManager:c,resolverMetaLookup:l}=r;if(!(t===true||typeof t=="object"&&t!==null))return {enabled:false,recordFactChange(){},startRun(){return 0},currentTrace:null,getEntries(){return null},attributeResolverStart(){},recordResolverComplete(){},recordResolverError(){},decrementInflight(){},finalizeCurrentRun(){},drainPendingChanges(){},destroy(){}};let o=(typeof t=="object"&&t!==null?t.maxRuns:void 0)??100,d=[],h=new Map,C=0,S=null,N=[],B=new Map,U=new Map,K=new Map,O=null,F=0,q=0,A={count:0,totalDuration:0,avgDuration:0,maxDuration:0,avgResolverCount:0,totalResolverCount:0,avgFactChangeCount:0,totalFactChangeCount:0};function Y(u){let R=h.get(u);if(R&&R.status==="pending"){R.status="settled";let j=K.get(u);R.duration=j!==void 0?performance.now()-j:Date.now()-R.timestamp,K.delete(u),U.delete(u),R.causalChain=V(R),te(R),q++,c.emitTraceComplete(R);}}function se(u){let R=B.get(u);if(B.delete(u),R!==void 0){let j=(U.get(R)??1)-1;j<=0?Y(R):U.set(R,j);}}function z(){let u=d.shift();if(u&&(h.delete(u.id),K.delete(u.id),u.status==="pending")){U.delete(u.id);for(let[R,j]of B)j===u.id&&B.delete(R);}}function V(u){let R=[];for(let j of u.factChanges)R.push(`${j.key} changed`);for(let j of u.derivationsRecomputed)R.push(`${j.id} recomputed`);for(let j of u.constraintsHit)R.push(`${j.id} constraint hit`);for(let j of u.requirementsAdded)R.push(`${j.type} requirement added`);for(let j of u.resolversCompleted)R.push(`${j.resolver} resolved (${j.duration.toFixed(0)}ms)`);for(let j of u.resolversErrored)R.push(`${j.resolver} errored`);for(let j of u.effectsRun)R.push(`${j.id} effect ran`);return R.join(" \u2192 ")}function te(u){A.count++,A.totalDuration+=u.duration,A.avgDuration=A.totalDuration/A.count,u.duration>A.maxDuration&&(A.maxDuration=u.duration);let R=u.resolversStarted.length;A.totalResolverCount+=R,A.avgResolverCount=A.totalResolverCount/A.count;let j=u.factChanges.length;A.totalFactChangeCount+=j,A.avgFactChangeCount=A.totalFactChangeCount/A.count;let Z=[];A.count>3&&u.duration>A.avgDuration*5&&Z.push(`Duration ${u.duration.toFixed(0)}ms is 5x+ above average (${A.avgDuration.toFixed(0)}ms)`),u.resolversErrored.length>0&&Z.push(`${u.resolversErrored.length} resolver(s) errored`),Z.length>0&&(u.anomalies=Z);}function ne(u){d.push(u),h.set(u.id,u),d.length>o&&z(),q++;}function m(u){return u.factChanges.length>0||u.constraintsHit.length>0||u.requirementsAdded.length>0||u.effectsRun.length>0}return {enabled:true,get currentTrace(){return S},set currentTrace(u){S=u;},recordFactChange(u,R,j){N.push({key:u,oldValue:R,newValue:j});},startRun(){let u=performance.now(),R=++C;return K.set(R,u),S={id:R,timestamp:Date.now(),duration:0,status:"pending",factChanges:N.splice(0),derivationsRecomputed:[],constraintsHit:[],requirementsAdded:[],requirementsRemoved:[],resolversStarted:[],resolversCompleted:[],resolversErrored:[],effectsRun:[],effectErrors:[]},u},getEntries(){return (!O||F!==q)&&(O=[...d],F=q),O},attributeResolverStart(u){S&&B.set(u,S.id);},recordResolverComplete(u,R,j){let Z=B.get(u);if(Z!==void 0){let re=h.get(Z);re&&re.resolversCompleted.push({resolver:R,requirementId:u,duration:j,meta:l?.(R)});}},recordResolverError(u,R,j){let Z=B.get(u);if(Z!==void 0){let re=h.get(Z);re&&re.resolversErrored.push({resolver:R,requirementId:u,error:j,meta:l?.(R)});}},decrementInflight(u){se(u);},finalizeCurrentRun(u){if(!S)return;if(S.duration=performance.now()-u,!m(S)){K.delete(S.id),S=null;return}let R=S.resolversStarted.length;R===0?(S.status="settled",S.causalChain=V(S),te(S),ne(S),c.emitTraceComplete(S)):(S.status="pending",ne(S),U.set(S.id,R)),S=null;},drainPendingChanges(){N.length=0;},destroy(){d.length=0,h.clear(),B.clear(),U.clear(),K.clear(),N.length=0,S=null,O=null;}}}function Ct(r,t){for(let[c,l]of Object.entries(r)){if(typeof l!="object"||l===null)continue;let s=Object.hasOwn(l,"handler"),o=Object.hasOwn(l,"patch");if(s&&o&&chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] event "${c}": both \`handler\` and \`patch\` provided \u2014 using \`handler\` (patch is ignored).`),s){let d=l;if(r[c]=d.handler,d.meta){let h=de(d.meta);h&&t.set(c,h);}continue}if(o){let d=l,h=d.patch;if(chunkEOLY64E6_cjs.a(h),r[c]=(C,S)=>ft(h,C,S??{}),d.meta){let C=de(d.meta);C&&t.set(c,C);}}}}function br(r){let t=Object.create(null),c=Object.create(null),l=Object.create(null),s=Object.create(null),o=Object.create(null),d=Object.create(null),h=new Map,C=new Map,S=new Map,N=new Map,B=new Map;for(let e of r.modules){let i=(M,k)=>{if(M)for(let $ of Object.keys(M)){if(chunkS3CFYDIB_cjs.l.has($))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${$}" in ${k}. This could indicate a prototype pollution attempt.`);if(k==="schema"&&$.startsWith("$"))throw new Error(`[Directive] Module "${e.id}" has schema key "${$}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};i(e.schema,"schema"),i(e.events,"events"),i(e.derive,"derive"),i(e.effects,"effects"),i(e.constraints,"constraints"),i(e.resolvers,"resolvers");for(let M of Object.keys(e.schema)){let k=S.get(M);if(k)throw new Error(`[Directive] Schema collision: Fact "${M}" is defined in both module "${k}" and "${e.id}". Use namespacing (e.g., "${e.id}::${M}") or merge into one module.`);S.set(M,e.id);}let g=(M,k)=>{if(M)for(let $ of Object.keys(M)){let _=N.get($);if(_&&_!==e.id)throw new Error(`[Directive] Definition collision: ${k} "${$}" is defined in both module "${_}" and "${e.id}". Use namespacing or rename to avoid conflicts.`);N.set($,e.id);}};if(g(e.derive,"derivation"),g(e.effects,"effect"),g(e.constraints,"constraint"),g(e.resolvers,"resolver"),g(e.events,"event"),Object.assign(t,e.schema),e.events&&(Ct(e.events,C),Object.assign(c,e.events)),e.derive&&Object.assign(l,e.derive),e.effects&&Object.assign(s,e.effects),e.constraints&&Object.assign(o,e.constraints),e.resolvers){Object.assign(d,e.resolvers);for(let M of Object.keys(e.resolvers))B.set(M,e);}if(e.meta){let M=de(e.meta);M&&h.set(e.id,M);}}for(let e of Object.values(o))e.meta&&(e.meta=de(e.meta));for(let e of Object.values(d))e.meta&&(e.meta=de(e.meta));for(let e of Object.values(s)){let i=e;i.meta&&(i.meta=de(i.meta));}for(let e of Object.values(t)){let i=e;i._meta&&(i._meta=de(i._meta));}let U=null;if(r.modules.some(e=>e.history?.snapshotEvents)){U=new Set;for(let e of r.modules){let i=e;if(i.history?.snapshotEvents)for(let g of i.history.snapshotEvents)U.add(g);else if(i.events)for(let g of Object.keys(i.events))U.add(g);}}let O=0,F=false;if(chunkS3CFYDIB_cjs.a){let e=new Set(Object.keys(l));for(let i of Object.keys(t))e.has(i)&&console.warn(`[Directive] "${i}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let q=bt();for(let e of r.plugins??[])q.register(e);let A=q.getPlugins().length>0,Y=q.register.bind(q),se=q.unregister.bind(q);q.register=e=>{Y(e),A=true;},q.unregister=e=>{se(e),A=q.getPlugins().length>0;};let z=()=>A,V=vt({config:r.errorBoundary,onError:e=>q.emitError(e),onRecovery:(e,i)=>q.emitErrorRecovery(e,i)}),te=null,ne=()=>{},m=()=>{},p=null,u=Mt({traceConfig:r.trace,pluginManager:q,resolverMetaLookup:e=>d[e]?.meta}),R=u.enabled,{store:j,facts:Z}=St({schema:t,onChange:(e,i,g)=>{q.emitFactSet(e,i,g),ne(e),R&&u.recordFactChange(String(e),g,i),!p?.isRestoring&&(O===0&&(F=true),W.changedKeys.add(e),ge());},onBatch:e=>{q.emitFactsBatch(e);let i=[];for(let g of e)i.push(g.key);if(R)for(let g of e)u.recordFactChange(g.key,g.prev,g.type==="delete"?void 0:g.value);if(m(i),!p?.isRestoring){O===0&&(F=true);for(let g of e)W.changedKeys.add(g.key);ge();}}}),re=pt({definitions:l,facts:Z,onCompute:(e,i,g,M)=>{z()&&q.emitDerivationCompute(e,i,M),u.currentTrace&&u.currentTrace.derivationsRecomputed.push({id:e,deps:M?[...M]:[],oldValue:g,newValue:i,meta:re.getMeta(e)});},onInvalidate:e=>{z()&&q.emitDerivationInvalidate(e);},onError:(e,i)=>{V.handleError("derivation",e,i)==="retry"&&re.invalidate(e);}});ne=e=>re.invalidate(e),m=e=>re.invalidateMany(e);let le=yt({definitions:s,facts:Z,store:j,onRun:(e,i)=>{z()&&q.emitEffectRun(e),u.currentTrace&&u.currentTrace.effectsRun.push({id:e,triggeredBy:i,meta:s[e]?.meta});},onError:(e,i)=>{let g=V.handleError("effect",e,i);z()&&q.emitEffectError(e,i),u.currentTrace&&u.currentTrace.effectErrors.push({id:e,error:String(i),meta:s[e]?.meta}),g==="disable"&&le.disable(e),g==="retry"&&(W.changedKeys.add("*"),ge());}});function be(e){if(Array.isArray(e)){let i=e;return g=>lt(i,g)}return e}let D=Object.create(null);for(let e of Object.values(d))e.key&&typeof e.requirement=="string"&&(D[e.requirement]=be(e.key));let f=mt({definitions:o,facts:Z,requirementKeys:D,onEvaluate:(e,i)=>{if(z()){let g=f.explainWhen(e);q.emitConstraintEvaluate(e,i,g);}},onError:(e,i)=>{let g=V.handleError("constraint",e,i);z()&&q.emitConstraintError(e,i),g==="disable"&&f.disable(e);}});function x(e){for(let i of Object.values(e))i.key&&typeof i.requirement=="string"&&f.setRequirementKey(i.requirement,be(i.key));}function T(e){let i=o[e];if(!i?.owns||i.owns.length===0)return;let g=f.getState(e);if(g?.isAsync||i.async){chunkS3CFYDIB_cjs.a&&(g?.isAsync&&!i.async?console.warn(`[Directive] constraint '${e}': owns binding disabled because when() returned a Promise \u2014 convert to a synchronous when, mark the constraint async: true and accept the binding being off, or use a data-form when (always sync).`):console.warn(`[Directive] Constraint "${e}" has \`owns\` but is async. Binding is disabled \u2014 async constraints cannot be bound.`));return}return {fields:i.owns}}let H=new Set,ee=Dt({definitions:d,facts:Z,store:j,getConstraintBinding:T,onStart:(e,i)=>{z()&&q.emitResolverStart(e,i);},onComplete:(e,i,g)=>{V.clearRetryAttempts(e),z()&&(q.emitResolverComplete(e,i,g),q.emitRequirementMet(i,e)),f.markResolved(i.fromConstraint),R&&(u.recordResolverComplete(i.id,e,g),u.decrementInflight(i.id));},onError:(e,i,g)=>{let M=V.handleError("resolver",e,g,i);if(z()&&q.emitResolverError(e,i,g),M==="disable"&&f.disable(i.fromConstraint),M==="retry"&&(W.previousRequirements.remove(i.id),ge()),M==="retry-later"){let X=V.getRetryLaterManager().getPendingRetries().find(G=>G.sourceId===e);X&&!X.callback&&(X.callback=()=>{ge();});}R&&(u.recordResolverError(i.id,e,String(g)),u.decrementInflight(i.id));let k=B.get(e),$=k?.hooks?.onResolverError;if($){let _=g instanceof Error?g:new Error(String(g));try{$(_,i.requirement,{facts:Z});}catch(X){console.error(`[Directive] onResolverError hook for module "${k?.id}" threw:`,X);}}},onRetry:(e,i,g)=>q.emitResolverRetry(e,i,g),onCancel:(e,i)=>{q.emitResolverCancel(e,i),q.emitRequirementCanceled(i),R&&u.decrementInflight(i.id);},onClobber:(e,i,g,M,k)=>{z()&&q.emitResolverWriteRejected({kind:"rejection",resolver:e,req:i,reason:"clobbered",fact:g,expected:M,actual:k});},onClobberSuppressed:(e,i,g)=>{z()&&q.emitResolverWriteRejected({kind:"summary",resolver:e,req:i,reason:"clobbered",dropped:g});},onResolutionComplete:()=>{we(),ge();},onRequeue:e=>{H.add(e);}}),ue=new Set;function ve(){for(let e of ue)e();}let he=r.history?ut({historyOption:r.history,facts:Z,store:j,onSnapshot:e=>{q.emitSnapshot(e),ve();},onHistoryChange:(e,i)=>{q.emitHistoryNavigate(e,i),ve();}}):dt();p=he;let Re=new Set;function we(){for(let e of Re)e();}let Ee=50,Oe=100,De=0,W={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new Me,readyPromise:null,readyResolve:null},oe=xt({mergedConstraints:o,mergedResolvers:d,mergedDerive:l,mergedEffects:s,constraintsManager:f,resolversManager:ee,derivationsManager:re,effectsManager:le,pluginManager:q,getState:()=>W,scheduleReconcile:ge,maxDeferredRegistrations:Oe});function ge(){!W.isRunning||W.reconcileScheduled||W.isInitializing||(W.reconcileScheduled=true,we(),queueMicrotask(()=>{W.reconcileScheduled=false,W.isRunning&&!W.isInitializing&&xe().catch(e=>{chunkS3CFYDIB_cjs.a&&console.error("[Directive] Unexpected error in reconcile:",e);});}));}async function xe(){if(W.isReconciling)return;if(De++,De>Ee){chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] Reconcile loop exceeded ${Ee} iterations. This usually means resolvers are creating circular requirement chains. Check that resolvers aren't mutating facts that re-trigger their own constraints.`),R&&u.drainPendingChanges(),W.previousRequirements=new Me,De=0;return}W.isReconciling=true,we();let e=R?u.startRun():0,i=u.currentTrace;if(i)for(let g of i.factChanges){let M=t[g.key];g.meta=M?._meta;}try{if(W.changedKeys.size>0){if(U===null||F){let n=W.changedKeys,a=n.size<=5?`facts-changed:${[...n].join(",")}`:`facts-changed:${[...n].slice(0,5).join(",")}+${n.size-5}more`;he.takeSnapshot(a);}F=!1;}let g=Z.$snapshot();q.emitReconcileStart(g),await le.runEffects(W.changedKeys);let M=new Set(W.changedKeys);W.changedKeys.clear();let k=await f.evaluate(M),$=new Me;for(let n of k)$.add(n),q.emitRequirementCreated(n);if(i){let n=new Set(k.map(a=>a.fromConstraint));for(let a of n){let v=f.getState(a);if(v){let E=f.getDependencies(a);i.constraintsHit.push({id:a,priority:v.priority,deps:E?[...E]:[],meta:o[a]?.meta});}}}let{added:_,removed:X}=$.diff(W.previousRequirements);if(i){for(let n of _)i.requirementsAdded.push({id:n.id,type:n.requirement.type,fromConstraint:n.fromConstraint});for(let n of X)i.requirementsRemoved.push({id:n.id,type:n.requirement.type,fromConstraint:n.fromConstraint});}for(let n of X)(n.fromConstraint?T(n.fromConstraint):void 0)?ee.detach(n.id):ee.cancel(n.id);let G;if(_.length>0){let n=new Set;for(let a of _){if(!a.fromConstraint)continue;let v=T(a.fromConstraint);if(v)for(let E of v.fields)n.add(E);}if(n.size>0){G=Object.create(null);for(let a of n)G[a]=j.get(a);}}for(let n of _)ee.resolve(n,{factsBaseline:G});if(i){let n=ee.getInflightInfo(),a=new Map(n.map(v=>[v.id,v]));for(let v of _){let P=a.get(v.id)?.resolverId??"unknown";i.resolversStarted.push({resolver:P,requirementId:v.id,meta:d[P]?.meta}),u.attributeResolverStart(v.id);}}if(W.previousRequirements=$,H.size>0){for(let n of H)W.previousRequirements.remove(n);H.clear(),ge();}let J=ee.getInflightInfo();if(r.plugins&&r.plugins.length>0){let n=X.length>0?new Map(J.map(v=>[v.id,v.resolverId])):void 0,a={unmet:k.filter(v=>!ee.isResolving(v.id)),inflight:J,completed:[],canceled:X.map(v=>({id:v.id,resolverId:n?.get(v.id)??"unknown"}))};q.emitReconcileEnd(a);}W.isReady||(W.isReady=!0,W.readyResolve&&(W.readyResolve(),W.readyResolve=null));}finally{R&&u.finalizeCurrentRun(e),W.isReconciling=false,oe.flushDeferred(),De=0,W.changedKeys.size>0&&ge(),we();}}function je(e,i){let g=c[e];if(g){O++,(U===null||U.has(e))&&(F=true);try{j.batch(()=>{g(Z,{type:e,...i});});}finally{O--;}}else chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] Unknown event type "${e}". No handler is registered for this event. Available events: ${Object.keys(c).join(", ")||"(none)"}`);}let y=kt({mergedDerive:l,getDerivation:e=>re.get(e),definitions:oe}),b=Et({mergedEvents:c,dispatchEvent:je});function w(){let e=[];for(let[i,g]of h)e.push({type:"module",id:i,meta:g});for(let i of Object.keys(t)){let g=t[i]?._meta;g&&e.push({type:"fact",id:i,meta:g});}for(let[i,g]of C)e.push({type:"event",id:i,meta:g});for(let[i,g]of Object.entries(o))g.meta&&e.push({type:"constraint",id:i,meta:g.meta});for(let[i,g]of Object.entries(d))g.meta&&e.push({type:"resolver",id:i,meta:g.meta});for(let[i,g]of Object.entries(s)){let M=g.meta;M&&e.push({type:"effect",id:i,meta:M});}for(let i of Object.keys(l)){let g=re.getMeta(i);g&&e.push({type:"derivation",id:i,meta:g});}return e}let I={facts:Z,history:he.isEnabled?he:null,derive:y,events:b,constraints:{disable:e=>f.disable(e),enable:e=>f.enable(e),isDisabled:e=>f.isDisabled(e),register:(e,i)=>{oe.register("constraint",e,i);},assign:(e,i)=>{oe.assign("constraint",e,i);},unregister:e=>{oe.unregister("constraint",e);},call:(e,i)=>oe.call("constraint",e,i),isDynamic:e=>oe.isDynamic("constraint",e),listDynamic:()=>oe.listDynamic("constraint")},effects:{disable:e=>le.disable(e),enable:e=>le.enable(e),isEnabled:e=>le.isEnabled(e),register:(e,i)=>{oe.register("effect",e,i);},assign:(e,i)=>{oe.assign("effect",e,i);},unregister:e=>{oe.unregister("effect",e);},call:e=>oe.call("effect",e),isDynamic:e=>oe.isDynamic("effect",e),listDynamic:()=>oe.listDynamic("effect")},resolvers:{register:(e,i)=>{oe.register("resolver",e,i),x({[e]:i});},assign:(e,i)=>{oe.assign("resolver",e,i),x({[e]:i});},unregister:e=>{let i=d[e];i?.key&&typeof i.requirement=="string"&&f.removeRequirementKey(i.requirement),oe.unregister("resolver",e);},call:(e,i)=>oe.call("resolver",e,i),isDynamic:e=>oe.isDynamic("resolver",e),listDynamic:()=>oe.listDynamic("resolver")},get trace(){return u.getEntries()},meta:{module(e){return h.get(e)},fact(e){return t[e]?._meta},event(e){return C.get(e)},constraint(e){return o[e]?.meta},resolver(e){return d[e]?.meta},effect(e){return s[e]?.meta},derivation(e){return re.getMeta(e)},byCategory(e){return w().filter(i=>i.meta.category===e)},byTag(e){return w().filter(i=>i.meta.tags?.includes(e))}},observe(e){if(q.getPlugins().filter(k=>k.name.startsWith("__observer_")).length>=100)return chunkS3CFYDIB_cjs.a&&console.warn("[Directive] Maximum observer limit (100) reached. Call the unsubscribe function returned by observe() to clean up."),()=>{};let g=`__observer_${Date.now()}_${Math.random().toString(36).slice(2)}`,M={name:g,onInit:()=>e({type:"system.init"}),onStart:()=>e({type:"system.start"}),onStop:()=>e({type:"system.stop"}),onDestroy:()=>e({type:"system.destroy"}),onFactSet:(k,$,_)=>e({type:"fact.change",key:k,prev:_,next:$}),onConstraintEvaluate:(k,$,_)=>{e(_?{type:"constraint.evaluate",id:k,active:$,whenExplain:_}:{type:"constraint.evaluate",id:k,active:$});},onConstraintError:(k,$)=>e({type:"constraint.error",id:k,error:$}),onRequirementCreated:k=>e({type:"requirement.created",id:k.id,requirementType:k.requirement.type}),onRequirementMet:(k,$)=>e({type:"requirement.met",id:k.id,byResolver:$}),onRequirementCanceled:k=>e({type:"requirement.canceled",id:k.id}),onResolverStart:(k,$)=>e({type:"resolver.start",resolver:k,requirementId:$.id}),onResolverComplete:(k,$,_)=>e({type:"resolver.complete",resolver:k,requirementId:$.id,duration:_}),onResolverError:(k,$,_)=>e({type:"resolver.error",resolver:k,requirementId:$.id,error:_}),onResolverWriteRejected:k=>{if(k.kind==="summary"){e({type:"resolver.write.rejected",kind:"summary",resolver:k.resolver,requirementId:k.req.id,reason:k.reason,dropped:k.dropped});return}e({type:"resolver.write.rejected",kind:"rejection",resolver:k.resolver,requirementId:k.req.id,reason:k.reason,fact:k.fact,expected:k.expected,actual:k.actual});},onEffectRun:k=>e({type:"effect.run",id:k}),onEffectError:(k,$)=>e({type:"effect.error",id:k,error:$}),onDerivationCompute:(k,$)=>e({type:"derivation.compute",id:k,value:$}),onReconcileStart:()=>e({type:"reconcile.start"}),onReconcileEnd:k=>{let $=k;e({type:"reconcile.end",resolversCompleted:Array.isArray($.completed)?$.completed.length:0,resolversCanceled:Array.isArray($.canceled)?$.canceled.length:0});}};return q.register(M),()=>q.unregister(g)},initialize(){if(!W.isInitialized){W.isInitializing=true;for(let e of r.modules)e.init&&j.batch(()=>{e.init(Z);});r.onAfterModuleInit&&j.batch(()=>{r.onAfterModuleInit();}),W.isInitializing=false,W.isInitialized=true;for(let e of Object.keys(l))re.get(e);}},start(){if(!W.isRunning){W.isInitialized||this.initialize(),W.isRunning=true;for(let e of r.modules)e.hooks?.onStart?.(I);if(q.emitStart(I),r.errorBoundary?.retryLater&&!te){let e=Math.max(r.errorBoundary.retryLater.delayMs??1e3,250);te=setInterval(()=>{let i=V.processDueRetries();for(let g of i)g.callback?g.callback():ge();},Math.min(e,500));}ge();}},stop(){if(W.isRunning){W.isRunning=false,te!==null&&(clearInterval(te),te=null),V.getRetryLaterManager().clearAll(),ee.cancelAll(),le.cleanupAll();for(let e of r.modules)e.hooks?.onStop?.(I);q.emitStop(I);}},destroy(){W.isDestroyed||(this.stop(),W.isDestroyed=true,j.destroy?.(),ee.destroy(),V.clearErrors(),Re.clear(),ue.clear(),u.destroy(),oe.destroy(),h.clear(),C.clear(),H.clear(),q.emitDestroy(I));},dispatch(e){chunkS3CFYDIB_cjs.l.has(e.type)||je(e.type,e);},read(e){return re.get(e)},subscribe(e,i){let g=[],M=[];for(let $ of e)$ in l?g.push($):$ in t?M.push($):chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] subscribe: unknown key "${$}"`);let k=[];return g.length>0&&k.push(re.subscribe(g,i)),M.length>0&&k.push(j.subscribe(M,i)),()=>{for(let $ of k)$();}},watch(e,i,g){let M=g?.equalityFn?($,_)=>g.equalityFn($,_):($,_)=>Object.is($,_);if(e in l){let $=re.get(e);return re.subscribe([e],()=>{let _=re.get(e);if(!M(_,$)){let X=$;$=_,i(_,X);}})}chunkS3CFYDIB_cjs.a&&(e in t||console.warn(`[Directive] watch: unknown key "${e}"`));let k=j.get(e);return j.subscribe([e],()=>{let $=j.get(e);if(!M($,k)){let _=k;k=$,i($,_);}})},when(e,i){return new Promise((g,M)=>{let k=j.toObject();if(e(k)){g();return}let $,_,X=()=>{$?.(),_!==void 0&&clearTimeout(_);};$=j.subscribeAll(()=>{let G=j.toObject();e(G)&&(X(),g());}),i?.timeout!==void 0&&i.timeout>0&&(_=setTimeout(()=>{X(),M(new Error(`[Directive] when: timed out after ${i.timeout}ms`));},i.timeout));})},inspect(){return {unmet:W.previousRequirements.all(),inflight:ee.getInflightInfo(),facts:Object.keys(t).map(e=>({key:e,meta:t[e]?._meta})),events:Object.keys(c).map(e=>({name:e,meta:C.get(e)})),constraints:f.getAllStates().map(e=>{let i=f.getWhenSpec(e.id);return {id:e.id,active:e.lastResult??false,disabled:f.isDisabled(e.id),priority:e.priority,hitCount:e.hitCount,lastActiveAt:e.lastActiveAt,meta:o[e.id]?.meta,...i?{whenSpec:i}:{}}}),resolvers:Object.fromEntries(ee.getInflight().map(e=>[e,ee.getStatus(e)])),resolverDefs:Object.entries(d).map(([e,i])=>({id:e,requirement:typeof i.requirement=="string"?i.requirement:"(predicate)",meta:i.meta})),effects:Object.entries(s).map(([e,i])=>({id:e,meta:i.meta})),derivations:Object.keys(l).map(e=>({id:e,meta:re.getMeta(e)})),modules:r.modules.map(e=>({id:e.id,meta:h.get(e.id)})),traceEnabled:R,...R?{trace:structuredClone(u.getEntries()??[])}:{}}},explain(e){let g=W.previousRequirements.all().find(P=>P.id===e);if(!g)return null;let M=f.getState(g.fromConstraint),k=ee.getStatus(e),$={},_=f.getDependencies(g.fromConstraint);if(_)for(let P of _)$[P]=j.get(P);else for(let[P,Q]of Object.entries(j.toObject()))$[P]=Q;let X=o[g.fromConstraint],G=X?.meta?.label??g.fromConstraint,J=[`Requirement "${g.requirement.type}" (id: ${g.id})`,`\u251C\u2500 Produced by constraint: ${G}`,`\u251C\u2500 Constraint priority: ${M?.priority??0}`,`\u251C\u2500 Constraint active: ${M?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${k.state}`];X?.meta?.description&&J.push(`\u251C\u2500 Description: ${X.meta.description}`);let n=f.explainWhen(g.fromConstraint),a=(P,Q,ae)=>{let ce=ae?"\u2514\u2500":"\u251C\u2500",Se=P.pass?"\u2713":"\u2717";if(P.children){if(P.op==="$not"){let Ue=P.pass?" (child failed)":" (child passed)";J.push(`${Q}${ce} ${Se} $not${Ue}`);}else J.push(`${Q}${ce} ${Se} ${P.op} (${P.actual}/${P.expected})`);let Ot=`${Q}${ae?" ":"\u2502 "}`;P.children.forEach((Ue,qt)=>{a(Ue,Ot,qt===P.children.length-1);});return}let $t=typeof P.expected=="object"?JSON.stringify(P.expected):String(P.expected),Pt=P.actual===void 0?"undefined":typeof P.actual=="object"?JSON.stringify(P.actual):String(P.actual);J.push(`${Q}${ce} ${Se} ${P.path} ${P.op} ${$t} (actual: ${Pt})`);};n&&n.length>0&&(J.push("\u251C\u2500 Predicate clauses:"),n.forEach((P,Q)=>{a(P,"\u2502 ",Q===n.length-1);}));let v=Object.entries(g.requirement).filter(([P])=>P!=="type").map(([P,Q])=>`${P}=${JSON.stringify(Q)}`).join(", ");v&&J.push(`\u251C\u2500 Requirement payload: { ${v} }`);let E=Object.entries($).slice(0,10);return E.length>0&&(J.push("\u2514\u2500 Relevant facts:"),E.forEach(([P,Q],ae)=>{let ce=ae===E.length-1?" \u2514\u2500":" \u251C\u2500",Se=typeof Q=="object"?JSON.stringify(Q):String(Q);J.push(`${ce} ${P} = ${Se.slice(0,50)}${Se.length>50?"...":""}`);})),J.join(`
2
+ `)},getOriginal(e,i){return oe.getOriginal(e,i)},restoreOriginal(e,i){return oe.restoreOriginal(e,i)},async settle(e=5e3){let i=()=>ee.getInflightCount()===0&&!W.isReconciling&&!W.reconcileScheduled&&!ee.hasPendingBatches();if(ee.hasPendingBatches()&&ee.processBatches(),await new Promise(g=>queueMicrotask(g)),!i())return new Promise((g,M)=>{let k=false,$=()=>{k||(k=true,clearTimeout(_),X());},_=setTimeout(()=>{$();let G=[],J=ee.getInflightInfo();J.length>0&&G.push(`${J.length} resolvers inflight: ${J.map(a=>a.resolverId).join(", ")}`),W.isReconciling&&G.push("reconciliation in progress"),W.reconcileScheduled&&G.push("reconcile scheduled");let n=W.previousRequirements.all();n.length>0&&G.push(`${n.length} unmet requirements: ${n.map(a=>a.requirement.type).join(", ")}`),M(new Error(`[Directive] settle() timed out after ${e}ms. ${G.join("; ")}`));},e),X=this.onSettledChange(()=>{ee.hasPendingBatches()&&ee.processBatches(),queueMicrotask(()=>{!k&&i()&&($(),g());});});})},getSnapshot(){return {facts:j.toObject(),version:1}},getDistributableSnapshot(e={}){let{includeDerivations:i,excludeDerivations:g,includeFacts:M,ttlSeconds:k,metadata:$,includeVersion:_}=e,X={},G=Object.keys(l),J=new Set(G),n;if(i){if(n=i.filter(E=>J.has(E)),chunkS3CFYDIB_cjs.a){let E=i.filter(P=>!J.has(P));E.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown derivation keys ignored: ${E.join(", ")}. Available: ${G.join(", ")||"(none)"}`);}}else n=G;if(g){let E=new Set(g);n=n.filter(P=>!E.has(P));}for(let E of n)try{X[E]=re.get(E);}catch(P){chunkS3CFYDIB_cjs.a&&console.warn(`[Directive] getDistributableSnapshot: Skipping derivation "${E}" due to error:`,P);}if(M&&M.length>0){let E=j.toObject(),P=Object.keys(E);if(chunkS3CFYDIB_cjs.a){let Q=M.filter(ae=>!(ae in E));Q.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown fact keys ignored: ${Q.join(", ")}. Available: ${P.join(", ")||"(none)"}`);}for(let Q of M)Q in E&&(X[Q]=E[Q]);}let a=Date.now(),v={data:X,createdAt:a};return k!==void 0&&k>0&&(v.expiresAt=a+k*1e3),_&&(v.version=chunkEOLY64E6_cjs.g(X)),$&&(v.metadata=$),v},watchDistributableSnapshot(e,i){let{includeDerivations:g,excludeDerivations:M}=e,k=Object.keys(l),$;if(g?$=g.filter(G=>k.includes(G)):$=k,M){let G=new Set(M);$=$.filter(J=>!G.has(J));}if($.length===0)return chunkS3CFYDIB_cjs.a&&console.warn("[Directive] watchDistributableSnapshot: No derivations to watch. Callback will never be called."),()=>{};let X=this.getDistributableSnapshot({...e,includeVersion:true}).version;return re.subscribe($,()=>{let G=this.getDistributableSnapshot({...e,includeVersion:true});G.version!==X&&(X=G.version,i(G));})},restore(e){if(!e||typeof e!="object")throw new Error("[Directive] restore() requires a valid snapshot object");if(!e.facts||typeof e.facts!="object")throw new Error("[Directive] restore() snapshot must have a facts object");if(!chunkEOLY64E6_cjs.e(e))throw new Error("[Directive] restore() rejected: snapshot contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");j.batch(()=>{for(let[i,g]of Object.entries(e.facts))chunkS3CFYDIB_cjs.l.has(i)||j.set(i,g);});},onSettledChange(e){return Re.add(e),()=>{Re.delete(e);}},onHistoryChange(e){return ue.add(e),()=>{ue.delete(e);}},batch(e){j.batch(e);},get isSettled(){return ee.getInflightCount()===0&&!ee.hasPendingBatches()&&!W.isReconciling&&!W.reconcileScheduled},get isRunning(){return W.isRunning},get isInitialized(){return W.isInitialized},get isReady(){return W.isReady},whenReady(){return W.isReady?Promise.resolve():W.isRunning?(W.readyPromise||(W.readyPromise=new Promise(e=>{W.readyResolve=e;})),W.readyPromise):Promise.reject(new Error("[Directive] whenReady() called before start(). Call system.start() first, then await system.whenReady()."))}};function L(e){if(W.isReconciling)throw new Error(`[Directive] Cannot register module "${e.id}" during reconciliation. Wait for the current reconciliation cycle to complete.`);if(W.isDestroyed)throw new Error(`[Directive] Cannot register module "${e.id}" on a destroyed system.`);let i=(g,M)=>{if(g)for(let k of Object.keys(g)){if(chunkS3CFYDIB_cjs.l.has(k))throw new Error(`[Directive] Security: Module "${e.id}" has dangerous key "${k}" in ${M}.`);if(M==="schema"&&k.startsWith("$"))throw new Error(`[Directive] Module "${e.id}" has schema key "${k}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};i(e.schema,"schema"),i(e.events,"events"),i(e.derive,"derive"),i(e.effects,"effects"),i(e.constraints,"constraints"),i(e.resolvers,"resolvers");for(let g of Object.keys(e.schema))if(g in t)throw new Error(`[Directive] Schema collision: Fact "${g}" already exists. Cannot register module "${e.id}".`);if(chunkS3CFYDIB_cjs.a&&e.derive){let g=new Set(Object.keys(t));for(let M of Object.keys(e.derive))g.has(M)&&console.warn(`[Directive] "${M}" exists as both a fact and a derivation after registering module "${e.id}".`);}if(e.history?.snapshotEvents){U===null&&(U=new Set(Object.keys(c)));for(let g of e.history.snapshotEvents)U.add(g);}else if(U!==null&&e.events)for(let g of Object.keys(e.events))U.add(g);Object.assign(t,e.schema);for(let g of Object.values(e.schema)){let M=g;M._meta&&(M._meta=de(M._meta));}if(e.events&&(Ct(e.events,C),Object.assign(c,e.events)),e.derive&&(Object.assign(l,e.derive),re.registerDefinitions(e.derive)),e.effects){for(let g of Object.values(e.effects)){let M=g;M.meta&&(M.meta=de(M.meta));}Object.assign(s,e.effects),le.registerDefinitions(e.effects);}if(e.constraints){for(let g of Object.values(e.constraints)){let M=g;M.meta&&(M.meta=de(M.meta));}Object.assign(o,e.constraints),f.registerDefinitions(e.constraints);}if(e.resolvers){for(let g of Object.values(e.resolvers)){let M=g;M.meta&&(M.meta=de(M.meta));}Object.assign(d,e.resolvers);for(let g of Object.keys(e.resolvers))B.set(g,e);ee.registerDefinitions(e.resolvers),x(e.resolvers);}if(j.registerKeys(e.schema),e.meta){let g=de(e.meta);g&&h.set(e.id,g);}r.modules.push(e),e.init&&j.batch(()=>{e.init(Z);}),e.hooks?.onInit?.(I),W.isRunning&&(e.hooks?.onStart?.(I),ge());}I.registerModule=L,q.emitInit(I);for(let e of r.modules)e.hooks?.onInit?.(I);return I}exports.A=Dn;exports.B=kn;exports.C=Me;exports.D=mt;exports.E=pt;exports.F=yt;exports.G=Ht;exports.H=vt;exports.I=Jt;exports.J=Xt;exports.K=St;exports.L=bt;exports.M=Dt;exports.N=br;exports.a=$e;exports.b=en;exports.c=ot;exports.d=Pe;exports.e=Ze;exports.f=sn;exports.g=We;exports.h=Le;exports.i=Ie;exports.j=at;exports.k=Ge;exports.l=an;exports.m=lt;exports.n=ft;exports.o=mn;exports.p=Te;exports.q=Ft;exports.r=Kt;exports.s=Wt;exports.t=Bt;exports.u=un;exports.v=dn;exports.w=ut;exports.x=dt;exports.y=zt;exports.z=wn;//# sourceMappingURL=chunk-K3KVGWLP.cjs.map
3
+ //# sourceMappingURL=chunk-K3KVGWLP.cjs.map