@directive-run/core 0.8.1 → 0.8.3

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 (62) hide show
  1. package/LICENSE +5 -0
  2. package/dist/adapter-utils.cjs +1 -1
  3. package/dist/adapter-utils.cjs.map +1 -1
  4. package/dist/adapter-utils.d.cts +1 -1
  5. package/dist/adapter-utils.d.ts +1 -1
  6. package/dist/adapter-utils.js +1 -1
  7. package/dist/adapter-utils.js.map +1 -1
  8. package/dist/chunk-6WG7FPH7.cjs +3 -0
  9. package/dist/chunk-6WG7FPH7.cjs.map +1 -0
  10. package/dist/chunk-DIK3SZBM.js +3 -0
  11. package/dist/chunk-DIK3SZBM.js.map +1 -0
  12. package/dist/chunk-GO63IIN5.js +2 -0
  13. package/dist/chunk-GO63IIN5.js.map +1 -0
  14. package/dist/chunk-KQKNE23L.cjs +2 -0
  15. package/dist/chunk-KQKNE23L.cjs.map +1 -0
  16. package/dist/chunk-LAH2FMON.cjs +16 -0
  17. package/dist/chunk-LAH2FMON.cjs.map +1 -0
  18. package/dist/chunk-MAARYRI4.js +16 -0
  19. package/dist/chunk-MAARYRI4.js.map +1 -0
  20. package/dist/chunk-O75OISQ2.js +2 -0
  21. package/dist/chunk-O75OISQ2.js.map +1 -0
  22. package/dist/chunk-PK2EH26L.cjs +2 -0
  23. package/dist/chunk-PK2EH26L.cjs.map +1 -0
  24. package/dist/helpers-50q7yhA9.d.ts +179 -0
  25. package/dist/helpers-B6SkcKCD.d.cts +179 -0
  26. package/dist/index.cjs +1 -16
  27. package/dist/index.cjs.map +1 -1
  28. package/dist/index.d.cts +42 -1421
  29. package/dist/index.d.ts +42 -1421
  30. package/dist/index.js +1 -16
  31. package/dist/index.js.map +1 -1
  32. package/dist/internals.cjs +2 -0
  33. package/dist/internals.cjs.map +1 -0
  34. package/dist/internals.d.cts +1176 -0
  35. package/dist/internals.d.ts +1176 -0
  36. package/dist/internals.js +2 -0
  37. package/dist/internals.js.map +1 -0
  38. package/dist/plugins/index.cjs +2 -2
  39. package/dist/plugins/index.cjs.map +1 -1
  40. package/dist/plugins/index.d.cts +1 -1
  41. package/dist/plugins/index.d.ts +1 -1
  42. package/dist/plugins/index.js +2 -2
  43. package/dist/plugins/index.js.map +1 -1
  44. package/dist/{plugins-DaglUQVX.d.cts → plugins-Bg_oq2sO.d.cts} +22 -2
  45. package/dist/{plugins-DaglUQVX.d.ts → plugins-Bg_oq2sO.d.ts} +22 -2
  46. package/dist/system-L2FVVUSN.js +2 -0
  47. package/dist/system-L2FVVUSN.js.map +1 -0
  48. package/dist/system-L45Z2N4U.cjs +2 -0
  49. package/dist/system-L45Z2N4U.cjs.map +1 -0
  50. package/dist/testing.cjs +1 -16
  51. package/dist/testing.cjs.map +1 -1
  52. package/dist/testing.d.cts +54 -16
  53. package/dist/testing.d.ts +54 -16
  54. package/dist/testing.js +1 -16
  55. package/dist/testing.js.map +1 -1
  56. package/dist/worker.cjs +1 -16
  57. package/dist/worker.cjs.map +1 -1
  58. package/dist/worker.d.cts +1 -1
  59. package/dist/worker.d.ts +1 -1
  60. package/dist/worker.js +1 -16
  61. package/dist/worker.js.map +1 -1
  62. package/package.json +13 -4
@@ -250,7 +250,7 @@ interface ConstraintDef<S extends Schema, R extends Requirement = Requirement> {
250
250
  * Constraint IDs whose resolvers must complete before this constraint is evaluated.
251
251
  * If a dependency's `when()` returns false (no requirements), this constraint proceeds.
252
252
  * If a dependency's resolver fails, this constraint remains blocked.
253
- * Cross-module: use "moduleName::constraintName" format (after references are not auto-prefixed).
253
+ * Same-module references are auto-prefixed. Cross-module: use "moduleName::constraintName" format.
254
254
  */
255
255
  after?: string[];
256
256
  /**
@@ -694,6 +694,12 @@ interface CreateSystemOptionsNamed<Modules extends ModulesMap> {
694
694
  * Enable zero-config mode with sensible defaults.
695
695
  */
696
696
  zeroConfig?: boolean;
697
+ /**
698
+ * Connect to Directive Cloud for remote traces, dashboards, and team collaboration.
699
+ *
700
+ * @see https://directive.run/pricing
701
+ */
702
+ cloud?: boolean | string;
697
703
  /**
698
704
  * Initial facts to set after module init (namespaced format).
699
705
  * Applied after all module `init()` functions but before reconciliation.
@@ -945,6 +951,12 @@ interface CreateSystemOptionsSingle<S extends ModuleSchema> {
945
951
  tickMs?: number;
946
952
  /** Enable zero-config mode with sensible defaults */
947
953
  zeroConfig?: boolean;
954
+ /**
955
+ * Connect to Directive Cloud for remote traces, dashboards, and team collaboration.
956
+ *
957
+ * @see https://directive.run/pricing
958
+ */
959
+ cloud?: boolean | string;
948
960
  /**
949
961
  * Initial facts to set after module init.
950
962
  * Applied after module `init()` but before reconciliation.
@@ -1981,6 +1993,14 @@ interface SystemConfig<M extends ModuleSchema = ModuleSchema> {
1981
1993
  */
1982
1994
  onAfterModuleInit?: () => void;
1983
1995
  tickMs?: number;
1996
+ /**
1997
+ * Connect to Directive Cloud for remote traces, dashboards, and team collaboration.
1998
+ *
1999
+ * Pass a license key string to authenticate with Directive Cloud.
2000
+ *
2001
+ * @see https://directive.run/pricing
2002
+ */
2003
+ cloud?: boolean | string;
1984
2004
  }
1985
2005
 
1986
2006
  /**
@@ -2218,4 +2238,4 @@ interface Plugin<M extends ModuleSchema = ModuleSchema> {
2218
2238
  onTraceComplete?: (entry: TraceEntry) => void;
2219
2239
  }
2220
2240
 
2221
- export { type CrossModuleDerivationFn as $, type FactChange as A, type BatchConfig as B, type CrossModuleDeps as C, type FactsSnapshot as D, type EffectsDef as E, type Facts as F, type ReconcileResult as G, type Snapshot as H, DirectiveError as I, type RecoveryStrategy as J, type TraceEntry as K, type ErrorSource as L, type ModuleSchema as M, type NamespacedSystem as N, type RetryLaterConfig as O, type Plugin as P, type HistoryAPI as Q, type Requirement as R, type Schema as S, type TypedDerivationsDef as T, type HistoryOption as U, type SystemConfig as V, type AnySystem as W, type BatchItemResult as X, type BatchResolveResults as Y, type ConstraintsControl as Z, type CrossModuleConstraintDef as _, type RequirementOutput$1 as a, type CrossModuleEffectDef as a0, type CrossModuleFactsWithSelf as a1, type DerivationKeys as a2, type DerivationReturnType as a3, type DerivationsControl as a4, type DerivationsSchema as a5, type DeriveAccessor as a6, type DispatchEventsFromSchema as a7, type DistributableSnapshot as a8, type DistributableSnapshotOptions as a9, type NamespacedDerivations as aA, type NamespacedEventsAccessor as aB, type NamespacedFacts as aC, type ObservableKeys as aD, type RequirementExplanation as aE, type RequirementOutput as aF, type RequirementPayloadSchema$1 as aG, type RequirementsSchema as aH, type ResolversControl as aI, type SnapshotMeta as aJ, type SystemEvent as aK, type SystemInspection as aL, type SystemMode as aM, type SystemSnapshot as aN, type TraceConfig as aO, type TypedConstraintDef as aP, type TypedResolverContext as aQ, type TypedResolverDef as aR, type UnionEvents as aS, isNamespacedSystem as aT, isSingleModuleSystem as aU, type DynamicConstraintDef as aa, type DynamicEffectDef as ab, type DynamicResolverDef as ac, type EffectCleanup as ad, type EffectsControl as ae, type EventPayloadSchema as af, type EventsAccessor as ag, type EventsAccessorFromSchema as ah, type EventsDef as ai, type EventsSchema as aj, type FactKeys as ak, type FactReturnType as al, type FlexibleEventHandler as am, type HistoryConfig as an, type HistoryState as ao, type InferDerivations as ap, type InferEventPayloadFromSchema as aq, type InferEvents as ar, type InferFacts as as, type InferRequirementPayloadFromSchema as at, type InferRequirementTypes as au, type InferRequirements as av, type InferSchema as aw, type InferSchemaType as ax, type InferSelectorState as ay, type MutableNamespacedFacts as az, type RetryPolicy as b, type ResolverContext as c, type SchemaType as d, type TypedEventsDef as e, type TypedConstraintsDef as f, type TypedResolversDef as g, type ModuleHooks as h, type CrossModuleDerivationsDef as i, type CrossModuleEffectsDef as j, type CrossModuleConstraintsDef as k, type ModuleDef as l, type CreateSystemOptionsSingle as m, type SingleModuleSystem as n, type ModulesMap as o, type CreateSystemOptionsNamed as p, type TraceOption as q, type ErrorBoundaryConfig as r, type RequirementWithId as s, type RequirementKeyFn as t, type FactsStore as u, type ConstraintsDef as v, type ConstraintState as w, type ResolversDef as x, type ResolverStatus as y, type System as z };
2241
+ export { isNamespacedSystem as $, type AnySystem as A, type BatchConfig as B, type CrossModuleDeps as C, DirectiveError as D, type EffectsDef as E, type Facts as F, type InferRequirementTypes as G, type HistoryAPI as H, type InferDerivations as I, type InferRequirements as J, type InferSchemaType as K, type InferSelectorState as L, type ModuleSchema as M, type NamespacedSystem as N, type RetryPolicy as O, type Plugin as P, type Schema as Q, type RequirementWithId as R, type SchemaType as S, type TypedDerivationsDef as T, type Snapshot as U, type System as V, type SystemConfig as W, type SystemInspection as X, type SystemMode as Y, type SystemSnapshot as Z, type TraceEntry as _, type TypedEventsDef as a, isSingleModuleSystem as a0, type FactsStore as a1, type ConstraintsDef as a2, type ConstraintState as a3, type ResolversDef as a4, type ResolverStatus as a5, type FactChange as a6, type ReconcileResult as a7, type RecoveryStrategy as a8, type ErrorSource as a9, type InferRequirementPayloadFromSchema as aA, type InferSchema as aB, type MutableNamespacedFacts as aC, type NamespacedDerivations as aD, type NamespacedEventsAccessor as aE, type NamespacedFacts as aF, type ObservableKeys as aG, type RequirementExplanation as aH, type RequirementOutput as aI, type RequirementPayloadSchema$1 as aJ, type RequirementsSchema as aK, type ResolverContext as aL, type ResolversControl as aM, type SnapshotMeta as aN, type SystemEvent as aO, type TraceConfig as aP, type TypedConstraintDef as aQ, type TypedResolverContext as aR, type TypedResolverDef as aS, type UnionEvents as aT, type RequirementOutput$1 as aU, type RetryLaterConfig as aa, type BatchItemResult as ab, type BatchResolveResults as ac, type ConstraintsControl as ad, type CrossModuleConstraintDef as ae, type CrossModuleDerivationFn as af, type CrossModuleEffectDef as ag, type CrossModuleFactsWithSelf as ah, type DerivationKeys as ai, type DerivationReturnType as aj, type DerivationsControl as ak, type DerivationsSchema as al, type DeriveAccessor as am, type DispatchEventsFromSchema as an, type EffectCleanup as ao, type EffectsControl as ap, type EventPayloadSchema as aq, type EventsAccessor as ar, type EventsAccessorFromSchema as as, type EventsDef as at, type EventsSchema as au, type FactKeys as av, type FactReturnType as aw, type FlexibleEventHandler as ax, type HistoryConfig as ay, type InferEventPayloadFromSchema as az, type TypedConstraintsDef as b, type TypedResolversDef as c, type ModuleHooks as d, type CrossModuleDerivationsDef as e, type CrossModuleEffectsDef as f, type CrossModuleConstraintsDef as g, type ModuleDef as h, type CreateSystemOptionsSingle as i, type SingleModuleSystem as j, type ModulesMap as k, type CreateSystemOptionsNamed as l, type TraceOption as m, type ErrorBoundaryConfig as n, type Requirement as o, type RequirementKeyFn as p, type DistributableSnapshot as q, type DistributableSnapshotOptions as r, type DynamicConstraintDef as s, type DynamicEffectDef as t, type DynamicResolverDef as u, type FactsSnapshot as v, type HistoryOption as w, type HistoryState as x, type InferEvents as y, type InferFacts as z };
@@ -250,7 +250,7 @@ interface ConstraintDef<S extends Schema, R extends Requirement = Requirement> {
250
250
  * Constraint IDs whose resolvers must complete before this constraint is evaluated.
251
251
  * If a dependency's `when()` returns false (no requirements), this constraint proceeds.
252
252
  * If a dependency's resolver fails, this constraint remains blocked.
253
- * Cross-module: use "moduleName::constraintName" format (after references are not auto-prefixed).
253
+ * Same-module references are auto-prefixed. Cross-module: use "moduleName::constraintName" format.
254
254
  */
255
255
  after?: string[];
256
256
  /**
@@ -694,6 +694,12 @@ interface CreateSystemOptionsNamed<Modules extends ModulesMap> {
694
694
  * Enable zero-config mode with sensible defaults.
695
695
  */
696
696
  zeroConfig?: boolean;
697
+ /**
698
+ * Connect to Directive Cloud for remote traces, dashboards, and team collaboration.
699
+ *
700
+ * @see https://directive.run/pricing
701
+ */
702
+ cloud?: boolean | string;
697
703
  /**
698
704
  * Initial facts to set after module init (namespaced format).
699
705
  * Applied after all module `init()` functions but before reconciliation.
@@ -945,6 +951,12 @@ interface CreateSystemOptionsSingle<S extends ModuleSchema> {
945
951
  tickMs?: number;
946
952
  /** Enable zero-config mode with sensible defaults */
947
953
  zeroConfig?: boolean;
954
+ /**
955
+ * Connect to Directive Cloud for remote traces, dashboards, and team collaboration.
956
+ *
957
+ * @see https://directive.run/pricing
958
+ */
959
+ cloud?: boolean | string;
948
960
  /**
949
961
  * Initial facts to set after module init.
950
962
  * Applied after module `init()` but before reconciliation.
@@ -1981,6 +1993,14 @@ interface SystemConfig<M extends ModuleSchema = ModuleSchema> {
1981
1993
  */
1982
1994
  onAfterModuleInit?: () => void;
1983
1995
  tickMs?: number;
1996
+ /**
1997
+ * Connect to Directive Cloud for remote traces, dashboards, and team collaboration.
1998
+ *
1999
+ * Pass a license key string to authenticate with Directive Cloud.
2000
+ *
2001
+ * @see https://directive.run/pricing
2002
+ */
2003
+ cloud?: boolean | string;
1984
2004
  }
1985
2005
 
