stroid 0.1.4 → 0.1.5

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 (150) hide show
  1. package/CHANGELOG.md +148 -34
  2. package/README.md +124 -17
  3. package/dist/async-internal.d.ts +30 -0
  4. package/dist/async.d.ts +7 -12
  5. package/dist/async.js +1 -1
  6. package/dist/chunk-4C666HHU.js +2 -0
  7. package/dist/chunk-4D6OA3DD.js +2 -0
  8. package/dist/chunk-6IBJ7CIK.js +14 -0
  9. package/dist/chunk-BWNLQKTY.js +2 -0
  10. package/dist/chunk-E33L4MII.js +2 -0
  11. package/dist/chunk-FSNVSMAV.js +2 -0
  12. package/dist/chunk-GZQGU64H.js +2 -0
  13. package/dist/chunk-LWUT37FW.js +13 -0
  14. package/dist/chunk-NFT6AZXY.js +2 -0
  15. package/dist/chunk-PHE2BCFG.js +2 -0
  16. package/dist/chunk-SF6EP56S.js +2 -0
  17. package/dist/chunk-WE3ZR6OG.js +2 -0
  18. package/dist/chunk-WXJ3IREA.js +2 -0
  19. package/dist/chunk-X2MKRN7O.js +14 -0
  20. package/dist/chunk-Y54SMROI.js +2 -0
  21. package/dist/computed.d.ts +6 -5
  22. package/dist/computed.js +1 -1
  23. package/dist/core-internal.d.ts +23 -0
  24. package/dist/core.d.ts +3 -2
  25. package/dist/core.js +1 -1
  26. package/dist/devtools-internal.d.ts +26 -0
  27. package/dist/devtools.d.ts +4 -25
  28. package/dist/devtools.js +1 -1
  29. package/dist/feature.d.ts +9 -2
  30. package/dist/feature.js +1 -1
  31. package/dist/fetch-4RH6MPY3.js +2 -0
  32. package/dist/graph-D28.d.ts +20 -0
  33. package/dist/helpers.d.ts +2 -1
  34. package/dist/helpers.js +1 -1
  35. package/dist/index-internal.d.ts +19 -19
  36. package/dist/index.d.cts +40 -22
  37. package/dist/index.d.ts +40 -22
  38. package/dist/index.js +1 -1
  39. package/dist/install.d.ts +16 -4
  40. package/dist/install.js +1 -1
  41. package/dist/metrics.d.ts +13 -0
  42. package/dist/persist.d.ts +3 -1
  43. package/dist/persist.js +1 -1
  44. package/dist/psr.d.ts +7 -8
  45. package/dist/psr.js +1 -1
  46. package/dist/query.d.ts +17 -0
  47. package/dist/query.js +2 -0
  48. package/dist/react/index.d.ts +10 -3
  49. package/dist/react/index.js +5 -5
  50. package/dist/registry.d.ts +22 -14
  51. package/dist/runtime-admin.js +1 -1
  52. package/dist/runtime-tools.d.ts +38 -65
  53. package/dist/runtime-tools.js +1 -1
  54. package/dist/selectors.d.ts +1 -1
  55. package/dist/selectors.js +1 -1
  56. package/dist/server/portable.d.ts +27 -0
  57. package/dist/server/portable.js +2 -0
  58. package/dist/server.d.ts +9 -20
  59. package/dist/server.js +1 -1
  60. package/dist/shared.d.ts +36 -0
  61. package/dist/store-registry.d.ts +3 -1
  62. package/dist/sync.d.ts +10 -1
  63. package/dist/sync.js +1 -1
  64. package/dist/testing.d.ts +1 -0
  65. package/dist/testing.js +1 -1
  66. package/dist/tsdoc-metadata.json +11 -0
  67. package/dist/types-internal-2.d.ts +168 -0
  68. package/dist/{computed-types.d.ts → types-internal-3.d.ts} +1 -1
  69. package/dist/{options.d.ts → types-internal.d.ts} +25 -9
  70. package/dist/types.d.ts +12 -2
  71. package/package.json +80 -26
  72. package/dist/chunk-645IESIU.js +0 -2
  73. package/dist/chunk-6ELWGQ4Q.js +0 -2
  74. package/dist/chunk-BW32TJGE.js +0 -13
  75. package/dist/chunk-FOQKGHPS.js +0 -26
  76. package/dist/chunk-KQCSFGHJ.js +0 -2
  77. package/dist/chunk-M2NJVI36.js +0 -2
  78. package/dist/chunk-PVATWAY4.js +0 -2
  79. package/dist/chunk-X3JR32JD.js +0 -2
  80. package/dist/computed-types.js +0 -2
  81. package/dist/types/adapters/options.d.ts +0 -335
  82. package/dist/types/async/cache.d.ts +0 -40
  83. package/dist/types/async/clone.d.ts +0 -10
  84. package/dist/types/async/errors.d.ts +0 -3
  85. package/dist/types/async/fetch.d.ts +0 -37
  86. package/dist/types/async/inflight.d.ts +0 -30
  87. package/dist/types/async/rate.d.ts +0 -5
  88. package/dist/types/async/registry.d.ts +0 -117
  89. package/dist/types/async/request.d.ts +0 -11
  90. package/dist/types/async/retry.d.ts +0 -10
  91. package/dist/types/async.d.ts +0 -10
  92. package/dist/types/computed/computed-graph.d.ts +0 -33
  93. package/dist/types/computed/index.d.ts +0 -21
  94. package/dist/types/computed/types.d.ts +0 -40
  95. package/dist/types/config.d.ts +0 -10
  96. package/dist/types/core/index.d.ts +0 -11
  97. package/dist/types/core/lifecycle-hooks.d.ts +0 -16
  98. package/dist/types/core/runtime-patch.d.ts +0 -67
  99. package/dist/types/core/store-admin-impl.d.ts +0 -9
  100. package/dist/types/core/store-admin.d.ts +0 -9
  101. package/dist/types/core/store-core.d.ts +0 -13
  102. package/dist/types/core/store-create.d.ts +0 -16
  103. package/dist/types/core/store-hydrate-impl.d.ts +0 -35
  104. package/dist/types/core/store-hydrate.d.ts +0 -9
  105. package/dist/types/core/store-lifecycle/hooks.d.ts +0 -20
  106. package/dist/types/core/store-lifecycle/identity.d.ts +0 -23
  107. package/dist/types/core/store-lifecycle/registry.d.ts +0 -54
  108. package/dist/types/core/store-lifecycle/types.d.ts +0 -67
  109. package/dist/types/core/store-lifecycle/validation.d.ts +0 -53
  110. package/dist/types/core/store-name.d.ts +0 -28
  111. package/dist/types/core/store-notify.d.ts +0 -13
  112. package/dist/types/core/store-read.d.ts +0 -18
  113. package/dist/types/core/store-registry.d.ts +0 -115
  114. package/dist/types/core/store-replace-impl.d.ts +0 -11
  115. package/dist/types/core/store-replace.d.ts +0 -9
  116. package/dist/types/core/store-set-impl.d.ts +0 -13
  117. package/dist/types/core/store-set.d.ts +0 -9
  118. package/dist/types/core/store-shared/core.d.ts +0 -13
  119. package/dist/types/core/store-shared/notify.d.ts +0 -12
  120. package/dist/types/core/store-transaction.d.ts +0 -28
  121. package/dist/types/core/store-write-shared.d.ts +0 -25
  122. package/dist/types/core/store-write.d.ts +0 -13
  123. package/dist/types/features/feature-registry.d.ts +0 -91
  124. package/dist/types/features/lifecycle.d.ts +0 -40
  125. package/dist/types/index.d.ts +0 -17
  126. package/dist/types/integrations/query.d.ts +0 -8
  127. package/dist/types/internals/computed-order.d.ts +0 -3
  128. package/dist/types/internals/config.d.ts +0 -116
  129. package/dist/types/internals/diagnostics.d.ts +0 -21
  130. package/dist/types/internals/reporting.d.ts +0 -9
  131. package/dist/types/internals/store-admin.d.ts +0 -7
  132. package/dist/types/internals/store-ops.d.ts +0 -13
  133. package/dist/types/internals/test-reset.d.ts +0 -2
  134. package/dist/types/internals/write-context.d.ts +0 -20
  135. package/dist/types/notification/delivery.d.ts +0 -3
  136. package/dist/types/notification/index.d.ts +0 -10
  137. package/dist/types/notification/metrics.d.ts +0 -12
  138. package/dist/types/notification/priority.d.ts +0 -9
  139. package/dist/types/notification/scheduler.d.ts +0 -11
  140. package/dist/types/notification/snapshot.d.ts +0 -8
  141. package/dist/types/runtime-admin/index.d.ts +0 -2
  142. package/dist/types/runtime-tools/index.d.ts +0 -63
  143. package/dist/types/store.d.ts +0 -16
  144. package/dist/types/types/utility.d.ts +0 -17
  145. package/dist/types/utils/clone.d.ts +0 -4
  146. package/dist/types/utils/devfreeze.d.ts +0 -2
  147. package/dist/types/utils/hash.d.ts +0 -8
  148. package/dist/types/utils/path.d.ts +0 -5
  149. package/dist/types/utils/validation.d.ts +0 -14
  150. package/dist/types/utils.d.ts +0 -13
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-PHE2BCFG.js';var p=false,g=()=>{if(typeof window>"u")return null;let t=Reflect.get(window,"__REDUX_DEVTOOLS_EXTENSION__");return !t||typeof t!="object"||typeof t.connect!="function"?null:t},f=t=>{try{return typeof structuredClone=="function"?structuredClone(t):JSON.parse(JSON.stringify(t))}catch{return t}},S=({name:t,useDevtools:n,existingDevtools:e,stores:o,warn:r})=>{if(!n)return e;let s=g();if(!s)return r(`DevTools requested for "${t}" but Redux DevTools extension not found.`),e;if(e)return e;let i=s.connect({name:"stroid"});return i.init(o),i},d=({data:t,redactor:n,deepClone:e})=>{if(typeof n=="function")try{return n(e(t))}catch{return t}return t},R=(t,n)=>{if(typeof t!="object"||typeof n!="object"||t===null||n===null)return null;let e=t,o=n,r=[],s=[],i=[],l=new Set(Object.keys(e)),u=new Set(Object.keys(o));return u.forEach(a=>{l.has(a)?Object.is(e[a],o[a])||i.push(a):r.push(a);}),l.forEach(a=>{u.has(a)||s.push(a);}),{added:r,removed:s,changed:i}},y=({name:t,action:n,prev:e,next:o,history:r,historyLimit:s,applyRedactor:i,deepClone:l})=>{if(s===0)return;r[t]||(r[t]=[]);let u={ts:Date.now(),action:n,prev:l(i(e)),next:l(i(o)),diff:R(e,o)};r[t].push(u),r[t].length>s&&r[t].splice(0,r[t].length-s);},v=({name:t,action:n,force:e=false,devtools:o,enabled:r,stores:s,applyRedactor:i})=>{if(!(!o||!e&&!r))try{let l={...s,[t]:i(s[t])};o.send({type:`${t}/${n}`},l);}catch{}},D=()=>{let t=Object.create(null),n;return {onStoreCreate(e){n=S({name:e.name,useDevtools:!!e.options.devtools,existingDevtools:n,stores:e.getAllStores(),warn:e.warn}),y({name:e.name,action:"create",prev:null,next:e.getStoreValue(),history:t,historyLimit:e.options.historyLimit??50,applyRedactor:o=>d({data:o,redactor:e.options.redactor,deepClone:e.deepClone}),deepClone:e.deepClone});},onStoreWrite(e){y({name:e.name,action:e.action,prev:e.prev,next:e.next,history:t,historyLimit:e.options.historyLimit??50,applyRedactor:o=>d({data:o,redactor:e.options.redactor,deepClone:e.deepClone}),deepClone:e.deepClone}),v({name:e.name,action:e.action,devtools:n,enabled:!!e.options.devtools,stores:e.getAllStores(),applyRedactor:o=>d({data:o,redactor:e.options.redactor,deepClone:e.deepClone})});},afterStoreDelete(e){e.options.devtools&&v({name:e.name,action:"delete",force:true,devtools:n,enabled:true,stores:e.getAllStores(),applyRedactor:o=>d({data:o,redactor:e.options.redactor,deepClone:e.deepClone})}),delete t[e.name];},resetAll(){Object.keys(t).forEach(e=>{delete t[e];}),n=void 0;},api:{getHistory(e,o){if(!t[e])return [];let r=t[e];return o&&o>0?f(r.slice(-o)):f(r)},clearHistory(e){if(e){delete t[e];return}Object.keys(t).forEach(o=>{delete t[o];});}}}},C=()=>{p||(p=true,a("devtools",D));},m=()=>{C();};export{m as a};//# sourceMappingURL=chunk-NFT6AZXY.js.map
2
+ //# sourceMappingURL=chunk-NFT6AZXY.js.map
@@ -0,0 +1,2 @@
1
+ var t=new Map,o=null,a=(e,r)=>{t.set(e,r),o?.(e,r);},n=e=>t.has(e),s=e=>t.get(e),u=()=>Array.from(t.keys()),i=e=>{o=e;};export{a,n as b,s as c,u as d,i as e};//# sourceMappingURL=chunk-PHE2BCFG.js.map
2
+ //# sourceMappingURL=chunk-PHE2BCFG.js.map
@@ -0,0 +1,2 @@
1
+ import {e}from'./chunk-LWUT37FW.js';import {x}from'./chunk-E33L4MII.js';import {F,d,h,j as j$1,i as i$1,g as g$1,k as k$1}from'./chunk-X2MKRN7O.js';import {n,V as V$1,o,p,q as q$1,r,I,z as z$1,v,A,S}from'./chunk-6IBJ7CIK.js';var i=()=>I(z$1(v)),a=t=>{let e=i();return A(e,t)?true:(S(t,Object.keys(e.stores)),false)},Q=(t,e)=>{if(!e)return true;if(e.endsWith("*")){let r=e.slice(0,-1);return t.startsWith(r)}return t===e},c=t=>{let e=i();return Object.keys(e.stores).filter(r=>Q(r,t))},g=t=>{if(!a(t))return null;let e=i().metaEntries[t];return n(e)},B=()=>V$1(i().initialStates),y=t=>{let e=i().metaEntries[t];return e?.metrics?n(e.metrics):null},j=t=>a(t)?F[t]?.size??0:0,f=(t={})=>{let e=t.unreadThresholdMs??6e4,r=Date.now();return n(c().map(n=>{let o=i().metaEntries[n],h=o?.createdAt?new Date(o.createdAt).getTime():r,C=o?.lastReadAtMs??null,O=Math.max(0,r-h),u;return (o?.readCount??0)===0&&(o?.updateCount??0)===0?u="cold":(o?.readCount??0)===0?u="write-only":C&&r-C>e?u="stale":u="active",{name:n,createdAt:o?.createdAt??new Date(h).toISOString(),lastReadAt:o?.lastReadAt??null,updateCount:o?.updateCount??0,readCount:o?.readCount??0,subscriberCount:j(n),ageMs:O,verdict:u}}).filter(n=>n.verdict==="cold"||n.verdict==="stale"||t.includeWriteOnly&&n.verdict==="write-only"))};var k=t=>a(t)?x(t):0,N=t=>{if(!a(t))return 0;let e=d("persist");return e?.getPersistQueueDepth?e.getPersistQueueDepth(t)??0:0},P=t=>{if(t){if(!a(t))return null;let r=g(t);return {name:t,meta:r,metrics:y(t),async:{inflight:k(t),lastCorrelationId:r?.lastCorrelationId??null,traceContext:r?.lastTraceContext??null},persist:{queueDepth:N(t)}}}let e$1=c().map(r=>P(r));return {stores:e$1,async:e(),registry:{totalStores:e$1.length,coldStores:f({})}}};var V=()=>h(),z=()=>j$1(),_=t=>i$1(t),J=t=>g$1(t),K=(t,e)=>k$1(t,e);var m=()=>I(z$1(v)),q=t=>n({store:t.store,authority:t.authority,policy:t.policy,hydratedAt:t.hydratedAt,hydratedAtMs:t.hydratedAtMs,firstDivergedAt:t.firstDivergedAt,firstDivergedAtMs:t.firstDivergedAtMs,lastDivergedAt:t.lastDivergedAt,lastDivergedAtMs:t.lastDivergedAtMs,lastResolution:t.lastResolution,lastSource:t.lastSource,driftCount:t.driftCount,queuedWrites:t.queuedWrites,replayedWrites:t.replayedWrites,invalidatedAt:t.invalidatedAt,invalidatedAtMs:t.invalidatedAtMs,baselineHash:t.baselineHash,currentHash:t.currentHash,baseline:t.baseline,...t.snapshotVersion!==void 0?{snapshotVersion:t.snapshotVersion}:{},...t.timestamp!==void 0?{timestamp:t.timestamp}:{},...t.checksum!==void 0?{checksum:t.checksum}:{},...t.schemaSignature!==void 0?{schemaSignature:t.schemaSignature}:{}}),L=t=>{if(typeof t=="string"){let e=o(m(),t);return e?q(e):null}return p(m()).map(q)},U=t=>n(q$1(m(),t)),X=()=>n(r(m()));export{c as a,g as b,B as c,y as d,j as e,f,k as g,N as h,P as i,V as j,z as k,_ as l,J as m,K as n,L as o,U as p,X as q};//# sourceMappingURL=chunk-SF6EP56S.js.map
2
+ //# sourceMappingURL=chunk-SF6EP56S.js.map
@@ -0,0 +1,2 @@
1
+ import {V,X}from'./chunk-6IBJ7CIK.js';var f=t=>{if(!t||typeof t!="object"||Array.isArray(t))return false;let e=Object.getPrototypeOf(t);return e===Object.prototype||e===null},r=(t,e=new WeakMap)=>{if(t===null||typeof t!="object")return t;if(e.has(t))return e.get(t);if(t instanceof Date)return new Date(t.getTime());if(t instanceof Map){let a=new Map;return e.set(t,a),t.forEach((n,p)=>{a.set(r(p,e),r(n,e));}),a}if(t instanceof Set){let a=new Set;return e.set(t,a),t.forEach(n=>{a.add(r(n,e));}),a}if(Array.isArray(t)){let a=[];return e.set(t,a),t.forEach((n,p)=>{a[p]=r(n,e);}),a}if(!f(t))return t;let o={};return e.set(t,o),Object.entries(t).forEach(([a,n])=>{o[a]=r(n,e);}),o},S=t=>t?r(t):void 0,c=t=>{if(!t)return;let e=t,o={};return e.scope&&e.scope!=="request"&&(o.scope=e.scope),e.lazy===true&&(o.lazy=true),e.pathCreate===true&&(o.pathCreate=true),e.validate&&(o.validate=e.validate),e.onError&&(o.onError=e.onError),e.onCreate&&(o.onCreate=e.onCreate),e.onSet&&(o.onSet=e.onSet),e.onReset&&(o.onReset=e.onReset),e.onDelete&&(o.onDelete=e.onDelete),Array.isArray(e.middleware)&&e.middleware.length>0&&(o.middleware=[...e.middleware]),e.features&&(o.features=r(e.features)),e.snapshot&&e.snapshot!=="deep"&&(o.snapshot=e.snapshot),e.snapshotSafety!==void 0&&(o.snapshotSafety=e.snapshotSafety),e.explicitPersist&&e.persist&&(o.persist=r({...e.persist,version:e.version,migrations:e.migrations})),e.explicitSync&&e.sync!==false&&e.sync!==void 0&&(o.sync=r(e.sync)),e.explicitDevtools&&(e.historyLimit!==void 0&&(o.historyLimit=e.historyLimit),e.redactor&&(o.redactor=e.redactor),o.devtools=e.devtools!==false),Object.keys(o).length>0?S(o):void 0},l=t=>{let e=Object.create(null);return Object.entries(t.options).forEach(([o,a])=>{let n=S(a);n!==void 0&&(e[o]=n);}),{snapshot:V(t.snapshot),options:e}},M=(t,e=null)=>{let o={},a=Object.create(null);return Object.keys(t.metaEntries).forEach(n=>{let p=e&&Object.prototype.hasOwnProperty.call(e,n)?e[n]:t.stores[n];o[n]=V(p);let i=c(t.metaEntries[n]?.options);i!==void 0&&(a[n]=i);}),{snapshot:o,options:a}},R=t=>{let e=o=>Object.prototype.hasOwnProperty.call(t.buffer,o);return {create:(o,a,n={})=>(t.buffer[o]=V(a),t.bufferedOptions[o]=S(n)??{},t.buffer[o]),set:(o,a)=>{if(!e(o))throw new Error(`createStoreForRequest.set("${o}") requires create("${o}", initialState) first.`);return t.buffer[o]=typeof a=="function"?X(t.buffer[o],a):V(a),t.buffer[o]},get:o=>e(o)?V(t.buffer[o]):void 0,snapshot:()=>V(t.buffer)}};export{S as a,l as b,M as c,R as d};//# sourceMappingURL=chunk-WE3ZR6OG.js.map
2
+ //# sourceMappingURL=chunk-WE3ZR6OG.js.map
@@ -0,0 +1,2 @@
1
+ import {u}from'./chunk-E33L4MII.js';import {N,Z,e,H}from'./chunk-X2MKRN7O.js';var p=()=>{if(N()){Z();return}Z(),u(),e();},S=i=>{H().clearStores(i),e();};export{p as a,S as b};//# sourceMappingURL=chunk-WXJ3IREA.js.map
2
+ //# sourceMappingURL=chunk-WXJ3IREA.js.map
@@ -0,0 +1,14 @@
1
+ import {a,z,v,I as I$1,u,C,P,x,A,F,m,j,M,O,J,aa,Q as Q$1,V,R as R$1,H,e as e$1,f,Y as Y$1,Z,$,W as W$1,_ as _$1,d as d$1,b,L as L$1,l,T,k,D as D$1,i,N,s,S,U as U$1,B,ba,h,t}from'./chunk-6IBJ7CIK.js';import {e,d,c,b as b$1}from'./chunk-PHE2BCFG.js';var Ne=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),be=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),wt=e=>{try{let t=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`,r=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`;return e(t)!==t?!1:e(r)===r}catch{return false}},bn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",rr=e=>{try{Reflect.set(e,bn,!0);}catch{}return e},Ct=(()=>{let e=new Map;return {getItem:t=>e.has(t)?e.get(t):null,setItem:(t,r)=>{e.set(t,r);},removeItem:t=>{e.delete(t);},type:"memory"}})(),Rt=e=>{try{return typeof window>"u"?Ct:e==="session"||e==="sessionStorage"?window.sessionStorage??Ct:window.localStorage??Ct}catch{return Ct}};var or=new Set,Xr=()=>{or.clear();};a("options.legacy-warnings",Xr,30);var Cn={allowSSRGlobalStore:'scope: "global"',schema:"validate",validator:"validate",version:"persist.version",migrations:"persist.migrations",historyLimit:"devtools.historyLimit",redactor:"devtools.redactor",middleware:"lifecycle.middleware",onCreate:"lifecycle.onCreate",onSet:"lifecycle.onSet",onReset:"lifecycle.onReset",onDelete:"lifecycle.onDelete"},nr=e=>{if(!Ne(e))return [];let t=[];return Object.entries(Cn).forEach(([r,o])=>{be(e,r)&&(or.has(r)||(or.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t};var sr=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:rr(m=>m),decrypt:rr(m=>m),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Rt("localStorage"),...r};if(typeof e=="string")return {driver:Rt(e),...r};let o=e.encrypt||r.encrypt,s=e.decrypt||r.decrypt,n=e.encryptAsync,i=e.decryptAsync,a=e.sensitiveData===true,d=e.allowPlaintext===true,p=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,u=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(n&&!i||!n&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(a&&wt(o)&&!n)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`);return {driver:e.driver||e.storage||Rt("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:o,decrypt:s,encryptAsync:n,decryptAsync:i,allowPlaintext:d,sensitiveData:a,maxSize:p,checksum:u,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}};var ir=(e={},t,r="deep",o="deep")=>{let s=e.scope??"request",n=e.lazy===true,i=e.pathCreate===true,a=Ne(e.lifecycle)?e.lifecycle:void 0,d=Ne(e.persist)?e.persist:void 0,p=Ne(e.devtools)?e.devtools:void 0,u=e.validate??e.validator??e.schema,m=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",c=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,l=e.resetClone==="none"||e.resetClone==="shallow"||e.resetClone==="deep"?e.resetClone:o,S=Ne(e.features)?{...e.features}:void 0,V=be(e,"persist"),h=be(e,"sync"),T=be(e,"devtools")||be(e,"historyLimit")||be(e,"redactor"),f=s==="global"?true:e.allowSSRGlobalStore??false,{persist:w=false,devtools:v=false,onError:O,sync:b}=e;if(d?.sensitiveData===true){let g=d.encrypt,P=d.encryptAsync;if((!g||wt(g))&&!P)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:s,lazy:n,pathCreate:i,persist:s==="temp"&&!V?null:sr(w,t),devtools:s==="temp"&&!T?false:typeof v=="boolean"?v:p?.enabled??true,middleware:a?.middleware??e.middleware??[],onSet:a?.onSet??e.onSet,onReset:a?.onReset??e.onReset,onDelete:a?.onDelete??e.onDelete,onCreate:a?.onCreate??e.onCreate,onError:O,validate:u,migrations:d?.migrations??e.migrations??{},version:d?.version??e.version??1,redactor:s==="temp"&&!T?void 0:p?.redactor??e.redactor,historyLimit:s==="temp"&&!T?0:p?.historyLimit??e.historyLimit??50,sync:s==="temp"&&!h?false:b??false,features:S,allowSSRGlobalStore:f,snapshot:m,resetClone:l,snapshotSafety:c,explicitPersist:V,explicitSync:h,explicitDevtools:T}};var _e=Symbol("stroid.middleware.abort"),Zr=new WeakSet,eo=({name:e,payload:t,middlewares:r,reportIssue:o,warn:s})=>{if(!Array.isArray(r)||r.length===0)return t.next;let n=V(t.next);for(let i of r){if(typeof i!="function")continue;let a,d=n;try{a=i({action:t.action,name:e,prev:t.prev,next:d,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(p){let u=`Middleware for "${e}" failed: ${p?.message??p}`;return o(u,"dev"),_e}if(a&&typeof a.then=="function"){let p=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(p,"dev"),_e}a===void 0?(M()&&!Zr.has(i)&&(Zr.add(i),s(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),n=d):n=a;}return n},kt=({name:e,label:t,fn:r,args:o,reportIssue:s})=>{if(typeof r=="function")try{r(...o);}catch(n){let i=`${t} for "${e}" failed: ${n?.message??n}`;s(i,"always");}};var Mt=new Set,ro=e=>e?Mt.has(e):Mt.size>0,oo=e=>{e&&Mt.add(e);},wn=()=>{Mt.clear();};a("ssr.warnings",wn,60);var to=new Set,Rn=e=>{let t=L$1();return !t||e.includes("::")?e:(M()&&!to.has(e)&&(to.add(e),O(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},pe=e=>Rn(typeof e=="string"?e:e.name),Oe=e=>G(e)&&!Pt(e)?true:(S(e,Object.keys(io)),false),no=(e,t,r={})=>{ba(t,{...r,onError:I[e]?.options?.onError});},so=(e,t,r={})=>{ba(e,{...r,onError:t});},U=(e,t,r="dev")=>{no(e,t,{severity:"warn",visibility:r});},kn=(e,t,r="dev")=>{so(e,t,{severity:"warn",visibility:r});},fe=(e,t)=>no(e,t,{severity:"critical",visibility:"always"}),ot=(e,t)=>so(e,t,{severity:"critical",visibility:"always"}),Tt=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
2
+ Import "stroid/${t}" before calling createStore("${e}", ...).`;if(kn(o,r,"always"),J().strictMissingFeatures)throw new Error(o)},Mn=e=>Q.get(e)?.api;var nt=0,Tn=(e,t)=>(nt>=Number.MAX_SAFE_INTEGER&&(nt=0),nt+=1,`${e}:${t}:${nt}`),Pn=e=>{let t=[e?.correlationId,e?.traceContext?.traceId,e?.traceContext?.spanId].filter(r=>typeof r=="string"&&r.length>0);return t.length>0?t:void 0},ao=e=>({...e,path:[...e.path],meta:{...e.meta,causedBy:e.meta.causedBy?[...e.meta.causedBy]:void 0}}),Fn=e=>{if(!e)return [];if(Array.isArray(e)){let t=true;for(let o=0;o<e.length;o+=1){let s=e[o];if(typeof s!="string"&&typeof s!="number"){t=false;break}}if(t)return e;let r=new Array(e.length);for(let o=0;o<e.length;o+=1){let s=e[o];r[o]=typeof s=="number"?s:String(s);}return r}return Y$1(e)},ar=e=>{let t=e.timestamp??Date.now(),r={id:Tn(e.source,t),store:e.store,path:Fn(e.path),op:e.op,meta:{timestamp:t,source:e.source}};e.value!==void 0&&(r.value=e.value);let o=Pn(e.context);return o&&(r.meta.causedBy=o),e.isUnsafe===true&&(r.meta.isUnsafe=true),e.asyncBoundary===true&&(r.meta.asyncBoundary=true),r},se=e=>ar({store:e.store,op:"set",path:[],value:e.value,source:e.source,context:e.context}),co=e=>e.intent.kind==="root"||!e.preserveIntent?[se({store:e.store,value:e.committedValue,source:"setStore",context:e.context})]:e.intent.kind==="merge"?[ar({store:e.store,op:"merge",path:[],value:e.intent.value,source:"setStore",context:e.context})]:[ar({store:e.store,op:"set",path:e.intent.path,value:e.intent.value,source:"setStore",context:e.context})],De=(e,t=R())=>{t.lastRuntimePatches=e.map(ao);},uo=(e=R())=>e.lastRuntimePatches.map(ao);a("runtime-patch.sequence",()=>{nt=0;},126);var te=null,ei=e=>{if(!e){te=null;return}if(te&&te!==e){P("injectTransactionRunner(...) was called more than once. The existing runner will be kept to avoid cross-request transaction leaks. If you need to replace it in tests, call injectTransactionRunner(null) first.");return}te=e;},Vn=()=>{te=null;};a("transaction.runner",Vn,120);var Ce=e=>{let t=te?.get();return t||(e??I$1()).transaction},po=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted"),En=e=>({notifyCount:e.notifyCount,totalNotifyMs:e.totalNotifyMs,lastNotifyMs:e.lastNotifyMs,resetCount:e.resetCount,totalResetMs:e.totalResetMs,lastResetMs:e.lastResetMs}),Nn=e=>({updatedAt:e.updatedAt,updatedAtMs:e.updatedAtMs,updateCount:e.updateCount,lastCorrelationId:e.lastCorrelationId,lastCorrelationAt:e.lastCorrelationAt,lastCorrelationAtMs:e.lastCorrelationAtMs,lastTraceContext:e.lastTraceContext,metrics:En(e.metrics)}),On=e=>{let t=new Map;Object.keys(e.stores).forEach(o=>{t.set(o,_(o,e));});let r=new Map;return Object.entries(e.metaEntries).forEach(([o,s])=>{r.set(o,Nn(s));}),{stores:t,meta:r,pendingNotifications:[...e.notify.pendingNotifications],lastRuntimePatches:uo(e)}},lo=(e,t)=>{let r=new Set(Object.keys(e.stores));t.stores.forEach((o,s)=>{Y(s,o,e),r.delete(s);}),r.forEach(o=>{delete e.stores[o];}),t.meta.forEach((o,s)=>{let n=e.metaEntries[s];n&&(n.updatedAt=o.updatedAt,n.updatedAtMs=o.updatedAtMs,n.updateCount=o.updateCount,n.lastCorrelationId=o.lastCorrelationId,n.lastCorrelationAt=o.lastCorrelationAt,n.lastCorrelationAtMs=o.lastCorrelationAtMs,n.lastTraceContext=o.lastTraceContext,n.metrics.notifyCount=o.metrics.notifyCount,n.metrics.totalNotifyMs=o.metrics.totalNotifyMs,n.metrics.lastNotifyMs=o.metrics.lastNotifyMs,n.metrics.resetCount=o.metrics.resetCount,n.metrics.totalResetMs=o.metrics.totalResetMs,n.metrics.lastResetMs=o.metrics.lastResetMs);}),e.notify.pendingNotifications.clear(),t.pendingNotifications.forEach(o=>{e.notify.pendingNotifications.add(o);}),De(t.lastRuntimePatches,e);},fo=e=>{let t=e??I$1(),r=te?.get();return !r&&te?.enterWith&&(r=x(),te.enterWith(r)),r||(r=Ce(t)),r.depth+=1,r.depth===1&&(r.pending=[],r.stagedValues.clear(),r.snapshotCache.clear(),r.runtimePatches.length=0,r.failed=false,r.error=void 0),t},D=()=>te?(te.get()?.depth??0)>0:Ce().depth>0,q=(e,t)=>{let r=Ce(t);r.failed=true,r.error||(r.error=po(e));},Ft=e=>{let t=I$1();Ce(t).pending.push(()=>H(t,e));},Vt=(e,t)=>{let r=Ce();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},mo=e=>{if(e.length===0)return;Ce().runtimePatches.push(...e);},ie=e=>{let t=Ce();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}},So=(e,t)=>{let r=Ce(t),o=t??I$1();if(r.depth===0||(e&&q(e,t),r.depth=Math.max(0,r.depth-1),r.depth>0))return null;let s=r.failed?r.error??new Error("setStoreBatch aborted"):null;if(!s){let n=On(o);for(let i of r.pending)try{if(i(),r.failed){s=r.error??new Error("setStoreBatch aborted"),lo(o,n);break}}catch(a){q(a,t),s||(s=r.error??po(a)),lo(o,n);break}!s&&r.failed&&(s=r.error??new Error("setStoreBatch aborted"));}return !s&&r.runtimePatches.length>0&&De(r.runtimePatches,o),r.pending=[],r.stagedValues.clear(),r.snapshotCache.clear(),r.runtimePatches.length=0,r.failed=false,r.error=void 0,s};var go=new WeakMap,yo=new WeakMap,Dn=500,An="",st=e=>{let t=go.get(e);return t||(t=new Map,go.set(e,t)),t},cr=e=>{let t=yo.get(e);return t||(t=new Map,yo.set(e,t)),t},$n=(e,t)=>{let r=cr(e),o=r.get(t);return o||(o=new Map,r.set(t,o)),o},In=()=>{let e=J().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?Dn:Math.max(0,Math.floor(e))},ho=(e,t,r,o)=>{if(o<=0){e.has(t)&&e.delete(t);return}for(e.has(t)&&e.delete(t),e.set(t,r);e.size>o;){let s=e.keys().next().value;if(!s)break;let n=e.get(s);e.delete(s),n?.node.verdicts&&(n.node.verdicts.delete(n.type),n.node.verdicts.size===0&&delete n.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=st(R());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let o=Reflect.get(r,t);return typeof o=="function"?o.bind(r):o},set:(e,t,r)=>Reflect.set(st(R()),t,r)});var xo=(e,t,r,o)=>{let s=I[e];if(!s)return {ok:true};let n=Y$1(r);if(n.length===0)return {ok:true};let i$1=i(o),a=In(),d=R(),p=st(d),u=$n(d,e),m=n.join(An),c=p.get(e);c||(c={children:new Map},p.set(e,c));let l=c;for(let w of n){let v=l.children.get(w);v||(v={children:new Map},l.children.set(w,v)),l=v;}let S=l.verdicts?.get(i$1);if(S){let w=`${m}|${i$1}`;return ho(u,w,{node:l,type:i$1},a),S}let V=s.options?.pathCreate===true,h=t,T={ok:true};for(let w=0;w<n.length;w++){let v=n[w],O=w===n.length-1;if(h==null){let g=`Path "${n.join(".")}" is invalid for "${e}" - "${n.slice(0,w).join(".")||"root"}" is ${h===null?"null":"undefined"}.`;N(g),T={ok:false,reason:g};break}if(typeof h!="object"){let g=`Path "${n.join(".")}" is invalid for "${e}" - "${n.slice(0,w).join(".")||"root"}" is not an object.`;N(g),T={ok:false,reason:g};break}if(Array.isArray(h)){let g=Number(v);if(!Number.isInteger(g)||g<0){let k=`Path "${n.join(".")}" targets non-numeric index "${v}" on an array in "${e}".`;N(k),T={ok:false,reason:k};break}let P=h;if(g>=P.length){let k=`Path "${n.join(".")}" is invalid for "${e}" - index ${g} is out of bounds (length ${P.length}).`;N(k),T={ok:false,reason:k};break}if(O){let k=P[g];if(k!=null){let M=i(k);if(M!==i$1){let H=`Type mismatch setting "${n.join(".")}" on "${e}": expected ${M}, received ${i$1}.`;N(H),T={ok:false,reason:H};break}}T={ok:true};break}h=P[g];continue}if(!Object.prototype.hasOwnProperty.call(h,v)){if(V&&O){T={ok:true};break}let g=`Path "${n.join(".")}" is invalid for "${e}" - unknown key "${v}" at "${n.slice(0,w).join(".")||"root"}".`;N(g),T={ok:false,reason:g};break}if(O){let g=h[v];if(g!=null){let P=i(g);if(P!==i$1){let k=`Type mismatch setting "${n.join(".")}" on "${e}": expected ${P}, received ${i$1}.`;N(k),T={ok:false,reason:k};break}}T={ok:true};break}h=h[v];}l.verdicts||(l.verdicts=new Map);let f=l.verdicts.has(i$1);if(l.verdicts.set(i$1,T),!f){let w=`${m}|${i$1}`;ho(u,w,{node:l,type:i$1},a);}return T},me=(e,t,r,o)=>{try{return o?.reuseInput&&k(t)?{ok:!0,value:t}:{ok:!0,value:l(t)}}catch(s){let n=`Sanitize failed for "${e}": ${s?.message??s}`;return aa(I[e]?.options?.onError,`onError(${e})`,n),aa(r,`onError(${e})`,n),O(n),{ok:false}}},jn=(e,t)=>{let r=new Set,o=I[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},ur=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let s=jn(e,o),n=(a,d)=>{s.forEach(p=>aa(p,`onError(${e})`,a)),d==="critical"?N(a):O(a);};if(typeof r=="function")try{let a=r(t);return a===!1?(n(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:a===!0?t:a}}catch(a){return n(`Validation for "${e}" failed: ${a?.message??a}`,"critical"),{ok:false}}let i=h(r,t);return i.ok?{ok:true,value:i.data??t}:(n(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Se=(e,t,r,o,s)=>{let n=me(e,t,o,s);if(!n.ok)return {ok:false};let i=ur(e,n.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},re=e=>{let t=R();st(t).delete(e),cr(t).delete(e);},zn=()=>{let e=R();st(e).clear(),cr(e).clear();};a("validation.path-cache",zn,50);vo(re);var Ae=(e,t=R())=>{if((D()?ie(e):{has:false}).has||t.stores[e]!==void 0)return true;let o=t.initialFactories[e];if(!o)return true;try{let s=o(),n=me(e,s,t.metaEntries[e]?.options?.onError);if(!n.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=Se(e,n.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(D()){let d=a.value;Vt(e,d),Ft(()=>{Y(e,d,t),t.initialStates[e]=V(d),delete t.initialFactories[e],re(e);});}else Y(e,a.value,t),t.initialStates[e]=V(a.value),delete t.initialFactories[e],re(e);return !0}catch(s){return fe(e,`Lazy initializer for "${e}" failed: ${s?.message??s}`),false}};var bo=new WeakMap,lr=e=>{let t=bo.get(e);return t||(t=new Map,bo.set(e,t)),t},Hn=()=>{lr(R()).clear();};a("features.contexts",Hn,100);var wo=(e,t=R())=>{lr(t).delete(e);};var Et=(e,t)=>t?e==="persist"?!!t.persist:e==="sync"?!!t.sync:true:e!=="persist"&&e!=="sync",Co=new WeakMap,dr=(e,t,r)=>{let o=Co.get(e);if(o&&o.notifyFn===r){e.notify=o.bound;return}let s=()=>r(t);Co.set(e,{notifyFn:r,bound:s}),e.notify=s;},pr=e=>{let t=R(),r=lr(t),o=I[e];if(!o)return O(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s=r.get(e);if(s&&s.options===o.options)return s;s&&r.delete(e);let n=()=>Object.fromEntries(Object.keys(t.metaEntries).map(a=>[a,_(a,t)])),i={name:e,options:o.options,getMeta:()=>I[e],getStoreValue:()=>_(e,t),getAllStores:n,getInitialState:()=>To[e],hasStore:()=>G(e),setStoreValue:a=>{Y(e,a);},applyFeatureState:(a,d,p)=>{let u=gr(e,a,d,p);return re(e),u},notify:()=>{},reportStoreError:a=>{fe(e,a);},warn:O,warnAlways:P,log:R$1,hashState:T,deepClone:V,sanitize:l,validate:a=>ur(e,a,I[e]?.options?.validate),isDev:M};return r.set(e,i),i},fr=(e,t)=>{let r=J();if(!r.strictMissingFeatures&&!r.assertRuntime)return;let o=[];if(typeof t.getMeta!="function"&&o.push("getMeta"),typeof t.getStoreValue!="function"&&o.push("getStoreValue"),typeof t.getAllStores!="function"&&o.push("getAllStores"),typeof t.getInitialState!="function"&&o.push("getInitialState"),typeof t.hasStore!="function"&&o.push("hasStore"),typeof t.setStoreValue!="function"&&o.push("setStoreValue"),typeof t.applyFeatureState!="function"&&o.push("applyFeatureState"),typeof t.notify!="function"&&o.push("notify"),typeof t.reportStoreError!="function"&&o.push("reportStoreError"),typeof t.warn!="function"&&o.push("warn"),typeof t.warnAlways!="function"&&o.push("warnAlways"),typeof t.log!="function"&&o.push("log"),typeof t.hashState!="function"&&o.push("hashState"),typeof t.deepClone!="function"&&o.push("deepClone"),typeof t.sanitize!="function"&&o.push("sanitize"),typeof t.validate!="function"&&o.push("validate"),typeof t.isDev!="function"&&o.push("isDev"),o.length===0)return;let s=`Feature hook context missing fields for "${e}": ${o.join(", ")}.`;if(fe(e,s),r.assertRuntime)throw new Error(s)},mr=()=>d().length>0,Sr=(e,t,r)=>{let o=I[e]?.options;if(!o)return false;let s=Q;for(let[n,i]of s)if(!r?.has(n)&&Et(n,o)&&(t==="onStoreCreate"&&i.onStoreCreate||t==="onStoreWrite"&&i.onStoreWrite||t==="beforeStoreDelete"&&i.beforeStoreDelete||t==="afterStoreDelete"&&i.afterStoreDelete))return true;return false},Ro=(e,t)=>{if(!mr()||(it(),!Sr(e,"onStoreCreate")))return;let r=pr(e);r&&(dr(r,e,t),fr(e,r),Q.forEach((o,s)=>{if(Et(s,r.options))try{o.onStoreCreate?.(r);}catch(n){U(e,`Feature "${String(s)}" onStoreCreate for "${e}" failed: ${n?.message??n}`,"always");}}));},ko=(e,t,r,o,s)=>{if(!mr()||(it(),!Sr(e,"onStoreWrite")))return;let n=pr(e);if(!n)return;let i=null;Q.forEach((a,d)=>{let p=a.onStoreWrite;if(p&&Et(d,n.options)){i||(dr(n,e,s),i=Object.create(n),i.action=t,i.prev=r,i.next=o,fr(e,i));try{p(i);}catch(u){U(e,`Feature "${String(d)}" onStoreWrite for "${e}" failed: ${u?.message??u}`,"always");}}});},ki=(e,t,r,o,s,n)=>{if(!mr())return;it();let i=new Set(n);if(!Sr(e,"onStoreWrite",i))return;let a=pr(e);if(!a)return;let d=null;Q.forEach((p,u)=>{let m=p.onStoreWrite;if(m&&!i.has(u)&&Et(u,a.options)){d||(dr(a,e,s),d=Object.create(a),d.action=t,d.prev=r,d.next=o,fr(e,d));try{m(d);}catch(c){U(e,`Feature "${String(u)}" onStoreWrite for "${e}" failed: ${c?.message??c}`,"always");}}});};var Nt=(e,t)=>{let r=I[e]?.options?.middleware,o=J().middleware,s=!!r&&r.length>0,n=!!o&&o.length>0;if(!s&&!n)return t.next;let i=s?n?[...r,...o]:r:o;return eo({name:e,payload:t,middlewares:i,reportIssue:(a,d)=>{U(e,a,d);},warn:O})},Ot=(e,t,r,o)=>kt({name:e,label:t,fn:r,args:o,reportIssue:(s,n)=>{U(e,s,n);}}),Mo=(e,t)=>{let r={...t};return r.persist&&!b$1("persist")&&(r.explicitPersist&&Tt(e,"persist",r.onError),r.persist=null),r.sync&&!b$1("sync")&&(r.explicitSync&&Tt(e,"sync",r.onError),r.sync=false),b$1("devtools")||(r.explicitDevtools&&Tt(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var Dt=null,Po=e=>{Dt=e;},Fo=e=>Dt?Dt(e):[];a("computed.order-resolver",()=>{Dt=null;},105);var No=()=>I$1(z(v)),Wn="opaque",$t=0,yr=-1,At=new Map,L=()=>No().computedEntries,at=()=>No().computedDependents,Do=()=>{$t+=1;},_n=()=>{$t=0,yr=-1,At.clear();};a("computed.topo-cache",_n,104);var Ln=(e,t)=>{let r=L(),o=new Set,s=[],n=i=>{if(i===e)return true;if(o.has(i))return false;o.add(i),s.push(i);let a=r[i]?.deps??[];for(let d of a)if(n(d))return true;return s.pop(),false};for(let i of t)if(s.length=0,n(i))return [e,...s,e].join(" -> ");return null},Ao=(e,t)=>{let r=at();for(let o of t){let s=r[o];s&&(s.delete(e),s.size===0&&delete r[o]);}},$o=(e,t,r,o=Wn)=>{let s=Ln(e,t);if(s)return Q$1(`[stroid] createComputed("${e}") rejected: circular dependency detected -> ${s}
3
+ Define relationships without cycles.`),false;let n=L(),i=at();n[e]&&Ao(e,n[e].deps),n[e]={deps:t,compute:r,stale:true,classification:o,hasLastOutput:false,lastOutput:void 0};for(let a of t)i[a]||(i[a]=new Set),i[a].add(e);return Do(),true},hr=e=>{let t=L(),r=t[e];r&&(Ao(e,r.deps),delete t[e],Do());},xr=e=>{let t=L();t[e]&&(t[e].stale=true);},It=e=>Object.prototype.hasOwnProperty.call(L(),e),jt=e=>L()[e],vr=e=>e==="asyncBoundary"?"async-boundary":"computed",Io=(e,t,r=[])=>JSON.stringify([e,t,[...r]]),Bn=e=>e==="leaf"||e==="computed"||e==="async-boundary",qn=e=>{try{let t=JSON.parse(e);if(!Array.isArray(t)||t.length!==3)return null;let[r,o,s]=t;return !Bn(r)||typeof o!="string"||!Array.isArray(s)||s.some(n=>typeof n!="string"&&typeof n!="number")?null:{type:r,storeId:o,path:[...s]}}catch{return null}},Vo=(e,t)=>({id:Io(e,t),storeId:t,path:[],type:e}),jo=e=>{let t=L()[e];return Vo(t?vr(t.classification):"leaf",e)},zo=e=>{let t=L();if(t[e])return e;let r=qn(e);if(!r||r.path.length!==0||r.type!=="computed"&&r.type!=="async-boundary")return null;let o=t[r.storeId];return o&&vr(o.classification)===r.type?r.storeId:null},Ho=(e,t)=>{let r=vr(t.classification);return {id:Io(r,e),storeId:e,path:[],dependencies:t.deps.map(o=>jo(o).id),nodeType:r,classification:t.classification,...t.classification==="asyncBoundary"?{asyncBoundary:true}:{}}},Un=e=>{let t=zo(e);if(!t)return null;let r=L()[t];return r?Ho(t,r):null},Gn=e=>{let t=L(),r=at(),o=new Set,s=[...e];for(;s.length>0;){let u=s.shift(),m=r[u];if(m)for(let c of m)o.has(c)||(o.add(c),s.push(c));}if(o.size===0)return [];let n=u=>{let m=t[u];if(m)for(let c of m.deps)t[c]&&(o.has(c)||(o.add(c),n(c)));};Array.from(o).forEach(u=>n(u));let i=new Map,a=new Map;for(let u of o){let m=t[u];if(!m)continue;let c=0;for(let l of m.deps)o.has(l)&&(c++,a.has(l)||a.set(l,[]),a.get(l).push(u));i.set(u,c);}let d=[];for(let[u,m]of i)m===0&&d.push(u);d.sort();let p=[];for(;d.length>0;){let u=d.shift();p.push(u);let m=a.get(u)??[];for(let c of m){let l=(i.get(c)??1)-1;if(i.set(c,l),l===0){let S=d.findIndex(V=>V>c);S===-1?d.push(c):d.splice(S,0,c);}}}return p},Kn=e=>{let t=Array.from(new Set(e)).sort();return JSON.stringify(t)},br=e=>{$t!==yr&&(At.clear(),yr=$t);let t=Kn(e),r=At.get(t);if(r)return [...r];let o=Gn(e);return At.set(t,o),[...o]};Po(br);var Qn=()=>{let e=L(),t=at(),r=Object.keys(e),o=[];for(let[s,n]of Object.entries(e))for(let i of n.deps)o.push({from:i,to:s});return {nodes:r,edges:o,dependencies:Object.fromEntries(Object.entries(e).map(([s,n])=>[s,[...n.deps]])),dependents:Object.fromEntries(Object.entries(t).map(([s,n])=>[s,[...n]]))}},Cr=e=>{let t=L()[e];if(!t)return null;let r=at()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}},Jn=()=>{let e=L(),t=new Map,r=new Map;for(let[n,i]of Object.entries(e)){let a=Ho(n,i);t.set(a.id,{id:a.id,storeId:a.storeId,path:a.path,type:a.nodeType}),i.deps.forEach((d,p)=>{let u=jo(d),m=L()[d]?"computed-input":"leaf-input";t.set(u.id,u),r.set(`${u.id}|${a.id}|${p}`,{from:u.id,to:a.id,type:m});});}let o=Array.from(t.values()).sort((n,i)=>n.id.localeCompare(i.id)),s=Array.from(r.values()).sort((n,i)=>{let a=n.from.localeCompare(i.from);if(a!==0)return a;let d=n.to.localeCompare(i.to);return d!==0?d:n.type.localeCompare(i.type)});return {granularity:"store",nodes:o,edges:s}},Yn=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Eo=(e,t)=>Yn(e,t)?e[t]:null,Wo=(e,t,r)=>{if(r.memo.has(e))return r.memo.get(e);if(r.stack.has(e))throw new Error(`evaluateComputed("${e}") detected a computed cycle`);let o=L()[e];if(!o)throw new Error(`evaluateComputed("${e}") could not find a computed descriptor`);if(o.classification!=="deterministic")throw new Error(`evaluateComputed("${e}") only supports deterministic computed nodes`);r.stack.add(e);try{let s=o.deps.map(i=>{let a=L()[i];if(!a)return Eo(t,i);if(a.classification!=="deterministic")throw new Error(`evaluateComputed("${e}") cannot cross non-deterministic dependency "${i}"`);return Wo(i,t,r)}),n;try{n=o.compute(...s);}catch{n=Eo(t,e);}return r.memo.set(e,n),n}finally{r.stack.delete(e);}},Xn=(e,t)=>{if(!t||typeof t!="object"||Array.isArray(t))throw new Error(`evaluateComputed("${e}") requires a snapshot record`);let r=zo(e);if(!r)throw new Error(`evaluateComputed("${e}") could not find a computed descriptor`);return Wo(r,t,{memo:new Map,stack:new Set})};var Le=new Map,Di=(e,t)=>{let r=Le.get(e);return r||(r=new Set,Le.set(e,r)),r.add(t),()=>{let o=Le.get(e);o&&(o.delete(t),o.size===0&&Le.delete(e));}},wr=e=>{let t=Le.get(e);return !!t&&t.size>0},Be=(e,t,r)=>{let o=Le.get(e);!o||o.size===0||o.forEach(s=>{try{s(t,r);}catch(n){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,n);}});};var Bo=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,s=e.initialFactories,n=e.metaEntries,i=e.snapshotCache,a=e.featureRuntimes,d$1=e.deletingStores,p=e.notify,u=()=>Object.fromEntries(Object.keys(n).map(f=>[f,_(f,e)])),m=(f,w)=>{ba(w,{onError:n[f]?.options?.onError,severity:"warn",visibility:"dev"});},c=({name:f,prev:w,options:v,initialState:O$1,getMeta:b,getStoreValue:g,getAllStores:P$1,hasStore:k})=>({name:f,options:v,prev:w,getMeta:b,getStoreValue:g,getAllStores:P$1,getInitialState:()=>O$1,hasStore:k,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:M=>{ba(M,{onError:v.onError,severity:"warn",visibility:"dev"});},warn:O,warnAlways:P,log:R$1,hashState:T,deepClone:V,sanitize:l,validate:()=>({ok:true,value:w}),isDev:M}),l$1=({name:f,prev:w,options:v,initialState:O,phase:b})=>{let g=c({name:f,prev:w,options:v,initialState:O,getMeta:()=>n[f],getStoreValue:()=>_(f,e),getAllStores:u,hasStore:()=>A(e,f)}),P=c({name:f,prev:w,options:v,initialState:O,getMeta:()=>{},getStoreValue:()=>w,getAllStores:u,hasStore:()=>false});d().forEach(k=>{let M=a.get(k),H=b==="before"?M?.beforeStoreDelete:M?.afterStoreDelete;if(H)try{H(b==="before"?g:P);}catch(oe){ba(`Feature "${String(k)}" ${b}StoreDelete for "${f}" failed: ${oe?.message??oe}`,{onError:v.onError,severity:"warn",visibility:"always"});}});},S=f=>{let w=e.hydration;delete w.stores[f];for(let v=w.queue.length-1;v>=0;v-=1)w.queue[v]?.store===f&&w.queue.splice(v,1);},V$1=f=>{if(!A(e,f))return;let w=_(f,e),v=n[f].options,O$1=o[f],b=r[f];d$1.add(f);try{b?.forEach(M=>{try{M(null);}catch(H){O(`Subscriber for "${f}" threw during delete: ${H?.message??H}`);}}),b?.clear(),kt({name:f,label:"onDelete",fn:v.onDelete,args:[w],reportIssue:(M,H)=>{ba(M,{onError:v.onError,severity:"warn",visibility:H});}}),l$1({name:f,prev:w,options:v,initialState:O$1,phase:"before"});let g=F();g&&delete g[f],delete t[f],delete r[f],delete o[f],delete s[f],delete n[f],delete i[f],S(f),p.pendingNotifications.delete(f);for(let M=p.pendingBuffer.length-1;M>=0;M-=1)p.pendingBuffer[M]===f&&p.pendingBuffer.splice(M,1);for(let M=p.orderedNames.length-1;M>=0;M-=1)p.orderedNames[M]===f&&p.orderedNames.splice(M,1);Be("storeDeleteCleanup",f,{type:"storeDeleteCleanup",prev:w}),wo(f,e),It(f)&&_o(f);let k=e.computedDependents[f];if(k)for(let M of [...k]){let H=Cr(M);if(H&&Lo(M,e)&&H.deps.every(oe=>!A(e,oe))){V$1(M);continue}O(`[stroid] source store "${f}" was deleted. Computed store "${M}" depends on it and will return stale data. Call deleteComputed("${M}") to clean up.`);}l$1({name:f,prev:w,options:v,initialState:O$1,phase:"after"}),Be("afterStoreDelete",f,{type:"afterStoreDelete",prev:w}),D$1(e,{type:"deleted",name:f}),R$1(`Store "${f}" deleted`);}finally{d$1.delete(f);}};return {deleteExistingStore:V$1,clearAllStores:()=>{let f=[],v=0,O$1=Number.POSITIVE_INFINITY;for(;v<20;){let g=Object.keys(t);if(g.length===0)break;g.forEach(k=>{A(e,k)&&(V$1(k),f.push(k));}),v+=1;let P=Object.keys(t).length;if(P===0||P>=O$1)break;O$1=P;}let b=Object.keys(t).length;return b>0?O(`clearAllStores stopped after ${v} pass${v===1?"":"es"}; ${b} store(s) still registered (likely recreated during deletion).`):R$1(`All stores cleared (${f.length} stores removed)`),f},clearStores:f=>{let w=Object.keys(t).filter(v=>f?f.endsWith("*")?v.startsWith(f.slice(0,-1)):v===f:true);return w.forEach(v=>V$1(v)),w},reportStoreError:m}};var kr=v,Go=z(kr),Ko=null,qo=Number.NaN,Rr="",W=()=>{let e=I$1(Go);return u(e),e};var R=()=>W(),zt=e=>(e===qo||(qo=e,Rr=new Date(e).toISOString()),Rr);var Qo=(e,t)=>{D$1(e,t);};function vo(e){Ko=e;}var qe=e=>new Proxy(Object.create(null),{get:(t,r)=>Reflect.get(e(),r),set:(t,r,o)=>Reflect.set(e(),r,o),deleteProperty:(t,r)=>Reflect.deleteProperty(e(),r),has:(t,r)=>Reflect.has(e(),r),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let o=Object.getOwnPropertyDescriptor(e(),r);if(o)return {...o,configurable:true}}}),Zn=e=>new Proxy(new Map,{get:(t,r)=>{let o=e();if(r==="size")return o.size;if(r===Symbol.iterator)return o[Symbol.iterator].bind(o);let s=Reflect.get(o,r);return typeof s=="function"?s.bind(o):s},set:(t,r,o)=>(Reflect.set(e(),r,o),true)}),es=e=>new Proxy({},{get:(t,r)=>{let o=e(),s=Reflect.get(o,r);return typeof s=="function"?s.bind(o):s},set:(t,r,o)=>(Reflect.set(e(),r,o),true)}),io=qe(()=>W().stores),na=qe(()=>W().subscribers),To=qe(()=>W().initialStates);qe(()=>W().initialFactories);var I=qe(()=>W().metaEntries);qe(()=>W().snapshotCache);var Q=Zn(()=>W().featureRuntimes),Uo=new WeakMap,Jo=e=>{let t=Uo.get(e);return t||(t=Bo(e),Uo.set(e,t)),t};es(()=>Jo(W()));var Mr=()=>Jo(W()),ts=e=>{let t=Q.get(e);if(t)return t;let r=c(e);if(!r)return;let o=r();return Q.set(e,o),o},it=()=>{d().forEach(e=>{ts(e);});};e((e,t)=>{Q.get(e)||Q.set(e,t());});it();var G=(e,t)=>A(t??W(),e),K=(e,t=W())=>{if(D()){let r=ie(e);if(r.has)return r.value}return _(e,t)},_=(e,t=W())=>{let r=F();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},Y=(e,t,r=W())=>{let o=F();o?(o[e]=t,Object.prototype.hasOwnProperty.call(r.stores,e)||(r.stores[e]=void 0)):r.stores[e]=t;},gr=(e,t$1,r=Date.now(),o={})=>{let s$1=W(),n=o.source??"unknown";if(!o.bypassHydrationQueue&&e$1(s$1,e,n))return f(s$1,e,n,()=>{gr(e,t$1,r,{...o,bypassHydrationQueue:true});}),t$1;let i=s({registry:s$1,store:e,value:t$1,source:n,normalize:o.validate}),a=i.value;return Y(e,a,s$1),I[e]&&(I[e].updatedAt=zt(r),I[e].updatedAtMs=r,I[e].lastCorrelationId=null,I[e].lastCorrelationAt=null,I[e].lastCorrelationAtMs=null,I[e].lastTraceContext=null,I[e].updateCount>=Number.MAX_SAFE_INTEGER?I[e].updateCount=0:I[e].updateCount+=1,Ko?.(e),i.invalidated&&(t(s$1,e,i.event?.live??t$1,n),i.needsRefetch&&s$1.async.fetchRegistry[e]&&queueMicrotask(()=>{import('./fetch-4RH6MPY3.js').then(async({refetchStore:d})=>{await d({name:e});}).catch(d=>{O(`Post-hydration refetch for "${e}" failed: ${d?.message??d}`);});}))),a},Ht=(e,t=W())=>{let r=t.metaEntries[e];if(!r)return;r.readCount=(r.readCount??0)+1;let o=Date.now();r.lastReadAtMs=o,r.lastReadAt=zt(o);},rs=()=>{C(W());},os=()=>{Q.forEach(e=>{try{e.resetAll?.();}catch{}}),Q.clear();};a("features.reset",os,10);a("registries.clear",rs,20);a("registry.default",()=>{kr=v,Go=z(kr);},115);var Pt=e=>B(W(),e);var Wt=null,Yo=e=>(Wt=e,()=>{Wt===e&&(Wt=null);}),Ue=e=>{Wt?.(e);};var _t=new Set,Lt=e=>{if(e){_t.delete(e);return}_t.clear();};a("store-create.ssr-global-warned",()=>Lt(),65);function ae(e,t,r={}){if(D()){let g=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;ot(g,r.onError),q(g);return}if(!m(e)){ot(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!j(t)){ot(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&M()&&O(`createStore("${e}") received an undefined initial value. This can be indistinguishable from a missing store in some consumers; consider null or an explicit shape if that is intentional.`),nr(r).forEach(g=>{O(g);});let s=J(),n=Mo(e,ir(r,e,s.defaultSnapshotMode,s.resetCloneMode));if(n.scope==="temp"&&r.persist){let g=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;aa(n.onError,`onError(${e})`,g),M()||P(g),Q$1(g);}let i=typeof window>"u",a=typeof process<"u"?process.env?.NODE_ENV:void 0,d=i&&a==="production",p=n.allowSSRGlobalStore??false,u=R(),m$1=u.stores,c=u.subscribers,l=u.initialStates,S=u.initialFactories,V$1=u.metaEntries,h=u.scope==="request";if(d&&!p&&!h){let g=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
4
+ Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;ot(g,r.onError);return}if(d&&p&&!h&&!_t.has(e)&&(_t.add(e),P(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
5
+ This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),G(e,u)){let g=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return U(e,g),{name:e}}i&&!p&&!h&&!ro(e)&&M()&&(oo(e),O(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let T=me(e,t,n.onError);if(!T.ok)return;let f=T.value,w=n.lazy===true&&typeof t=="function",v=(c[e]?.size??0)>0;if(w)m$1[e]=void 0,S[e]=t;else {let g=Se(e,f,n.validate,n.onError);if(!g.ok)return;Y(e,g.value,u),l[e]=V(g.value);}let O$1=Date.now(),b=new Date(O$1).toISOString();return V$1[e]={createdAt:b,updatedAt:b,updatedAtMs:O$1,updateCount:0,version:n.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0,resetCount:0,totalResetMs:0,lastResetMs:0},options:n,readCount:0,lastReadAt:null,lastReadAtMs:null,lastCorrelationId:null,lastCorrelationAt:null,lastCorrelationAtMs:null,lastTraceContext:null},re(e),Ro(e,Ue),Ot(e,"onCreate",V$1[e].options.onCreate,[f]),Qo(u,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),v&&Ue(e),R$1(`Store "${e}" created -> ${JSON.stringify(f)}`),{name:e}}function Xo(e,t,r={}){let o=(r.lazy===true,ae(e,t,r));if(o)return o;throw new Error(`createStoreStrict("${String(e)}") failed. See earlier warnings/errors or onError callbacks for the cause.`)}var Zo=e=>{if(typeof e!="object"||e===null)return false;let t=e;if(t.$$typeof||typeof window<"u"&&e instanceof Element)return false;let r=t.constructor?.name;return !(typeof r=="string"&&r!=="Object"&&r!=="Array")},ct=e=>(Zo(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Bt=e=>{if(!Zo(e))return e;let t=[e],r=new WeakSet;for(;t.length>0;){let o=t.pop();if(!r.has(o)){r.add(o),Object.isFrozen(o)||Object.freeze(o);for(let s of Object.keys(o)){let n=o[s];typeof n=="object"&&n!==null&&!r.has(n)&&t.push(n);}}}return e};var qt=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Ge=(e,t)=>{if(t==="ref")try{return ct(e)}catch{return e}if(t==="shallow"){let o=U$1(e);try{return ct(o)}catch{return o}}let r=V(e);if(!M())return r;try{return Bt(r)}catch{return r}};var en=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:o}=e,s=J().flush,n=s.priorityStores||[],i=n.length?new Set(n):null;if(o.length=0,r.length=0,i){let c=new Set;for(let l of t)r.push(l),c.add(l);for(let l of n)c.has(l)&&o.push(l);for(let l of r)i.has(l)||o.push(l);}else for(let c of t)r.push(c),o.push(c);t.clear();let a=Fo(o);if(a.length>0){let c=new Set(o);for(let l of a)c.has(l)||(o.push(l),c.add(l));}let d=Number.isFinite(s.chunkSize)&&s.chunkSize>0?s.chunkSize:Number.POSITIVE_INFINITY,p=s.chunkDelayMs,u=d===Number.POSITIVE_INFINITY&&p===0;return {names:o,sliceSize:d,chunkDelayMs:p,runInline:u,prioritySet:i}};var ns=()=>({notifyCount:0,totalNotifyMs:0,lastNotifyMs:0,resetCount:0,totalResetMs:0,lastResetMs:0}),Tr=e=>e??ns(),Pr=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),Fr=(e,t)=>{e&&e.metrics!==t&&(e.metrics=t);};var ut=(e,t,r)=>{let o=()=>H(e,t);if(r>0&&typeof setTimeout=="function"){setTimeout(o,r);return}if(typeof queueMicrotask=="function"){queueMicrotask(o);return}Promise.resolve().then(o);},tn=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>H(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var lt=null,we=null,Aa=e=>{if(!e){we=null;return}if(we&&we!==e){P("injectWriteContextRunner(...) was called more than once. The existing runner will be kept to avoid cross-request write-context leaks. If you need to replace it in tests, call injectWriteContextRunner(null) first.");return}we=e;},ss=()=>{lt=null,we=null;};a("write-context.runner",ss,121);var Ut=()=>we?.get()??lt,Vr=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext&&!e.sourceHint)return t();if(we)return we.run(e,t);let r=lt;lt=e;try{return t()}finally{lt=r;}};var rn=e=>{if(!(e instanceof TypeError))return false;let t=e?.message??String(e);return /read only|readonly|cannot assign|cannot add property|cannot delete property/i.test(t)},on=(e,t,r,o)=>{let s=e.notify,{names:n,sliceSize:i,chunkDelayMs:a,runInline:d,prioritySet:p}=t,u=F(),m=e.stores,c=e.subscribers,l=e.metaEntries,S=e.snapshotCache,V$1=J().defaultSnapshotMode,h=x=>qt(l[x],V$1),T=x=>u&&Object.prototype.hasOwnProperty.call(u,x)?u[x]:m[x],f=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),w=wr("beforeFlush"),v=wr("afterFlush"),O$1=x=>{w&&Be("beforeFlush",x,{type:"beforeFlush"});},b=(x,A)=>{v&&Be("afterFlush",x,{type:"afterFlush",elapsedMs:A});},g=x=>{let A=l[x];if(!A)return null;let j=A.lastCorrelationId??void 0,y=A.lastTraceContext??void 0;return !j&&!y?null:{correlationId:j,traceContext:y}},P$1=()=>{o();};if(d){for(let x of n){let A=c[x];if(!A||A.size===0)continue;let j=l[x]?.updateCount??0,y=h(x),$e=T(x),X=S[x],Z=X&&X.source===$e&&X.mode===y?X.snapshot:(()=>{let B=Ge($e,y);return S[x]={version:r,snapshot:B,source:$e,mode:y},B})(),ce=Tr(l[x]?.metrics);O$1(x);let Me=f(),ye=Array.from(A),Ye=g(x),Xe=()=>{for(let B of ye)try{B(Z);}catch(Te){let ue=l[x]?.options?.snapshotSafety??"warn";if((y==="ref"||y==="shallow")&&rn(Te)){if(ue==="throw")throw Te;if(ue==="auto-clone")try{let et=V(Z);P(`Snapshot mutation detected for "${x}". Delivered a cloned snapshot to the subscriber.`);try{B(et);}catch(tr){O(`Subscriber for "${x}" threw on cloned snapshot: ${tr?.message??tr}`);}continue}catch{}P(`Snapshot mutation detected for "${x}": ${Te?.message??Te}`);continue}O(`Subscriber for "${x}" threw: ${Te?.message??Te}`);}};Ye?Vr(Ye,Xe):Xe();let Ze=f()-Me;b(x,Ze),Pr(ce,Ze),Fr(l[x],ce),(l[x]?.updateCount??j)!==j&&s.pendingNotifications.add(x);}P$1();return}let k=x=>{let A=[];for(let j of n){if(x&&!x(j))continue;let y=c[j];if(!y||y.size===0)continue;let $e=l[j]?.updateCount??0,X=h(j),Z=T(j),ce=S[j],Me=ce&&ce.source===Z&&ce.mode===X?ce.snapshot:(()=>{let ye=Ge(Z,X);return S[j]={version:r,snapshot:ye,source:Z,mode:X},ye})();A.push({name:j,snapshot:Me,version:$e,subscribers:Array.from(y),subscriberSet:new Set(y),notified:new Set,metrics:Tr(l[j]?.metrics),totalMs:0,beforeHooked:false});}return A},M=p?k(x=>p.has(x)):[],H=k(x=>!p||!p.has(x)),oe=(x,A)=>{let j=()=>{if(x.length===0){A();return}let y=x.shift();if((l[y.name]?.updateCount??y.version)!==y.version){if(s.pendingNotifications.add(y.name),x.length===0){A();return}ut(e,j,a);return}let X=()=>{let ne=c[y.name];if(!(!ne||ne.size===0))for(let B of ne)y.subscriberSet.has(B)||(y.subscriberSet.add(B),y.subscribers.push(B));};X();let Z=y.subscribers;if(Z.length===0){if(x.length===0){A();return}ut(e,j,a);return}y.beforeHooked||(y.beforeHooked=true,O$1(y.name));let ce=f(),Me=0,ye=false,Ye=g(y.name),Xe=()=>{for(let ne=0;ne<Z.length&&Me<i;ne+=1){let B=Z[ne];if(y.notified.has(B))continue;y.notified.add(B);try{B(y.snapshot);}catch(ue){let er=l[y.name]?.options?.snapshotSafety??"warn",et=h(y.name);if((et==="ref"||et==="shallow")&&rn(ue)){if(er==="throw")throw ue;if(er==="auto-clone")try{let Ar=V(y.snapshot);P(`Snapshot mutation detected for "${y.name}". Delivered a cloned snapshot to the subscriber.`);try{B(Ar);}catch($r){O(`Subscriber for "${y.name}" threw on cloned snapshot: ${$r?.message??$r}`);}if(y.notified.add(B),Me+=1,(l[y.name]?.updateCount??y.version)!==y.version){ye=!0,s.pendingNotifications.add(y.name);break}continue}catch{}P(`Snapshot mutation detected for "${y.name}": ${ue?.message??ue}`);continue}O(`Subscriber for "${y.name}" threw: ${ue?.message??ue}`);}if(Me+=1,(l[y.name]?.updateCount??y.version)!==y.version){ye=true,s.pendingNotifications.add(y.name);break}}};if(Ye?Vr(Ye,Xe):Xe(),y.totalMs+=f()-ce,ye){if(x.length===0){A();return}ut(e,j,a);return}X();let Ze=false;for(let ne of Z)if(!y.notified.has(ne)){Ze=true;break}if(Ze?x.push(y):(Pr(y.metrics,y.totalMs),Fr(l[y.name],y.metrics),b(y.name,y.totalMs)),x.length===0){A();return}ut(e,j,a);};j();};M.length>0?oe(M,()=>oe(H,P$1)):oe(H,P$1);};var nn=(e,t)=>{let r=e.notify;r.isFlushing=true,r.flushId=r.flushId+1>>>0;let o=r.flushId,s=en(r),n=t.inline?{...s,runInline:true,sliceSize:Number.POSITIVE_INFINITY,chunkDelayMs:0}:s;on(e,n,o,()=>{r.isFlushing=false,r.notifyScheduled=false,!t.inline&&r.pendingNotifications.size>0&&Gt(e);});},Gt=e=>{tn(e,t=>{nn(t,{inline:false});});},is=e=>{let t=e.notify;if(t.batchDepth>0)return;let r=0;for(;(t.notifyScheduled||t.pendingNotifications.size>0)&&!t.isFlushing;)if(nn(e,{inline:true}),r+=1,r>1e4)throw new Error("flushPendingNotificationsInline exceeded safety pass limit.")},as=e=>{if(typeof setTimeout=="function"){setTimeout(e,0);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Qa=e=>new Promise((t,r)=>{let s=0,n=()=>{try{is(e);}catch(a){r(a);return}let i=e.notify;if(!i.isFlushing&&!i.notifyScheduled&&i.pendingNotifications.size===0){t();return}if(s+=1,s>2e4){r(new Error("waitForNotificationIdle exceeded safety check limit."));return}as(n);};n();});var Kt=(e,t)=>{if(!(!e||typeof e!="object")){if(t==="ref"||t==="shallow"){ct(e);return}t==="deep"&&Bt(e);}},cs=e=>{let t=R(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&Gt(t);};Yo(cs);var ac=e=>{if(typeof e!="function"){O("setStoreBatch requires a synchronous function callback.");return}let t=Object.prototype.toString.call(e);if(t==="[object AsyncFunction]"||t==="[object AsyncGeneratorFunction]"){P("setStoreBatch does not support async functions. Move async work outside and batch only synchronous mutations.");return}if(t==="[object GeneratorFunction]"){P("setStoreBatch does not support generator functions. Move generator logic outside and batch only synchronous mutations.");return}let r=R(),o=typeof window>"u",s=typeof process<"u"?process.env?.NODE_ENV:void 0;if(o&&s==="production"&&r.scope!=="request")throw new Error("setStoreBatch() called in a global SSR context. Use createStoreForRequest() to ensure transaction isolation.");let n=r.notify;n.batchDepth=Math.max(0,n.batchDepth+1),fo(r);let i;try{let a=H(r,e);a&&typeof a.then=="function"&&(i=new Error("setStoreBatch does not support promise-returning callbacks. Move async work outside and batch only synchronous mutations."));}catch(a){i=a;}finally{let a=So(i,r);n.batchDepth=Math.max(0,n.batchDepth-1),n.batchDepth===0&&n.pendingNotifications.size>0&&Gt(r),a&&!i&&(i=a);}if(i){let a=i instanceof Error?i.message:String(i);P(`setStoreBatch failed: ${a}`);}},Er=(e,t)=>{let o=R().subscribers;o[e]||(o[e]=new Set),o[e].add(t);let s=false;return ()=>{s||(s=true,o[e]?.delete(t),o[e]?.size===0&&delete o[e]);}};var sn=(e,t)=>{if(!G(e))return null;let r=R();t.trackRead&&Ht(e,r);let o=qt(r.metaEntries[e],J().defaultSnapshotMode);if(!t.committedOnly&&D()){let d=r.transaction.snapshotCache,p=K(e);if(p===void 0&&r.initialFactories[e])return null;let u=d.get(e);if(u&&u.source===p&&u.mode===o){let c=u.snapshot;return Kt(c,o),c}let m=Ge(p,o);return d.set(e,{source:p,snapshot:m,mode:o}),Kt(m,o),m}let s=r.notify.flushId,n=t.committedOnly?_(e,r):K(e,r);if(n===void 0&&r.initialFactories[e])return null;let i=r.snapshotCache[e];if(i&&i.source===n&&i.mode===o){let d=i.snapshot;return Kt(d,o),d}let a=Ge(n,o);return Kt(a,o),r.snapshotCache[e]={version:s,snapshot:a,source:n,mode:o},a},cc=e=>sn(e,{trackRead:true,committedOnly:false}),uc=e=>sn(e,{trackRead:false,committedOnly:true});var us=()=>{let e=R().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};a("notify.reset",us,40);var ls=32,dt=new Set;a("store-write.slow-mutator-warned",()=>dt.clear(),65);var ds=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;},cn=()=>{dt.clear();},un=e=>{dt.delete(e);},ln=(e,t)=>{M()&&(t<ls||dt.has(e)||(dt.add(e),O(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},Qt=e=>e??Ut(),ps=(e,t)=>t?.sourceHint?t.sourceHint:e==="hydrate"?"hydrate":"effect",fs=e=>e==="replace"?"replaceStore":e==="reset"?"resetStore":e==="hydrate"?"hydrateStores":"setStore",ms=(e,t)=>{if(!e||!t)return;let r=t.resetElapsedMs;typeof r=="number"&&(e.metrics.resetCount=(e.metrics.resetCount??0)+1,e.metrics.totalResetMs=(e.metrics.totalResetMs??0)+r,e.metrics.lastResetMs=r);},an=(e,{name:t,prev:r,next:o,action:s,hookLabel:n,logMessage:i,context:a,metricsUpdate:d})=>{let p=e.metaEntries;Y(t,o,e),re(t);let u=Date.now(),m=zt(u);p[t].updatedAt=m,p[t].updatedAtMs=u;let c=a??Ut();c&&(c.correlationId||c.traceContext)?(p[t].lastCorrelationId=c.correlationId??null,p[t].lastCorrelationAt=m,p[t].lastCorrelationAtMs=u,p[t].lastTraceContext=c.traceContext??null):(p[t].lastCorrelationId=null,p[t].lastCorrelationAt=null,p[t].lastCorrelationAtMs=null,p[t].lastTraceContext=null),ds(p[t]),ms(p[t],d),ko(t,s,r,o,Ue),Ot(t,n,p[t].options[n],[r,o]),Ue(t),R$1(i);},Ke=(e,t$1)=>{let r=t$1.context??Ut(),o=ps(t$1.action,r),s$1=s({registry:e,store:t$1.name,value:t$1.next,source:o,normalize:t$1.normalizeHydrationCandidate}),n=s$1.value,i=t$1.runtimePatches&&t$1.runtimePatches.length>0&&Object.is(n,t$1.next)?t$1.runtimePatches:t$1.runtimePatches&&t$1.runtimePatches.length>0?[se({store:t$1.name,value:n,source:fs(t$1.action),context:r})]:t$1.runtimePatches,a=()=>{s$1.invalidated&&(t(e,t$1.name,s$1.event?.live??n,o),!(!s$1.needsRefetch||!e.async.fetchRegistry[t$1.name])&&queueMicrotask(()=>{import('./fetch-4RH6MPY3.js').then(async({refetchStore:d})=>{await d({name:t$1.name});}).catch(d=>{O(`Post-hydration refetch for "${t$1.name}" failed: ${d?.message??d}`);});}));};if(D()){Vt(t$1.name,n),mo(i??[]),Ft(()=>{an(e,{...t$1,next:n,context:r}),a();});return}an(e,{...t$1,next:n,context:r}),i&&i.length>0&&De(i,e),a();};function Nr(e,t,r){return Or(e,t,r)}var Or=(e,t,r,o,s=false)=>{let n=pe(e),i=R(),a=i.metaEntries,d=J(),p=D(),u=b=>{p&&q(b);};if(!Ae(n,i))return {ok:false,reason:"validate"};if(!G(n,i)){let b=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return fe(n,b),u(b),{ok:false,reason:"not-found"}}let m=o?.sourceHint??"effect";if(!s&&e$1(i,n,m))return f(i,n,m,()=>{Or(e,t,r,o,true);}),{ok:true};let c,l={kind:"root"},S=K(n,i);if(p){let b=ie(n);b.has&&(S=b.value);}if(typeof t=="function"&&r===void 0){let b=M()?Date.now():0;try{let g=d.mutatorProduce,P=!1,k,M$1=d.strictMutatorReturns,H=x=>{let A=t(x);return A!==void 0&&(P=!0,k=A),A},oe=g?g(S,H):(()=>{let x=V(S);return H(x),x})();if(P&&M$1){let x=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return fe(n,x),u(x),{ok:!1,reason:"validate"}}P&&M()&&!M$1&&O(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),c=P&&!M$1?k:oe,l={kind:"root"};}catch(g){return fe(n,`Mutator for "${n}" failed: ${g?.message??g}`),u(g),{ok:false,reason:"validate"}}finally{b&&ln(n,Date.now()-b);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!j(t))return u(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof S!="object"||S===null||Array.isArray(S))return Q$1(`setStore("${n}", data) only merges into object stores.
6
+ Use setStore("${n}", "path", value) or recreate the store with an object shape.`),u(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let b=me(n,t);if(!b.ok)return u(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};c=Object.assign({},S,b.value),l={kind:"merge",value:b.value};}else if(typeof t=="string"||Array.isArray(t)){let b=Y$1(t);if(!Z(b))return u(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let g=me(n,r);if(!g.ok)return u(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let P=g.value,k=xo(n,S,b,P);if(!k.ok)return aa(a[n]?.options?.onError,`onError(${n})`,k.reason??`Invalid path for "${n}".`),u(k.reason),{ok:false,reason:"path"};c=$(S,b,P),l={kind:"path",path:b,value:P};}else {let b=`setStore("${n}") - invalid arguments.
7
+ Usage:
8
+ setStore("${n}", "field", value)
9
+ setStore("${n}", "nested.field", value)
10
+ setStore("${n}", { field: value })
11
+ setStore(storeDef, draft => { draft.field = value })
12
+ replaceStore("${n}", value) // full-store replace`;return Q$1(b),aa(a[n]?.options?.onError,`onError(${n})`,b),u(b),{ok:false,reason:"invalid-args"}}if(!j(c))return u(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let h=a[n]?.options?.validate,T=Qt(o),f$1=Nt(n,{action:"set",prev:S,next:c,path:t,correlationId:T?.correlationId,traceContext:T?.traceContext});if(f$1===_e)return u(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let w=Object.is(f$1,c),v=Se(n,f$1,h,void 0,w?{reuseInput:true}:void 0);if(!v.ok)return u(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};let O$1=co({store:n,intent:l,committedValue:v.value,preserveIntent:l.kind!=="root"&&Object.is(f$1,c)&&Object.is(v.value,f$1),context:T});if(Object.is(S,v.value))return {ok:true};try{if(W$1(S,v.value))return {ok:!0}}catch{}return Ke(i,{name:n,prev:S,next:v.value,action:"set",hookLabel:"onSet",logMessage:`Store "${n}" updated`,context:T,runtimePatches:O$1,normalizeHydrationCandidate:b=>Se(n,b,h)}),{ok:true}},Qe=(e,t,r,o)=>Or(e,t,r,o);function Re(e,t){let r=pe(e);if(!r)return {ok:false,reason:"invalid-args"};let o=R(),s=Jt(o,r,t,"replace");return s.ok?{ok:true}:s.reason==="not-found"?{ok:false,reason:"not-found"}:s.reason==="middleware"?{ok:false,reason:"middleware"}:{ok:false,reason:"validate"}}var Jt=(e,t,r,o="hydrate",s,n={})=>{let i=(h,T)=>(D()&&q(T??h),{ok:false,reason:h});if(!Oe(t))return i("not-found",`replaceStore("${t}") called before createStore().`);let a=(o==="hydrate"?"hydrate":"effect");if(o!=="hydrate"&&!n.bypassHydrationQueue&&e$1(e,t,a))return f(e,t,a,()=>{Jt(e,t,r,o,s,{bypassHydrationQueue:true});}),{ok:true};let d=D()?ie(t):{has:false,value:void 0},p=d.has?d.value:K(t,e),u=me(t,r);if(!u.ok)return i("sanitize",`replaceStore("${t}") failed sanitize`);let m=u.value;if(m===void 0){let h=`Whole-store undefined replacement is blocked for "${t}". Use null for intentional empty state.`;return U(t,h),i("undefined",h)}let c=e.metaEntries[t]?.options?.validate,l=Qt(s),S=Nt(t,{action:o,prev:p,next:m,path:null,correlationId:l?.correlationId,traceContext:l?.traceContext});if(S===_e)return i("middleware",`replaceStore("${t}") aborted by middleware`);let V=Se(t,S,c);return V.ok?(Ke(e,{name:t,prev:p,next:V.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:l,runtimePatches:[se({store:t,value:V.value,source:o==="hydrate"?"hydrateStores":"replaceStore",context:l})],normalizeHydrationCandidate:h=>Se(t,h,c)}),{ok:true}):i("validate",`replaceStore("${t}") failed validation`)};var Ss=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},dn=(e,t)=>t==="ref"?e:t==="shallow"?U$1(e):V(e);function ge(e,t){let r=pe(e);if(!Oe(r))return null;let o=R();if(!Ae(r,o))return null;Ht(r,o);let s=K(r,o),n=Ss(o.metaEntries[r],J().defaultSnapshotMode);if(t===void 0)return s===null||typeof s!="object"?s:dn(s,n);if(!Z(t))return null;let i=_$1(s,t);return i===null||typeof i!="object"?i:dn(i,n)}var Je=e=>G(e)&&!Pt(e);var eu=e=>{let r=R().metaEntries[e];return r?.metrics?{...r.metrics}:null};var pt=256*1024,gs=1,pn=(e,t)=>{let r=0;for(let o=0;o<e.length;o+=1){let s=e.charCodeAt(o);if(s<=127)r+=1;else if(s<=2047)r+=2;else if(s>=55296&&s<=56319&&o+1<e.length){let n=e.charCodeAt(o+1);n>=56320&&n<=57343?(r+=4,o+=1):r+=3;}else r+=3;if(r>=t)return t}return r},Dr=(e,t,r=new WeakSet,o=false)=>{if(t<=0)return 0;if(e===null)return Math.min(4,t);let s=typeof e;if(s==="string")return Math.min(t,pn(e,t)+2);if(s==="number")return Number.isFinite(e)?Math.min(String(e).length,t):Math.min(4,t);if(s==="boolean")return Math.min(e?4:5,t);if(s==="bigint")return t;if(s==="undefined"||s==="function"||s==="symbol")return o?Math.min(4,t):0;if(s!=="object")return 0;let n=e;if(r.has(n))return t;if(n instanceof Date)return Math.min(Number.isNaN(n.getTime())?4:26,t);if(ArrayBuffer.isView(n)||n instanceof ArrayBuffer)return Math.min(n.byteLength+16,t);if(n instanceof Map||n instanceof Set)return Math.min(2,t);let i;try{i=Object.getOwnPropertyDescriptors(n);}catch{return t}r.add(n);try{if(Array.isArray(n)){let p=n,u=2;for(let m=0;m<p.length;m+=1){if(m>0&&(u+=1,u>=t))return t;let l=Object.prototype.hasOwnProperty.call(p,m)?p[m]:null,S=Dr(l,t-u,r,!0);if(u+=S,u>=t)return t}return u}let a=2,d=!0;for(let[p,u]of Object.entries(i)){if(!u.enumerable)continue;if("get"in u||"set"in u)return t;let m="value"in u?u.value:void 0,c=Dr(m,t-a,r,!1);if(c===0)continue;let l=pn(p,t-a),S=(d?0:1)+l+3;if(a+=S,a>=t||(a+=c,a>=t))return t;d=!1;}return a}finally{r.delete(n);}},ys=e=>{if(typeof e=="string")return e.length;if(Dr(e,pt)>=pt)return pt;try{let r=JSON.stringify(e);return typeof r=="string"?r.length:0}catch{return pt}};var hs=(e,t)=>{if(!t||t.bootWindow!==void 0||t.bootWindowMs!==void 0)return false;let r=0,o=Object.values(e);for(let s=0;s<o.length;s+=1)if(r+=ys(o[s]),r>=pt)return true;return false},xs=(e,t)=>hs(e,t)?{...t,bootWindow:{mode:"timer",ms:gs}}:t,fn=(e,t={},r,o)=>{if(D()){let c="hydrateStores(...) cannot be called inside setStoreBatch.";return O(c),q(c),{hydrated:[],created:[],failed:[],blocked:{reason:"transaction"}}}let s={hydrated:[],created:[],failed:[]};if(!e||typeof e!="object")return s;let n=R(),i=[],a=r??{};if(!(a.allowTrusted===true||a.allowHydration===true||a.allowUntrusted===true||J().allowUntrustedHydration===true))return P("hydrateStores(...) requires explicit trust. Pass { allowTrusted: true } (or { allowHydration: true }) as the third argument or configureStroid({ allowTrustedHydration: true })."),s.blocked={reason:"untrusted"},s;if(typeof a.validate=="function"){let c=false;try{let l=a.validate(e);if(l&&typeof l=="object"&&typeof l.then=="function"){let S="hydrateStores() trust.validate must return a boolean synchronously. Async validators are not supported in hydrateStores().";if(M())throw new Error(S);return P(S),s.blocked={reason:"validation-error",cause:new Error(S)},s}c=!!l;}catch(l){let S=`hydrateStores() trust.validate threw: ${l?.message??l}`;if(M())throw new Error(`hydrateStores() trust.validate threw an error. Fix your validator before this becomes a silent production failure.
13
+ Original error: ${l?.message??l}`);let V=t?.default?.onError;if(typeof V=="function")try{V(S);}catch(h){P(`hydrateStores(...) onError threw: ${h?.message??h}`);}if(P(S),typeof a.onValidationError=="function")try{if(!!a.onValidationError(l,e))c=!0;else return s.blocked={reason:"validation-error",cause:l},s}catch(h){return P(`hydrateStores(...) onValidationError threw: ${h?.message??h}`),s.blocked={reason:"validation-error",cause:h},s}else return s.blocked={reason:"validation-error",cause:l},s}if(!c)return P("hydrateStores(...) rejected by trust validation."),s.blocked={reason:"validation-failed"},s}let p=[];Object.entries(e).forEach(([c,l])=>{if(!m(c)){s.failed.push({name:c,reason:"invalid-name"});return}if(G(c,n)){let S=Jt(n,c,l,"hydrate");S.ok?(s.hydrated.push(c),p.push(c),i.push(se({store:c,value:_(c,n),source:"hydrateStores"}))):s.failed.push({name:c,reason:"merge-failed",cause:S.reason,received:l});}else {let S=t;ae(c,l,S[c]||S.default||{})?(s.created.push(c),p.push(c),i.push(se({store:c,value:_(c,n),source:"hydrateStores"}))):s.failed.push({name:c,reason:"create-failed",received:l});}}),p.length>0&&br(p).forEach(l=>{let S=n.computedEntries[l];if(!S)return;let V=S.deps.map(h=>ge(ke(h)));try{let h=S.compute(...V);if(h&&typeof h.then=="function"){O(`hydrateStores recompute for "${l}" returned a Promise; skipping.`);return}let T=_(l,n);if(S.hasLastOutput&&Object.is(h,S.lastOutput)||Object.is(h,T))return;S.lastOutput=h,S.hasLastOutput=!0,Re(ke(l),h);}catch(h){O(`hydrateStores recompute for "${l}" failed: ${h?.message??h}`);}}),i.length>0&&De(i,n);let u=xs(e,o),m$1=d$1(n,e,u);return m$1&&(s.bootWindow=m$1),s};function Yt(e){let t=pe(e);if(!Oe(t))return;let r=R();if(!Ae(t,r))return;if(D()){let s=`deleteStore("${t}") cannot be called inside setStoreBatch. Move deleteStore outside the batch to preserve transaction semantics.`;U(t,s),q(s);return}Mr().deleteExistingStore(t),re(t),un(t),Lt(t);}function Xt(e){return mn(e)}var mn=(e,t={})=>{let r=pe(e);if(!Oe(r))return {ok:false,reason:"not-found"};let o=R();if(!t.bypassHydrationQueue&&e$1(o,r,"effect"))return f(o,r,"effect",()=>{mn(e,{bypassHydrationQueue:true});}),{ok:true};if(o.metaEntries[r]?.options?.lazy===true&&!!o.initialFactories[r]){let c=`resetStore("${r}") cannot run on a lazy store before it is initialized. Read the store once (getStore) to materialize it before resetting.`;return U(r,c),D()&&q(c),{ok:false,reason:"lazy-uninitialized"}}if(!Ae(r,o))return {ok:false,reason:"validate"};if(!Object.prototype.hasOwnProperty.call(o.initialStates,r)){let c=`resetStore("${r}") has no initial state to reset to. If this is a lazy store, ensure it has been initialized before calling resetStore.`;return U(r,c),D()&&q(c),{ok:false,reason:"no-initial-state"}}let n=o.metaEntries[r]?.options?.resetClone??"deep",i=c=>n==="none"?c:n==="shallow"?c&&typeof c=="object"?U$1(c):c:V(c),a=D()?ie(r):{has:false,value:void 0},d=a.has?a.value:K(r,o),p=typeof performance<"u"&&performance.now?performance.now():Date.now(),u=i(o.initialStates[r]),m=(typeof performance<"u"&&performance.now?performance.now():Date.now())-p;return Ke(o,{name:r,prev:d,next:u,action:"reset",hookLabel:"onReset",logMessage:`Store "${r}" reset to initial state/value`,metricsUpdate:{resetElapsedMs:m},runtimePatches:[se({store:r,value:u,source:"resetStore"})],normalizeHydrationCandidate:c=>({ok:true,value:c})}),{ok:true}},Sn=()=>{if(D()){let t="clearAllStores() cannot be called inside setStoreBatch.";O(t),q(t);return}Mr().clearAllStores(),cn(),Lt();},gn=()=>{b();};var ke=e=>({name:e}),ju=e=>{let t=`${e}::`,r=i=>i.includes("::")?i:`${t}${i}`,o=i=>typeof i=="string"?ke(r(i)):{...i,name:r(i.name)},s=i=>i.replace(/\\/g,"\\\\").replace(/\./g,"\\."),n=i=>typeof i=="string"?i:i.map(a=>s(String(a))).join(".");return {store:i=>({name:r(i)}),create:(i,a,d)=>ae(r(i),a,d),createStrict:(i,a,d)=>Xo(r(i),a,d),set:(i,...a)=>a.length===1?Qe(o(i),a[0],void 0,null):a.length===2?Qe(o(i),a[0],a[1],null):{ok:false,reason:"invalid-args"},get:(i,a)=>a===void 0?ge(o(i)):ge(o(i),n(a)),delete:i=>Yt(o(i)),reset:i=>Xt(o(i))}};var vs=()=>typeof window>"u"&&typeof process<"u"&&process.env?.NODE_ENV==="production",bs=(e,t)=>!vs()||t.scope==="request"?false:e.length>0&&e.every(r=>t.metaEntries[r]?.options.allowSSRGlobalStore===true),Zt=()=>R().computedCleanups,yn=new WeakMap,hn=new WeakMap,ft=e=>{let t=yn.get(e);return t||(t=new Map,yn.set(e,t)),t},Cs=e=>{let t=hn.get(e);return t||(t=new Map,hn.set(e,t)),t};function Zu(e,t,r,o={}){if(!e||typeof e!="string"){O("createComputed requires a store name as first argument");return}if(!Array.isArray(t)||t.length===0){O(`createComputed("${e}") requires at least one dependency`);return}if(typeof r!="function"){O(`createComputed("${e}") requires a compute function as third argument`);return}let s=Zt(),n=s.get(e);n&&(n(),s.delete(e));let i=t.map(l=>typeof l=="string"?l:l?.name);if(i.some(l=>!l||typeof l!="string")){O(`createComputed("${e}") dependencies must be store names or store handles.`);return}if(M()){let l=i.filter(S=>!Je(S));l.length>0&&O(`createComputed("${e}") dependencies not found at registration: ${l.join(", ")}. Computed values will receive null until those stores are created.`);}if(!$o(e,i,r,o.classification??"opaque"))return;let d=R();ft(d).set(e,{...o});let p=xn(e,t,r,o.onError),u=jt(e);u&&(u.lastOutput=p,u.hasLastOutput=true);let m=ke(e);if(Je(e))Re(m,p);else if(!(bs(i,d)?ae(e,p,{scope:"global"}):ae(e,p))&&!Je(e)){hr(e),ft(d).delete(e);return}let c=[];for(let l of i){let S=Er(l,()=>{vn(e,i,r,o.onError);});c.push(S);}return Zt().set(e,()=>{c.forEach(l=>l()),hr(e),ft(R()).delete(e);}),M()&&R$1(`computed store "${e}" created, deps: [${i.join(", ")}]`),m}var xn=(e,t,r,o)=>{let s=t.map(n=>typeof n=="string"?ge(ke(n)):ge(n));try{return r(...s)}catch(n){return O(`createComputed("${e}") compute function threw: ${n?.message??n}`),aa(o,`computed.onError(${e})`,n),Je(e)?K(e,R()):null}},vn=(e,t,r,o)=>{let s=jt(e);if(!s)return;let n=R();if(n.notify.isFlushing){let u=n.notify.flushId,m=Cs(n);if(m.get(e)===u)return;m.set(e,u);}let i=xn(e,t,r,o),a=ke(e),d=K(e,n);s.hasLastOutput&&Object.is(i,s.lastOutput)||Object.is(i,d)||(s.lastOutput=i,s.hasLastOutput=true,Re(a,i),xr(e));},el=e=>{let t=jt(e);if(!t){O(`invalidateComputed("${e}") -- "${e}" is not a computed store`);return}xr(e),vn(e,t.deps,t.compute);},_o=e=>{let t=Zt(),r=t.get(e);if(!r){M()&&O(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);},tl=e=>It(e),Lo=(e,t=R())=>ft(t).get(e)?.autoDispose===true,rl=()=>{let e=Zt();e.forEach(t=>t()),e.clear(),ft(R()).clear();};export{_o as A,tl as B,Lo as C,rl as D,R as E,na as F,I as G,Mr as H,G as I,K as J,_ as K,ei as L,fo as M,D as N,So as O,Gt as P,is as Q,Qa as R,ac as S,Er as T,cc as U,uc as V,fn as W,Yt as X,Xt as Y,Sn as Z,gn as _,ct as a,Bt as b,pe as c,Mn as d,zn as e,ki as f,Un as g,Qn as h,Cr as i,Jn as j,Xn as k,ae as l,Xo as m,ge as n,Je as o,eu as p,ke as q,ju as r,Aa as s,Vr as t,Di as u,Re as v,Nr as w,Qe as x,Zu as y,el as z};//# sourceMappingURL=chunk-X2MKRN7O.js.map
14
+ //# sourceMappingURL=chunk-X2MKRN7O.js.map
@@ -0,0 +1,2 @@
1
+ import {b,a as a$1}from'./chunk-4D6OA3DD.js';import {T as T$1,aa,P}from'./chunk-6IBJ7CIK.js';import {a}from'./chunk-PHE2BCFG.js';var ee=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",z=t=>Reflect.get(t,ee)===true,C=t=>{try{let r=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`,s=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`;return t(r)!==r?!1:t(s)===s}catch{return false}},K=(t,r,s)=>{let o="__stroid_persist_roundtrip_probe__",a;try{a=r(o);}catch(p){return {ok:false,reason:`persist: encrypt failed for store "${t}" (${p?.message??p})`}}if(typeof a!="string")return {ok:false,reason:`persist: encrypt must return a string for store "${t}".`};let d;try{d=s(a);}catch(p){return {ok:false,reason:`persist: decrypt failed for store "${t}" (${p?.message??p})`}}return typeof d!="string"?{ok:false,reason:`persist: decrypt must return a string for store "${t}".`}:d!==o?{ok:false,reason:`persist: encrypt/decrypt must round-trip for store "${t}".`}:{ok:true}};var te=t=>!!t&&typeof t.then=="function",D=(t,r,s)=>{t[r]&&(t[r].lastPresent=s);},I=({name:t,persistConfig:r,persistWatchState:s})=>{let o=r?.onStorageCleared;if(!r||typeof o!="function"||typeof window>"u"||typeof window.addEventListener!="function")return;s[t]?.dispose();let a=window,d=()=>{try{let e=r.driver.getItem?.(r.key)??null;return te(e)?Promise.resolve(e).then(u=>u!=null,()=>!1):e!=null}catch{return false}},p=e=>{let u=s[t];if(!u)return;let c=u.lastPresent,m=l=>{let f=s[t];if(f){if(!c||l){f.lastPresent=l;return}f.lastPresent=false,o({name:t,key:r.key,reason:e});}},S=d();if(typeof S=="boolean"){m(S);return}S.then(m);},g=e=>{if(e.key===null){p("clear");return}e.key===r.key&&e.newValue===null&&p("remove");},y=()=>{p("missing");};a.addEventListener("storage",g),a.addEventListener("focus",y);let v=d();s[t]={lastPresent:typeof v=="boolean"?v:false,dispose:()=>{a.removeEventListener("storage",g),a.removeEventListener("focus",y);}},typeof v!="boolean"&&v.then(e=>{let u=s[t];u&&(u.lastPresent=e);});};var re=t=>{let r=new Uint8Array(t),s="";for(let o=0;o<r.length;o++)s+=r[o].toString(16).padStart(2,"0");return s},se=async t=>{let r=globalThis.crypto?.subtle;if(typeof r?.digest=="function"){let s=typeof TextEncoder<"u"?new TextEncoder:null;if(!s&&typeof Buffer>"u")throw new Error("sha256 checksum is not supported in this environment");let o=s?s.encode(t):new Uint8Array(Buffer.from(t)),a=await r.digest("SHA-256",o);return re(a)}try{let{createHash:s}=await import('crypto');return s("sha256").update(t).digest("hex")}catch{throw new Error("sha256 checksum is not supported in this environment")}},F=async(t,r,s=T$1)=>t==="none"?null:t==="sha256"?se(r):s(r);var Q=1e6,ne=t=>!!t&&typeof t.then=="function",T=(t,r,s)=>(r(t,`Could not load store "${t}" (${s?.message||s})`),true),X=(t,r)=>{let s=t?.options?.migrations??{};if(Object.keys(s).length>0)return s;let o=r?.migrate;if(typeof o!="function")return s;let a=t?.version??1;return !Number.isFinite(a)||a<=1?s:{[a]:o}},R=({name:t,persisted:r,reason:s,persistConfig:o,initialState:a,reportStoreError:d,sanitize:p,deepClone:g})=>{d(t,s);let y=o?.onMigrationFail??"reset";if(y==="keep")return {state:r,requiresValidation:true};if(typeof y=="function")try{let v=y(g(r));if(v!==void 0)return {state:p(v),requiresValidation:!0};d(t,`onMigrationFail for "${t}" returned undefined. Falling back to initial state.`);}catch(v){d(t,`onMigrationFail for "${t}" failed: ${v?.message??v}`);}return {state:g(a),requiresValidation:true}},N=t=>{let s=t.getMeta()?.options?.persist;if(!s)return false;let o;try{o=s.driver.getItem?.(s.key)??null;}catch(d){return T(t.name,t.reportStoreError,d)}return ne(o)||!!s.decryptAsync||s.checksum==="sha256"?Y(t,o):oe(t,o)},oe=({name:t,silent:r=false,getMeta:s,getInitialState:o,applyFeatureState:a,reportStoreError:d,warnMissingMaxSize:p,validate:g,log:y,hashState:v,deepClone:e,sanitize:u,shouldApply:c},m)=>{let S=s(),l=S?.options?.persist;if(!l)return false;let f=X(S,l),i=n=>a$1({value:n,validate:g});try{let n=m===void 0?l.driver.getItem?.(l.key)??null:m;if(n==null)return !1;if(typeof n!="string")return d(t,`Persist driver for "${t}" returned an async value during sync hydration. Provide async decrypt hooks or use an async-capable persist driver.`),!0;if(typeof l.maxSize!="number"&&n.length>Q&&p?.(n.length),typeof l.maxSize=="number"&&n.length>l.maxSize)return d(t,`Persist payload for "${t}" exceeds maxSize (${n.length} > ${l.maxSize}). Skipping hydration.`),!0;let h=l.decrypt(n),P=JSON.parse(h),{v:w=1,checksum:b$1,data:k,updatedAt:_,updatedAtMs:V}=P||{};if(k===void 0)return !0;let $=b({value:typeof V=="number"?V:_,fallbackMs:Date.now(),onInvalid:()=>{y(`persist: corrupt updatedAt in stored data for "${t}". Using current time to prevent sync overwrite.`);}});if(l.checksum!=="none"&&b$1!==v(k))return d(t,`Checksum mismatch loading store "${t}". Falling back to initial state.`),(!c||c())&&a(e(o()),Date.now(),{source:"storage",validate:i}),!0;let j=l.deserialize(k),O=S?.version??1,E=G({name:t,parsed:j,v:w,targetVersion:O,cfg:l,migrations:f,getInitialState:o,reportStoreError:d,sanitize:u,deepClone:e,validateState:i,safeUpdatedAt:$,applyFeatureState:a,shouldApply:c});return E.ok&&(j=E.state,(!c||c())&&(a(E.state,$,{source:"storage",validate:i}),r||y(`Store "${t}" loaded from persistence`))),!0}catch(n){return T(t,d,n)}},Y=async({name:t,silent:r=false,getMeta:s,getInitialState:o,applyFeatureState:a,reportStoreError:d,warnMissingMaxSize:p,validate:g,log:y,hashState:v,deepClone:e,sanitize:u,shouldApply:c},m)=>{let S=s(),l=S?.options?.persist;if(!l)return false;let f=X(S,l),i=n=>a$1({value:n,validate:g});try{let n=await Promise.resolve(m===void 0?l.driver.getItem?.(l.key)??null:m);if(n==null)return !1;if(typeof n!="string")return d(t,`Persist driver for "${t}" returned a non-string value during async hydration. Persist payloads must resolve to strings before decrypt/deserialize runs.`),!0;if(typeof l.maxSize!="number"&&n.length>Q&&p?.(n.length),typeof l.maxSize=="number"&&n.length>l.maxSize)return d(t,`Persist payload for "${t}" exceeds maxSize (${n.length} > ${l.maxSize}). Skipping hydration.`),!0;let h=l.decryptAsync?await l.decryptAsync(n):l.decrypt(n),P=JSON.parse(h),{v:w=1,checksum:b$1,data:k,updatedAt:_,updatedAtMs:V}=P||{};if(k===void 0)return !0;let $=b({value:typeof V=="number"?V:_,fallbackMs:Date.now(),onInvalid:()=>{y(`persist: corrupt updatedAt in stored data for "${t}". Using current time to prevent sync overwrite.`);}}),j=await F(l.checksum,k,v);if(l.checksum!=="none"&&b$1!==j)return d(t,`Checksum mismatch loading store "${t}". Falling back to initial state.`),(!c||c())&&a(e(o()),Date.now(),{source:"storage",validate:i}),!0;let O=l.deserialize(k),E=S?.version??1,U=G({name:t,parsed:O,v:w,targetVersion:E,cfg:l,migrations:f,getInitialState:o,reportStoreError:d,sanitize:u,deepClone:e,validateState:i,safeUpdatedAt:$,applyFeatureState:a,shouldApply:c});return U.ok&&(!c||c())&&(a(U.state,$,{source:"storage",validate:i}),r||y(`Store "${t}" loaded from persistence`)),!0}catch(n){return T(t,d,n)}},G=({name:t,parsed:r,v:s,targetVersion:o,cfg:a,migrations:d,getInitialState:p,reportStoreError:g,sanitize:y,deepClone:v,validateState:e,safeUpdatedAt:u,applyFeatureState:c,shouldApply:m})=>{if(s!==o){let l=Object.keys(d).map(n=>Number(n)).filter(n=>n>s&&n<=o).sort((n,h)=>n-h);if(l.length===0){let n=R({name:t,persisted:r,reason:`No migration path from v${s} to v${o} for "${t}". Applying onMigrationFail strategy.`,persistConfig:a,initialState:p(),reportStoreError:g,sanitize:y,deepClone:v});if(r=n.state,!n.requiresValidation)return (!m||m())&&c(r,u,{source:"storage",validate:e}),{ok:false,state:r}}let f=false,i=true;if(l.forEach(n=>{if(!f)try{let h=d[n](r);h!==void 0&&(r=h);}catch(h){let P=R({name:t,persisted:r,reason:`Migration to v${n} failed for "${t}": ${h?.message||h}`,persistConfig:a,initialState:p(),reportStoreError:g,sanitize:y,deepClone:v});r=P.state,i=P.requiresValidation,f=true;}}),f){if(!i)return (!m||m())&&c(r,u,{source:"storage",validate:e}),{ok:false,state:r};let n=e(r);return n.ok?{ok:true,state:n.value??r}:((!m||m())&&c(v(p()),Date.now(),{source:"storage",validate:e}),{ok:false,state:r})}}let S=e(r);if(!S.ok){if(s!==o){let l=a?.onMigrationFail??"reset",f=R({name:t,persisted:r,reason:`Persisted state for "${t}" failed schema after version change. Applying onMigrationFail strategy.`,persistConfig:a,initialState:p(),reportStoreError:g,sanitize:y,deepClone:v});if(!f.requiresValidation)return (!m||m())&&c(f.state,u,{source:"storage",validate:e}),{ok:false,state:f.state};let i=e(f.state);if(i.ok)return l==="reset"&&g(t,`Persisted state for "${t}" failed schema; resetting to initial.`),{ok:true,state:i.value??f.state}}return g(t,`Persisted state for "${t}" failed schema; resetting to initial.`),(!m||m())&&c(v(p()),Date.now(),{source:"storage",validate:e}),{ok:false,state:r}}return {ok:true,state:S.value??r}};var ie=async t=>{try{let r=await Promise.resolve(t.driver.getItem?.(t.key)??null);if(typeof r!="string"||r.length===0)return null;let s=t.decryptAsync?await t.decryptAsync(r):t.decrypt(r),o=JSON.parse(s);if(!o||typeof o!="object")return null;let a=b({value:typeof o.updatedAtMs=="number"?o.updatedAtMs:o.updatedAt,fallbackMs:0});return Number.isFinite(a)?a:null}catch{return null}},Z=({name:t,persistTimers:r,persistInFlight:s,persistSequence:o,persistWatchState:a,plaintextWarningsIssued:d,exists:p,getMeta:g,getStoreValue:y,reportStoreError:v,hashState:e},u=false)=>{let c=g()?.options?.persist;if(!c)return;let m=async f=>{let i=g();if(!(!i?.options?.persist||i.options.persist!==c||!p())&&!(f!==void 0&&o[t]!==f)){if(!c.allowPlaintext&&!d.has(t)&&z(c.encrypt)&&z(c.decrypt)){d.add(t);let n=`[stroid/persist] Store '${t}' is persisted in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`;aa(i.options.onError,`onError(${t})`,n),P(n);}try{let n=typeof i.updatedAtMs=="number"?i.updatedAtMs:Date.now();if(i.options.sync){let k=await ie(c);if(k!=null&&k>n){D(a,t,!0);return}}let h=c.serialize(y()),P=await F(c.checksum,h,e),w=JSON.stringify({v:i.version??1,updatedAt:i.updatedAt,updatedAtMs:n,checksum:P,data:h}),b=c.encryptAsync?await c.encryptAsync(w):c.encrypt(w);if(f!==void 0&&o[t]!==f)return;await Promise.resolve(c.driver.setItem?.(c.key,b)),D(a,t,!0);}catch(n){v(t,`Could not persist store "${t}" (${n?.message||n})`);}}},S=f=>{let i=s[t],n=(o[t]??0)+1;o[t]=n;let P=(async()=>{i&&await i,!(f&&r[t]!==f)&&o[t]===n&&await m(n);})().finally(()=>{s[t]===P&&(s[t]=null),f&&r[t]===f&&delete r[t];});s[t]=P;};if(u){r[t]&&(clearTimeout(r[t]),delete r[t]),S();return}r[t]&&clearTimeout(r[t]);let l=setTimeout(()=>{r[t]===l&&S(l);},0);r[t]=l;},M=t=>Z(t),W=(t,r)=>Z({...r,name:t},true);var x=false,ae=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,ue=(()=>{if(typeof import.meta>"u")return;let t=Reflect.get(import.meta,"env");if(!t||typeof t!="object")return;let r=Reflect.get(t,"MODE");return typeof r=="string"?r:void 0})(),le=ae??ue,de=()=>le==="production",ce=()=>{let t={},r={},s=Object.create(null),o=Object.create(null),a=Object.create(null),d=new Set,p=new Set,g=Object.create(null),y=Object.create(null),v=e=>{e&&typeof e.then=="function"&&Promise.resolve(e).catch(()=>{});};return {api:{getPersistQueueDepth(e){return t[e]?1:0}},onStoreCreate(e){let u=e.options.persist;if(!u)return;if(!u.encryptAsync&&C(u.encrypt)&&C(u.decrypt)&&!u.allowPlaintext){let i=`[stroid/persist] Store "${e.name}" is configured for plaintext persistence. Provide encrypt/decrypt hooks or set persist.allowPlaintext: true to acknowledge.`;if(de()){e.reportStoreError(i),e.options.persist=null;return}e.warn(i);}if(u.sensitiveData&&!u.encryptAsync&&C(u.encrypt)){e.reportStoreError(`persist: store "${e.name}" is marked sensitiveData but has no encrypt function. Plaintext data will be written to storage.`);return}let m=K(e.name,u.encrypt,u.decrypt);if(!m.ok){e.reportStoreError(m.reason??`persist: encrypt/decrypt validation failed for store "${e.name}".`),e.options.persist=null;return}if(u.key){let i=o[u.key];i&&i!==e.name&&e.isDev()?e.warn(`Persist key collision: "${u.key}" already used by store "${i}". Store "${e.name}" will overwrite the same storage key.`):o[u.key]=e.name;}let S=e.getMeta()?.updateCount??0,l=()=>{let i=e.getMeta();return i?(i.updateCount??0)===S:false},f=N({name:e.name,silent:true,getMeta:e.getMeta,getInitialState:e.getInitialState,applyFeatureState:e.applyFeatureState,reportStoreError:(i,n)=>e.reportStoreError(n),warnMissingMaxSize:i=>{p.has(e.name)||(p.add(e.name),e.warnAlways(`[stroid/persist] Store "${e.name}" loaded ${i} bytes without a maxSize guard. Set persist.maxSize to prevent oversized payloads.`));},validate:e.validate,log:e.log,hashState:e.hashState,deepClone:e.deepClone,sanitize:e.sanitize,shouldApply:l});if(typeof f?.then=="function"?(g[e.name]={loading:true,pendingSave:false},f.then(i=>{let n=g[e.name];n&&(n.loading=false,(!i||n.pendingSave)&&M({name:e.name,persistTimers:t,persistInFlight:r,persistSequence:s,persistWatchState:a,plaintextWarningsIssued:d,exists:()=>e.hasStore(),getMeta:e.getMeta,getStoreValue:e.getStoreValue,reportStoreError:(h,P)=>e.reportStoreError(P),hashState:e.hashState}),delete g[e.name]);}).catch(()=>{let i=g[e.name];i&&(i.loading=false,i.pendingSave&&M({name:e.name,persistTimers:t,persistInFlight:r,persistSequence:s,persistWatchState:a,plaintextWarningsIssued:d,exists:()=>e.hasStore(),getMeta:e.getMeta,getStoreValue:e.getStoreValue,reportStoreError:(n,h)=>e.reportStoreError(h),hashState:e.hashState}),delete g[e.name]);})):f||M({name:e.name,persistTimers:t,persistInFlight:r,persistSequence:s,persistWatchState:a,plaintextWarningsIssued:d,exists:()=>e.hasStore(),getMeta:e.getMeta,getStoreValue:e.getStoreValue,reportStoreError:(i,n)=>e.reportStoreError(n),hashState:e.hashState}),typeof window<"u"&&typeof window.addEventListener=="function"){y[e.name]?.();let i=window,n=false,h=false,P=false,w=()=>{if(!n){if(n=true,h)try{i.removeEventListener("pagehide",b);}catch{}if(P)try{i.removeEventListener("beforeunload",b);}catch{}delete y[e.name];}},b=()=>{w(),W(e.name,{name:e.name,persistTimers:t,persistInFlight:r,persistSequence:s,persistWatchState:a,plaintextWarningsIssued:d,exists:()=>e.hasStore(),getMeta:e.getMeta,getStoreValue:e.getStoreValue,reportStoreError:(k,_)=>e.reportStoreError(_),hashState:e.hashState});};try{i.addEventListener("pagehide",b,{once:!0}),h=!0;}catch{}try{i.addEventListener("beforeunload",b,{once:!0}),P=!0;}catch{}(h||P)&&(y[e.name]=w);}I({name:e.name,persistConfig:u,persistWatchState:a});},onStoreWrite(e){if(!e.options.persist)return;let u=g[e.name];if(u?.loading){u.pendingSave=true;return}M({name:e.name,persistTimers:t,persistInFlight:r,persistSequence:s,persistWatchState:a,plaintextWarningsIssued:d,exists:()=>e.hasStore(),getMeta:e.getMeta,getStoreValue:e.getStoreValue,reportStoreError:(c,m)=>e.reportStoreError(m),hashState:e.hashState});},beforeStoreDelete(e){let u=e.options.persist;if(u){delete g[e.name],p.delete(e.name),t[e.name]&&(clearTimeout(t[e.name]),delete t[e.name]),r[e.name]=null,delete s[e.name];try{v(u.driver.removeItem?.(u.key));}catch{}u.key&&o[u.key]===e.name&&delete o[u.key],y[e.name]?.(),a[e.name]?.dispose(),delete y[e.name],delete a[e.name];}},resetAll(){Object.values(t).forEach(e=>clearTimeout(e)),Object.values(y).forEach(e=>{try{e();}catch{}}),Object.values(a).forEach(e=>{try{e.dispose();}catch{}}),Object.keys(t).forEach(e=>delete t[e]),Object.keys(r).forEach(e=>{r[e]=null,delete r[e];}),Object.keys(s).forEach(e=>delete s[e]),Object.keys(o).forEach(e=>delete o[e]),Object.keys(a).forEach(e=>delete a[e]),Object.keys(g).forEach(e=>delete g[e]),d.clear(),p.clear();}}},fe=()=>{x||(x=true,a("persist",ce));},Fe=()=>{fe();};export{Fe as a};//# sourceMappingURL=chunk-Y54SMROI.js.map
2
+ //# sourceMappingURL=chunk-Y54SMROI.js.map
@@ -1,9 +1,10 @@
1
- import { d as StoreName, a as StoreDefinition, S as StoreValue, b as StoreKey, e as StateFor } from './types.js';
1
+ import { a as StoreDefinition, S as StoreValue, b as StoreKey, d as StoreName, e as StateFor } from './types.js';
2
2
  import { S as StoreRegistry } from './store-registry.js';
3
- import { RuntimeNodeId, ComputedDescriptor, RuntimeGraph, ComputedClassification } from './computed-types.js';
4
- export { RuntimeEdgeType, RuntimeGraphEdge, RuntimeGraphGranularity, RuntimeGraphNode, RuntimeNodeType } from './computed-types.js';
3
+ import { f as RuntimeNodeId, a as ComputedDescriptor, R as RuntimeGraph, C as ComputedClassification } from './types-internal-3.js';
4
+ export { b as RuntimeEdgeType, c as RuntimeGraphEdge, d as RuntimeGraphGranularity, e as RuntimeGraphNode, g as RuntimeNodeType } from './types-internal-3.js';
5
+ import './types-internal-2.js';
5
6
  import './feature.js';
6
- import './options.js';
7
+ import './types-internal.js';
7
8
  import './utility.js';
8
9
  import './runtime-patch.js';
9
10
  import './registry.js';
@@ -50,4 +51,4 @@ declare const isComputedStore: (name: string) => boolean;
50
51
  declare const shouldAutoDisposeComputed: (name: string, registry?: StoreRegistry) => boolean;
51
52
  declare const _resetComputedForTests: () => void;
52
53
 
53
- export { ComputedClassification, ComputedDescriptor, type ComputedOptions, RuntimeGraph, RuntimeNodeId, _resetComputedForTests, createComputed, deleteComputed, evaluateComputedFromSnapshot, getComputedDepsFor, getComputedDescriptor, getFullComputedGraph, getRuntimeComputedGraph, invalidateComputed, isComputedStore, shouldAutoDisposeComputed };
54
+ export { ComputedClassification, ComputedDescriptor, type ComputedOptions, type DepHandle, type DepValue, RuntimeGraph, RuntimeNodeId, _resetComputedForTests, createComputed, deleteComputed, evaluateComputedFromSnapshot, getComputedDepsFor, getComputedDescriptor, getFullComputedGraph, getRuntimeComputedGraph, invalidateComputed, isComputedStore, shouldAutoDisposeComputed };
package/dist/computed.js CHANGED
@@ -1,2 +1,2 @@
1
- export{$ as _resetComputedForTests,W as createComputed,Y as deleteComputed,F as evaluateComputedFromSnapshot,D as getComputedDepsFor,B as getComputedDescriptor,C as getFullComputedGraph,E as getRuntimeComputedGraph,X as invalidateComputed,Z as isComputedStore,_ as shouldAutoDisposeComputed}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';//# sourceMappingURL=computed.js.map
1
+ export{D as _resetComputedForTests,y as createComputed,A as deleteComputed,k as evaluateComputedFromSnapshot,i as getComputedDepsFor,g as getComputedDescriptor,h as getFullComputedGraph,j as getRuntimeComputedGraph,z as invalidateComputed,B as isComputedStore,C as shouldAutoDisposeComputed}from'./chunk-X2MKRN7O.js';import'./chunk-6IBJ7CIK.js';import'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';//# sourceMappingURL=computed.js.map
2
2
  //# sourceMappingURL=computed.js.map
@@ -0,0 +1,23 @@
1
+ import { StoreFeatureMeta } from './feature.js';
2
+
3
+ declare const listStores: (pattern?: string) => string[];
4
+ declare const getStoreMeta: (name: string) => StoreFeatureMeta | null;
5
+ declare const getInitialState: () => Record<string, unknown>;
6
+ declare const getMetrics: (name: string) => StoreFeatureMeta["metrics"] | null;
7
+ declare const getSubscriberCount: (name: string) => number;
8
+ type ColdStoreReport = {
9
+ name: string;
10
+ createdAt: string;
11
+ lastReadAt: string | null;
12
+ updateCount: number;
13
+ readCount: number;
14
+ subscriberCount: number;
15
+ ageMs: number;
16
+ verdict: "cold" | "write-only" | "stale" | "active";
17
+ };
18
+ declare const findColdStores: (options?: {
19
+ unreadThresholdMs?: number;
20
+ includeWriteOnly?: boolean;
21
+ }) => ColdStoreReport[];
22
+
23
+ export { type ColdStoreReport as C, getInitialState as a, getMetrics as b, getSubscriberCount as c, findColdStores as f, getStoreMeta as g, listStores as l };
package/dist/core.d.ts CHANGED
@@ -1,5 +1,6 @@
1
- export { c as createStore, d as deleteStore, b as getStore, h as hasStore, r as resetStore, s as setStore } from './index-internal.js';
2
- import './options.js';
1
+ export { f as createStore, h as deleteStore, j as getStore, k as hasStore, r as resetStore, s as setStore } from './index-internal.js';
2
+ import './types-internal.js';
3
3
  import './utility.js';
4
4
  import './types.js';
5
+ import './types-internal-2.js';
5
6
  import './feature.js';
package/dist/core.js CHANGED
@@ -1,2 +1,2 @@
1
- export{K as createStore,ra as deleteStore,M as getStore,N as hasStore,sa as resetStore,U as setStore}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';//# sourceMappingURL=core.js.map
1
+ export{l as createStore,X as deleteStore,n as getStore,o as hasStore,Y as resetStore,w as setStore}from'./chunk-X2MKRN7O.js';import'./chunk-6IBJ7CIK.js';import'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';//# sourceMappingURL=core.js.map
2
2
  //# sourceMappingURL=core.js.map
@@ -0,0 +1,26 @@
1
+ import { a as StoreValue } from './types-internal.js';
2
+
3
+ /**
4
+ * @module features/devtools
5
+ *
6
+ * LAYER: Feature runtime
7
+ * OWNS: Module-level behavior and exports for features/devtools.
8
+ *
9
+ * Consumers: Internal imports and public API.
10
+ */
11
+
12
+ type HistoryDiff = {
13
+ added: string[];
14
+ removed: string[];
15
+ changed: string[];
16
+ } | null;
17
+ type HistoryEntry = {
18
+ ts: number;
19
+ action: string;
20
+ prev: StoreValue;
21
+ next: StoreValue;
22
+ diff: HistoryDiff;
23
+ };
24
+ declare const installDevtools: () => void;
25
+
26
+ export { type HistoryEntry as H, type HistoryDiff as a, installDevtools as i };
@@ -1,30 +1,9 @@
1
- import { a as StoreValue } from './options.js';
2
- export { installDevtools } from './install.js';
1
+ import { H as HistoryEntry } from './devtools-internal.js';
2
+ export { a as HistoryDiff, i as installDevtools } from './devtools-internal.js';
3
+ import './types-internal.js';
3
4
  import './utility.js';
4
5
 
5
- /**
6
- * @module features/devtools
7
- *
8
- * LAYER: Feature runtime
9
- * OWNS: Module-level behavior and exports for features/devtools.
10
- *
11
- * Consumers: Internal imports and public API.
12
- */
13
-
14
- type HistoryDiff = {
15
- added: string[];
16
- removed: string[];
17
- changed: string[];
18
- } | null;
19
- type HistoryEntry = {
20
- ts: number;
21
- action: string;
22
- prev: StoreValue;
23
- next: StoreValue;
24
- diff: HistoryDiff;
25
- };
26
-
27
6
  declare const getHistory: (name: string, limit?: number) => HistoryEntry[];
28
7
  declare const clearHistory: (name?: string) => void;
29
8
 
30
- export { type HistoryDiff, type HistoryEntry, clearHistory, getHistory };
9
+ export { HistoryEntry, clearHistory, getHistory };
package/dist/devtools.js CHANGED
@@ -1,2 +1,2 @@
1
- export{c as installDevtools}from'./chunk-PVATWAY4.js';import {H}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';var s=(t,r)=>H("devtools")?.getHistory?.(t,r)??[],i=t=>{H("devtools")?.clearHistory?.(t);};export{i as clearHistory,s as getHistory};//# sourceMappingURL=devtools.js.map
1
+ export{a as installDevtools}from'./chunk-NFT6AZXY.js';import {d}from'./chunk-X2MKRN7O.js';import'./chunk-6IBJ7CIK.js';import'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';var s=(t,r)=>d("devtools")?.getHistory?.(t,r)??[],i=t=>{d("devtools")?.clearHistory?.(t);};export{i as clearHistory,s as getHistory};//# sourceMappingURL=devtools.js.map
2
2
  //# sourceMappingURL=devtools.js.map
package/dist/feature.d.ts CHANGED
@@ -1,5 +1,6 @@
1
- import { N as NormalizedOptions, a as StoreValue } from './options.js';
1
+ import { N as NormalizedOptions, a as StoreValue } from './types-internal.js';
2
2
  import { T as TraceContext } from './utility.js';
3
+ import { d as HydrationConsistencySource } from './types-internal-2.js';
3
4
 
4
5
  /**
5
6
  * @module feature-registry
@@ -45,7 +46,13 @@ interface FeatureHookContext {
45
46
  getInitialState: () => StoreValue;
46
47
  hasStore: () => boolean;
47
48
  setStoreValue: (value: StoreValue) => void;
48
- applyFeatureState: (value: StoreValue, updatedAtMs?: number) => void;
49
+ applyFeatureState: (value: StoreValue, updatedAtMs?: number, options?: {
50
+ source?: HydrationConsistencySource;
51
+ validate?: (candidate: StoreValue) => {
52
+ ok: boolean;
53
+ value?: StoreValue;
54
+ };
55
+ }) => StoreValue;
49
56
  notify: () => void;
50
57
  reportStoreError: (message: string) => void;
51
58
  warn: (message: string) => void;
package/dist/feature.js CHANGED
@@ -1,2 +1,2 @@
1
- export{e as getRegisteredFeatureNames,c as hasRegisteredStoreFeature,b as registerStoreFeature}from'./chunk-KQCSFGHJ.js';//# sourceMappingURL=feature.js.map
1
+ export{d as getRegisteredFeatureNames,b as hasRegisteredStoreFeature,a as registerStoreFeature}from'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';//# sourceMappingURL=feature.js.map
2
2
  //# sourceMappingURL=feature.js.map
@@ -0,0 +1,2 @@
1
+ export{f as _resetAsyncStateForTests,d as cleanupAllRevalidateHandlers,c as enableRevalidateOnFocus,a as fetchStore,e as getAsyncMetrics,b as refetchStore}from'./chunk-LWUT37FW.js';import'./chunk-E33L4MII.js';import'./chunk-X2MKRN7O.js';import'./chunk-6IBJ7CIK.js';import'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';//# sourceMappingURL=fetch-4RH6MPY3.js.map
2
+ //# sourceMappingURL=fetch-4RH6MPY3.js.map
@@ -0,0 +1,20 @@
1
+ import { f as RuntimeNodeId, a as ComputedDescriptor, R as RuntimeGraph } from './types-internal-3.js';
2
+
3
+ declare const getComputedGraph: () => {
4
+ nodes: string[];
5
+ edges: Array<{
6
+ from: string;
7
+ to: string;
8
+ }>;
9
+ dependencies: Record<string, string[]>;
10
+ dependents: Record<string, string[]>;
11
+ };
12
+ declare const getRuntimeGraph: () => RuntimeGraph;
13
+ declare const getComputedDeps: (name: string) => {
14
+ deps: string[];
15
+ dependents: string[];
16
+ } | null;
17
+ declare const getComputedDescriptor: (nodeId: RuntimeNodeId) => ComputedDescriptor | null;
18
+ declare const evaluateComputed: (nodeId: RuntimeNodeId, snapshot: Record<string, unknown>) => unknown;
19
+
20
+ export { getComputedDeps as a, getComputedGraph as b, getRuntimeGraph as c, evaluateComputed as e, getComputedDescriptor as g };
package/dist/helpers.d.ts CHANGED
@@ -1,5 +1,6 @@
1
1
  import { W as WriteResult } from './types.js';
2
- import { S as StoreOptions } from './options.js';
2
+ import { S as StoreOptions } from './types-internal.js';
3
+ import './types-internal-2.js';
3
4
  import './utility.js';
4
5
 
5
6
  declare const createCounterStore: (name: string, initial?: number, options?: StoreOptions<{
package/dist/helpers.js CHANGED
@@ -1,2 +1,2 @@
1
- import {P,K,M,sa,U}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';var a=0,S=(n,o=0,i={})=>{let e=P(n);return K(n,{value:o},i),{inc:(t=1)=>U(e,s=>{s.value+=t;}),dec:(t=1)=>U(e,s=>{s.value-=t;}),set:t=>U(e,"value",t),reset:()=>sa(e),get:()=>M(e,"value")}},v=(n,o=[],i={})=>{let e=P(n);return K(n,{items:o},i),{push:t=>U(e,s=>{s.items.push(t);}),removeAt:t=>U(e,s=>{s.items.splice(t,1);}),clear:()=>U(e,t=>{t.items=[];}),replace:t=>U(e,s=>{s.items=t;}),all:()=>{let t=M(e,"items");return t?[...t]:[]}}},h=(n,o={})=>{let i=P(n);return K(n,{entities:{},ids:[]},o),{upsert:e=>U(i,t=>{let s=e.id??e._id??(typeof crypto<"u"&&crypto.randomUUID?crypto.randomUUID():`e_${++a}_${Date.now()}`);t.ids.includes(s)||t.ids.push(s),t.entities[s]=e;}),remove:e=>U(i,t=>{t.ids=t.ids.filter(s=>s!==e),delete t.entities[e];}),all:()=>{let t=M(i);return t?t.ids.map(s=>t.entities[s]):[]},get:e=>{let t=M(i,"entities");return t?t[e]??null:null},clear:()=>sa(i)}};export{S as createCounterStore,h as createEntityStore,v as createListStore};//# sourceMappingURL=helpers.js.map
1
+ import {q,l,n,Y,w}from'./chunk-X2MKRN7O.js';import'./chunk-6IBJ7CIK.js';import'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';var p=0,v=(i,o=0,n$1={})=>{let e=q(i);return l(i,{value:o},n$1),{inc:(t=1)=>w(e,s=>{s.value+=t;}),dec:(t=1)=>w(e,s=>{s.value-=t;}),set:t=>w(e,"value",t),reset:()=>Y(e),get:()=>n(e,"value")}},h=(i,o=[],n$1={})=>{let e=q(i);return l(i,{items:o},n$1),{push:t=>w(e,s=>{s.items.push(t);}),removeAt:t=>w(e,s=>{s.items.splice(t,1);}),clear:()=>w(e,t=>{t.items=[];}),replace:t=>w(e,s=>{s.items=t;}),all:()=>{let t=n(e,"items");return t?[...t]:[]}}},R=(i,o={})=>{let n$1=q(i);return l(i,{entities:{},ids:[]},o),{upsert:e=>w(n$1,t=>{let s=(()=>{let l=Reflect.get(globalThis,"crypto");if(!l||typeof l!="object")return null;let d=Reflect.get(l,"randomUUID");if(typeof d!="function")return null;try{return d.call(l)}catch{return null}})(),m=e.id??e._id??(s||`e_${++p}_${Date.now()}`);t.ids.includes(m)||t.ids.push(m),t.entities[m]=e;}),remove:e=>w(n$1,t=>{t.ids=t.ids.filter(s=>s!==e),delete t.entities[e];}),all:()=>{let t=n(n$1);return t?t.ids.map(s=>t.entities[s]):[]},get:e=>{let t=n(n$1,"entities");return t?t[e]??null:null},clear:()=>Y(n$1)}};export{v as createCounterStore,R as createEntityStore,h as createListStore};//# sourceMappingURL=helpers.js.map
2
2
  //# sourceMappingURL=helpers.js.map
@@ -1,24 +1,8 @@
1
- import { S as StoreOptions } from './options.js';
1
+ import { S as StoreOptions } from './types-internal.js';
2
2
  import { N as NonFunction } from './utility.js';
3
- import { S as StoreValue, a as StoreDefinition, b as StoreKey, d as StoreName, i as Path, e as StateFor, j as PathValue, W as WriteResult, P as PartialDeep } from './types.js';
3
+ import { a as StoreDefinition, k as Path, n as PathValue, b as StoreKey, d as StoreName, e as StateFor, S as StoreValue, P as PartialDeep, W as WriteResult } from './types.js';
4
4
  import { FeatureMetrics } from './feature.js';
5
5
 
6
- type IsStoreNameLoose = string extends StoreName ? true : false;
7
- type StoreUpdate<State> = State | Partial<State> | PartialDeep<State> | ((draft: State) => void);
8
- type StoreTarget<Name extends string = string, State = StoreValue> = StoreDefinition<Name, State> | StoreKey<Name, State> | StoreName;
9
- type StorePathForTarget<T> = T extends StoreDefinition<any, infer S> ? Path<S> : T extends StoreKey<any, infer S> ? Path<S> : (IsStoreNameLoose extends true ? string | string[] : (T extends StoreName ? Path<StateFor<T>> : string | string[]));
10
- type StorePathValueForTarget<T, P> = T extends StoreDefinition<any, infer S> ? (P extends Path<S> ? PathValue<S, P> : never) : T extends StoreKey<any, infer S> ? (P extends Path<S> ? PathValue<S, P> : never) : (IsStoreNameLoose extends true ? unknown : (T extends StoreName ? (P extends Path<StateFor<T>> ? PathValue<StateFor<T>, P> : never) : unknown));
11
- type StoreUpdateForTarget<T> = T extends StoreDefinition<any, infer S> ? StoreUpdate<S> : T extends StoreKey<any, infer S> ? StoreUpdate<S> : (IsStoreNameLoose extends true ? StoreUpdate<StoreValue> : (T extends StoreName ? StoreUpdate<StateFor<T>> : StoreUpdate<StoreValue>));
12
- declare function setStore<T extends StoreTarget, P extends StorePathForTarget<T>>(name: T, path: P, value: StorePathValueForTarget<T, P>): WriteResult;
13
- declare function setStore<T extends StoreTarget>(name: T, update: StoreUpdateForTarget<T>): WriteResult;
14
-
15
- declare function deleteStore<Name extends string, State>(name: StoreDefinition<Name, State>): void;
16
- declare function deleteStore<Name extends string, State>(name: StoreKey<Name, State>): void;
17
- declare function deleteStore<Name extends StoreName>(name: Name): void;
18
- declare function resetStore<Name extends string, State>(name: StoreDefinition<Name, State>): WriteResult;
19
- declare function resetStore<Name extends string, State>(name: StoreKey<Name, State>): WriteResult;
20
- declare function resetStore<Name extends StoreName>(name: Name): WriteResult;
21
-
22
6
  type LazyDisallow<T> = T extends {
23
7
  lazy: true;
24
8
  } ? never : T;
@@ -41,4 +25,20 @@ declare function getStore<Name extends StoreName>(name: Name, path?: undefined):
41
25
  declare const hasStore: (name: string) => boolean;
42
26
  declare const getMetrics: (name: string) => FeatureMetrics | null;
43
27
 
44
- export { createStoreStrict as a, getStore as b, createStore as c, deleteStore as d, getMetrics as g, hasStore as h, resetStore as r, setStore as s };
28
+ type IsStoreNameLoose = string extends StoreName ? true : false;
29
+ type StoreUpdate<State> = State | Partial<State> | PartialDeep<State> | ((draft: State) => void);
30
+ type StoreTarget<Name extends string = string, State = StoreValue> = StoreDefinition<Name, State> | StoreKey<Name, State> | StoreName;
31
+ type StorePathForTarget<T> = T extends StoreDefinition<infer _Name extends string, infer S> ? Path<S> : T extends StoreKey<infer _Name extends string, infer S> ? Path<S> : (IsStoreNameLoose extends true ? string | string[] : (T extends StoreName ? Path<StateFor<T>> : string | string[]));
32
+ type StorePathValueForTarget<T, P> = T extends StoreDefinition<infer _Name extends string, infer S> ? (P extends Path<S> ? PathValue<S, P> : never) : T extends StoreKey<infer _Name extends string, infer S> ? (P extends Path<S> ? PathValue<S, P> : never) : (IsStoreNameLoose extends true ? unknown : (T extends StoreName ? (P extends Path<StateFor<T>> ? PathValue<StateFor<T>, P> : never) : unknown));
33
+ type StoreUpdateForTarget<T> = T extends StoreDefinition<infer _Name extends string, infer S> ? StoreUpdate<S> : T extends StoreKey<infer _Name extends string, infer S> ? StoreUpdate<S> : (IsStoreNameLoose extends true ? StoreUpdate<StoreValue> : (T extends StoreName ? StoreUpdate<StateFor<T>> : StoreUpdate<StoreValue>));
34
+ declare function setStore<T extends StoreTarget, P extends StorePathForTarget<T>>(name: T, path: P, value: StorePathValueForTarget<T, P>): WriteResult;
35
+ declare function setStore<T extends StoreTarget>(name: T, update: StoreUpdateForTarget<T>): WriteResult;
36
+
37
+ declare function deleteStore<Name extends string, State>(name: StoreDefinition<Name, State>): void;
38
+ declare function deleteStore<Name extends string, State>(name: StoreKey<Name, State>): void;
39
+ declare function deleteStore<Name extends StoreName>(name: Name): void;
40
+ declare function resetStore<Name extends string, State>(name: StoreDefinition<Name, State>): WriteResult;
41
+ declare function resetStore<Name extends string, State>(name: StoreKey<Name, State>): WriteResult;
42
+ declare function resetStore<Name extends StoreName>(name: Name): WriteResult;
43
+
44
+ export { type IsStoreNameLoose as I, type LazyDisallow as L, type StorePathForTarget as S, type StorePathValueForTarget as a, type StoreSnapshot as b, type StoreTarget as c, type StoreUpdate as d, type StoreUpdateForTarget as e, createStore as f, createStoreStrict as g, deleteStore as h, getMetrics as i, getStore as j, hasStore as k, resetStore as r, setStore as s };