1986
2006
  /**
@@ -2218,4 +2238,4 @@ interface Plugin<M extends ModuleSchema = ModuleSchema> {
2218
2238
  onTraceComplete?: (entry: TraceEntry) => void;
2219
2239
  }
2220
2240
 
2221
- export { type CrossModuleDerivationFn as $, type FactChange as A, type BatchConfig as B, type CrossModuleDeps as C, type FactsSnapshot as D, type EffectsDef as E, type Facts as F, type ReconcileResult as G, type Snapshot as H, DirectiveError as I, type RecoveryStrategy as J, type TraceEntry as K, type ErrorSource as L, type ModuleSchema as M, type NamespacedSystem as N, type RetryLaterConfig as O, type Plugin as P, type HistoryAPI as Q, type Requirement as R, type Schema as S, type TypedDerivationsDef as T, type HistoryOption as U, type SystemConfig as V, type AnySystem as W, type BatchItemResult as X, type BatchResolveResults as Y, type ConstraintsControl as Z, type CrossModuleConstraintDef as _, type RequirementOutput$1 as a, type CrossModuleEffectDef as a0, type CrossModuleFactsWithSelf as a1, type DerivationKeys as a2, type DerivationReturnType as a3, type DerivationsControl as a4, type DerivationsSchema as a5, type DeriveAccessor as a6, type DispatchEventsFromSchema as a7, type DistributableSnapshot as a8, type DistributableSnapshotOptions as a9, type NamespacedDerivations as aA, type NamespacedEventsAccessor as aB, type NamespacedFacts as aC, type ObservableKeys as aD, type RequirementExplanation as aE, type RequirementOutput as aF, type RequirementPayloadSchema$1 as aG, type RequirementsSchema as aH, type ResolversControl as aI, type SnapshotMeta as aJ, type SystemEvent as aK, type SystemInspection as aL, type SystemMode as aM, type SystemSnapshot as aN, type TraceConfig as aO, type TypedConstraintDef as aP, type TypedResolverContext as aQ, type TypedResolverDef as aR, type UnionEvents as aS, isNamespacedSystem as aT, isSingleModuleSystem as aU, type DynamicConstraintDef as aa, type DynamicEffectDef as ab, type DynamicResolverDef as ac, type EffectCleanup as ad, type EffectsControl as ae, type EventPayloadSchema as af, type EventsAccessor as ag, type EventsAccessorFromSchema as ah, type EventsDef as ai, type EventsSchema as aj, type FactKeys as ak, type FactReturnType as al, type FlexibleEventHandler as am, type HistoryConfig as an, type HistoryState as ao, type InferDerivations as ap, type InferEventPayloadFromSchema as aq, type InferEvents as ar, type InferFacts as as, type InferRequirementPayloadFromSchema as at, type InferRequirementTypes as au, type InferRequirements as av, type InferSchema as aw, type InferSchemaType as ax, type InferSelectorState as ay, type MutableNamespacedFacts as az, type RetryPolicy as b, type ResolverContext as c, type SchemaType as d, type TypedEventsDef as e, type TypedConstraintsDef as f, type TypedResolversDef as g, type ModuleHooks as h, type CrossModuleDerivationsDef as i, type CrossModuleEffectsDef as j, type CrossModuleConstraintsDef as k, type ModuleDef as l, type CreateSystemOptionsSingle as m, type SingleModuleSystem as n, type ModulesMap as o, type CreateSystemOptionsNamed as p, type TraceOption as q, type ErrorBoundaryConfig as r, type RequirementWithId as s, type RequirementKeyFn as t, type FactsStore as u, type ConstraintsDef as v, type ConstraintState as w, type ResolversDef as x, type ResolverStatus as y, type System as z };
2241
+ export { isNamespacedSystem as $, type AnySystem as A, type BatchConfig as B, type CrossModuleDeps as C, DirectiveError as D, type EffectsDef as E, type Facts as F, type InferRequirementTypes as G, type HistoryAPI as H, type InferDerivations as I, type InferRequirements as J, type InferSchemaType as K, type InferSelectorState as L, type ModuleSchema as M, type NamespacedSystem as N, type RetryPolicy as O, type Plugin as P, type Schema as Q, type RequirementWithId as R, type SchemaType as S, type TypedDerivationsDef as T, type Snapshot as U, type System as V, type SystemConfig as W, type SystemInspection as X, type SystemMode as Y, type SystemSnapshot as Z, type TraceEntry as _, type TypedEventsDef as a, isSingleModuleSystem as a0, type FactsStore as a1, type ConstraintsDef as a2, type ConstraintState as a3, type ResolversDef as a4, type ResolverStatus as a5, type FactChange as a6, type ReconcileResult as a7, type RecoveryStrategy as a8, type ErrorSource as a9, type InferRequirementPayloadFromSchema as aA, type InferSchema as aB, type MutableNamespacedFacts as aC, type NamespacedDerivations as aD, type NamespacedEventsAccessor as aE, type NamespacedFacts as aF, type ObservableKeys as aG, type RequirementExplanation as aH, type RequirementOutput as aI, type RequirementPayloadSchema$1 as aJ, type RequirementsSchema as aK, type ResolverContext as aL, type ResolversControl as aM, type SnapshotMeta as aN, type SystemEvent as aO, type TraceConfig as aP, type TypedConstraintDef as aQ, type TypedResolverContext as aR, type TypedResolverDef as aS, type UnionEvents as aT, type RequirementOutput$1 as aU, type RetryLaterConfig as aa, type BatchItemResult as ab, type BatchResolveResults as ac, type ConstraintsControl as ad, type CrossModuleConstraintDef as ae, type CrossModuleDerivationFn as af, type CrossModuleEffectDef as ag, type CrossModuleFactsWithSelf as ah, type DerivationKeys as ai, type DerivationReturnType as aj, type DerivationsControl as ak, type DerivationsSchema as al, type DeriveAccessor as am, type DispatchEventsFromSchema as an, type EffectCleanup as ao, type EffectsControl as ap, type EventPayloadSchema as aq, type EventsAccessor as ar, type EventsAccessorFromSchema as as, type EventsDef as at, type EventsSchema as au, type FactKeys as av, type FactReturnType as aw, type FlexibleEventHandler as ax, type HistoryConfig as ay, type InferEventPayloadFromSchema as az, type TypedConstraintsDef as b, type TypedResolversDef as c, type ModuleHooks as d, type CrossModuleDerivationsDef as e, type CrossModuleEffectsDef as f, type CrossModuleConstraintsDef as g, type ModuleDef as h, type CreateSystemOptionsSingle as i, type SingleModuleSystem as j, type ModulesMap as k, type CreateSystemOptionsNamed as l, type TraceOption as m, type ErrorBoundaryConfig as n, type Requirement as o, type RequirementKeyFn as p, type DistributableSnapshot as q, type DistributableSnapshotOptions as r, type DynamicConstraintDef as s, type DynamicEffectDef as t, type DynamicResolverDef as u, type FactsSnapshot as v, type HistoryOption as w, type HistoryState as x, type InferEvents as y, type InferFacts as z };
@@ -0,0 +1,2 @@
1
+ export{a as createSystem}from'./chunk-MAARYRI4.js';import'./chunk-DIK3SZBM.js';import'./chunk-O75OISQ2.js';import'./chunk-GO63IIN5.js';//# sourceMappingURL=system-L2FVVUSN.js.map
2
+ //# sourceMappingURL=system-L2FVVUSN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"system-L2FVVUSN.js"}
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunkLAH2FMON_cjs=require('./chunk-LAH2FMON.cjs');require('./chunk-6WG7FPH7.cjs'),require('./chunk-PK2EH26L.cjs'),require('./chunk-KQKNE23L.cjs');Object.defineProperty(exports,"createSystem",{enumerable:true,get:function(){return chunkLAH2FMON_cjs.a}});//# sourceMappingURL=system-L45Z2N4U.cjs.map
2
+ //# sourceMappingURL=system-L45Z2N4U.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"system-L45Z2N4U.cjs"}
package/dist/testing.cjs CHANGED
@@ -1,17 +1,2 @@
1
- 'use strict';async function ge(r,t,g){let l,m=new Promise((i,c)=>{l=setTimeout(()=>c(new Error(g)),t);});try{return await Promise.race([r,m])}finally{clearTimeout(l);}}function ve(r,t=50){let g=new WeakSet;function l(m,i){if(i>t)return '"[max depth exceeded]"';if(m===null)return "null";if(m===void 0)return "undefined";let c=typeof m;if(c==="string")return JSON.stringify(m);if(c==="number"||c==="boolean")return String(m);if(c==="function")return '"[function]"';if(c==="symbol")return '"[symbol]"';if(Array.isArray(m)){if(g.has(m))return '"[circular]"';g.add(m);let D=`[${m.map(p=>l(p,i+1)).join(",")}]`;return g.delete(m),D}if(c==="object"){let D=m;if(g.has(D))return '"[circular]"';g.add(D);let q=`{${Object.keys(D).sort().map(b=>`${JSON.stringify(b)}:${l(D[b],i+1)}`).join(",")}}`;return g.delete(D),q}return '"[unknown]"'}return l(r,0)}function oe(r,t=50){let g=new Set(["__proto__","constructor","prototype"]),l=new WeakSet;function m(i,c){if(c>t)return false;if(i==null||typeof i!="object")return true;let D=i;if(l.has(D))return true;if(l.add(D),Array.isArray(D)){for(let p of D)if(!m(p,c+1))return l.delete(D),false;return l.delete(D),true}for(let p of Object.keys(D))if(g.has(p)||!m(D[p],c+1))return l.delete(D),false;return l.delete(D),true}return m(r,0)}function be(r){let t=ve(r),g=5381;for(let l=0;l<t.length;l++)g=(g<<5)+g^t.charCodeAt(l);return (g>>>0).toString(16)}function et(r){return typeof r=="boolean"?{enabled:r,maxSnapshots:100}:{enabled:true,maxSnapshots:r.maxSnapshots??100}}function ke(r){let{historyOption:t,facts:g,store:l,onSnapshot:m,onHistoryChange:i}=r,{enabled:c,maxSnapshots:D}=et(t),p=[],S=-1,q=1,b=false,d=false,k=[],E=null,B=-1;function j(){return l.toObject()}function x(){let T=j();return structuredClone(T)}function R(T){if(!oe(T)){console.error("[Directive] Potential prototype pollution detected in snapshot data, skipping restore");return}l.batch(()=>{for(let[F,$]of Object.entries(T)){if(F==="__proto__"||F==="constructor"||F==="prototype"){console.warn(`[Directive] Skipping dangerous key "${F}" during fact restoration`);continue}g[F]=$;}});}return {get isEnabled(){return c},get isRestoring(){return d},get isPaused(){return b},get snapshots(){return [...p]},get currentIndex(){return S},takeSnapshot(T){if(!c||b)return {id:-1,timestamp:Date.now(),facts:{},trigger:T};let F={id:q++,timestamp:Date.now(),facts:x(),trigger:T};for(S<p.length-1&&p.splice(S+1),p.push(F),S=p.length-1;p.length>D;)p.shift(),S--;return m?.(F),F},restore(T){if(c){b=true,d=true;try{R(T.facts);}finally{b=false,d=false;}}},goBack(T=1){if(!c||p.length===0)return;let F=S,$=S,e=k.find(a=>S>a.startIndex&&S<=a.endIndex);if(e)$=e.startIndex;else if(k.find(C=>S===C.startIndex)){let C=k.find(I=>I.endIndex<S&&S-I.endIndex<=T);$=C?C.startIndex:Math.max(0,S-T);}else $=Math.max(0,S-T);if(F===$)return;S=$;let s=p[S];s&&(this.restore(s),i?.(F,$));},goForward(T=1){if(!c||p.length===0)return;let F=S,$=S,e=k.find(a=>S>=a.startIndex&&S<a.endIndex);if(e?$=e.endIndex:$=Math.min(p.length-1,S+T),F===$)return;S=$;let s=p[S];s&&(this.restore(s),i?.(F,$));},goTo(T){if(!c)return;let F=p.findIndex(s=>s.id===T);if(F===-1){console.warn(`[Directive] Snapshot ${T} not found`);return}let $=S;S=F;let e=p[S];e&&(this.restore(e),i?.($,F));},replay(){if(!c||p.length===0)return;S=0;let T=p[0];T&&this.restore(T);},export(){return JSON.stringify({version:1,snapshots:p,currentIndex:S})},import(T){if(c)try{let F=JSON.parse(T);if(typeof F!="object"||F===null)throw new Error("Invalid history data: expected object");if(F.version!==1)throw new Error(`Unsupported history export version: ${F.version}`);if(!Array.isArray(F.snapshots))throw new Error("Invalid history data: snapshots must be an array");if(typeof F.currentIndex!="number")throw new Error("Invalid history data: currentIndex must be a number");for(let e of F.snapshots){if(typeof e!="object"||e===null)throw new Error("Invalid snapshot: expected object");if(typeof e.id!="number"||typeof e.timestamp!="number"||typeof e.trigger!="string"||typeof e.facts!="object")throw new Error("Invalid snapshot structure");if(!oe(e.facts))throw new Error("Invalid fact data: potential prototype pollution detected in nested objects")}p.length=0,p.push(...F.snapshots),S=F.currentIndex;let $=p[S];$&&this.restore($);}catch(F){console.error("[Directive] Failed to import history data:",F);}},beginChangeset(T){c&&(E=T,B=S);},endChangeset(){!c||E===null||(S>B&&k.push({label:E,startIndex:B,endIndex:S}),E=null,B=-1);},pause(){b=true;},resume(){b=false;}}}function De(){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 Ee=new WeakMap;function tt(r,t){if(t)return t(r);let g=Ee.get(r);if(g!==void 0)return g;let{type:l,...m}=r,i=ve(m),c=`${l}:${i}`;return Ee.set(r,c),c}function pe(r,t,g){return {requirement:r,id:tt(r,g),fromConstraint:t}}var le=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 g of this.map.values())t.add(g);return t}diff(t){let g=[],l=[],m=[];for(let i of this.map.values())t.has(i.id)?m.push(i):g.push(i);for(let i of t.map.values())this.map.has(i.id)||l.push(i);return {added:g,removed:l,unchanged:m}}};var de=[];function nt(){let r=new Set;return {get isTracking(){return true},track(t){r.add(t);},getDependencies(){return r}}}var rt={isTracking:false,track(){},getDependencies(){return new Set}};function st(){return de[de.length-1]??rt}function fe(r){let t=nt();de.push(t);try{return {value:r(),deps:t.getDependencies()}}finally{de.pop();}}function he(r){let t=de.splice(0,de.length);try{return r()}finally{for(let g of t)de.push(g);}}function ye(r){st().track(r);}var G=Object.freeze(new Set(["__proto__","constructor","prototype"]));var it=5e3;function xe(r){let{definitions:t,facts:g,requirementKeys:l={},defaultTimeout:m=it,onEvaluate:i,onError:c}=r,D=new Map,p=new Set,S=new Set,q=new Map,b=new Map,d=new Set,k=new Map,E=new Map,B=false,j=new Set,x=new Set,R=new Map,V=[],T=new Map;function F(){R.clear();for(let[u,w]of Object.entries(t))if(w.after)for(let v of w.after)t[v]&&(R.has(v)||R.set(v,new Set),R.get(v).add(u));}function $(){let u=new Set,w=new Set,v=[];function M(A,ee){if(u.has(A))return;if(w.has(A)){let f=ee.indexOf(A),h=[...ee.slice(f),A].join(" \u2192 ");throw new Error(`[Directive] Constraint cycle detected: ${h}. Remove one of the \`after\` dependencies to break the cycle.`)}w.add(A),ee.push(A);let n=t[A];if(n?.after)for(let f of n.after)t[f]&&M(f,ee);ee.pop(),w.delete(A),u.add(A),v.push(A);}for(let A of Object.keys(t))M(A,[]);V=v,T=new Map(V.map((A,ee)=>[A,ee]));}if($(),F(),process.env.NODE_ENV!=="production"){for(let[u,w]of Object.entries(t))if(w.after)for(let v of w.after)t[v]||console.warn(`[Directive] Constraint "${u}" references unknown constraint "${v}" in \`after\`. This dependency will be ignored. Check for typos or ensure the constraint exists.`);}function e(u,w){return w.async!==void 0?w.async:!!S.has(u)}function s(u){let w=t[u];if(!w)throw new Error(`[Directive] Unknown constraint: ${u}`);let v=e(u,w);v&&S.add(u);let M={id:u,priority:w.priority??0,isAsync:v,lastResult:null,isEvaluating:false,error:null,lastResolvedAt:null,after:w.after??[],hitCount:0,lastActiveAt:null};return D.set(u,M),M}function a(u){return D.get(u)??s(u)}function C(u,w){let v=q.get(u)??new Set;if(v.size===w.size&&v.size>0){let M=true;for(let A of w)if(!v.has(A)){M=false;break}if(M)return}for(let M of v){let A=b.get(M);A?.delete(u),A&&A.size===0&&b.delete(M);}for(let M of w)b.has(M)||b.set(M,new Set),b.get(M).add(u);q.set(u,w);}function I(u){let w=t[u];if(!w)return false;let v=a(u);v.isEvaluating=true,v.error=null;try{let M;if(w.deps)M=w.when(g),k.set(u,new Set(w.deps));else {let A=fe(()=>w.when(g));M=A.value,k.set(u,A.deps);}return M instanceof Promise?(S.add(u),v.isAsync=!0,process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Constraint "${u}" returned a Promise but was not marked as async. Add \`async: true\` to the constraint definition to avoid this warning and improve performance.`),M.then(A=>(v.lastResult=A,A&&(v.hitCount++,v.lastActiveAt=Date.now()),v.isEvaluating=!1,i?.(u,A),A)).catch(A=>(v.error=A instanceof Error?A:new Error(String(A)),v.lastResult=!1,v.isEvaluating=!1,c?.(u,A),!1))):(v.lastResult=M,M&&(v.hitCount++,v.lastActiveAt=Date.now()),v.isEvaluating=!1,i?.(u,M),M)}catch(M){return v.error=M instanceof Error?M:new Error(String(M)),v.lastResult=false,v.isEvaluating=false,c?.(u,M),false}}async function o(u){let w=t[u];if(!w)return false;let v=a(u),M=w.timeout??m;if(v.isEvaluating=true,v.error=null,w.deps?.length){let A=new Set(w.deps);C(u,A),k.set(u,A);}try{let A=w.when(g),ee=await ge(A,M,`Constraint "${u}" timed out after ${M}ms`);return v.lastResult=ee,ee&&(v.hitCount++,v.lastActiveAt=Date.now()),v.isEvaluating=!1,i?.(u,ee),ee}catch(A){return v.error=A instanceof Error?A:new Error(String(A)),v.lastResult=false,v.isEvaluating=false,c?.(u,A),false}}let y=10;function O(u,w){if(u==null)return [];if(Array.isArray(u)){let v=u.filter(M=>M!=null);return process.env.NODE_ENV!=="production"&&v.length>y&&w&&console.warn(`[Directive] Constraint "${w}" produced ${v.length} requirements. Consider splitting into multiple constraints for better performance.`),v}return [u]}function N(u){let w=t[u];if(!w)return {requirements:[],deps:new Set};let v=w.require;if(typeof v=="function"){let{value:A,deps:ee}=fe(()=>v(g));return {requirements:O(A,u),deps:ee}}return {requirements:O(v,u),deps:new Set}}function z(u,w){if(w.size===0)return;let v=q.get(u)??new Set;for(let M of w)v.add(M),b.has(M)||b.set(M,new Set),b.get(M).add(u);q.set(u,v);}let J=null;function P(){return J||(J=Object.keys(t).sort((u,w)=>{let v=a(u),A=a(w).priority-v.priority;if(A!==0)return A;let ee=T.get(u)??0,n=T.get(w)??0;return ee-n})),J}for(let u of Object.keys(t))s(u);if(process.env.NODE_ENV!=="production")for(let[u,w]of Object.entries(t))w.async&&!w.deps&&console.warn(`[Directive] Async constraint "${u}" has no \`deps\` declared. Auto-tracking cannot work across async boundaries. Add \`deps: ["key1", "key2"]\` to enable dependency tracking.`);function L(u){let w=D.get(u);if(!w||w.after.length===0)return true;for(let v of w.after)if(t[v]&&!p.has(v)&&!x.has(v)&&!j.has(v))return false;return true}return {async evaluate(u){let w=new le;x.clear();let v=P().filter(h=>!p.has(h)),M;if(!B||!u||u.size===0)M=v,B=true;else {let h=new Set;for(let H of u){let K=b.get(H);if(K)for(let W of K)p.has(W)||h.add(W);}for(let H of d)p.has(H)||h.add(H);d.clear(),M=[...h];for(let H of v)if(!h.has(H)){let K=E.get(H);if(K)for(let W of K)w.add(W);}}function A(h,H){if(p.has(h))return;let K=k.get(h);if(!H){K!==void 0&&C(h,K),x.add(h),E.set(h,[]);return}x.delete(h);let W,Z;try{let Q=N(h);W=Q.requirements,Z=Q.deps;}catch(Q){c?.(h,Q),K!==void 0&&C(h,K),E.set(h,[]);return}if(K!==void 0){let Q=new Set(K);for(let Y of Z)Q.add(Y);C(h,Q);}else z(h,Z);if(W.length>0){let Q=l[h],Y=W.map(te=>pe(te,h,Q));for(let te of Y)w.add(te);E.set(h,Y);}else E.set(h,[]);}async function ee(h){let H=[],K=[];for(let Y of h)if(L(Y))K.push(Y);else {H.push(Y);let te=E.get(Y);if(te)for(let X of te)w.add(X);}if(K.length===0)return H;let W=[],Z=[];for(let Y of K)a(Y).isAsync?Z.push(Y):W.push(Y);let Q=[];for(let Y of W){let te=I(Y);if(te instanceof Promise){Q.push({id:Y,promise:te});continue}A(Y,te);}if(Q.length>0){let Y=await Promise.all(Q.map(async({id:te,promise:X})=>({id:te,active:await X})));for(let{id:te,active:X}of Y)A(te,X);}if(Z.length>0){let Y=await Promise.all(Z.map(async te=>({id:te,active:await o(te)})));for(let{id:te,active:X}of Y)A(te,X);}return H}let n=M,f=M.length+1;for(;n.length>0&&f>0;){let h=n.length;if(n=await ee(n),n.length===h)break;f--;}return w.all()},getState(u){return D.get(u)},getDependencies(u){return q.get(u)},getAllStates(){return [...D.values()]},disable(u){if(!D.has(u)){console.warn(`[Directive] constraints.disable("${u}") \u2014 no such constraint`);return}p.add(u),J=null,E.delete(u);let w=q.get(u);if(w){for(let v of w){let M=b.get(v);M&&(M.delete(u),M.size===0&&b.delete(v));}q.delete(u);}k.delete(u);},enable(u){if(!D.has(u)){console.warn(`[Directive] constraints.enable("${u}") \u2014 no such constraint`);return}p.delete(u),J=null,d.add(u);},isDisabled(u){return p.has(u)},invalidate(u){let w=b.get(u);if(w)for(let v of w)d.add(v);},markResolved(u){j.add(u);let w=D.get(u);w&&(w.lastResolvedAt=Date.now());let v=R.get(u);if(v)for(let M of v)d.add(M);},isResolved(u){return j.has(u)},registerDefinitions(u){let w=false;for(let[v,M]of Object.entries(u))t[v]=M,s(v),d.add(v),M.after?.length&&(w=true);J=null,w&&$(),F();},assignDefinition(u,w){if(!t[u])throw new Error(`[Directive] Cannot assign constraint "${u}" \u2014 it does not exist. Use register() to create it.`);t[u]=w,s(u),d.add(u),J=null,$(),F();},unregisterDefinition(u){if(!t[u])return;delete t[u],D.delete(u),p.delete(u),S.delete(u),d.delete(u),x.delete(u),j.delete(u),E.delete(u),k.delete(u);let w=q.get(u);if(w){for(let v of w){let M=b.get(v);M&&(M.delete(u),M.size===0&&b.delete(v));}q.delete(u);}R.delete(u);for(let v of R.values())v.delete(u);J=null,$(),F();},async callOne(u,w){if(!t[u])throw new Error(`[Directive] Cannot call constraint "${u}" \u2014 it does not exist.`);if(p.has(u))return [];let M=a(u),A;if(M.isAsync)A=await o(u);else {let h=I(u);A=h instanceof Promise?await h:h;}if(!A)return [];let{requirements:ee}=N(u);if(ee.length===0)return [];let n=l[u],f=[];for(let h of ee){let H=w?{...h,...w}:h;f.push(pe(H,u,n));}return f}}}function Ce(r){let{definitions:t,facts:g,onCompute:m,onInvalidate:i,onError:c}=r,D=new Map,p=new Map,S=new Map,q=new Map,b=0,d=new Set,k=false,E=100,B;function j(e){if(!t[e])throw new Error(`[Directive] Unknown derivation: ${e}`);let a={id:e,compute:()=>R(e),cachedValue:void 0,dependencies:new Set,isStale:true,isComputing:false};return D.set(e,a),a}function x(e){return D.get(e)??j(e)}function R(e){let s=x(e),a=t[e];if(!a)throw new Error(`[Directive] Unknown derivation: ${e}`);if(s.isComputing)throw new Error(`[Directive] Circular dependency detected in derivation: ${e}`);s.isComputing=true;try{let C=s.cachedValue,{value:I,deps:o}=fe(()=>a(g,B));return s.cachedValue=I,s.isStale=!1,V(e,o),m?.(e,I,C,[...o]),I}catch(C){throw c?.(e,C),C}finally{s.isComputing=false;}}function V(e,s){let a=x(e),C=a.dependencies;if(C.size===s.size){let I=true;for(let o of s)if(!C.has(o)){I=false;break}if(I)return}for(let I of C)if(D.has(I)){let o=q.get(I);o?.delete(e),o&&o.size===0&&q.delete(I);}else {let o=S.get(I);o?.delete(e),o&&o.size===0&&S.delete(I);}for(let I of s)t[I]?(q.has(I)||q.set(I,new Set),q.get(I).add(e)):(S.has(I)||S.set(I,new Set),S.get(I).add(e));a.dependencies=s;}function T(){if(!(b>0||k)){k=true;try{let e=0;for(;d.size>0;){if(++e>E){let a=[...d];throw d.clear(),new Error(`[Directive] Infinite derivation notification loop detected after ${E} iterations. Remaining: ${a.join(", ")}. This usually means a derivation listener is mutating facts that re-trigger the same derivation.`)}let s=[...d];d.clear();for(let a of s)p.get(a)?.forEach(C=>C());}}finally{k=false;}}}function F(e,s=new Set){let a=[e];for(;a.length>0;){let C=a.pop();if(s.has(C))continue;s.add(C);let I=D.get(C);if(!I||I.isStale)continue;I.isStale=true,i?.(C),d.add(C);let o=q.get(C);if(o)for(let y of o)a.push(y);}}return B=new Proxy({},{get(e,s){if(typeof s=="symbol"||G.has(s)||!t[s])return;ye(s);let a=x(s);return a.isStale&&R(s),a.cachedValue},set(){return false},deleteProperty(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),{get(e){let s=x(e);return s.isStale&&R(e),s.cachedValue},isStale(e){return D.get(e)?.isStale??true},invalidate(e){let s=S.get(e);if(!s)return;b++;let a=new Set;try{for(let C of s)F(C,a);}finally{b--,T();}},invalidateMany(e){b++;let s=new Set;try{for(let a of e){let C=S.get(a);if(C)for(let I of C)F(I,s);}}finally{b--,T();}},invalidateAll(){b++;try{for(let e of D.values())e.isStale||(e.isStale=!0,d.add(e.id));}finally{b--,T();}},subscribe(e,s){for(let a of e){let C=a;p.has(C)||p.set(C,new Set),p.get(C).add(s);}return ()=>{for(let a of e){let C=a,I=p.get(C);I?.delete(s),I&&I.size===0&&p.delete(C);}}},getProxy(){return B},getDependencies(e){return x(e).dependencies},registerDefinitions(e){for(let[s,a]of Object.entries(e))t[s]=a,j(s);},assignDefinition(e,s){if(!t[e])throw new Error(`[Directive] Cannot assign derivation "${e}" \u2014 it does not exist. Use register() to create it.`);t[e]=s;let a=D.get(e);a&&(a.isStale=true,d.add(e)),T();},unregisterDefinition(e){if(!t[e])return;let s=D.get(e);if(s)for(let C of s.dependencies)if(D.has(C)){let I=q.get(C);I?.delete(e),I&&I.size===0&&q.delete(C);}else {let I=S.get(C);I?.delete(e),I&&I.size===0&&S.delete(C);}let a=q.get(e);if(a){b++;try{for(let C of a)F(C);}finally{b--;}q.delete(e);}delete t[e],D.delete(e),p.delete(e),d.delete(e),T();},callOne(e){if(!t[e])throw new Error(`[Directive] Cannot call derivation "${e}" \u2014 it does not exist.`);return R(e)}}}var ot=3;function Me(r){let{definitions:t,facts:g,store:l,onRun:m,onError:i}=r,c=new Map,D=null,p=false;function S(x){let R=t[x];if(!R)throw new Error(`[Directive] Unknown effect: ${x}`);let V={id:x,enabled:true,hasExplicitDeps:!!R.deps,dependencies:R.deps?new Set(R.deps):null,cleanup:null,stableRunCount:0,depsStable:false};return c.set(x,V),V}function q(x){return c.get(x)??S(x)}function b(){return l.toObject()}function d(x,R){let V=q(x);if(!V.enabled)return false;if(V.dependencies){for(let T of V.dependencies)if(R.has(T))return V.depsStable&&(V.depsStable=false,V.stableRunCount=0),true;return false}return true}function k(x){if(x.cleanup){try{x.cleanup();}catch(R){i?.(x.id,R),console.error(`[Directive] Effect "${x.id}" cleanup threw an error:`,R);}x.cleanup=null;}}function E(x,R){if(typeof R=="function")if(p)try{R();}catch(V){i?.(x.id,V),console.error(`[Directive] Effect "${x.id}" cleanup threw an error:`,V);}else x.cleanup=R;}async function B(x){let R=q(x),V=t[x];if(!(!R.enabled||!V)){k(R),m?.(x,R.dependencies?[...R.dependencies]:[]);try{if(R.hasExplicitDeps){let T;if(l.batch(()=>{T=V.run(g,D);}),T instanceof Promise){let F=await T;E(R,F);}else E(R,T);}else if(R.depsStable&&R.dependencies){let T;if(l.batch(()=>{T=V.run(g,D);}),T instanceof Promise){let F=await T;E(R,F);}else E(R,T);}else {let T,F=fe(()=>(l.batch(()=>{T=V.run(g,D);}),T)),$=F.deps,e=F.value;if(e instanceof Promise&&(e=await e),E(R,e),R.dependencies&&$.size===R.dependencies.size){let s=!0;for(let a of $)if(!R.dependencies.has(a)){s=!1;break}s?(R.stableRunCount++,R.stableRunCount>=ot&&(R.depsStable=!0)):(R.stableRunCount=0,R.depsStable=!1);}else R.stableRunCount=0,R.depsStable=!1;R.dependencies=$.size>0?$:null;}}catch(T){i?.(x,T),console.error(`[Directive] Effect "${x}" threw an error:`,T),R.hasExplicitDeps||(R.stableRunCount=0,R.depsStable=false);}}}for(let x of Object.keys(t))S(x);return {async runEffects(x){let R=[];for(let V of Object.keys(t))d(V,x)&&R.push(V);await Promise.all(R.map(B)),D=b();},async runAll(){let x=Object.keys(t);await Promise.all(x.map(R=>{let V=q(R);return V.enabled?(V.depsStable=false,V.stableRunCount=0,B(R)):Promise.resolve()})),D=b();},disable(x){let R=q(x);R.enabled=false;},enable(x){let R=q(x);R.enabled=true;},isEnabled(x){return q(x).enabled},cleanupAll(){p=true;for(let x of c.values())k(x);},registerDefinitions(x){for(let[R,V]of Object.entries(x))t[R]=V,S(R);},assignDefinition(x,R){if(!t[x])throw new Error(`[Directive] Cannot assign effect "${x}" \u2014 it does not exist. Use register() to create it.`);let V=c.get(x);V&&k(V),t[x]=R,S(x);},unregisterDefinition(x){if(!t[x])return;let R=c.get(x);R&&k(R),delete t[x],c.delete(x);},async callOne(x){let R=t[x];if(!R)throw new Error(`[Directive] Cannot call effect "${x}" \u2014 it does not exist.`);let V=q(x);if(V.enabled){k(V),m?.(x,V.dependencies?[...V.dependencies]:[]);try{let T;if(l.batch(()=>{T=R.run(g,D);}),T instanceof Promise){let F=await T;E(V,F);}else E(V,T);}catch(T){i?.(x,T),console.error(`[Directive] Effect "${x}" threw an error:`,T);}}}}}function $e(r){let{mergedDerive:t,getDerivation:g,definitions:l}=r,m={register:(i,c)=>l.register("derivation",i,c),assign:(i,c)=>l.assign("derivation",i,c),unregister:i=>l.unregister("derivation",i),call:i=>l.call("derivation",i),isDynamic:i=>l.isDynamic("derivation",i),listDynamic:()=>l.listDynamic("derivation")};return new Proxy({},{get(i,c){if(typeof c!="symbol"&&!G.has(c)){if(c in m)return m[c];if(c in t)return g(c)}},has(i,c){return typeof c=="symbol"||G.has(c)?false:c in t||c in m},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(i,c){if(typeof c!="symbol"&&!G.has(c)&&(c in t||c in m))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function Oe(r){let{mergedEvents:t,dispatchEvent:g}=r;return new Proxy({},{get(l,m){if(typeof m!="symbol"&&!G.has(m))return i=>{g(m,i);}},has(l,m){return typeof m=="symbol"||G.has(m)?false:m in t},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(l,m){if(typeof m!="symbol"&&!G.has(m)&&m in t)return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}var Te=new Set(["register","assign","unregister","call","isDynamic","listDynamic"]);function Pe(r){let{mergedConstraints:t,mergedResolvers:g,mergedDerive:l,mergedEffects:m,constraintsManager:i,resolversManager:c,derivationsManager:D,effectsManager:p,pluginManager:S,getState:q,scheduleReconcile:b,maxDeferredRegistrations:d}=r,k={constraints:new Set,resolvers:new Set,derivations:new Set,effects:new Set},E={constraints:new Map,resolvers:new Map,derivations:new Map,effects:new Map},B=[];function j($){if(typeof $!="string"||$.length===0)throw new Error(`[Directive] Definition ID must be a non-empty string. Received: ${String($)}`);if(G.has($))throw new Error(`[Directive] Security: Definition ID "${$}" is a blocked property.`);if($.includes("::"))throw new Error(`[Directive] Definition ID "${$}" cannot contain "::". This separator is reserved for namespacing.`)}function x($,e,s){switch($){case "constraint":{if(e in t)throw new Error(`[Directive] Constraint "${e}" already exists. Use assign() to override.`);let a=s;t[e]=a,i.registerDefinitions({[e]:a}),k.constraints.add(e),S.emitDefinitionRegister($,e,s),b();break}case "resolver":{if(e in g)throw new Error(`[Directive] Resolver "${e}" already exists. Use assign() to override.`);let a=s;g[e]=a,c.registerDefinitions({[e]:a}),k.resolvers.add(e),S.emitDefinitionRegister($,e,s),b();break}case "derivation":{if(Te.has(e))throw new Error(`[Directive] Derivation ID "${e}" conflicts with a reserved derive method name.`);if(e in l)throw new Error(`[Directive] Derivation "${e}" already exists. Use assign() to override.`);l[e]=s,D.registerDefinitions({[e]:s}),k.derivations.add(e),S.emitDefinitionRegister($,e,s);break}case "effect":{if(e in m)throw new Error(`[Directive] Effect "${e}" already exists. Use assign() to override.`);let a=s;m[e]=a,p.registerDefinitions({[e]:a}),k.effects.add(e),S.emitDefinitionRegister($,e,s);break}}}function R($,e,s){switch($){case "constraint":{if(!(e in t))throw new Error(`[Directive] Constraint "${e}" does not exist. Use register() to create it.`);let a=t[e];i.assignDefinition(e,s),E.constraints.set(e,a),t[e]=s,S.emitDefinitionAssign($,e,s,a),b();break}case "resolver":{if(!(e in g))throw new Error(`[Directive] Resolver "${e}" does not exist. Use register() to create it.`);let a=g[e];c.assignDefinition(e,s),E.resolvers.set(e,a),g[e]=s,S.emitDefinitionAssign($,e,s,a),b();break}case "derivation":{if(Te.has(e))throw new Error(`[Directive] Derivation ID "${e}" conflicts with a reserved derive method name.`);if(!(e in l))throw new Error(`[Directive] Derivation "${e}" does not exist. Use register() to create it.`);let a=l[e];D.assignDefinition(e,s),E.derivations.set(e,a),l[e]=s,S.emitDefinitionAssign($,e,s,a);break}case "effect":{if(!(e in m))throw new Error(`[Directive] Effect "${e}" does not exist. Use register() to create it.`);let a=m[e];p.assignDefinition(e,s),E.effects.set(e,a),m[e]=s,S.emitDefinitionAssign($,e,s,a);break}}}function V($,e){switch($){case "constraint":{if(!k.constraints.has(e)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static constraint "${e}". Only dynamically registered constraints can be removed.`);return}i.unregisterDefinition(e),delete t[e],k.constraints.delete(e),E.constraints.delete(e),S.emitDefinitionUnregister($,e),b();break}case "resolver":{if(!k.resolvers.has(e)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static resolver "${e}". Only dynamically registered resolvers can be removed.`);return}c.unregisterDefinition(e),delete g[e],k.resolvers.delete(e),E.resolvers.delete(e),S.emitDefinitionUnregister($,e);break}case "derivation":{if(!k.derivations.has(e)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static derivation "${e}". Only dynamically registered derivations can be removed.`);return}D.unregisterDefinition(e),delete l[e],k.derivations.delete(e),E.derivations.delete(e),S.emitDefinitionUnregister($,e);break}case "effect":{if(!k.effects.has(e)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Cannot unregister static effect "${e}". Only dynamically registered effects can be removed.`);return}p.unregisterDefinition(e),delete m[e],k.effects.delete(e),E.effects.delete(e),S.emitDefinitionUnregister($,e);break}}}function T(){if(B.length===0)return;let $=B.splice(0);for(let e of $)try{switch(e.op){case "register":x(e.type,e.id,e.def);break;case "assign":R(e.type,e.id,e.def);break;case "unregister":V(e.type,e.id);break}}catch(s){process.env.NODE_ENV!=="production"&&console.error(`[Directive] Error in deferred ${e.op} for ${e.type} "${e.id}":`,s);}}function F($,e,s,a){let{isDestroyed:C,isReconciling:I}=q();if(C)throw new Error(`[Directive] Cannot ${$} ${e} "${s}" on a destroyed system.`);if(j(s),I){if(B.length>=d)throw new Error(`[Directive] Too many deferred registrations (max ${d}). Avoid calling register/assign/unregister in resolver or effect callbacks during reconciliation.`);$==="unregister"?B.push({op:$,type:e,id:s}):B.push({op:$,type:e,id:s,def:a});return}switch($){case "register":x(e,s,a);break;case "assign":R(e,s,a);break;case "unregister":V(e,s);break}}return {register($,e,s){F("register",$,e,s);},assign($,e,s){F("assign",$,e,s);},unregister($,e){F("unregister",$,e);},call($,e,s){let{isDestroyed:a}=q();if(a)throw new Error(`[Directive] Cannot call ${$} "${e}" on a destroyed system.`);switch(j(e),S.emitDefinitionCall($,e,s),$){case "constraint":return i.callOne(e,s);case "resolver":return c.callOne(e,s);case "derivation":return D.callOne(e);case "effect":return p.callOne(e)}},isDynamic($,e){switch($){case "constraint":return k.constraints.has(e);case "resolver":return k.resolvers.has(e);case "derivation":return k.derivations.has(e);case "effect":return k.effects.has(e)}},listDynamic($){switch($){case "constraint":return [...k.constraints];case "resolver":return [...k.resolvers];case "derivation":return [...k.derivations];case "effect":return [...k.effects]}},flushDeferred:T,getOriginal($,e){let a={constraint:E.constraints,resolver:E.resolvers,derivation:E.derivations,effect:E.effects}[$];if(a)return a.get(e)},restoreOriginal($,e){let a={constraint:E.constraints,resolver:E.resolvers,derivation:E.derivations,effect:E.effects}[$];if(!a||!a.has(e))return false;let C=a.get(e);return F("assign",$,e,C),a.delete(e),true},destroy(){B.length=0,k.constraints.clear(),k.resolvers.clear(),k.derivations.clear(),k.effects.clear(),E.constraints.clear(),E.resolvers.clear(),E.derivations.clear(),E.effects.clear();}}}function qe(r){let{traceConfig:t,pluginManager:g}=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 m=(typeof t=="object"&&t!==null?t.maxRuns:void 0)??100,i=[],c=new Map,D=0,p=null,S=[],q=new Map,b=new Map,d=new Map,k=null,E=0,B=0,j={count:0,totalDuration:0,avgDuration:0,maxDuration:0,avgResolverCount:0,totalResolverCount:0,avgFactChangeCount:0,totalFactChangeCount:0};function x(e){let s=c.get(e);if(s&&s.status==="pending"){s.status="settled";let a=d.get(e);s.duration=a!==void 0?performance.now()-a:Date.now()-s.timestamp,d.delete(e),b.delete(e),s.causalChain=T(s),F(s),B++,g.emitTraceComplete(s);}}function R(e){let s=q.get(e);if(q.delete(e),s!==void 0){let a=(b.get(s)??1)-1;a<=0?x(s):b.set(s,a);}}function V(){let e=i.shift();if(e&&(c.delete(e.id),d.delete(e.id),e.status==="pending")){b.delete(e.id);for(let[s,a]of q)a===e.id&&q.delete(s);}}function T(e){let s=[];for(let a of e.factChanges)s.push(`${a.key} changed`);for(let a of e.derivationsRecomputed)s.push(`${a.id} recomputed`);for(let a of e.constraintsHit)s.push(`${a.id} constraint hit`);for(let a of e.requirementsAdded)s.push(`${a.type} requirement added`);for(let a of e.resolversCompleted)s.push(`${a.resolver} resolved (${a.duration.toFixed(0)}ms)`);for(let a of e.resolversErrored)s.push(`${a.resolver} errored`);for(let a of e.effectsRun)s.push(`${a.id} effect ran`);return s.join(" \u2192 ")}function F(e){j.count++,j.totalDuration+=e.duration,j.avgDuration=j.totalDuration/j.count,e.duration>j.maxDuration&&(j.maxDuration=e.duration);let s=e.resolversStarted.length;j.totalResolverCount+=s,j.avgResolverCount=j.totalResolverCount/j.count;let a=e.factChanges.length;j.totalFactChangeCount+=a,j.avgFactChangeCount=j.totalFactChangeCount/j.count;let C=[];j.count>3&&e.duration>j.avgDuration*5&&C.push(`Duration ${e.duration.toFixed(0)}ms is 5x+ above average (${j.avgDuration.toFixed(0)}ms)`),e.resolversErrored.length>0&&C.push(`${e.resolversErrored.length} resolver(s) errored`),C.length>0&&(e.anomalies=C);}return {enabled:true,get currentTrace(){return p},set currentTrace(e){p=e;},recordFactChange(e,s,a){S.push({key:e,oldValue:s,newValue:a});},startRun(){let e=performance.now(),s=++D;return d.set(s,e),p={id:s,timestamp:Date.now(),duration:0,status:"pending",factChanges:S.splice(0),derivationsRecomputed:[],constraintsHit:[],requirementsAdded:[],requirementsRemoved:[],resolversStarted:[],resolversCompleted:[],resolversErrored:[],effectsRun:[],effectErrors:[]},e},getEntries(){return (!k||E!==B)&&(k=[...i],E=B),k},attributeResolverStart(e){p&&q.set(e,p.id);},recordResolverComplete(e,s,a){let C=q.get(e);if(C!==void 0){let I=c.get(C);I&&I.resolversCompleted.push({resolver:s,requirementId:e,duration:a});}},recordResolverError(e,s,a){let C=q.get(e);if(C!==void 0){let I=c.get(C);I&&I.resolversErrored.push({resolver:s,requirementId:e,error:a});}},decrementInflight(e){R(e);},finalizeCurrentRun(e){if(!p)return;if(p.duration=performance.now()-e,p.factChanges.length>0||p.constraintsHit.length>0||p.requirementsAdded.length>0||p.effectsRun.length>0){let a=p.resolversStarted.length;a===0?(p.status="settled",p.causalChain=T(p),F(p),i.push(p),c.set(p.id,p),i.length>m&&V(),B++,g.emitTraceComplete(p)):(p.status="pending",i.push(p),c.set(p.id,p),i.length>m&&V(),B++,b.set(p.id,a));}else d.delete(p.id);p=null;},drainPendingChanges(){S.length=0;},destroy(){i.length=0,c.clear(),q.clear(),b.clear(),d.clear(),S.length=0,p=null,k=null;}}}var me=class extends Error{constructor(g,l,m,i,c=true){super(g);this.source=l;this.sourceId=m;this.context=i;this.recoverable=c;this.name="DirectiveError";}};function at(r={}){let{delayMs:t=1e3,maxRetries:g=3,backoffMultiplier:l=2,maxDelayMs:m=3e4}=r,i=new Map;function c(D){let p=t*l**(D-1);return Math.min(p,m)}return {scheduleRetry(D,p,S,q,b){if(q>g)return null;let d=c(q),k={source:D,sourceId:p,context:S,attempt:q,nextRetryTime:Date.now()+d,callback:b};return i.set(p,k),k},getPendingRetries(){return Array.from(i.values())},processDueRetries(){let D=Date.now(),p=[];for(let[S,q]of i)q.nextRetryTime<=D&&(p.push(q),i.delete(S));return p},cancelRetry(D){i.delete(D);},clearAll(){i.clear();}}}var ct={constraint:"skip",resolver:"skip",effect:"skip",derivation:"skip",system:"throw"};function Ie(r={}){let{config:t={},onError:g,onRecovery:l}=r,m=[],i=100,c=at(t.retryLater),D=new Map,p=1e3;function S(d,k,E,B){if(E instanceof me)return E;let j=E instanceof Error?E.message:String(E),x=d!=="system";return new me(j,d,k,B,x)}function q(d,k,E){let B=(()=>{switch(d){case "constraint":return t.onConstraintError;case "resolver":return t.onResolverError;case "effect":return t.onEffectError;case "derivation":return t.onDerivationError;default:return}})();if(typeof B=="function"){try{let j=B(E,k);if(typeof j=="string")return j}catch(j){console.error("[Directive] Error in error handler callback:",j);}return "skip"}return typeof B=="string"?B:ct[d]}return {handleError(d,k,E,B){let j=S(d,k,E,B);m.push(j),m.length>i&&m.shift();try{g?.(j);}catch(R){console.error("[Directive] Error in onError callback:",R);}try{t.onError?.(j);}catch(R){console.error("[Directive] Error in config.onError callback:",R);}let x=q(d,k,E instanceof Error?E:new Error(String(E)));if(x==="retry-later"){let R=(D.get(k)??0)+1;if(D.set(k,R),D.size>p){let T=D.keys().next().value;T!==void 0&&D.delete(T);}c.scheduleRetry(d,k,B,R)||(x="skip",D.delete(k),typeof process<"u"&&process.env?.NODE_ENV!=="production"&&console.warn(`[Directive] ${d} "${k}" exceeded max retry-later attempts. Skipping.`));}try{l?.(j,x);}catch(R){console.error("[Directive] Error in onRecovery callback:",R);}if(x==="throw")throw j;return x},getLastError(){return m[m.length-1]??null},getAllErrors(){return [...m]},clearErrors(){m.length=0;},getRetryLaterManager(){return c},processDueRetries(){return c.processDueRetries()},clearRetryAttempts(d){D.delete(d),c.cancelRetry(d);}}}function ut(r,t=100){try{return JSON.stringify(r)?.slice(0,t)??String(r)}catch{return "[circular or non-serializable]"}}function lt(r){let{schema:t,onChange:g,onBatch:l}=r,i=Object.keys(t).length===0,c=r.validate??process.env.NODE_ENV!=="production",D=r.strictKeys??(process.env.NODE_ENV!=="production"&&!i),p=r.redactErrors??false,S=new Map,q=new Set,b=new Map,d=new Set,k=0,E=[],B=new Set,j=false,x=[],R=100;function V(o){return o!==null&&typeof o=="object"&&"safeParse"in o&&typeof o.safeParse=="function"&&"_def"in o&&"parse"in o&&typeof o.parse=="function"}function T(o){let y=o;if(y._typeName)return y._typeName;if(V(o)){let O=o._def;if(O?.typeName)return O.typeName.replace(/^Zod/,"").toLowerCase()}return "unknown"}function F(o){return p?"[redacted]":ut(o)}function $(o,y){if(!c)return;let O=t[o];if(!O){if(D)throw new Error(`[Directive] Unknown fact key: "${o}". Key not defined in schema.`);console.warn(`[Directive] Unknown fact key: "${o}"`);return}if(V(O)){let P=O.safeParse(y);if(!P.success){let L=y===null?"null":Array.isArray(y)?"array":typeof y,_=F(y),u=P.error?.message??P.error?.issues?.[0]?.message??"Validation failed",w=T(O);throw new Error(`[Directive] Validation failed for "${o}": expected ${w}, got ${L} ${_}. ${u}`)}return}let N=O,z=N._validators;if(!z||!Array.isArray(z)||z.length===0)return;let J=N._typeName??"unknown";for(let P=0;P<z.length;P++){let L=z[P];if(typeof L=="function"&&!L(y)){let _=y===null?"null":Array.isArray(y)?"array":typeof y,u=F(y),w="";typeof N._lastFailedIndex=="number"&&N._lastFailedIndex>=0&&(w=` (element at index ${N._lastFailedIndex} failed)`,N._lastFailedIndex=-1);let v=P===0?"":` (validator ${P+1} failed)`;throw new Error(`[Directive] Validation failed for "${o}": expected ${J}, got ${_} ${u}${v}${w}`)}}}function e(o){b.get(o)?.forEach(y=>y());}function s(){d.forEach(o=>o());}function a(o,y,O){if(j){x.push({key:o,value:y,prev:O});return}j=true;try{g?.(o,y,O),e(o),s();let N=0;for(;x.length>0;){if(++N>R)throw x.length=0,new Error(`[Directive] Infinite notification loop detected after ${R} iterations. A listener is repeatedly mutating facts that re-trigger notifications.`);let z=[...x];x.length=0;for(let J of z)g?.(J.key,J.value,J.prev),e(J.key);s();}}finally{j=false;}}function C(){if(!(k>0)){if(l&&E.length>0&&l([...E]),B.size>0){j=true;try{for(let y of B)e(y);s();let o=0;for(;x.length>0;){if(++o>R)throw x.length=0,new Error(`[Directive] Infinite notification loop detected during flush after ${R} iterations.`);let y=[...x];x.length=0;for(let O of y)g?.(O.key,O.value,O.prev),e(O.key);s();}}finally{j=false;}}E.length=0,B.clear();}}let I={get(o){return ye(o),S.get(o)},has(o){return ye(o),S.has(o)},set(o,y){$(o,y);let O=S.get(o);Object.is(O,y)||(S.set(o,y),q.add(o),k>0?(E.push({key:o,value:y,prev:O,type:"set"}),B.add(o)):a(o,y,O));},delete(o){let y=S.get(o);S.delete(o),q.delete(o),k>0?(E.push({key:o,value:void 0,prev:y,type:"delete"}),B.add(o)):a(o,void 0,y);},batch(o){k++;try{o();}finally{k--,C();}},subscribe(o,y){for(let O of o){let N=O;b.has(N)||b.set(N,new Set),b.get(N).add(y);}return ()=>{for(let O of o){let N=b.get(O);N&&(N.delete(y),N.size===0&&b.delete(O));}}},subscribeAll(o){return d.add(o),()=>d.delete(o)},toObject(){let o={};for(let y of q)S.has(y)&&(o[y]=S.get(y));return o}};return I.destroy=()=>{b.clear(),d.clear();},I.registerKeys=o=>{for(let y of Object.keys(o))G.has(y)||(t[y]=o[y],q.add(y));},I}function Ae(r,t,g=t){return new Proxy(r,{get(l,m){let i=Reflect.get(l,m);return typeof m=="symbol"||typeof i!="object"||i===null?i:Ae(i,t,`${g}.${String(m)}`)},set(l,m,i){return typeof m!="symbol"&&console.warn(`[Directive] Nested mutation on "facts.${g}.${String(m)}" will not trigger reactivity. Use: facts.${t} = { ...facts.${t}, ... }`),Reflect.set(l,m,i)}})}function dt(r,t){let g=()=>({get:m=>he(()=>r.get(m)),has:m=>he(()=>r.has(m))});return new Proxy({},{get(m,i){if(i==="$store")return r;if(i==="$snapshot")return g;if(typeof i=="symbol"||G.has(i))return;let c=r.get(i);return process.env.NODE_ENV!=="production"&&c!==null&&typeof c=="object"?Ae(c,i):c},set(m,i,c){return typeof i=="symbol"||i==="$store"||i==="$snapshot"||G.has(i)?false:(r.set(i,c),true)},deleteProperty(m,i){return typeof i=="symbol"||i==="$store"||i==="$snapshot"||G.has(i)?false:(r.delete(i),true)},has(m,i){return i==="$store"||i==="$snapshot"?true:typeof i=="symbol"||G.has(i)?false:r.has(i)},ownKeys(){return Object.keys(t)},getOwnPropertyDescriptor(m,i){return i==="$store"||i==="$snapshot"?{configurable:true,enumerable:false,writable:false}:{configurable:true,enumerable:true,writable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function je(r){let t=lt(r),g=dt(t,r.schema);return {store:t,facts:g}}function Fe(){let r=[];function t(i){if(i)try{return i()}catch(c){console.error("[Directive] Plugin error:",c);return}}async function g(i){if(i)try{return await i()}catch(c){console.error("[Directive] Plugin error:",c);return}}function l(i){return (...c)=>{for(let D of r)t(()=>D[i]?.(...c));}}return {register(i){r.some(c=>c.name===i.name)&&(console.warn(`[Directive] Plugin "${i.name}" is already registered, replacing...`),this.unregister(i.name)),r.push(i);},unregister(i){let c=r.findIndex(D=>D.name===i);c!==-1&&r.splice(c,1);},getPlugins(){return [...r]},async emitInit(i){for(let c of r)await g(()=>c.onInit?.(i));},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"),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 Ne={attempts:1,backoff:"none",initialDelay:100,maxDelay:3e4},_e={enabled:false,windowMs:50};function ft(r,t){let{backoff:g,initialDelay:l=100,maxDelay:m=3e4}=r,i;switch(g){case "none":i=l;break;case "linear":i=l*t;break;case "exponential":i=l*2**(t-1);break;default:i=l;}return Math.max(1,Math.min(i,m))}function Ve(r){let{definitions:t,facts:g,store:l,onStart:m,onComplete:i,onError:c,onRetry:D,onCancel:p,onResolutionComplete:S}=r;if(process.env.NODE_ENV!=="production")for(let[o,y]of Object.entries(t)){if(!y.resolve&&!y.resolveBatch&&!y.resolveBatchWithResults)throw new Error(`[Directive] Resolver "${o}" must define either resolve() or resolveBatch(). Add one of these methods to handle requirements.`);if(y.batch?.enabled&&!y.resolveBatch&&!y.resolveBatchWithResults)if(y.resolve)console.warn(`[Directive] Resolver "${o}" has batch.enabled but no resolveBatch(). Falling back to individual resolve() calls. Add resolveBatch() for true bulk operations.`);else throw new Error(`[Directive] Resolver "${o}" has batch.enabled=true but no resolve(), resolveBatch(), or resolveBatchWithResults() method.`)}let q=new Map,b=new Map,d=1e3,k=new Map,E=new Map,B=1e3;function j(){if(b.size>d){let o=b.size-d,y=b.keys();for(let O=0;O<o;O++){let N=y.next().value;N&&b.delete(N);}}}function x(o){return typeof o=="object"&&o!==null&&"requirement"in o&&typeof o.requirement=="string"}function R(o){return typeof o=="object"&&o!==null&&"requirement"in o&&typeof o.requirement=="function"}function V(o,y){return x(o)?y.type===o.requirement:R(o)?o.requirement(y):false}function T(o){let y=o.type,O=E.get(y);if(O){E.delete(y),E.set(y,O);for(let N of O){let z=t[N];if(z&&V(z,o))return N}}for(let[N,z]of Object.entries(t))if(V(z,o)){if(!E.has(y)){if(E.size>=B){let J=E.keys().next().value;J!==void 0&&E.delete(J);}E.set(y,new Set);}return E.get(y).add(N),N}return null}function F(o){return {facts:g,signal:o,snapshot:()=>g.$snapshot()}}async function $(o,y,O,N){let z=o instanceof Error?o:new Error(String(o));if(N.signal.aborted)return {action:"abort",error:z};if(O.shouldRetry&&!O.shouldRetry(z,y))return {action:"break",error:z};if(y<O.attempts){if(N.signal.aborted)return {action:"abort",error:z};let J=ft(O,y);if(await new Promise(P=>{let L=setTimeout(P,J),_=()=>{clearTimeout(L),P();};N.signal.addEventListener("abort",_,{once:true});}),N.signal.aborted)return {action:"abort",error:z}}return {action:"continue",error:z}}async function e(o,y,O){let N=t[o];if(!N)return;let z={...Ne,...N.retry},J=null;for(let P=1;P<=z.attempts;P++){if(O.signal.aborted)return;let L=q.get(y.id);L&&(L.attempt=P,L.status={state:"running",requirementId:y.id,startedAt:L.startedAt,attempt:P});try{let _=F(O.signal);if(N.resolve){let w;l.batch(()=>{w=N.resolve(y.requirement,_);});let v=N.timeout;v&&v>0?await ge(w,v,`Resolver "${o}" timed out after ${v}ms`):await w;}let u=Date.now()-(L?.startedAt??Date.now());b.set(y.id,{state:"success",requirementId:y.id,completedAt:Date.now(),duration:u}),j(),i?.(o,y,u);return}catch(_){let u=await $(_,P,z,O);if(J=u.error,u.action==="abort")return;if(u.action==="break")break;P<z.attempts&&D?.(o,y,P+1);}}b.set(y.id,{state:"error",requirementId:y.id,error:J,failedAt:Date.now(),attempts:z.attempts}),j(),c?.(o,y,J);}async function s(o,y){let O=t[o];if(!O)return;if(!O.resolveBatch&&!O.resolveBatchWithResults){await Promise.all(y.map(u=>{let w=new AbortController;return e(o,u,w)}));return}let N={...Ne,...O.retry},z={..._e,...O.batch},J=new AbortController,P=Date.now(),L=null,_=z.timeoutMs??O.timeout;for(let u=1;u<=N.attempts;u++){if(J.signal.aborted)return;try{let w=F(J.signal),v=y.map(M=>M.requirement);if(O.resolveBatchWithResults){let M,A;if(l.batch(()=>{A=O.resolveBatchWithResults(v,w);}),_&&_>0?M=await ge(A,_,`Batch resolver "${o}" timed out after ${_}ms`):M=await A,M.length!==y.length)throw new Error(`[Directive] Batch resolver "${o}" returned ${M.length} results but expected ${y.length}. Results array must match input order.`);let ee=Date.now()-P,n=!1;for(let f=0;f<y.length;f++){let h=y[f],H=M[f];if(H.success)b.set(h.id,{state:"success",requirementId:h.id,completedAt:Date.now(),duration:ee}),i?.(o,h,ee);else {n=!0;let K=H.error??new Error("Batch item failed");b.set(h.id,{state:"error",requirementId:h.id,error:K,failedAt:Date.now(),attempts:u}),c?.(o,h,K);}}if(!n||y.some((f,h)=>M[h]?.success))return}else {let M;l.batch(()=>{M=O.resolveBatch(v,w);}),_&&_>0?await ge(M,_,`Batch resolver "${o}" timed out after ${_}ms`):await M;let A=Date.now()-P;for(let ee of y)b.set(ee.id,{state:"success",requirementId:ee.id,completedAt:Date.now(),duration:A}),i?.(o,ee,A);return}}catch(w){let v=await $(w,u,N,J);if(L=v.error,v.action==="abort")return;if(v.action==="break")break;if(u<N.attempts)for(let M of y)D?.(o,M,u+1);}}for(let u of y)b.set(u.id,{state:"error",requirementId:u.id,error:L,failedAt:Date.now(),attempts:N.attempts}),c?.(o,u,L);j();}function a(o,y){let O=t[o];if(!O)return;let N={..._e,...O.batch};k.has(o)||k.set(o,{resolverId:o,requirements:[],timer:null});let z=k.get(o);if(z.requirements.push(y),N.maxSize&&z.requirements.length>=N.maxSize){z.timer&&(clearTimeout(z.timer),z.timer=null),C(o);return}z.timer&&clearTimeout(z.timer),z.timer=setTimeout(()=>{C(o);},N.windowMs);}function C(o){let y=k.get(o);if(!y||y.requirements.length===0)return;let O=[...y.requirements];y.requirements=[],y.timer=null,s(o,O).then(()=>{S?.();});}return {resolve(o){if(q.has(o.id))return;let y=T(o.requirement);if(!y){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] No resolver found for requirement type "${o.requirement.type}" (id: ${o.id})`);return}let O=t[y];if(!O)return;if(O.batch?.enabled){a(y,o);return}let N=new AbortController,z=Date.now(),J={requirementId:o.id,resolverId:y,controller:N,startedAt:z,attempt:1,status:{state:"pending",requirementId:o.id,startedAt:z},originalRequirement:o};q.set(o.id,J),m?.(y,o),e(y,o,N).finally(()=>{q.delete(o.id)&&S?.();});},cancel(o){let y=q.get(o);if(y){y.controller.abort(),q.delete(o),b.set(o,{state:"canceled",requirementId:o,canceledAt:Date.now()}),j(),p?.(y.resolverId,y.originalRequirement);return}for(let O of k.values()){let N=O.requirements.findIndex(z=>z.id===o);if(N!==-1){let[z]=O.requirements.splice(N,1);b.set(o,{state:"canceled",requirementId:o,canceledAt:Date.now()}),j(),z&&p?.(O.resolverId,z);return}}},cancelAll(){let o=[...q.keys()];for(let y of o)this.cancel(y);for(let y of k.values()){y.timer&&clearTimeout(y.timer);for(let O of y.requirements)b.set(O.id,{state:"canceled",requirementId:O.id,canceledAt:Date.now()}),p?.(y.resolverId,O);}k.clear(),j();},getStatus(o){let y=q.get(o);if(y)return y.status;let O=b.get(o);return O||{state:"idle"}},getInflight(){return [...q.keys()]},getInflightInfo(){return [...q.values()].map(o=>({id:o.requirementId,resolverId:o.resolverId,startedAt:o.startedAt}))},isResolving(o){return q.has(o)},processBatches(){for(let o of k.keys())C(o);},hasPendingBatches(){for(let o of k.values())if(o.requirements.length>0)return true;return false},registerDefinitions(o){for(let[y,O]of Object.entries(o))t[y]=O;E.clear();},assignDefinition(o,y){if(!t[o])throw new Error(`[Directive] Cannot assign resolver "${o}" \u2014 it does not exist. Use register() to create it.`);t[o]=y,E.clear();},unregisterDefinition(o){if(!t[o])return;for(let[O,N]of q)N.resolverId===o&&(N.controller.abort(),q.delete(O),b.set(O,{state:"canceled",requirementId:O,canceledAt:Date.now()}),p?.(o,N.originalRequirement));let y=k.get(o);if(y){y.timer&&clearTimeout(y.timer);for(let O of y.requirements)b.set(O.id,{state:"canceled",requirementId:O.id,canceledAt:Date.now()}),p?.(o,O);k.delete(o);}delete t[o],E.clear(),j();},async callOne(o,y){let O=t[o];if(!O)throw new Error(`[Directive] Cannot call resolver "${o}" \u2014 it does not exist.`);let N=new AbortController,z=F(N.signal);if(O.resolve){let J;l.batch(()=>{J=O.resolve(y,z);}),await J;}},destroy(){this.cancelAll(),b.clear(),E.clear();}}}function we(r){let t=Object.create(null),g=Object.create(null),l=Object.create(null),m=Object.create(null),i=Object.create(null),c=Object.create(null),D=new Map;for(let n of r.modules){let f=(h,H)=>{if(h)for(let K of Object.keys(h)){if(G.has(K))throw new Error(`[Directive] Security: Module "${n.id}" has dangerous key "${K}" in ${H}. This could indicate a prototype pollution attempt.`);if(H==="schema"&&K.startsWith("$"))throw new Error(`[Directive] Module "${n.id}" has schema key "${K}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};if(f(n.schema,"schema"),f(n.events,"events"),f(n.derive,"derive"),f(n.effects,"effects"),f(n.constraints,"constraints"),f(n.resolvers,"resolvers"),process.env.NODE_ENV!=="production")for(let h of Object.keys(n.schema)){let H=D.get(h);if(H)throw new Error(`[Directive] Schema collision: Fact "${h}" is defined in both module "${H}" and "${n.id}". Use namespacing (e.g., "${n.id}::${h}") or merge into one module.`);D.set(h,n.id);}Object.assign(t,n.schema),n.events&&Object.assign(g,n.events),n.derive&&Object.assign(l,n.derive),n.effects&&Object.assign(m,n.effects),n.constraints&&Object.assign(i,n.constraints),n.resolvers&&Object.assign(c,n.resolvers);}let p=null;if(r.modules.some(n=>n.history?.snapshotEvents)){p=new Set;for(let n of r.modules){let f=n;if(f.history?.snapshotEvents)for(let h of f.history.snapshotEvents)p.add(h);else if(f.events)for(let h of Object.keys(f.events))p.add(h);}}let q=0,b=false;if(process.env.NODE_ENV!=="production"){let n=new Set(Object.keys(l));for(let f of Object.keys(t))n.has(f)&&console.warn(`[Directive] "${f}" exists as both a fact and a derivation. This may cause unexpected dependency tracking behavior.`);}let d=Fe();for(let n of r.plugins??[])d.register(n);let k=Ie({config:r.errorBoundary,onError:n=>d.emitError(n),onRecovery:(n,f)=>d.emitErrorRecovery(n,f)}),E=null,B=()=>{},j=()=>{},x=null,R=qe({traceConfig:r.trace,pluginManager:d}),V=R.enabled,{store:T,facts:F}=je({schema:t,onChange:(n,f,h)=>{d.emitFactSet(n,f,h),B(n),V&&R.recordFactChange(String(n),h,f),!x?.isRestoring&&(q===0&&(b=true),P.changedKeys.add(n),_());},onBatch:n=>{d.emitFactsBatch(n);let f=[];for(let h of n)f.push(h.key);if(V)for(let h of n)R.recordFactChange(h.key,h.prev,h.type==="delete"?void 0:h.value);if(j(f),!x?.isRestoring){q===0&&(b=true);for(let h of n)P.changedKeys.add(h.key);_();}}}),$=Ce({definitions:l,facts:F,onCompute:(n,f,h,H)=>{d.emitDerivationCompute(n,f,H),R.currentTrace&&R.currentTrace.derivationsRecomputed.push({id:n,deps:H?[...H]:[],oldValue:h,newValue:f});},onInvalidate:n=>d.emitDerivationInvalidate(n),onError:(n,f)=>{k.handleError("derivation",n,f)==="retry"&&$.invalidate(n);}});B=n=>$.invalidate(n),j=n=>$.invalidateMany(n);let e=Me({definitions:m,facts:F,store:T,onRun:(n,f)=>{d.emitEffectRun(n),R.currentTrace&&R.currentTrace.effectsRun.push({id:n,triggeredBy:f});},onError:(n,f)=>{let h=k.handleError("effect",n,f);d.emitEffectError(n,f),R.currentTrace&&R.currentTrace.effectErrors.push({id:n,error:String(f)}),h==="disable"&&e.disable(n),h==="retry"&&(P.changedKeys.add("*"),_());}}),s=xe({definitions:i,facts:F,onEvaluate:(n,f)=>d.emitConstraintEvaluate(n,f),onError:(n,f)=>{let h=k.handleError("constraint",n,f);d.emitConstraintError(n,f),h==="disable"&&s.disable(n);}}),a=Ve({definitions:c,facts:F,store:T,onStart:(n,f)=>d.emitResolverStart(n,f),onComplete:(n,f,h)=>{k.clearRetryAttempts(n),d.emitResolverComplete(n,f,h),d.emitRequirementMet(f,n),s.markResolved(f.fromConstraint),V&&(R.recordResolverComplete(f.id,n,h),R.decrementInflight(f.id));},onError:(n,f,h)=>{let H=k.handleError("resolver",n,h,f);if(d.emitResolverError(n,f,h),H==="disable"&&s.disable(f.fromConstraint),H==="retry"&&(P.previousRequirements.remove(f.id),_()),H==="retry-later"){let W=k.getRetryLaterManager().getPendingRetries().find(Z=>Z.sourceId===n);W&&!W.callback&&(W.callback=()=>{_();});}V&&(R.recordResolverError(f.id,n,String(h)),R.decrementInflight(f.id));},onRetry:(n,f,h)=>d.emitResolverRetry(n,f,h),onCancel:(n,f)=>{d.emitResolverCancel(n,f),d.emitRequirementCanceled(f),V&&R.decrementInflight(f.id);},onResolutionComplete:()=>{O(),_();}}),C=new Set;function I(){for(let n of C)n();}let o=r.history?ke({historyOption:r.history,facts:F,store:T,onSnapshot:n=>{d.emitSnapshot(n),I();},onHistoryChange:(n,f)=>{d.emitHistoryNavigate(n,f),I();}}):De();x=o;let y=new Set;function O(){for(let n of y)n();}let N=50,z=100,J=0,P={isRunning:false,isReconciling:false,reconcileScheduled:false,isInitializing:false,isInitialized:false,isReady:false,isDestroyed:false,changedKeys:new Set,previousRequirements:new le,readyPromise:null,readyResolve:null},L=Pe({mergedConstraints:i,mergedResolvers:c,mergedDerive:l,mergedEffects:m,constraintsManager:s,resolversManager:a,derivationsManager:$,effectsManager:e,pluginManager:d,getState:()=>P,scheduleReconcile:_,maxDeferredRegistrations:z});function _(){!P.isRunning||P.reconcileScheduled||P.isInitializing||(P.reconcileScheduled=true,O(),queueMicrotask(()=>{P.reconcileScheduled=false,P.isRunning&&!P.isInitializing&&u().catch(n=>{process.env.NODE_ENV!=="production"&&console.error("[Directive] Unexpected error in reconcile:",n);});}));}async function u(){if(P.isReconciling)return;if(J++,J>N){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Reconcile loop exceeded ${N} iterations. This usually means resolvers are creating circular requirement chains. Check that resolvers aren't mutating facts that re-trigger their own constraints.`),V&&R.drainPendingChanges(),J=0;return}P.isReconciling=true,O();let n=V?R.startRun():0,f=R.currentTrace;try{P.changedKeys.size>0&&((p===null||b)&&o.takeSnapshot(`facts-changed:${[...P.changedKeys].join(",")}`),b=!1);let h=F.$snapshot();d.emitReconcileStart(h),await e.runEffects(P.changedKeys);let H=new Set(P.changedKeys);P.changedKeys.clear();let K=await s.evaluate(H),W=new le;for(let X of K)W.add(X),d.emitRequirementCreated(X);if(f){let X=new Set(K.map(re=>re.fromConstraint));for(let re of X){let ne=s.getState(re);if(ne){let ie=s.getDependencies(re);f.constraintsHit.push({id:re,priority:ne.priority,deps:ie?[...ie]:[]});}}}let{added:Z,removed:Q}=W.diff(P.previousRequirements);if(f){for(let X of Z)f.requirementsAdded.push({id:X.id,type:X.requirement.type,fromConstraint:X.fromConstraint});for(let X of Q)f.requirementsRemoved.push({id:X.id,type:X.requirement.type,fromConstraint:X.fromConstraint});}for(let X of Q)a.cancel(X.id);for(let X of Z)a.resolve(X);if(f){let X=a.getInflightInfo(),re=new Map(X.map(ne=>[ne.id,ne]));for(let ne of Z){let ie=re.get(ne.id);f.resolversStarted.push({resolver:ie?.resolverId??"unknown",requirementId:ne.id}),R.attributeResolverStart(ne.id);}}P.previousRequirements=W;let Y=a.getInflightInfo(),te={unmet:K.filter(X=>!a.isResolving(X.id)),inflight:Y,completed:[],canceled:Q.map(X=>({id:X.id,resolverId:Y.find(re=>re.id===X.id)?.resolverId??"unknown"}))};d.emitReconcileEnd(te),P.isReady||(P.isReady=!0,P.readyResolve&&(P.readyResolve(),P.readyResolve=null));}finally{V&&R.finalizeCurrentRun(n),P.isReconciling=false,L.flushDeferred(),P.changedKeys.size>0?_():P.reconcileScheduled||(J=0),O();}}function w(n,f){let h=g[n];if(h){q++,(p===null||p.has(n))&&(b=true);try{T.batch(()=>{h(F,{type:n,...f});});}finally{q--;}}else process.env.NODE_ENV!=="production"&&console.warn(`[Directive] Unknown event type "${n}". No handler is registered for this event. Available events: ${Object.keys(g).join(", ")||"(none)"}`);}let v=$e({mergedDerive:l,getDerivation:n=>$.get(n),definitions:L}),M=Oe({mergedEvents:g,dispatchEvent:w}),A={facts:F,history:o.isEnabled?o:null,derive:v,events:M,constraints:{disable:n=>s.disable(n),enable:n=>s.enable(n),isDisabled:n=>s.isDisabled(n),register:(n,f)=>L.register("constraint",n,f),assign:(n,f)=>L.assign("constraint",n,f),unregister:n=>L.unregister("constraint",n),call:(n,f)=>L.call("constraint",n,f),isDynamic:n=>L.isDynamic("constraint",n),listDynamic:()=>L.listDynamic("constraint")},effects:{disable:n=>e.disable(n),enable:n=>e.enable(n),isEnabled:n=>e.isEnabled(n),register:(n,f)=>L.register("effect",n,f),assign:(n,f)=>L.assign("effect",n,f),unregister:n=>L.unregister("effect",n),call:n=>L.call("effect",n),isDynamic:n=>L.isDynamic("effect",n),listDynamic:()=>L.listDynamic("effect")},resolvers:{register:(n,f)=>L.register("resolver",n,f),assign:(n,f)=>L.assign("resolver",n,f),unregister:n=>L.unregister("resolver",n),call:(n,f)=>L.call("resolver",n,f),isDynamic:n=>L.isDynamic("resolver",n),listDynamic:()=>L.listDynamic("resolver")},get trace(){return R.getEntries()},initialize(){if(!P.isInitialized){P.isInitializing=true;for(let n of r.modules)n.init&&T.batch(()=>{n.init(F);});r.onAfterModuleInit&&T.batch(()=>{r.onAfterModuleInit();}),P.isInitializing=false,P.isInitialized=true;for(let n of Object.keys(l))$.get(n);}},start(){if(!P.isRunning){P.isInitialized||this.initialize(),P.isRunning=true;for(let n of r.modules)n.hooks?.onStart?.(A);if(d.emitStart(A),r.errorBoundary?.retryLater&&!E){let n=Math.max(r.errorBoundary.retryLater.delayMs??1e3,250);E=setInterval(()=>{let f=k.processDueRetries();for(let h of f)h.callback?h.callback():_();},Math.min(n,500));}_();}},stop(){if(P.isRunning){P.isRunning=false,E!==null&&(clearInterval(E),E=null),k.getRetryLaterManager().clearAll(),a.cancelAll(),e.cleanupAll();for(let n of r.modules)n.hooks?.onStop?.(A);d.emitStop(A);}},destroy(){P.isDestroyed||(this.stop(),P.isDestroyed=true,T.destroy?.(),a.destroy(),k.clearErrors(),y.clear(),C.clear(),R.destroy(),L.destroy(),d.emitDestroy(A));},dispatch(n){G.has(n.type)||w(n.type,n);},read(n){return $.get(n)},subscribe(n,f){let h=[],H=[];for(let W of n)W in l?h.push(W):W in t?H.push(W):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe: unknown key "${W}"`);let K=[];return h.length>0&&K.push($.subscribe(h,f)),H.length>0&&K.push(T.subscribe(H,f)),()=>{for(let W of K)W();}},watch(n,f,h){let H=h?.equalityFn?(W,Z)=>h.equalityFn(W,Z):(W,Z)=>Object.is(W,Z);if(n in l){let W=$.get(n);return $.subscribe([n],()=>{let Z=$.get(n);if(!H(Z,W)){let Q=W;W=Z,f(Z,Q);}})}process.env.NODE_ENV!=="production"&&(n in t||console.warn(`[Directive] watch: unknown key "${n}"`));let K=T.get(n);return T.subscribe([n],()=>{let W=T.get(n);if(!H(W,K)){let Z=K;K=W,f(W,Z);}})},when(n,f){return new Promise((h,H)=>{let K=T.toObject();if(n(K)){h();return}let W,Z,Q=()=>{W?.(),Z!==void 0&&clearTimeout(Z);};W=T.subscribeAll(()=>{let Y=T.toObject();n(Y)&&(Q(),h());}),f?.timeout!==void 0&&f.timeout>0&&(Z=setTimeout(()=>{Q(),H(new Error(`[Directive] when: timed out after ${f.timeout}ms`));},f.timeout));})},inspect(){return {unmet:P.previousRequirements.all(),inflight:a.getInflightInfo(),constraints:s.getAllStates().map(n=>({id:n.id,active:n.lastResult??false,disabled:s.isDisabled(n.id),priority:n.priority,hitCount:n.hitCount,lastActiveAt:n.lastActiveAt})),resolvers:Object.fromEntries(a.getInflight().map(n=>[n,a.getStatus(n)])),resolverDefs:Object.entries(c).map(([n,f])=>({id:n,requirement:typeof f.requirement=="string"?f.requirement:"(predicate)"})),traceEnabled:V,...V?{trace:(R.getEntries()??[]).map(n=>({...n,factChanges:n.factChanges.map(f=>({...f})),derivationsRecomputed:n.derivationsRecomputed.map(f=>({...f,deps:[...f.deps]})),constraintsHit:n.constraintsHit.map(f=>({...f,deps:[...f.deps]})),requirementsAdded:n.requirementsAdded.map(f=>({...f})),requirementsRemoved:n.requirementsRemoved.map(f=>({...f})),resolversStarted:n.resolversStarted.map(f=>({...f})),resolversCompleted:n.resolversCompleted.map(f=>({...f})),resolversErrored:n.resolversErrored.map(f=>({...f})),effectsRun:n.effectsRun.map(f=>({...f,triggeredBy:[...f.triggeredBy]})),effectErrors:n.effectErrors.map(f=>({...f}))}))}:{}}},explain(n){let h=P.previousRequirements.all().find(X=>X.id===n);if(!h)return null;let H=s.getState(h.fromConstraint),K=a.getStatus(n),W={},Z=T.toObject();for(let[X,re]of Object.entries(Z))W[X]=re;let Q=[`Requirement "${h.requirement.type}" (id: ${h.id})`,`\u251C\u2500 Produced by constraint: ${h.fromConstraint}`,`\u251C\u2500 Constraint priority: ${H?.priority??0}`,`\u251C\u2500 Constraint active: ${H?.lastResult??"unknown"}`,`\u251C\u2500 Resolver status: ${K.state}`],Y=Object.entries(h.requirement).filter(([X])=>X!=="type").map(([X,re])=>`${X}=${JSON.stringify(re)}`).join(", ");Y&&Q.push(`\u251C\u2500 Requirement payload: { ${Y} }`);let te=Object.entries(W).slice(0,10);return te.length>0&&(Q.push("\u2514\u2500 Relevant facts:"),te.forEach(([X,re],ne)=>{let ie=ne===te.length-1?" \u2514\u2500":" \u251C\u2500",ce=typeof re=="object"?JSON.stringify(re):String(re);Q.push(`${ie} ${X} = ${ce.slice(0,50)}${ce.length>50?"...":""}`);})),Q.join(`
2
- `)},getOriginal(n,f){return L.getOriginal(n,f)},restoreOriginal(n,f){return L.restoreOriginal(n,f)},async settle(n=5e3){let f=Date.now();for(;;){a.hasPendingBatches()&&a.processBatches(),await new Promise(K=>setTimeout(K,0));let h=this.inspect();if(h.inflight.length===0&&!P.isReconciling&&!P.reconcileScheduled&&!a.hasPendingBatches())return;if(Date.now()-f>n){let K=[];h.inflight.length>0&&K.push(`${h.inflight.length} resolvers inflight: ${h.inflight.map(Z=>Z.resolverId).join(", ")}`),P.isReconciling&&K.push("reconciliation in progress"),P.reconcileScheduled&&K.push("reconcile scheduled");let W=P.previousRequirements.all();throw W.length>0&&K.push(`${W.length} unmet requirements: ${W.map(Z=>Z.requirement.type).join(", ")}`),new Error(`[Directive] settle() timed out after ${n}ms. ${K.join("; ")}`)}await new Promise(K=>setTimeout(K,10));}},getSnapshot(){return {facts:T.toObject(),version:1}},getDistributableSnapshot(n={}){let{includeDerivations:f,excludeDerivations:h,includeFacts:H,ttlSeconds:K,metadata:W,includeVersion:Z}=n,Q={},Y=Object.keys(l),te;if(f){if(te=f.filter(ne=>Y.includes(ne)),process.env.NODE_ENV!=="production"){let ne=f.filter(ie=>!Y.includes(ie));ne.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown derivation keys ignored: ${ne.join(", ")}. Available: ${Y.join(", ")||"(none)"}`);}}else te=Y;if(h){let ne=new Set(h);te=te.filter(ie=>!ne.has(ie));}for(let ne of te)try{Q[ne]=$.get(ne);}catch(ie){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] getDistributableSnapshot: Skipping derivation "${ne}" due to error:`,ie);}if(H&&H.length>0){let ne=T.toObject(),ie=Object.keys(ne);if(process.env.NODE_ENV!=="production"){let ce=H.filter(Qe=>!(Qe in ne));ce.length>0&&console.warn(`[Directive] getDistributableSnapshot: Unknown fact keys ignored: ${ce.join(", ")}. Available: ${ie.join(", ")||"(none)"}`);}for(let ce of H)ce in ne&&(Q[ce]=ne[ce]);}let X=Date.now(),re={data:Q,createdAt:X};return K!==void 0&&K>0&&(re.expiresAt=X+K*1e3),Z&&(re.version=be(Q)),W&&(re.metadata=W),re},watchDistributableSnapshot(n,f){let{includeDerivations:h,excludeDerivations:H}=n,K=Object.keys(l),W;if(h?W=h.filter(Y=>K.includes(Y)):W=K,H){let Y=new Set(H);W=W.filter(te=>!Y.has(te));}if(W.length===0)return process.env.NODE_ENV!=="production"&&console.warn("[Directive] watchDistributableSnapshot: No derivations to watch. Callback will never be called."),()=>{};let Q=this.getDistributableSnapshot({...n,includeVersion:true}).version;return $.subscribe(W,()=>{let Y=this.getDistributableSnapshot({...n,includeVersion:true});Y.version!==Q&&(Q=Y.version,f(Y));})},restore(n){if(!n||typeof n!="object")throw new Error("[Directive] restore() requires a valid snapshot object");if(!n.facts||typeof n.facts!="object")throw new Error("[Directive] restore() snapshot must have a facts object");if(!oe(n))throw new Error("[Directive] restore() rejected: snapshot contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");T.batch(()=>{for(let[f,h]of Object.entries(n.facts))G.has(f)||T.set(f,h);});},onSettledChange(n){return y.add(n),()=>{y.delete(n);}},onHistoryChange(n){return C.add(n),()=>{C.delete(n);}},batch(n){T.batch(n);},get isSettled(){return a.getInflight().length===0&&!a.hasPendingBatches()&&!P.isReconciling&&!P.reconcileScheduled},get isRunning(){return P.isRunning},get isInitialized(){return P.isInitialized},get isReady(){return P.isReady},whenReady(){return P.isReady?Promise.resolve():P.isRunning?(P.readyPromise||(P.readyPromise=new Promise(n=>{P.readyResolve=n;})),P.readyPromise):Promise.reject(new Error("[Directive] whenReady() called before start(). Call system.start() first, then await system.whenReady()."))}};function ee(n){if(P.isReconciling)throw new Error(`[Directive] Cannot register module "${n.id}" during reconciliation. Wait for the current reconciliation cycle to complete.`);if(P.isDestroyed)throw new Error(`[Directive] Cannot register module "${n.id}" on a destroyed system.`);let f=(h,H)=>{if(h)for(let K of Object.keys(h)){if(G.has(K))throw new Error(`[Directive] Security: Module "${n.id}" has dangerous key "${K}" in ${H}.`);if(H==="schema"&&K.startsWith("$"))throw new Error(`[Directive] Module "${n.id}" has schema key "${K}" starting with "$". Keys starting with $ are reserved for internal accessors ($store, $snapshot).`)}};f(n.schema,"schema"),f(n.events,"events"),f(n.derive,"derive"),f(n.effects,"effects"),f(n.constraints,"constraints"),f(n.resolvers,"resolvers");for(let h of Object.keys(n.schema))if(h in t)throw new Error(`[Directive] Schema collision: Fact "${h}" already exists. Cannot register module "${n.id}".`);if(process.env.NODE_ENV!=="production"&&n.derive){let h=new Set(Object.keys(t));for(let H of Object.keys(n.derive))h.has(H)&&console.warn(`[Directive] "${H}" exists as both a fact and a derivation after registering module "${n.id}".`);}if(n.history?.snapshotEvents){p===null&&(p=new Set(Object.keys(g)));for(let h of n.history.snapshotEvents)p.add(h);}else if(p!==null&&n.events)for(let h of Object.keys(n.events))p.add(h);Object.assign(t,n.schema),n.events&&Object.assign(g,n.events),n.derive&&(Object.assign(l,n.derive),$.registerDefinitions(n.derive)),n.effects&&(Object.assign(m,n.effects),e.registerDefinitions(n.effects)),n.constraints&&(Object.assign(i,n.constraints),s.registerDefinitions(n.constraints)),n.resolvers&&(Object.assign(c,n.resolvers),a.registerDefinitions(n.resolvers)),T.registerKeys(n.schema),r.modules.push(n),n.init&&T.batch(()=>{n.init(F);}),n.hooks?.onInit?.(A),P.isRunning&&(n.hooks?.onStart?.(A),_());}A.registerModule=ee,d.emitInit(A);for(let n of r.modules)n.hooks?.onInit?.(A);return A}var U="::";function gt(r){let t=Object.keys(r),g=new Set,l=new Set,m=[],i=[];function c(D){if(g.has(D))return;if(l.has(D)){let S=i.indexOf(D),q=[...i.slice(S),D].join(" \u2192 ");throw new Error(`[Directive] Circular dependency detected: ${q}. Modules cannot have circular crossModuleDeps. Break the cycle by removing one of the cross-module references.`)}l.add(D),i.push(D);let p=r[D];if(p?.crossModuleDeps)for(let S of Object.keys(p.crossModuleDeps))t.includes(S)&&c(S);i.pop(),l.delete(D),g.add(D),m.push(D);}for(let D of t)c(D);return m}var Be=new WeakMap,Ke=new WeakMap,He=new WeakMap,We=new WeakMap;function Le(r){if("module"in r){if(!r.module)throw new Error("[Directive] createSystem requires a module. Got: "+typeof r.module);return pt(r)}let t=r;if(Array.isArray(t.modules))throw new Error(`[Directive] createSystem expects modules as an object, not an array.
3
-
4
- Instead of:
5
- createSystem({ modules: [authModule, dataModule] })
6
-
7
- Use:
8
- createSystem({ modules: { auth: authModule, data: dataModule } })
9
-
10
- Or for a single module:
11
- createSystem({ module: counterModule })`);let g=t.modules;if(g&&typeof g=="object"&&"id"in g&&"schema"in g)throw new Error(`[Directive] A single module was passed to \`modules:\`. For a single module, use \`module:\` instead:
12
-
13
- createSystem({ module: myModule })
14
-
15
- For multiple modules, wrap in an object:
16
- createSystem({ modules: { myName: myModule } })`);return mt(t)}function mt(r){let t=r.modules,g=new Set(Object.keys(t)),l=typeof r.history=="object"?r.history:null,m=l?.snapshotModules?new Set(l.snapshotModules):null;if(r.tickMs!==void 0&&r.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(process.env.NODE_ENV!=="production"){for(let[e,s]of Object.entries(t))if(s.crossModuleDeps)for(let a of Object.keys(s.crossModuleDeps))a===e?console.warn(`[Directive] Module "${e}" references itself in crossModuleDeps. Use "facts.self" to access own module's facts instead.`):g.has(a)||console.warn(`[Directive] Module "${e}" declares crossModuleDeps.${a}, but no module with namespace "${a}" exists in the system. Available modules: ${[...g].join(", ")}`);}if(process.env.NODE_ENV!=="production"&&l?.snapshotModules)for(let e of l.snapshotModules)g.has(e)||console.warn(`[Directive] history.snapshotModules entry "${e}" doesn't match any module. Available modules: ${[...g].join(", ")}`);let i,c=r.initOrder??"auto";if(Array.isArray(c)){let e=c,s=Object.keys(t).filter(a=>!e.includes(a));if(s.length>0)throw new Error(`[Directive] initOrder is missing modules: ${s.join(", ")}. All modules must be included in the explicit order.`);i=e;}else c==="declaration"?i=Object.keys(t):i=gt(t);let{history:D,trace:p,errorBoundary:S}=Je(r);for(let e of Object.keys(t)){if(e.includes(U))throw new Error(`[Directive] Module name "${e}" contains the reserved separator "${U}". Module names cannot contain "${U}".`);let s=t[e];if(s){for(let a of Object.keys(s.schema.facts))if(a.includes(U))throw new Error(`[Directive] Schema key "${a}" in module "${e}" contains the reserved separator "${U}". Schema keys cannot contain "${U}".`)}}let q=[];for(let e of i){let s=t[e];if(!s)continue;let a=s.crossModuleDeps&&Object.keys(s.crossModuleDeps).length>0,C=a?Object.keys(s.crossModuleDeps):[],I={};for(let[_,u]of Object.entries(s.schema.facts))I[`${e}${U}${_}`]=u;let o={};if(s.schema.derivations)for(let[_,u]of Object.entries(s.schema.derivations))o[`${e}${U}${_}`]=u;let y={};if(s.schema.events)for(let[_,u]of Object.entries(s.schema.events))y[`${e}${U}${_}`]=u;let O=s.init?_=>{let u=se(_,e);s.init(u);}:void 0,N={};if(s.derive)for(let[_,u]of Object.entries(s.derive))N[`${e}${U}${_}`]=(w,v)=>{let M=a?ae(w,e,C):se(w,e),A=Re(v,e);return u(M,A)};let z={};if(s.events)for(let[_,u]of Object.entries(s.events))z[`${e}${U}${_}`]=(w,v)=>{let M=se(w,e);u(M,v);};let J={};if(s.constraints)for(let[_,u]of Object.entries(s.constraints)){let w=u;J[`${e}${U}${_}`]={...w,deps:w.deps?.map(v=>`${e}${U}${v}`),when:v=>{let M=a?ae(v,e,C):se(v,e);return w.when(M)},require:typeof w.require=="function"?v=>{let M=a?ae(v,e,C):se(v,e);return w.require(M)}:w.require};}let P={};if(s.resolvers)for(let[_,u]of Object.entries(s.resolvers)){let w=u;P[`${e}${U}${_}`]={...w,resolve:async(v,M)=>{let A=Se(M.facts,t,()=>Object.keys(t));await w.resolve(v,{facts:A[e],signal:M.signal});}};}let L={};if(s.effects)for(let[_,u]of Object.entries(s.effects)){let w=u;L[`${e}${U}${_}`]={...w,run:(v,M)=>{let A=a?ae(v,e,C):se(v,e),ee=M?a?ae(M,e,C):se(M,e):void 0;return w.run(A,ee)},deps:w.deps?.map(v=>`${e}${U}${v}`)};}q.push({id:s.id,schema:{facts:I,derivations:o,events:y,requirements:s.schema.requirements??{}},init:O,derive:N,events:z,effects:L,constraints:J,resolvers:P,hooks:s.hooks,history:{snapshotEvents:m&&!m.has(e)?[]:s.history?.snapshotEvents?.map(_=>`${e}${U}${_}`)}});}process.env.NODE_ENV!=="production"&&r.tickMs&&r.tickMs>0&&(q.some(s=>s.events&&Object.keys(s.events).some(a=>a.endsWith(`${U}tick`)))||console.warn(`[Directive] tickMs is set to ${r.tickMs}ms but no module defines a "tick" event handler.`));let b=null,d=null;function k(e){for(let[s,a]of Object.entries(e)){if(G.has(s)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains blocked namespace "${s}". Skipping.`);continue}if(!g.has(s)){process.env.NODE_ENV!=="production"&&console.warn(`[Directive] initialFacts/hydrate contains unknown namespace "${s}". Available modules: ${[...g].join(", ")}`);continue}if(a&&typeof a=="object"&&!oe(a))throw new Error(`[Directive] initialFacts/hydrate for namespace "${s}" contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.`);for(let[C,I]of Object.entries(a))G.has(C)||(d.facts[`${s}${U}${C}`]=I);}}d=we({modules:q.map(e=>({id:e.id,schema:e.schema.facts,requirements:e.schema.requirements,init:e.init,derive:e.derive,events:e.events,effects:e.effects,constraints:e.constraints,resolvers:e.resolvers,hooks:e.hooks,history:e.history})),plugins:r.plugins,history:D,trace:p,errorBoundary:S,tickMs:r.tickMs,onAfterModuleInit:()=>{r.initialFacts&&k(r.initialFacts),b&&(k(b),b=null);}});let E=new Map;for(let e of Object.keys(t)){let s=t[e];if(!s)continue;let a=[];for(let C of Object.keys(s.schema.facts))a.push(`${e}${U}${C}`);if(s.schema.derivations)for(let C of Object.keys(s.schema.derivations))a.push(`${e}${U}${C}`);E.set(e,a);}let B={names:null};function j(){return B.names===null&&(B.names=Object.keys(t)),B.names}let x=Se(d.facts,t,j),R=yt(d.derive,t,j),V=vt(d,t,j),T=null,F=r.tickMs,$={_mode:"namespaced",facts:x,history:d.history,derive:R,events:V,constraints:d.constraints,effects:d.effects,resolvers:d.resolvers,async hydrate(e){if(d.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let s=await e();s&&typeof s=="object"&&(b=s);},initialize(){d.initialize();},start(){if(d.start(),F&&F>0){let e=Object.keys(q[0]?.events??{}).find(s=>s.endsWith(`${U}tick`));e&&(T=setInterval(()=>{d.dispatch({type:e});},F));}},stop(){T&&(clearInterval(T),T=null),d.stop();},destroy(){this.stop(),d.destroy();},dispatch(e){d.dispatch(e);},read(e){return d.read(ue(e))},subscribe(e,s){let a=[];for(let C of e)if(C.endsWith(".*")){let I=C.slice(0,-2),o=E.get(I);o?a.push(...o):process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribe wildcard "${C}" \u2014 namespace "${I}" not found.`);}else a.push(ue(C));return d.subscribe(a,s)},subscribeModule(e,s){let a=E.get(e);return !a||a.length===0?(process.env.NODE_ENV!=="production"&&console.warn(`[Directive] subscribeModule("${e}") \u2014 namespace not found. Available: ${[...E.keys()].join(", ")}`),()=>{}):d.subscribe(a,s)},watch(e,s,a){return d.watch(ue(e),s,a)},when(e,s){return d.when(()=>e(x),s)},getDistributableSnapshot(e){let s={...e,includeDerivations:e?.includeDerivations?.map(ue),excludeDerivations:e?.excludeDerivations?.map(ue),includeFacts:e?.includeFacts?.map(ue)},a=d.getDistributableSnapshot(s),C={};for(let[I,o]of Object.entries(a.data)){let y=I.indexOf(U);if(y>0){let O=I.slice(0,y),N=I.slice(y+U.length);C[O]||(C[O]={}),C[O][N]=o;}else C._root||(C._root={}),C._root[I]=o;}return {...a,data:C}},watchDistributableSnapshot(e,s){let a={...e,includeDerivations:e?.includeDerivations?.map(ue),excludeDerivations:e?.excludeDerivations?.map(ue),includeFacts:e?.includeFacts?.map(ue)};return d.watchDistributableSnapshot(a,C=>{let I={};for(let[o,y]of Object.entries(C.data)){let O=o.indexOf(U);if(O>0){let N=o.slice(0,O),z=o.slice(O+U.length);I[N]||(I[N]={}),I[N][z]=y;}else I._root||(I._root={}),I._root[o]=y;}s({...C,data:I});})},registerModule(e,s){if(g.has(e))throw new Error(`[Directive] Module namespace "${e}" already exists. Cannot register a duplicate namespace.`);if(e.includes(U))throw new Error(`[Directive] Module name "${e}" contains the reserved separator "${U}".`);if(G.has(e))throw new Error(`[Directive] Module name "${e}" is a blocked property.`);for(let _ of Object.keys(s.schema.facts))if(_.includes(U))throw new Error(`[Directive] Schema key "${_}" in module "${e}" contains the reserved separator "${U}".`);let a=s,C=a.crossModuleDeps&&Object.keys(a.crossModuleDeps).length>0,I=C?Object.keys(a.crossModuleDeps):[],o={};for(let[_,u]of Object.entries(a.schema.facts))o[`${e}${U}${_}`]=u;let y=a.init?_=>{let u=se(_,e);a.init(u);}:void 0,O={};if(a.derive)for(let[_,u]of Object.entries(a.derive))O[`${e}${U}${_}`]=(w,v)=>{let M=C?ae(w,e,I):se(w,e),A=Re(v,e);return u(M,A)};let N={};if(a.events)for(let[_,u]of Object.entries(a.events))N[`${e}${U}${_}`]=(w,v)=>{let M=se(w,e);u(M,v);};let z={};if(a.constraints)for(let[_,u]of Object.entries(a.constraints)){let w=u;z[`${e}${U}${_}`]={...w,deps:w.deps?.map(v=>`${e}${U}${v}`),when:v=>{let M=C?ae(v,e,I):se(v,e);return w.when(M)},require:typeof w.require=="function"?v=>{let M=C?ae(v,e,I):se(v,e);return w.require(M)}:w.require};}let J={};if(a.resolvers)for(let[_,u]of Object.entries(a.resolvers)){let w=u;J[`${e}${U}${_}`]={...w,resolve:async(v,M)=>{let A=Se(M.facts,t,j);await w.resolve(v,{facts:A[e],signal:M.signal});}};}let P={};if(a.effects)for(let[_,u]of Object.entries(a.effects)){let w=u;P[`${e}${U}${_}`]={...w,run:(v,M)=>{let A=C?ae(v,e,I):se(v,e),ee=M?C?ae(M,e,I):se(M,e):void 0;return w.run(A,ee)},deps:w.deps?.map(v=>`${e}${U}${v}`)};}g.add(e),t[e]=a,B.names=null;let L=[];for(let _ of Object.keys(a.schema.facts))L.push(`${e}${U}${_}`);if(a.schema.derivations)for(let _ of Object.keys(a.schema.derivations))L.push(`${e}${U}${_}`);E.set(e,L),d.registerModule({id:a.id,schema:o,requirements:a.schema.requirements??{},init:y,derive:Object.keys(O).length>0?O:void 0,events:Object.keys(N).length>0?N:void 0,effects:Object.keys(P).length>0?P:void 0,constraints:Object.keys(z).length>0?z:void 0,resolvers:Object.keys(J).length>0?J:void 0,hooks:a.hooks,history:{snapshotEvents:m&&!m.has(e)?[]:a.history?.snapshotEvents?.map(_=>`${e}${U}${_}`)}});}};return Xe($,d),Ge($),$}function Je(r){let t=r.history,g=r.trace,l=r.errorBoundary;if(r.zeroConfig){let m=process.env.NODE_ENV!=="production";t=t??m,l={onConstraintError:"skip",onResolverError:"skip",onEffectError:"skip",onDerivationError:"skip",...r.errorBoundary};}return {history:t,trace:g,errorBoundary:l}}function Xe(r,t){Object.defineProperties(r,{trace:{get(){return t.trace},enumerable:true,configurable:true},isRunning:{get(){return t.isRunning},enumerable:true,configurable:true},isSettled:{get(){return t.isSettled},enumerable:true,configurable:true},isInitialized:{get(){return t.isInitialized},enumerable:true,configurable:true},isReady:{get(){return t.isReady},enumerable:true,configurable:true}}),r.whenReady=t.whenReady.bind(t),r.batch=t.batch.bind(t),r.onSettledChange=t.onSettledChange.bind(t),r.onHistoryChange=t.onHistoryChange.bind(t),r.inspect=t.inspect.bind(t),r.settle=t.settle.bind(t),r.explain=t.explain.bind(t),r.getSnapshot=t.getSnapshot.bind(t),r.restore=t.restore.bind(t);}function Ge(r){process.env.NODE_ENV!=="production"&&process.env.NODE_ENV!=="test"&&setTimeout(()=>{!r.isRunning&&!r.isInitialized&&console.warn("[Directive] System created but start() was never called. Constraints, resolvers, and effects will not run until you call system.start().");},0);}function ue(r){if(r.includes(".")){let[t,...g]=r.split(".");return `${t}${U}${g.join(U)}`}return r}function se(r,t){let g=Be.get(r);if(g){let m=g.get(t);if(m)return m}else g=new Map,Be.set(r,g);let l=new Proxy({},{get(m,i){if(typeof i!="symbol"&&!G.has(i))return i==="$store"||i==="$snapshot"?r[i]:r[`${t}${U}${i}`]},set(m,i,c){return typeof i=="symbol"||G.has(i)?false:(r[`${t}${U}${i}`]=c,true)},has(m,i){return typeof i=="symbol"||G.has(i)?false:`${t}${U}${i}`in r},deleteProperty(m,i){return typeof i=="symbol"||G.has(i)?false:(delete r[`${t}${U}${i}`],true)},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return g.set(t,l),l}function Se(r,t,g){let l=Ke.get(r);if(l)return l;let m=new Proxy({},{get(i,c){if(typeof c!="symbol"&&!G.has(c)&&Object.hasOwn(t,c))return se(r,c)},has(i,c){return typeof c=="symbol"||G.has(c)?false:Object.hasOwn(t,c)},ownKeys(){return g()},getOwnPropertyDescriptor(i,c){if(typeof c!="symbol"&&Object.hasOwn(t,c))return {configurable:true,enumerable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return Ke.set(r,m),m}var ze=new WeakMap;function ae(r,t,g){let l=`${t}:${JSON.stringify([...g].sort())}`,m=ze.get(r);if(m){let p=m.get(l);if(p)return p}else m=new Map,ze.set(r,m);let i=new Set(g),c=["self",...g],D=new Proxy({},{get(p,S){if(typeof S!="symbol"&&!G.has(S)){if(S==="self")return se(r,t);if(i.has(S))return se(r,S);process.env.NODE_ENV!=="production"&&typeof S=="string"&&console.warn(`[Directive] Module "${t}" accessed undeclared cross-module property "${S}". Add it to crossModuleDeps or use "facts.self.${S}" for own module facts.`);}},has(p,S){return typeof S=="symbol"||G.has(S)?false:S==="self"||i.has(S)},ownKeys(){return c},getOwnPropertyDescriptor(p,S){if(typeof S!="symbol"&&(S==="self"||i.has(S)))return {configurable:true,enumerable:true}},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return m.set(l,D),D}function Re(r,t){let g=We.get(r);if(g){let m=g.get(t);if(m)return m}else g=new Map,We.set(r,g);let l=new Proxy({},{get(m,i){if(typeof i!="symbol"&&!G.has(i))return r[`${t}${U}${i}`]},has(m,i){return typeof i=="symbol"||G.has(i)?false:`${t}${U}${i}`in r},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return g.set(t,l),l}function yt(r,t,g){let l=He.get(r);if(l)return l;let m=new Proxy({},{get(i,c){if(typeof c!="symbol"&&!G.has(c)&&Object.hasOwn(t,c))return Re(r,c)},has(i,c){return typeof c=="symbol"||G.has(c)?false:Object.hasOwn(t,c)},ownKeys(){return g()},getOwnPropertyDescriptor(i,c){if(typeof c!="symbol"&&Object.hasOwn(t,c))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return He.set(r,m),m}var Ue=new WeakMap;function vt(r,t,g){let l=Ue.get(r);return l||(l=new Map,Ue.set(r,l)),new Proxy({},{get(m,i){if(typeof i=="symbol"||G.has(i)||!Object.hasOwn(t,i))return;let c=l.get(i);if(c)return c;let D=new Proxy({},{get(p,S){if(typeof S!="symbol"&&!G.has(S))return q=>{r.dispatch({type:`${i}${U}${S}`,...q});}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}});return l.set(i,D),D},has(m,i){return typeof i=="symbol"||G.has(i)?false:Object.hasOwn(t,i)},ownKeys(){return g()},getOwnPropertyDescriptor(m,i){if(typeof i!="symbol"&&Object.hasOwn(t,i))return {configurable:true,enumerable:true}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}})}function pt(r){let t=r.module;if(!t)throw new Error("[Directive] createSystem requires a module. Got: "+typeof t);if(r.tickMs!==void 0&&r.tickMs<=0)throw new Error("[Directive] tickMs must be a positive number");if(r.initialFacts&&!oe(r.initialFacts))throw new Error("[Directive] initialFacts contains potentially dangerous keys (__proto__, constructor, or prototype). This may indicate a prototype pollution attack.");process.env.NODE_ENV!=="production"&&(t.crossModuleDeps&&Object.keys(t.crossModuleDeps).length>0&&console.warn("[Directive] Single module mode ignores crossModuleDeps. Use multiple modules if cross-module access is needed: createSystem({ modules: { ... } })"),r.tickMs&&r.tickMs>0&&(t.events&&"tick"in t.events||console.warn(`[Directive] tickMs is set to ${r.tickMs}ms but module has no "tick" event handler.`)),(typeof r.history=="object"?r.history:null)?.snapshotModules&&console.warn("[Directive] history.snapshotModules has no effect in single-module mode. Use history.snapshotEvents on the module definition instead, or switch to createSystem({ modules: { ... } }) for multi-module filtering."));let{history:g,trace:l,errorBoundary:m}=Je(r),i=null,c=null;c=we({modules:[{id:t.id,schema:t.schema.facts,requirements:t.schema.requirements,init:t.init,derive:t.derive,events:t.events,effects:t.effects,constraints:t.constraints,resolvers:t.resolvers,hooks:t.hooks,history:t.history}],plugins:r.plugins,history:g,trace:l,errorBoundary:m,tickMs:r.tickMs,onAfterModuleInit:()=>{if(r.initialFacts)if(!oe(r.initialFacts))process.env.NODE_ENV!=="production"&&console.warn("[Directive] initialFacts contains potentially dangerous keys. Skipping.");else for(let[b,d]of Object.entries(r.initialFacts))G.has(b)||(c.facts[b]=d);if(i){if(!oe(i))process.env.NODE_ENV!=="production"&&console.warn("[Directive] hydrate() data contains potentially dangerous keys. Skipping.");else for(let[b,d]of Object.entries(i))G.has(b)||(c.facts[b]=d);i=null;}}});let D=new Proxy({},{get(b,d){if(typeof d!="symbol"&&!G.has(d))return k=>{c.dispatch({type:d,...k});}},set(){return false},defineProperty(){return false},getPrototypeOf(){return null},setPrototypeOf(){return false}}),p=null,S=r.tickMs,q={_mode:"single",facts:c.facts,history:c.history,derive:c.derive,events:D,constraints:c.constraints,effects:c.effects,resolvers:c.resolvers,async hydrate(b){if(c.isRunning)throw new Error("[Directive] hydrate() must be called before start(). The system is already running.");let d=await b();d&&typeof d=="object"&&(i=d);},initialize(){c.initialize();},start(){c.start(),S&&S>0&&t.events&&"tick"in t.events&&(p=setInterval(()=>{c.dispatch({type:"tick"});},S));},stop(){p&&(clearInterval(p),p=null),c.stop();},destroy(){this.stop(),c.destroy();},dispatch(b){c.dispatch(b);},read(b){return c.read(b)},subscribe(b,d){return c.subscribe(b,d)},watch(b,d,k){return c.watch(b,d,k)},when(b,d){return c.when(b,d)},getDistributableSnapshot:c.getDistributableSnapshot.bind(c),watchDistributableSnapshot:c.watchDistributableSnapshot.bind(c),registerModule(b){c.registerModule({id:b.id,schema:b.schema.facts,requirements:b.schema.requirements,init:b.init,derive:b.derive,events:b.events,effects:b.effects,constraints:b.constraints,resolvers:b.resolvers,hooks:b.hooks,history:b.history});}};return Xe(q,c),Ge(q),q}async function Ye(){for(let r=0;r<10;r++)await Promise.resolve();}async function yn(r,t,g={}){let{totalTime:l=5e3,stepSize:m=10,maxIterations:i=1e3}=g,c=0,D=0;for(;c<l&&D<i;){if(await Ye(),r.inspect().inflight.length===0){await Ye();return}t(m),c+=m,D++;}let p=r.inspect();if(p.inflight.length>0){let S=p.inflight.map(q=>q.resolverId).join(", ");throw new Error(`[Directive] settleWithFakeTimers did not settle after ${l}ms. ${p.inflight.length} resolvers still inflight: ${S}`)}}function vn(){let r=0,t=[];return {async advance(g){let l=r+g;for(;t.length>0&&t[0].time<=l;){let m=t.shift();r=m.time,m.callback(),await Promise.resolve();}r=l;},async next(){if(t.length===0)return;let g=t.shift();r=g.time,g.callback(),await Promise.resolve();},async runAll(){for(;t.length>0;)await this.next();},now(){return r},reset(){r=0,t.length=0;}}}function ht(r){let t=typeof r=="string"?{requirement:(l=>l.type===r)}:r,g=t.calls??[];return {requirement:t.requirement??(l=>true),async resolve(l,m){if(g.push(l),t.delay&&await new Promise(i=>setTimeout(i,t.delay)),t.error)throw typeof t.error=="string"?new Error(t.error):t.error;t.resolve&&await t.resolve(l,m);}}}function pn(r){let t=[],g=[];return {...{get calls(){return t},get pending(){return g},resolve(i){let c=g.shift();c&&c.resolve(i);},reject(i){let c=g.shift();c&&c.reject(i);},resolveAll(i){for(;g.length>0;)this.resolve(i);},rejectAll(i){for(;g.length>0;)this.reject(i);},reset(){t.length=0,g.length=0;}},handler:(i,c)=>(t.push(i),new Promise((D,p)=>{g.push({requirement:i,resolve:()=>D(),reject:p});}))}}function hn(r){let t=[],g=new Map,l=[],m=[],i={};if(r.mocks?.resolvers)for(let[d,k]of Object.entries(r.mocks.resolvers)){let E=[];g.set(d,E),i[d]=ht({...k,calls:E});}let c={};for(let[d,k]of Object.entries(r.modules))c[d]={...k,resolvers:{...k.resolvers,...i}};let D=new Set(Object.keys(r.modules)),S=Le({...r,modules:c,plugins:[{name:"__test-tracking__",onFactSet:(d,k,E)=>{let j=d.indexOf("::"),x,R;if(j>0){let V=d.substring(0,j);D.has(V)?(x=V,R=d.substring(j+2)):R=d;}else R=d;m.push({key:R,fullKey:d,namespace:x,previousValue:E,newValue:k,timestamp:Date.now()});},onRequirementCreated:d=>{l.push(d);}},...r.plugins??[]]}),q=S.dispatch.bind(S);return S.dispatch=d=>{t.push(d),q(d);},{...S,eventHistory:t,resolverCalls:g,get allRequirements(){return l},getFactsHistory(){return [...m]},resetFactsHistory(){m.length=0;},async waitForIdle(d=5e3){let k=Date.now(),E=async()=>{await new Promise(j=>setTimeout(j,0));let B=S.inspect();if(B.inflight.length>0){if(Date.now()-k>d){let j=B.inflight.map(x=>x.id).join(", ");throw new Error(`[Directive] waitForIdle timed out after ${d}ms. ${B.inflight.length} resolvers still inflight: ${j}`)}return await new Promise(j=>setTimeout(j,10)),E()}};return E()},assertRequirement(d){if(!l.some(E=>E.requirement.type===d))throw new Error(`[Directive] Expected requirement of type "${d}" but none found`)},assertResolverCalled(d,k){let E=g.get(d)??[];if(k!==void 0){if(E.length!==k)throw new Error(`[Directive] Expected resolver "${d}" to be called ${k} times but was called ${E.length} times`)}else if(E.length===0)throw new Error(`[Directive] Expected resolver "${d}" to be called but it was not`)},assertFactSet(d,k){let E=m.filter(B=>B.key===d);if(E.length===0)throw new Error(`[Directive] Expected fact "${d}" to be set but it was not`);if(k!==void 0&&!E.some(j=>j.newValue===k)){let j=E.map(x=>JSON.stringify(x.newValue)).join(", ");throw new Error(`[Directive] Expected fact "${d}" to be set to ${JSON.stringify(k)} but got: ${j}`)}},assertFactChanges(d,k){let E=m.filter(B=>B.key===d);if(E.length!==k)throw new Error(`[Directive] Expected fact "${d}" to change ${k} times but it changed ${E.length} times`)}}}function wn(r,t,g){if(!Ze(r,t,g))throw new Error(`[Directive] Expected ${t} "${g}" to be dynamic, but it is not.`)}function Sn(r,t,g){if(Ze(r,t,g))throw new Error(`[Directive] Expected ${t} "${g}" to NOT be dynamic, but it is.`)}function Ze(r,t,g){switch(t){case "constraint":return r.constraints.isDynamic(g);case "resolver":return r.resolvers.isDynamic(g);case "derivation":return r.derive.isDynamic(g);case "effect":return r.effects.isDynamic(g)}}exports.assertDynamic=wn;exports.assertNotDynamic=Sn;exports.createFakeTimers=vn;exports.createMockResolver=ht;exports.createTestSystem=hn;exports.flushMicrotasks=Ye;exports.mockResolver=pn;exports.settleWithFakeTimers=yn;//# sourceMappingURL=testing.cjs.map
1
+ 'use strict';var chunkLAH2FMON_cjs=require('./chunk-LAH2FMON.cjs');require('./chunk-6WG7FPH7.cjs'),require('./chunk-PK2EH26L.cjs'),require('./chunk-KQKNE23L.cjs');async function S(){for(let t=0;t<10;t++)await Promise.resolve();}async function D(t,r,n={}){let{totalTime:a=5e3,stepSize:c=10,maxIterations:l=1e3}=n,d=0,h=0;for(;d<a&&h<l;){if(await S(),t.inspect().inflight.length===0){await S();return}r(c),d+=c,h++;}let g=t.inspect();if(g.inflight.length>0){let v=g.inflight.map(y=>y.resolverId).join(", ");throw new Error(`[Directive] settleWithFakeTimers did not settle after ${a}ms. ${g.inflight.length} resolvers still inflight: ${v}`)}}function T(){let t=0,r=[];return {async advance(n){let a=t+n;for(;r.length>0&&r[0].time<=a;){let c=r.shift();t=c.time,c.callback(),await Promise.resolve();}t=a;},async next(){if(r.length===0)return;let n=r.shift();t=n.time,n.callback(),await Promise.resolve();},async runAll(){for(;r.length>0;)await this.next();},now(){return t},reset(){t=0,r.length=0;}}}function k(t){let r=typeof t=="string"?{requirement:(a=>a.type===t)}:t,n=r.calls??[];return {requirement:r.requirement??(a=>true),async resolve(a,c){if(n.push(a),r.delay&&await new Promise(l=>setTimeout(l,r.delay)),r.error)throw typeof r.error=="string"?new Error(r.error):r.error;r.resolve&&await r.resolve(a,c);}}}function E(t){let r=[],n=[];return {...{get calls(){return r},get pending(){return n},resolve(l){let d=n.shift();d&&d.resolve(l);},reject(l){let d=n.shift();d&&d.reject(l);},resolveAll(l){for(;n.length>0;)this.resolve(l);},rejectAll(l){for(;n.length>0;)this.reject(l);},reset(){r.length=0,n.length=0;}},handler:(l,d)=>(r.push(l),new Promise((h,g)=>{n.push({requirement:l,resolve:v=>h(v),reject:g});}))}}function C(t){return "module"in t?x(t):M(t)}function x(t){let r=[],n=new Map,a=[],c=[],l={};if(t.mocks?.resolvers)for(let[o,e]of Object.entries(t.mocks.resolvers)){let s=[];n.set(o,s),l[o]=k({...e,calls:s});}let d={...t.module,resolvers:{...t.module.resolvers,...l}},g=chunkLAH2FMON_cjs.a({...t,module:d,plugins:[{name:"__test-tracking__",onFactSet:(o,e,s)=>{c.push({key:o,fullKey:o,namespace:void 0,previousValue:s,newValue:e,timestamp:Date.now()});},onRequirementCreated:o=>{a.push(o);}},...t.plugins??[]]}),v=g.dispatch.bind(g);return g.dispatch=o=>{r.push(o),v(o);},{...g,eventHistory:r,resolverCalls:n,get allRequirements(){return a},getFactsHistory(){return [...c]},resetFactsHistory(){c.length=0;},async waitForIdle(o=5e3){let e=Date.now(),s=async()=>{await new Promise(m=>setTimeout(m,0));let i=g.inspect();if(i.inflight.length>0){if(Date.now()-e>o){let m=i.inflight.map(u=>u.id).join(", ");throw new Error(`[Directive] waitForIdle timed out after ${o}ms. ${i.inflight.length} resolvers still inflight: ${m}`)}return await new Promise(m=>setTimeout(m,10)),s()}};return s()},assertRequirement(o){if(!a.some(s=>s.requirement.type===o))throw new Error(`[Directive] Expected requirement of type "${o}" but none found`)},assertResolverCalled(o,e){let s=n.get(o)??[];if(e!==void 0){if(s.length!==e)throw new Error(`[Directive] Expected resolver "${o}" to be called ${e} times but was called ${s.length} times`)}else if(s.length===0)throw new Error(`[Directive] Expected resolver "${o}" to be called but it was not`)},assertFactSet(o,e){let s=c.filter(i=>i.key===o);if(s.length===0)throw new Error(`[Directive] Expected fact "${o}" to be set but it was not`);if(e!==void 0&&!s.some(m=>m.newValue===e)){let m=s.map(u=>JSON.stringify(u.newValue)).join(", ");throw new Error(`[Directive] Expected fact "${o}" to be set to ${JSON.stringify(e)} but got: ${m}`)}},assertFactChanges(o,e){let s=c.filter(i=>i.key===o);if(s.length!==e)throw new Error(`[Directive] Expected fact "${o}" to change ${e} times but it changed ${s.length} times`)}}}function M(t){let r=[],n=new Map,a=[],c=[],l={};if(t.mocks?.resolvers)for(let[e,s]of Object.entries(t.mocks.resolvers)){let i=[];n.set(e,i),l[e]=k({...s,calls:i});}let d={};for(let[e,s]of Object.entries(t.modules))d[e]={...s,resolvers:{...s.resolvers,...l}};let h=new Set(Object.keys(t.modules)),v=chunkLAH2FMON_cjs.a({...t,modules:d,plugins:[{name:"__test-tracking__",onFactSet:(e,s,i)=>{let u=e.indexOf("::"),f,p;if(u>0){let R=e.substring(0,u);h.has(R)?(f=R,p=e.substring(u+2)):p=e;}else p=e;c.push({key:p,fullKey:e,namespace:f,previousValue:i,newValue:s,timestamp:Date.now()});},onRequirementCreated:e=>{a.push(e);}},...t.plugins??[]]}),y=v.dispatch.bind(v);return v.dispatch=e=>{r.push(e),y(e);},{...v,eventHistory:r,resolverCalls:n,get allRequirements(){return a},getFactsHistory(){return [...c]},resetFactsHistory(){c.length=0;},async waitForIdle(e=5e3){let s=Date.now(),i=async()=>{await new Promise(u=>setTimeout(u,0));let m=v.inspect();if(m.inflight.length>0){if(Date.now()-s>e){let u=m.inflight.map(f=>f.id).join(", ");throw new Error(`[Directive] waitForIdle timed out after ${e}ms. ${m.inflight.length} resolvers still inflight: ${u}`)}return await new Promise(u=>setTimeout(u,10)),i()}};return i()},assertRequirement(e){if(!a.some(i=>i.requirement.type===e))throw new Error(`[Directive] Expected requirement of type "${e}" but none found`)},assertResolverCalled(e,s){let i=n.get(e)??[];if(s!==void 0){if(i.length!==s)throw new Error(`[Directive] Expected resolver "${e}" to be called ${s} times but was called ${i.length} times`)}else if(i.length===0)throw new Error(`[Directive] Expected resolver "${e}" to be called but it was not`)},assertFactSet(e,s){let i=c.filter(m=>m.key===e);if(i.length===0)throw new Error(`[Directive] Expected fact "${e}" to be set but it was not`);if(s!==void 0&&!i.some(u=>u.newValue===s)){let u=i.map(f=>JSON.stringify(f.newValue)).join(", ");throw new Error(`[Directive] Expected fact "${e}" to be set to ${JSON.stringify(s)} but got: ${u}`)}},assertFactChanges(e,s){let i=c.filter(m=>m.key===e);if(i.length!==s)throw new Error(`[Directive] Expected fact "${e}" to change ${s} times but it changed ${i.length} times`)}}}function $(t,r,n){if(!b(t,r,n))throw new Error(`[Directive] Expected ${r} "${n}" to be dynamic, but it is not.`)}function P(t,r,n){if(b(t,r,n))throw new Error(`[Directive] Expected ${r} "${n}" to NOT be dynamic, but it is.`)}function b(t,r,n){switch(r){case "constraint":return t.constraints.isDynamic(n);case "resolver":return t.resolvers.isDynamic(n);case "derivation":return t.derive.isDynamic(n);case "effect":return t.effects.isDynamic(n)}}exports.assertDynamic=$;exports.assertNotDynamic=P;exports.createFakeTimers=T;exports.createMockResolver=k;exports.createTestSystem=C;exports.flushMicrotasks=S;exports.mockResolver=E;exports.settleWithFakeTimers=D;//# sourceMappingURL=testing.cjs.map
17
2
  //# sourceMappingURL=testing.cjs.map