stroid 0.1.2 → 0.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/CHANGELOG.md +27 -2
  2. package/dist/async.js +22 -22
  3. package/dist/async.js.map +1 -1
  4. package/dist/computed.d.ts +7 -1
  5. package/dist/computed.js +11 -11
  6. package/dist/computed.js.map +1 -1
  7. package/dist/core.js +14 -14
  8. package/dist/core.js.map +1 -1
  9. package/dist/devtools.js +1 -1
  10. package/dist/devtools.js.map +1 -1
  11. package/dist/feature.js.map +1 -1
  12. package/dist/helpers.js +14 -14
  13. package/dist/helpers.js.map +1 -1
  14. package/dist/index.d.cts +1 -0
  15. package/dist/index.d.ts +1 -0
  16. package/dist/index.js +24 -24
  17. package/dist/index.js.map +1 -1
  18. package/dist/install.js +1 -1
  19. package/dist/install.js.map +1 -1
  20. package/dist/persist.js +1 -1
  21. package/dist/persist.js.map +1 -1
  22. package/dist/react/index.js +25 -25
  23. package/dist/react/index.js.map +1 -1
  24. package/dist/runtime-admin.js +1 -1
  25. package/dist/runtime-admin.js.map +1 -1
  26. package/dist/runtime-tools.js +2 -2
  27. package/dist/runtime-tools.js.map +1 -1
  28. package/dist/selectors.js +1 -1
  29. package/dist/selectors.js.map +1 -1
  30. package/dist/server.js +11 -11
  31. package/dist/server.js.map +1 -1
  32. package/dist/store-registry.d.ts +0 -1
  33. package/dist/sync.js +1 -1
  34. package/dist/sync.js.map +1 -1
  35. package/dist/testing.js +14 -14
  36. package/dist/testing.js.map +1 -1
  37. package/package.json +4 -1
  38. package/dist/types/adapters/options.d.ts +0 -335
  39. package/dist/types/async/cache.d.ts +0 -39
  40. package/dist/types/async/clone.d.ts +0 -10
  41. package/dist/types/async/errors.d.ts +0 -3
  42. package/dist/types/async/fetch.d.ts +0 -37
  43. package/dist/types/async/inflight.d.ts +0 -13
  44. package/dist/types/async/rate.d.ts +0 -5
  45. package/dist/types/async/registry.d.ts +0 -116
  46. package/dist/types/async/request.d.ts +0 -11
  47. package/dist/types/async/retry.d.ts +0 -10
  48. package/dist/types/async.d.ts +0 -10
  49. package/dist/types/computed/computed-graph.d.ts +0 -29
  50. package/dist/types/computed/index.d.ts +0 -16
  51. package/dist/types/config.d.ts +0 -10
  52. package/dist/types/core/index.d.ts +0 -11
  53. package/dist/types/core/lifecycle-hooks.d.ts +0 -16
  54. package/dist/types/core/store-admin-impl.d.ts +0 -9
  55. package/dist/types/core/store-admin.d.ts +0 -9
  56. package/dist/types/core/store-core.d.ts +0 -13
  57. package/dist/types/core/store-create.d.ts +0 -16
  58. package/dist/types/core/store-hydrate-impl.d.ts +0 -35
  59. package/dist/types/core/store-hydrate.d.ts +0 -9
  60. package/dist/types/core/store-lifecycle/hooks.d.ts +0 -19
  61. package/dist/types/core/store-lifecycle/identity.d.ts +0 -23
  62. package/dist/types/core/store-lifecycle/registry.d.ts +0 -53
  63. package/dist/types/core/store-lifecycle/types.d.ts +0 -67
  64. package/dist/types/core/store-lifecycle/validation.d.ts +0 -53
  65. package/dist/types/core/store-name.d.ts +0 -28
  66. package/dist/types/core/store-notify.d.ts +0 -12
  67. package/dist/types/core/store-read.d.ts +0 -18
  68. package/dist/types/core/store-registry.d.ts +0 -108
  69. package/dist/types/core/store-replace-impl.d.ts +0 -11
  70. package/dist/types/core/store-replace.d.ts +0 -9
  71. package/dist/types/core/store-set-impl.d.ts +0 -13
  72. package/dist/types/core/store-set.d.ts +0 -9
  73. package/dist/types/core/store-shared/core.d.ts +0 -13
  74. package/dist/types/core/store-shared/notify.d.ts +0 -12
  75. package/dist/types/core/store-transaction.d.ts +0 -26
  76. package/dist/types/core/store-write-shared.d.ts +0 -19
  77. package/dist/types/core/store-write.d.ts +0 -13
  78. package/dist/types/features/feature-registry.d.ts +0 -91
  79. package/dist/types/features/lifecycle.d.ts +0 -40
  80. package/dist/types/index.d.ts +0 -17
  81. package/dist/types/integrations/query.d.ts +0 -8
  82. package/dist/types/internals/computed-order.d.ts +0 -3
  83. package/dist/types/internals/config.d.ts +0 -116
  84. package/dist/types/internals/diagnostics.d.ts +0 -21
  85. package/dist/types/internals/reporting.d.ts +0 -9
  86. package/dist/types/internals/store-admin.d.ts +0 -7
  87. package/dist/types/internals/store-ops.d.ts +0 -13
  88. package/dist/types/internals/test-reset.d.ts +0 -2
  89. package/dist/types/internals/write-context.d.ts +0 -15
  90. package/dist/types/notification/delivery.d.ts +0 -3
  91. package/dist/types/notification/index.d.ts +0 -10
  92. package/dist/types/notification/metrics.d.ts +0 -12
  93. package/dist/types/notification/priority.d.ts +0 -9
  94. package/dist/types/notification/scheduler.d.ts +0 -11
  95. package/dist/types/notification/snapshot.d.ts +0 -8
  96. package/dist/types/runtime-admin/index.d.ts +0 -2
  97. package/dist/types/runtime-tools/index.d.ts +0 -58
  98. package/dist/types/store.d.ts +0 -16
  99. package/dist/types/types/utility.d.ts +0 -17
  100. package/dist/types/utils/clone.d.ts +0 -4
  101. package/dist/types/utils/devfreeze.d.ts +0 -2
  102. package/dist/types/utils/hash.d.ts +0 -8
  103. package/dist/types/utils/path.d.ts +0 -5
  104. package/dist/types/utils/validation.d.ts +0 -14
  105. package/dist/types/utils.d.ts +0 -13
@@ -1,4 +1,9 @@
1
1
  import { c as StoreName, a as StoreDefinition, d as StoreValue, b as StoreKey, e as StateFor } from './types.js';
2
+ import { S as StoreRegistry } from './store-registry.js';
3
+ import './feature.js';
4
+ import './options.js';
5
+ import './utility.js';
6
+ import './registry.js';
2
7
 
3
8
  /**
4
9
  * @module computed-graph
@@ -35,6 +40,7 @@ declare function createComputed<TResult, Deps extends readonly (StoreName | DepH
35
40
  declare const invalidateComputed: (name: string) => void;
36
41
  declare const deleteComputed: (name: string) => void;
37
42
  declare const isComputedStore: (name: string) => boolean;
43
+ declare const shouldAutoDisposeComputed: (name: string, registry?: StoreRegistry) => boolean;
38
44
  declare const _resetComputedForTests: () => void;
39
45
 
40
- export { type ComputedOptions, _resetComputedForTests, createComputed, deleteComputed, getComputedDepsFor, getFullComputedGraph, invalidateComputed, isComputedStore };
46
+ export { type ComputedOptions, _resetComputedForTests, createComputed, deleteComputed, getComputedDepsFor, getFullComputedGraph, invalidateComputed, isComputedStore, shouldAutoDisposeComputed };
package/dist/computed.js CHANGED
@@ -1,13 +1,13 @@
1
- var Lo=new Map,v=(e,t,r=0)=>{!e||typeof t!="function"||Lo.set(e,{name:e,order:r,fn:t});};var xt=new Map;var Ge=e=>xt.has(e),Ke=e=>xt.get(e),fe=()=>Array.from(xt.keys());var ur=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),dr=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,warnedOnce:ur(),storeCleanups:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}}),pr=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(o=>{try{o();}catch{}});});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.storeCleanups).forEach(t=>delete e.storeCleanups[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),ur().forEach((t,r)=>{e.warnedOnce.set(r,t);}),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var Rt=new Map,fr=new WeakSet,Ct=e=>{fr.has(e)||(fr.add(e),fe().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Ke(t);r&&e.featureRuntimes.set(t,r());}}));},qo=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,gr,Mt=e=>(gr||qo||e).replace(/\.ts(\?|$)/,".js$1"),ge=Mt(new URL("../../store.js",import.meta.url).href);var Uo=()=>{gr=void 0,Rt.clear();};v("registry.scope-override",Uo,110);var Go=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Ko=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},yr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),Yo=(e="default")=>{let t={scope:e,stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:yr(),async:dr(),notify:Go(),lifecycleListener:null};return Ct(t),t},ye=e=>{let t=Mt(e),r=Rt.get(t);if(r)return r;let o=Yo();return Rt.set(t,o),o},Se=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),Sr=(e,t)=>e.deletingStores.has(t),mr=e=>{e.computedCleanups.forEach(t=>{try{t();}catch{}}),e.computedCleanups.clear(),[e.stores,e.subscribers,e.initialStates,e.initialFactories,e.metaEntries,e.snapshotCache,e.computedEntries,e.computedDependents].forEach(t=>{Object.keys(t).forEach(r=>{delete t[r];});}),e.deletingStores.clear(),e.transaction.depth=0,e.transaction.pending=[],e.transaction.stagedValues.clear(),e.transaction.snapshotCache.clear(),e.transaction.failed=false,e.transaction.error=void 0,Ko(e.notify),pr(e.async),e.lifecycleListener=null;};var Ye=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var Fe=()=>null,Y=[],br={run:(e,t)=>{Y.push(e);try{return t()}finally{Y.pop();}},get:()=>Y.length>0?Y[Y.length-1]:null,enterWith:e=>{if(Y.length>0){Y[Y.length-1]=e;return}Y.push(e);}};var Je=(e,t)=>(br).run(e,t),J=e=>(br).get()||e||ye(ge);var Xo={log:(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},warn:(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},critical:(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));}},wr={logSink:Xo,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",autoCorrelationIds:false,acknowledgeLooseTypes:false,pathCacheSize:500,defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0,selectorCloneFrozen:true},Ft=e=>({logSink:{...e.logSink},flush:{...e.flush},revalidateOnFocus:{...e.revalidateOnFocus},namespace:e.namespace,strictMissingFeatures:e.strictMissingFeatures,assertRuntime:e.assertRuntime,strictMutatorReturns:e.strictMutatorReturns,asyncAutoCreate:e.asyncAutoCreate,asyncCloneResult:e.asyncCloneResult,autoCorrelationIds:e.autoCorrelationIds,acknowledgeLooseTypes:e.acknowledgeLooseTypes,pathCacheSize:e.pathCacheSize,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce,selectorCloneFrozen:e.selectorCloneFrozen}),Et=new WeakMap,vr=Ft(wr),Qo=e=>{let t=Et.get(e);return t||(t=Ft(vr),Et.set(e,t)),t};var x=()=>Qo(J());var rn=()=>{Et=new WeakMap,vr=Ft(wr);};v("config.reset",rn,90);var kr=()=>x().namespace;var on=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,nn=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,xr=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,sn="production",an=on??nn??sn,Te=typeof xr=="boolean"?xr:an!=="production",w=()=>Te,Tt=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},cn=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},ln=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},ie=(e,t)=>{if((x().logSink.critical??cn)(e,t),x().assertRuntime)throw new Error(e)},d=(e,t)=>{if(!Te)return;if((x().logSink.warn??Tt)(e,t),x().assertRuntime)throw new Error(e)},L=(e,t)=>{if((x().logSink.warn??Tt)(e,t),x().assertRuntime)throw new Error(e)},I=(e,t)=>{if(Te&&(x().logSink.warn??Tt)(e,t),ie(e,t),x().assertRuntime)throw new Error(e)},$=(e,t)=>{if(!Te)return;(x().logSink.log??ln)(e,t);},Rr=()=>`Functions cannot be stored in stroid.
2
- Store data only - handle functions outside the store.`,Cr=()=>`Map/Set detected. stroid converts these to plain objects.
3
- Use arrays or plain objects for best results.`,Mr=()=>`Date object detected. stroid stores it as ISO string.
4
- Use new Date(value) to convert back when reading.`,Er=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Fr=()=>"Map detected; converting to plain object.",Tr=()=>"Set detected; converting to array.",Ar=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,jr=e=>`Store name "${e}" contains spaces.
5
- Use camelCase or kebab-case: "userName" or "user-name"`,Pr=e=>`Store name "${e}" is not allowed.
6
- Reserved names: "__proto__", "constructor", "prototype".`,un=128,dn=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=un,pn=(e,t)=>{if(e===t)return 0;if(e.length===0)return t.length;if(t.length===0)return e.length;let r=Array.from({length:e.length+1},(n,s)=>s),o=new Array(e.length+1);for(let n=1;n<=t.length;n++){o[0]=n;for(let s=1;s<=e.length;s++)o[s]=t[n-1]===e[s-1]?r[s-1]:Math.min(r[s-1],o[s-1],r[s])+1;[r,o]=[o,r];}return r[e.length]},Ot=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||dn(n,s)&&pn(n,s)<=2});if(r){d(`Store "${e}" not found. Did you mean "${r}"?`);return}I(`Store "${e}" not found.
1
+ var Uo=new Map,x=(e,t,r=0)=>{!e||typeof t!="function"||Uo.set(e,{name:e,order:r,fn:t});};var Ct=new Map;var Ye=e=>Ct.has(e),Je=e=>Ct.get(e),ge=()=>Array.from(Ct.keys());var pr=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),fr=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,warnedOnce:pr(),storeCleanups:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}}),gr=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(o=>{try{o();}catch{}});});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.storeCleanups).forEach(t=>delete e.storeCleanups[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),pr().forEach((t,r)=>{e.warnedOnce.set(r,t);}),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var Mt=new Map,yr=new WeakSet,Et=e=>{yr.has(e)||(yr.add(e),ge().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Je(t);r&&e.featureRuntimes.set(t,r());}}));},Ko=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,Sr,Ft=e=>(Sr||Ko||e).replace(/\.ts(\?|$)/,".js$1"),ye=Ft("stroid:default-registry");var Yo=()=>{Sr=void 0,Mt.clear();};x("registry.scope-override",Yo,110);var Jo=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Xo=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},mr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),Qo=(e="default")=>{let t={scope:e,stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:mr(),async:fr(),notify:Jo(),lifecycleListener:null};return Et(t),t},Se=e=>{let t=Ft(e),r=Mt.get(t);if(r)return r;let o=Qo();return Mt.set(t,o),o},ie=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),hr=(e,t)=>e.deletingStores.has(t),br=e=>{e.computedCleanups.forEach(t=>{try{t();}catch{}}),e.computedCleanups.clear(),[e.stores,e.subscribers,e.initialStates,e.initialFactories,e.metaEntries,e.snapshotCache,e.computedEntries,e.computedDependents].forEach(t=>{Object.keys(t).forEach(r=>{delete t[r];});}),e.deletingStores.clear(),e.transaction.depth=0,e.transaction.pending=[],e.transaction.stagedValues.clear(),e.transaction.snapshotCache.clear(),e.transaction.failed=false,e.transaction.error=void 0,Xo(e.notify),gr(e.async),e.lifecycleListener=null;};var Xe=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var Te=()=>null,Y=[],vr={run:(e,t)=>{Y.push(e);try{return t()}finally{Y.pop();}},get:()=>Y.length>0?Y[Y.length-1]:null,enterWith:e=>{if(Y.length>0){Y[Y.length-1]=e;return}Y.push(e);}};var Qe=(e,t)=>(vr).run(e,t),J=e=>(vr).get()||e||Se(ye);var en={log:(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},warn:(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},critical:(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));}},xr={logSink:en,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",autoCorrelationIds:false,acknowledgeLooseTypes:false,pathCacheSize:500,defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0,selectorCloneFrozen:true},Ot=e=>({logSink:{...e.logSink},flush:{...e.flush},revalidateOnFocus:{...e.revalidateOnFocus},namespace:e.namespace,strictMissingFeatures:e.strictMissingFeatures,assertRuntime:e.assertRuntime,strictMutatorReturns:e.strictMutatorReturns,asyncAutoCreate:e.asyncAutoCreate,asyncCloneResult:e.asyncCloneResult,autoCorrelationIds:e.autoCorrelationIds,acknowledgeLooseTypes:e.acknowledgeLooseTypes,pathCacheSize:e.pathCacheSize,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce,selectorCloneFrozen:e.selectorCloneFrozen}),Tt=new WeakMap,kr=Ot(xr),tn=e=>{let t=Tt.get(e);return t||(t=Ot(kr),Tt.set(e,t)),t};var C=()=>tn(J());var sn=()=>{Tt=new WeakMap,kr=Ot(xr);};x("config.reset",sn,90);var Rr=()=>C().namespace;var an=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,cn=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,Cr=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,ln="production",un=an??cn??ln,Oe=typeof Cr=="boolean"?Cr:un!=="production",v=()=>Oe,Vt=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},dn=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},pn=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},ae=(e,t)=>{if((C().logSink.critical??dn)(e,t),C().assertRuntime)throw new Error(e)},p=(e,t)=>{if(!Oe)return;if((C().logSink.warn??Vt)(e,t),C().assertRuntime)throw new Error(e)},L=(e,t)=>{if((C().logSink.warn??Vt)(e,t),C().assertRuntime)throw new Error(e)},$=(e,t)=>{if(Oe&&(C().logSink.warn??Vt)(e,t),ae(e,t),C().assertRuntime)throw new Error(e)},z=(e,t)=>{if(!Oe)return;(C().logSink.log??pn)(e,t);},Mr=()=>`Functions cannot be stored in stroid.
2
+ Store data only - handle functions outside the store.`,Er=()=>`Map/Set detected. stroid converts these to plain objects.
3
+ Use arrays or plain objects for best results.`,Fr=()=>`Date object detected. stroid stores it as ISO string.
4
+ Use new Date(value) to convert back when reading.`,Tr=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Or=()=>"Map detected; converting to plain object.",Vr=()=>"Set detected; converting to array.",Pr=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Ir=e=>`Store name "${e}" contains spaces.
5
+ Use camelCase or kebab-case: "userName" or "user-name"`,$r=e=>`Store name "${e}" is not allowed.
6
+ Reserved names: "__proto__", "constructor", "prototype".`,fn=128,gn=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=fn,yn=(e,t)=>{if(e===t)return 0;if(e.length===0)return t.length;if(t.length===0)return e.length;let r=Array.from({length:e.length+1},(n,s)=>s),o=new Array(e.length+1);for(let n=1;n<=t.length;n++){o[0]=n;for(let s=1;s<=e.length;s++)o[s]=t[n-1]===e[s-1]?r[s-1]:Math.min(r[s-1],o[s-1],r[s])+1;[r,o]=[o,r];}return r[e.length]},Dt=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||gn(n,s)&&yn(n,s)<=2});if(r){p(`Store "${e}" not found. Did you mean "${r}"?`);return}$(`Store "${e}" not found.
7
7
  Available stores: [${t.join(", ")}]
8
- Call createStore("${e}", data) first.`);};var re=new Set(["__proto__","constructor","prototype"]),Dt=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let n=r.error,s=n?.details?.[0]?.message||n?.message||r.message||e.errors;if(s)return {ok:!1,error:s};if(n)return {ok:!1,error:n}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var Ve=e=>e===null?"null":Array.isArray(e)?"array":e instanceof Map?"map":e instanceof Set?"set":e instanceof Date?"date":typeof e=="function"?"function":typeof e,Ir=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null},Nt=e=>{let t=Ve(e);return t==="function"?(I(Rr()),false):t==="map"||t==="set"?(d(Cr()),true):(t==="date"&&d(Mr()),true)},Vt=(e,t)=>{let r=Ir(e);if(r)throw new Error(`${r} values are not supported`);let o=Ve(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return true}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date"||o==="map"||o==="set")return false;if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n=Object.keys(e);for(let s of n){let i=Number(s);if(!Number.isInteger(i))return false}for(let s=0;s<e.length;s+=1)if(s in e&&!Vt(e[s],t))return false;return true}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");if(t.add(e),Object.getOwnPropertySymbols(e).length>0)return false;let n=Object.getOwnPropertyDescriptors(e);for(let[s,i]of Object.entries(n)){if(!i.enumerable||re.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Vt(i.value,t))return false}return true}return true},At=e=>Vt(e,new WeakSet),Oe=(e,t)=>{let r=Ir(e);if(r)throw new Error(`${r} values are not supported`);let o=Ve(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date")return w()&&d(Er()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),w()&&d(Fr());let n={};for(let[s,i]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");n[String(s)]=Oe(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),w()&&d(Tr()),Array.from(e,n=>Oe(n,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n={},s=Object.getOwnPropertyDescriptors(e);for(let[i,c]of Object.entries(s))if(c.enumerable&&!re.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=Oe(c.value,t);}return n}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(n=>Oe(n,t))}return e},ae=e=>Oe(e,new WeakSet),jt=e=>typeof e!="string"||e.trim()===""?(I(Ar(e)),false):re.has(e)?(I(Pr(e)),false):e.includes(" ")?(I(jr(e)),false):true;var Pt=null,fn=()=>{if(Pt)return Pt;let e,t=[];for(let r=0;r<256;r++){e=r;for(let o=0;o<8;o++)e=e&1?3988292384^e>>>1:e>>>1;t[r]=e>>>0;}return Pt=t,t},zr=e=>{let t=fn(),r=-1;for(let o=0;o<e.length;o++)r=r>>>0,r=r>>>8^t[(r^e.charCodeAt(o))&255];return (r^-1)>>>0},gn=2166136261,yn=2654435761,Sn=1e5,oe=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},ce=(e,t)=>{oe(e,t.length);for(let r=0;r<t.length;r++)oe(e,t.charCodeAt(r));},E=(e,t)=>{ce(e,t);},$r=(e,t)=>{if(Number.isNaN(t)){E(e,"NaN");return}if(!Number.isFinite(t)){E(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){E(e,"-0");return}let r=t|0;if(t===r){E(e,"int"),oe(e,r);return}E(e,"num"),ce(e,String(t));},me=(e,t)=>{if(e.nodes++>Sn){E(e,"[max]");return}if(t===null){E(e,"null");return}let r=typeof t;if(r==="string"){E(e,"string"),ce(e,t);return}if(r==="number"){E(e,"number"),$r(e,t);return}if(r==="boolean"){E(e,t?"true":"false");return}if(r==="undefined"){E(e,"undefined");return}if(r==="bigint"){E(e,"bigint"),ce(e,t.toString());return}if(r==="symbol"){E(e,"symbol");let a=t;ce(e,Symbol.keyFor(a)??a.description??String(a));return}if(r==="function"){E(e,"function"),ce(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){E(e,"ref"),oe(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){E(e,"array"),oe(e,o.length);for(let a=0;a<o.length;a++)Object.prototype.hasOwnProperty.call(o,a)?me(e,o[a]):E(e,"hole");return}if(o instanceof Date){E(e,"date"),$r(e,o.getTime());return}if(o instanceof Map){E(e,"map"),oe(e,o.size),o.forEach((a,p)=>{me(e,p),me(e,a);});return}if(o instanceof Set){E(e,"set"),oe(e,o.size),o.forEach(a=>{me(e,a);});return}E(e,"object");let i=Object.getOwnPropertyDescriptors(o),c=[];Object.entries(i).forEach(([a,p])=>{p?.enumerable&&(re.has(a)||"get"in p||"set"in p||c.push([a,p]));}),oe(e,c.length);for(let[a,p]of c)ce(e,a),me(e,p.value);},De=e=>{if(typeof e=="string")return zr(JSON.stringify(e));let t={h1:gn,h2:yn,seen:new WeakMap,nextId:1,nodes:0};me(t,e);let r=t.h1>>>0,o=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,o^=o>>>16,o=Math.imul(o,668265261),o^=o>>>15,o=Math.imul(o,374761393),o^=o>>>16,(r&2097151)*4294967296+(o>>>0)};var mn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Ne=e=>{if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map)return new Map(e);if(e instanceof Set)return new Set(e);if(Array.isArray(e))return e.slice();let t={},r=Object.getOwnPropertyDescriptors(e);return Object.entries(r).forEach(([o,n])=>{n.enumerable&&(re.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},It=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=[["WeakMap",globalThis.WeakMap],["WeakSet",globalThis.WeakSet],["WeakRef",globalThis.WeakRef],["Promise",globalThis.Promise],["ReadableStream",globalThis.ReadableStream],["WritableStream",globalThis.WritableStream],["TransformStream",globalThis.TransformStream],["EventTarget",globalThis.EventTarget]];for(let[o,n]of t)if(typeof n=="function"&&e instanceof n)return o;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},hn=e=>It(e)===null,bn=e=>{let t=It(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},le=(e,t=new WeakMap)=>{if(bn(e),e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let n=new Map;return t.set(e,n),e.forEach((s,i)=>{n.set(le(i,t),le(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(le(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=le(s,t);}),n}let r={};t.set(e,r);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch(n){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${n?.message??n}`)}return Object.entries(o).forEach(([n,s])=>{!s.enumerable||re.has(n)||"get"in s||"set"in s||(r[n]=le(s.value,t));}),r},O=e=>{if(mn)try{return structuredClone(e)}catch(t){if(!hn(e)){let r=It(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return d(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),le(e)}return le(e)};var Wt=new Set,kn=()=>{Wt.clear();};v("options.legacy-warnings",kn,30);var Qe=(()=>{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"}})(),_t=e=>{try{return typeof window>"u"?Qe:e==="session"||e==="sessionStorage"?window.sessionStorage??Qe:window.localStorage??Qe}catch{return Qe}},Ae=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),he=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Hr=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}},xn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Wr=e=>{try{e[xn]=!0;}catch{}return e},Rn={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"},Cn=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Wr(f=>f),decrypt:Wr(f=>f),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:_t("localStorage"),...r};if(typeof e=="string")return {driver:_t(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,a=e.allowPlaintext===true,p=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,g=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(c&&Hr(o)&&!s)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||_t("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:o,decrypt:n,encryptAsync:s,decryptAsync:i,allowPlaintext:a,sensitiveData:c,maxSize:p,checksum:g,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Lr=e=>{if(!Ae(e))return [];let t=[];return Object.entries(Rn).forEach(([r,o])=>{he(e,r)&&(Wt.has(r)||(Wt.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},Br=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=Ae(e.lifecycle)?e.lifecycle:void 0,c=Ae(e.persist)?e.persist:void 0,a=Ae(e.devtools)?e.devtools:void 0,p=e.validate??e.validator??e.schema,g=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",f=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,m=Ae(e.features)?{...e.features}:void 0,C=he(e,"persist"),y=he(e,"sync"),l=he(e,"devtools")||he(e,"historyLimit")||he(e,"redactor"),k=o==="global"?true:e.allowSSRGlobalStore??false,{persist:b=false,devtools:V=false,onError:N,sync:P}=e;if(c?.sensitiveData===true){let D=c.encrypt,h=c.encryptAsync;if((!D||Hr(D))&&!h)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:o,lazy:n,pathCreate:s,persist:o==="temp"&&!C?null:Cn(b,t),devtools:o==="temp"&&!l?false:typeof V=="boolean"?V:a?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:N,validate:p,migrations:c?.migrations??e.migrations??{},version:c?.version??e.version??1,redactor:o==="temp"&&!l?void 0:a?.redactor??e.redactor,historyLimit:o==="temp"&&!l?0:a?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!y?false:P??false,features:m,allowSSRGlobalStore:k,snapshot:g,snapshotSafety:f,explicitPersist:C,explicitSync:y,explicitDevtools:l}};var Ze=Symbol("stroid.middleware.abort"),qr=({name:e,payload:t,middlewares:r,reportIssue:o,warn:n})=>{if(!Array.isArray(r)||r.length===0)return t.next;let s=new WeakSet,i=O(t.next);for(let c of r){if(typeof c!="function")continue;let a,p=i;try{a=c({action:t.action,name:e,prev:t.prev,next:p,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(g){let f=`Middleware for "${e}" failed: ${g?.message??g}`;return o(f,"dev"),Ze}if(a&&typeof a.then=="function"){let g=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(g,"dev"),Ze}a===void 0?(w()&&!s.has(c)&&(s.add(c),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=p):i=a;}return i},et=({name:e,label:t,fn:r,args:o,reportIssue:n})=>{if(typeof r=="function")try{r(...o);}catch(s){let i=`${t} for "${e}" failed: ${s?.message??s}`;n(i,"always");}};var X=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;L(`${t} callback threw: ${String(n)}`);}},ue=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(X(n,"onError",e),r==="critical"){o==="dev"&&d(e),ie(e);return}if(o==="always"){L(e);return}d(e);};var tt=null,Ur=e=>{tt=e;},Gr=e=>tt?tt(e):[];v("computed.order-resolver",()=>{tt=null;},105);var Kr=()=>J(ye(ge)),Q=()=>Kr().computedEntries,je=()=>Kr().computedDependents,Mn=(e,t)=>{let r=Q(),o=new Set,n=[],s=i=>{if(i===e)return true;if(o.has(i))return false;o.add(i),n.push(i);let c=r[i]?.deps??[];for(let a of c)if(s(a))return true;return n.pop(),false};for(let i of t)if(n.length=0,s(i))return [e,...n,e].join(" -> ");return null},Yr=(e,t)=>{let r=je();for(let o of t){let n=r[o];n&&(n.delete(e),n.size===0&&delete r[o]);}},Jr=(e,t,r)=>{let o=Mn(e,t);if(o)return I(`[stroid] createComputed("${e}") rejected: circular dependency detected -> ${o}
9
- Define relationships without cycles.`),false;let n=Q(),s=je();n[e]&&Yr(e,n[e].deps),n[e]={deps:t,compute:r,stale:true};for(let i of t)s[i]||(s[i]=new Set),s[i].add(e);return true},Xr=e=>{let t=Q(),r=t[e];r&&(Yr(e,r.deps),delete t[e]);},Ht=e=>{let t=Q();t[e]&&(t[e].stale=true);},rt=e=>Object.prototype.hasOwnProperty.call(Q(),e),Lt=e=>Q()[e],En=e=>{let t=Q(),r=je(),o=new Set,n=[...e];for(;n.length>0;){let g=n.shift(),f=r[g];if(f)for(let m of f)o.has(m)||(o.add(m),n.push(m));}if(o.size===0)return [];let s=g=>{let f=t[g];if(f)for(let m of f.deps)t[m]&&(o.has(m)||(o.add(m),s(m)));};Array.from(o).forEach(g=>s(g));let i=new Map,c=new Map;for(let g of o){let f=t[g];if(!f)continue;let m=0;for(let C of f.deps)o.has(C)&&(m++,c.has(C)||c.set(C,[]),c.get(C).push(g));i.set(g,m);}let a=[];for(let[g,f]of i)f===0&&a.push(g);a.sort();let p=[];for(;a.length>0;){let g=a.shift();p.push(g);let f=c.get(g)??[];for(let m of f){let C=(i.get(m)??1)-1;if(i.set(m,C),C===0){let y=a.findIndex(l=>l>m);y===-1?a.push(m):a.splice(y,0,m);}}}return p};Ur(En);var Fn=()=>{let e=Q(),t=je(),r=Object.keys(e),o=[];for(let[n,s]of Object.entries(e))for(let i of s.deps)o.push({from:i,to:n});return {nodes:r,edges:o,dependencies:Object.fromEntries(Object.entries(e).map(([n,s])=>[n,[...s.deps]])),dependents:Object.fromEntries(Object.entries(t).map(([n,s])=>[n,[...s]]))}},Tn=e=>{let t=Q()[e];if(!t)return null;let r=je()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Qr=new Map;var Bt=e=>{let t=Qr.get(e);return !!t&&t.size>0},Pe=(e,t,r)=>{let o=Qr.get(e);!o||o.size===0||o.forEach(n=>{try{n(t,r);}catch(s){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,s);}});};var Zr=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,a=e.deletingStores,p=(l,k)=>{ue(k,{onError:s[l]?.options?.onError,severity:"warn",visibility:"dev"});},g=({name:l,prev:k,options:b,initialState:V,getMeta:N,getStoreValue:P,hasStore:D})=>({name:l,options:b,prev:k,getMeta:N,getStoreValue:P,getAllStores:()=>t,getInitialState:()=>V,hasStore:D,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:h=>{ue(h,{onError:b.onError,severity:"warn",visibility:"dev"});},warn:d,warnAlways:L,log:$,hashState:De,deepClone:O,sanitize:ae,validate:()=>({ok:true,value:k}),isDev:w}),f=({name:l,prev:k,options:b,initialState:V,phase:N})=>{let P=g({name:l,prev:k,options:b,initialState:V,getMeta:()=>s[l],getStoreValue:()=>t[l],hasStore:()=>Se(e,l)}),D=g({name:l,prev:k,options:b,initialState:V,getMeta:()=>{},getStoreValue:()=>k,hasStore:()=>false});fe().forEach(h=>{let _=c.get(h);N==="before"?_?.beforeStoreDelete?.(P):_?.afterStoreDelete?.(D);});},m=l=>{if(!Se(e,l))return;let k=t[l],b=s[l].options,V=o[l],N=r[l];a.add(l);try{N?.forEach(h=>{try{h(null);}catch(_){d(`Subscriber for "${l}" threw during delete: ${_?.message??_}`);}}),et({name:l,label:"onDelete",fn:b.onDelete,args:[k],reportIssue:(h,_)=>{ue(h,{onError:b.onError,severity:"warn",visibility:_});}}),f({name:l,prev:k,options:b,initialState:V,phase:"before"}),delete t[l],delete r[l],delete o[l],delete n[l],delete s[l],delete i[l],rt(l)&&eo(l);let D=e.computedDependents[l];if(D)for(let h of D)d(`[stroid] source store "${l}" was deleted. Computed store "${h}" depends on it and will return stale data. Call deleteComputed("${h}") to clean up.`);f({name:l,prev:k,options:b,initialState:V,phase:"after"}),Pe("afterStoreDelete",l,{type:"afterStoreDelete",prev:k}),Ye(e,{type:"deleted",name:l}),$(`Store "${l}" deleted`);}finally{a.delete(l);}};return {deleteExistingStore:m,clearAllStores:()=>{let l=[],b=0,V=Number.POSITIVE_INFINITY;for(;b<20;){let P=Object.keys(t);if(P.length===0)break;P.forEach(h=>{Se(e,h)&&(m(h),l.push(h));}),b+=1;let D=Object.keys(t).length;if(D===0||D>=V)break;V=D;}let N=Object.keys(t).length;return N>0?d(`clearAllStores stopped after ${b} pass${b===1?"":"es"}; ${N} store(s) still registered (likely recreated during deletion).`):d(`All stores cleared (${l.length} stores removed)`),l},clearStores:l=>{let k=Object.keys(t).filter(b=>l?l.endsWith("*")?b.startsWith(l.slice(0,-1)):b===l:true);return k.forEach(b=>m(b)),k},reportStoreError:p}};var ot=null;var On=()=>{ot=null;};v("transaction.runner",On,120);var Ie=e=>{let t=ot?.get();return t||(e??J()).transaction},Vn=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var z=()=>ot?(ot.get()?.depth??0)>0:Ie().depth>0,nt=(e,t)=>{let r=Ie(t);r.failed=true,r.error||(r.error=Vn(e));},st=e=>{let t=J();Ie(t).pending.push(()=>Je(t,e));},it=(e,t)=>{let r=Ie();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},be=e=>{let t=Ie();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var qt=ge,ro=ye(qt),oo=null,j=()=>{let e=J(ro);return Ct(e),e};var R=()=>j();var no=(e,t)=>{Ye(e,t);};function so(e){oo=e;}var we=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,o)=>(e()[r]=o,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let o=Object.getOwnPropertyDescriptor(e(),r);if(o)return {...o,configurable:true}}}),Dn=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 n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),Nn=e=>new Proxy({},{get:(t,r)=>{let o=e(),n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),$e=we(()=>j().stores);we(()=>j().subscribers);var io=we(()=>j().initialStates);we(()=>j().initialFactories);var T=we(()=>j().metaEntries);we(()=>j().snapshotCache);var q=Dn(()=>j().featureRuntimes),to=new WeakMap,An=e=>{let t=to.get(e);return t||(t=Zr(e),to.set(e,t)),t};Nn(()=>An(j()));var jn=e=>{let t=q.get(e);if(t)return t;let r=Ke(e);if(!r)return;let o=r();return q.set(e,o),o},at=()=>{fe().forEach(e=>{jn(e);});};at();var Z=(e,t)=>Se(t??j(),e),ze=(e,t=j())=>{if(z()){let o=be(e);if(o.has)return o.value}let r=Fe();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},U=(e,t,r=j())=>{r.stores[e]=t;},ao=(e,t,r=Date.now())=>{U(e,t),T[e]&&(T[e].updatedAt=new Date(r).toISOString(),T[e].updatedAtMs=r,T[e].lastCorrelationId=null,T[e].lastCorrelationAt=null,T[e].lastCorrelationAtMs=null,T[e].lastTraceContext=null,T[e].updateCount>=Number.MAX_SAFE_INTEGER?T[e].updateCount=0:T[e].updateCount+=1,oo?.(e));},Ut=(e,t=j())=>{let r=t.metaEntries[e];if(!r)return;r.readCount=(r.readCount??0)+1;let o=Date.now();r.lastReadAtMs=o,r.lastReadAt=new Date(o).toISOString();},Pn=()=>{mr(j());},In=()=>{q.forEach(e=>{try{e.resetAll?.();}catch{}}),q.clear();};v("features.reset",In,10);v("registries.clear",Pn,20);v("registry.default",()=>{qt=ge,ro=ye(qt);},115);var co=e=>Sr(j(),e);var ct=new Set,uo=e=>e?ct.has(e):ct.size>0,po=e=>{e&&ct.add(e);},$n=()=>{ct.clear();};v("ssr.warnings",$n,60);var lo=new Set,zn=e=>{let t=kr();return !t||e.includes("::")?e:(w()&&!lo.has(e)&&(lo.add(e),d(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},lt=e=>zn(typeof e=="string"?e:e.name),ut=e=>Z(e)&&!co(e)?true:(Ot(e,Object.keys($e)),false),fo=(e,t,r={})=>{ue(t,{...r,onError:T[e]?.options?.onError});},go=(e,t,r={})=>{ue(e,{...r,onError:t});},de=(e,t,r="dev")=>{fo(e,t,{severity:"warn",visibility:r});},_n=(e,t,r="dev")=>{go(e,t,{severity:"warn",visibility:r});},_e=(e,t)=>fo(e,t,{severity:"critical",visibility:"always"}),We=(e,t)=>go(e,t,{severity:"critical",visibility:"always"}),dt=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
10
- Import "stroid/${t}" before calling createStore("${e}", ...).`;if(_n(o,r,"always"),x().strictMissingFeatures)throw new Error(o)};var yo=new WeakMap,So=new WeakMap;var pt=e=>{let t=yo.get(e);return t||(t=new Map,yo.set(e,t)),t},mo=e=>{let t=So.get(e);return t||(t=new Map,So.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=pt(R());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let o=r[t];return typeof o=="function"?o.bind(r):o},set:(e,t,r)=>(pt(R())[t]=r,true)});var ve=(e,t,r,o)=>{try{return o?.reuseInput&&At(t)?{ok:!0,value:t}:{ok:!0,value:ae(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return X(T[e]?.options?.onError,`onError(${e})`,s),X(r,`onError(${e})`,s),d(s),{ok:false}}},Wn=(e,t)=>{let r=new Set,o=T[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Gt=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=Wn(e,o),s=(c,a)=>{n.forEach(p=>X(p,`onError(${e})`,c)),a==="critical"?ie(c):d(c);};if(typeof r=="function")try{let c=r(t);return c===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:c===!0?t:c}}catch(c){return s(`Validation for "${e}" failed: ${c?.message??c}`,"critical"),{ok:false}}let i=Dt(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},He=(e,t,r,o,n)=>{let s=ve(e,t,o,n);if(!s.ok)return {ok:false};let i=Gt(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},ee=e=>{let t=R();pt(t).delete(e),mo(t).delete(e);},Hn=()=>{let e=R();pt(e).clear(),mo(e).clear();};v("validation.path-cache",Hn,50);so(ee);var ho=(e,t=R())=>{if((z()?be(e):{has:false}).has||t.stores[e]!==void 0)return true;let o=t.initialFactories[e];if(!o)return true;try{let n=o(),s=ve(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,c=He(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!c.ok)return !1;if(z()){let a=c.value;it(e,a),st(()=>{U(e,a,t),t.initialStates[e]=O(a),delete t.initialFactories[e],ee(e);});}else U(e,c.value,t),t.initialStates[e]=O(c.value),delete t.initialFactories[e],ee(e);return !0}catch(n){return _e(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var bo=new WeakMap,wo=e=>{let t=bo.get(e);return t||(t=new Map,bo.set(e,t)),t},Ln=()=>{wo(R()).clear();};v("features.contexts",Ln,100);var vo=e=>{let t=R(),r=wo(t),o=r.get(e);if(o)return o;let n=T[e];if(!n)return d(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>T[e],getStoreValue:()=>$e[e],getAllStores:()=>$e,getInitialState:()=>io[e],hasStore:()=>Z(e),setStoreValue:i=>{U(e,i);},applyFeatureState:(i,c)=>{ao(e,i,c),ee(e);},notify:()=>{},reportStoreError:i=>{_e(e,i);},warn:d,warnAlways:L,log:$,hashState:De,deepClone:O,sanitize:ae,validate:i=>Gt(e,i,T[e]?.options?.validate),isDev:w};return r.set(e,s),s},ko=(e,t)=>{let r=x();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 n=`Feature hook context missing fields for "${e}": ${o.join(", ")}.`;if(_e(e,n),r.assertRuntime)throw new Error(n)},xo=(e,t)=>{at();let r=vo(e);r&&(r.notify=()=>t(e),ko(e,r),q.forEach(o=>{o.onStoreCreate?.(r);}));},Ro=(e,t,r,o,n)=>{at();let s=vo(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});ko(e,i),q.forEach(c=>{c.onStoreWrite?.(i);});};var Co=(e,t)=>qr({name:e,payload:t,middlewares:(()=>{let r=T[e]?.options?.middleware||[],o=x().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{de(e,r,o);},warn:d}),ft=(e,t,r,o)=>et({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{de(e,n,s);}}),Mo=(e,t)=>{let r={...t};return r.persist&&!Ge("persist")&&(r.explicitPersist&&dt(e,"persist",r.onError),r.persist=null),r.sync&&!Ge("sync")&&(r.explicitSync&&dt(e,"sync",r.onError),r.sync=false),Ge("devtools")||(r.explicitDevtools&&dt(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var gt=null,Eo=e=>(gt=e,()=>{gt===e&&(gt=null);}),ke=e=>{gt?.(e);};var yt=new Set,Bn=e=>{yt.clear();};v("store-create.ssr-global-warned",()=>Bn(),65);function Kt(e,t,r={}){if(z()){let h=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;We(h,r.onError),nt(h);return}if(!jt(e)){We(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Nt(t)){We(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&w()&&d(`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.`),Lr(r).forEach(h=>{d(h);});let n=Mo(e,Br(r,e,x().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let h=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;X(n.onError,`onError(${e})`,h),w()||L(h),I(h);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=s&&i==="production",a=n.allowSSRGlobalStore??false,p=R(),g=p.stores,f=p.subscribers,m=p.initialStates,C=p.initialFactories,y=p.metaEntries,l=p.scope==="request";if(c&&!a&&!l){let h=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
11
- Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;We(h,r.onError);return}if(c&&a&&!l&&!yt.has(e)&&(yt.add(e),L(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
12
- This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),Z(e,p)){let h=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return de(e,h),{name:e}}s&&!a&&!l&&!uo(e)&&w()&&(po(e),d(`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 k=ve(e,t,n.onError);if(!k.ok)return;let b=k.value,V=n.lazy===true&&typeof t=="function",N=(f[e]?.size??0)>0;if(V)g[e]=void 0,C[e]=t;else {let h=He(e,b,n.validate,n.onError);if(!h.ok)return;U(e,h.value,p),m[e]=O(h.value);}let P=Date.now(),D=new Date(P).toISOString();return y[e]={createdAt:D,updatedAt:D,updatedAtMs:P,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},ee(e),xo(e,ke),ft(e,"onCreate",y[e].options.onCreate,[b]),no(p,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),N&&ke(e),$(`Store "${e}" created -> ${JSON.stringify(b)}`),{name:e}}var Fo=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 !(r&&r!=="Object"&&r!=="Array")},Yt=e=>(Fo(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),To=e=>{if(!Fo(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 n of Object.keys(o)){let s=o[n];typeof s=="object"&&s!==null&&!r.has(s)&&t.push(s);}}}return e};var Oo=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Jt=(e,t)=>{if(t==="ref"){if(!w())return e;try{return Yt(e)}catch{return e}}if(t==="shallow"){let o=Ne(e);if(!w())return o;try{return Yt(o)}catch{return o}}let r=O(e);if(!w())return r;try{return To(r)}catch{return r}};var Vo=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:o}=e,n=x().flush,s=n.priorityStores||[],i=s.length?new Set(s):null;o.length=0,r.length=0;let c=new Set;if(i){for(let y of t)r.push(y),c.add(y);for(let y of s)c.has(y)&&o.push(y);for(let y of r)i.has(y)||o.push(y);}else for(let y of t)r.push(y),c.add(y),o.push(y);t.clear();let a=Gr(o),p=new Set(o);for(let y of a)p.has(y)||(o.push(y),p.add(y));let g=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,f=n.chunkDelayMs,m=g===Number.POSITIVE_INFINITY&&f===0;return {names:o,sliceSize:g,chunkDelayMs:f,runInline:m,prioritySet:i}};var Xt=e=>({notifyCount:e?.notifyCount??0,totalNotifyMs:e?.totalNotifyMs??0,lastNotifyMs:e?.lastNotifyMs??0,resetCount:e?.resetCount??0,totalResetMs:e?.totalResetMs??0,lastResetMs:e?.lastResetMs??0}),Qt=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),Zt=(e,t)=>{e&&(e.metrics=t);};var Le=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Do=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>Je(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var St=null,mt=()=>St,er=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();let r=St;St=e;try{return t()}finally{St=r;}};var No=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)},Ao=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:c,runInline:a,prioritySet:p}=t,f=n.subscriberBuffer,m=e.stores,C=e.subscribers,y=e.metaEntries,l=e.snapshotCache,k=x().defaultSnapshotMode,b=S=>Oo(y[S],k),V=S=>m[S],N=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),P=Bt("beforeFlush"),D=Bt("afterFlush"),h=S=>{P&&Pe("beforeFlush",S,{type:"beforeFlush"});},_=(S,F)=>{D&&Pe("afterFlush",S,{type:"afterFlush",elapsedMs:F});},or=S=>{let F=y[S];if(!F)return null;let M=F.lastCorrelationId??void 0,u=F.lastTraceContext??void 0;return !M&&!u?null:{correlationId:M,traceContext:u}},Ho=S=>{f.length=0;for(let F of S)f.push(F);return f},bt=()=>{o();};if(a){for(let S of s){let F=C[S];if(!F||F.size===0)continue;let M=y[S]?.updateCount??0,u=b(S),pe=V(S),W=l[S],H=W&&W.source===pe&&W.mode===u?W.snapshot:(()=>{let A=Jt(pe,u);return l[S]={version:r,snapshot:A,source:pe,mode:u},A})(),G=Xt(y[S]?.metrics);h(S);let ne=N(),te=Ho(F),Re=or(S),Ce=()=>{for(let A of te)try{A(H);}catch(se){let K=y[S]?.options?.snapshotSafety??"warn";if(w()&&(u==="ref"||u==="shallow")&&No(se)){if(K==="throw")throw se;if(K==="auto-clone")try{let Ee=O(H);d(`Snapshot mutation detected for "${S}". Delivered a cloned snapshot to the subscriber.`);try{A(Ee);}catch(kt){d(`Subscriber for "${S}" threw on cloned snapshot: ${kt?.message??kt}`);}continue}catch{}d(`Snapshot mutation detected for "${S}": ${se?.message??se}`);continue}d(`Subscriber for "${S}" threw: ${se?.message??se}`);}};Re?er(Re,Ce):Ce();let Me=N()-ne;_(S,Me),Qt(G,Me),Zt(y[S],G),(y[S]?.updateCount??M)!==M&&n.pendingNotifications.add(S);}bt();return}let nr=S=>{let F=[];for(let M of s){if(S&&!S(M))continue;let u=C[M];if(!u||u.size===0)continue;let pe=y[M]?.updateCount??0,W=b(M),H=V(M),G=l[M],ne=G&&G.source===H&&G.mode===W?G.snapshot:(()=>{let te=Jt(H,W);return l[M]={version:r,snapshot:te,source:H,mode:W},te})();F.push({name:M,snapshot:ne,version:pe,subscribers:Array.from(u),subscriberSet:new Set(u),notified:new Set,metrics:Xt(y[M]?.metrics),totalMs:0,beforeHooked:false});}return F},sr=p?nr(S=>p.has(S)):[],ir=nr(S=>!p||!p.has(S)),wt=(S,F)=>{let M=()=>{if(S.length===0){F();return}let u=S.shift();if((y[u.name]?.updateCount??u.version)!==u.version){if(n.pendingNotifications.add(u.name),S.length===0){F();return}Le(M,c);return}let W=()=>{let B=C[u.name];if(!(!B||B.size===0))for(let A of B)u.subscriberSet.has(A)||(u.subscriberSet.add(A),u.subscribers.push(A));};W();let H=u.subscribers;if(H.length===0){if(S.length===0){F();return}Le(M,c);return}u.beforeHooked||(u.beforeHooked=true,h(u.name));let G=N(),ne=0,te=false,Re=or(u.name),Ce=()=>{for(let B=0;B<H.length&&ne<i;B+=1){let A=H[B];if(u.notified.has(A))continue;u.notified.add(A);try{A(u.snapshot);}catch(K){let vt=y[u.name]?.options?.snapshotSafety??"warn",Ee=b(u.name);if(w()&&(Ee==="ref"||Ee==="shallow")&&No(K)){if(vt==="throw")throw K;if(vt==="auto-clone")try{let ar=O(u.snapshot);d(`Snapshot mutation detected for "${u.name}". Delivered a cloned snapshot to the subscriber.`);try{A(ar);}catch(cr){d(`Subscriber for "${u.name}" threw on cloned snapshot: ${cr?.message??cr}`);}if(u.notified.add(A),ne+=1,(y[u.name]?.updateCount??u.version)!==u.version){te=!0,n.pendingNotifications.add(u.name);break}continue}catch{}d(`Snapshot mutation detected for "${u.name}": ${K?.message??K}`);continue}d(`Subscriber for "${u.name}" threw: ${K?.message??K}`);}if(ne+=1,(y[u.name]?.updateCount??u.version)!==u.version){te=true,n.pendingNotifications.add(u.name);break}}};if(Re?er(Re,Ce):Ce(),u.totalMs+=N()-G,te){if(S.length===0){F();return}Le(M,c);return}W();let Me=false;for(let B of H)if(!u.notified.has(B)){Me=true;break}if(Me?S.push(u):(Qt(u.metrics,u.totalMs),Zt(y[u.name],u.metrics),_(u.name,u.totalMs)),S.length===0){F();return}Le(M,c);};M();};sr.length>0?wt(sr,()=>wt(ir,bt)):wt(ir,bt);};var qn=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=Vo(t);Ao(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&tr(e);});},tr=e=>{Do(e,qn);};var Un=e=>{let t=R(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&tr(t);};Eo(Un);var rr=(e,t)=>{let o=R().subscribers;return o[e]||(o[e]=new Set),o[e].add(t),()=>{o[e]?.delete(t),o[e]?.size===0&&delete o[e];}};var Gn=()=>{let e=R().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0;};v("notify.reset",Gn,40);var Kn=new Set;v("store-write.slow-mutator-warned",()=>Kn.clear(),65);var Yn=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var Po=e=>mt(),jo=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:c})=>{let a=e.metaEntries;U(t,o,e),ee(t);let p=Date.now();a[t].updatedAt=new Date(p).toISOString(),a[t].updatedAtMs=p;let g=c??mt();g&&(g.correlationId||g.traceContext)?(a[t].lastCorrelationId=g.correlationId??null,a[t].lastCorrelationAt=new Date(p).toISOString(),a[t].lastCorrelationAtMs=p,a[t].lastTraceContext=g.traceContext??null):(a[t].lastCorrelationId=null,a[t].lastCorrelationAt=null,a[t].lastCorrelationAtMs=null,a[t].lastTraceContext=null),Yn(a[t]),Ro(t,n,r,o,ke),ft(t,s,a[t].options[s],[r,o]),ke(t),$(i);},Io=(e,t)=>{let r=t.context??mt();if(z()){it(t.name,t.next),st(()=>jo(e,{...t,context:r}));return}jo(e,{...t,context:r});};function Be(e,t){let r=lt(e);if(!r)return {ok:false,reason:"invalid-args"};let o=R(),n=Jn(o,r,t,"replace");return n.ok?{ok:true}:n.reason==="not-found"?{ok:false,reason:"not-found"}:n.reason==="middleware"?{ok:false,reason:"middleware"}:{ok:false,reason:"validate"}}var Jn=(e,t,r,o="hydrate",n)=>{let s=(y,l)=>(z()&&nt(l??y),{ok:false,reason:y});if(!ut(t))return s("not-found",`replaceStore("${t}") called before createStore().`);let i=z()?be(t):{has:false,value:void 0},c=i.has?i.value:ze(t,e),a=ve(t,r);if(!a.ok)return s("sanitize",`replaceStore("${t}") failed sanitize`);let p=a.value;if(p===void 0){let y=`Whole-store undefined replacement is blocked for "${t}". Use null for intentional empty state.`;return de(t,y),s("undefined",y)}let g=e.metaEntries[t]?.options?.validate,f=Po(),m=Co(t,{action:o,prev:c,next:p,path:null,correlationId:f?.correlationId,traceContext:f?.traceContext});if(m===Ze)return s("middleware",`replaceStore("${t}") aborted by middleware`);let C=He(t,m,g);return C.ok?(Io(e,{name:t,prev:c,next:C.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:f}),{ok:true}):s("validate",`replaceStore("${t}") failed validation`)};var Xn=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},$o=(e,t)=>t==="ref"?e:t==="shallow"?Ne(e):O(e);function xe(e,t){let r=lt(e);if(!ut(r))return null;let o=R();if(!ho(r,o))return null;Ut(r,o);let n=ze(r,o),s=Xn(o.metaEntries[r],x().defaultSnapshotMode);return n===null||typeof n!="object"?n:$o(n,s);}var qe=e=>Z(e);var Ue=e=>({name:e});var ht=()=>R().computedCleanups,zo=new WeakMap,Qn=e=>{let t=zo.get(e);return t||(t=new Map,zo.set(e,t)),t};function mc(e,t,r,o={}){if(!e||typeof e!="string"){d("createComputed requires a store name as first argument");return}if(!Array.isArray(t)||t.length===0){d(`createComputed("${e}") requires at least one dependency`);return}if(typeof r!="function"){d(`createComputed("${e}") requires a compute function as third argument`);return}let n=ht(),s=n.get(e);s&&(s(),n.delete(e));let i=t.map(f=>typeof f=="string"?f:f?.name);if(i.some(f=>!f||typeof f!="string")){d(`createComputed("${e}") dependencies must be store names or store handles.`);return}if(w()){let f=i.filter(m=>!qe(m));f.length>0&&d(`createComputed("${e}") dependencies not found at registration: ${f.join(", ")}. Computed values will receive null until those stores are created.`);}if(!Jr(e,i,r))return;let a=_o(e,t,r,o.onError),p=Ue(e);qe(e)?Be(p,a):Kt(e,a);let g=[];for(let f of i){let m=rr(f,()=>{Wo(e,i,r,o.onError);});g.push(m);}return ht().set(e,()=>{g.forEach(f=>f()),Xr(e);}),w()&&$(`computed store "${e}" created, deps: [${i.join(", ")}]`),p}var _o=(e,t,r,o)=>{let n=t.map(s=>typeof s=="string"?xe(Ue(s)):xe(s));try{return r(...n)}catch(s){d(`createComputed("${e}") compute function threw: ${s?.message??s}`),X(o,`computed.onError(${e})`,s);let i=Ue(e);return qe(e)?xe(i):null}},Wo=(e,t,r,o)=>{if(!Lt(e))return;let s=R();if(s.notify.isFlushing){let p=s.notify.flushId,g=Qn(s);if(g.get(e)===p)return;g.set(e,p);}let i=_o(e,t,r,o),c=Ue(e),a=xe(c);Object.is(i,a)||(Be(c,i),Ht(e));},hc=e=>{let t=Lt(e);if(!t){d(`invalidateComputed("${e}") -- "${e}" is not a computed store`);return}Ht(e),Wo(e,t.deps,t.compute);},eo=e=>{let t=ht(),r=t.get(e);if(!r){w()&&d(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);},bc=e=>rt(e),wc=()=>{let e=ht();e.forEach(t=>t()),e.clear();};export{wc as _resetComputedForTests,mc as createComputed,eo as deleteComputed,Tn as getComputedDepsFor,Fn as getFullComputedGraph,hc as invalidateComputed,bc as isComputedStore};//# sourceMappingURL=computed.js.map
8
+ Call createStore("${e}", data) first.`);};var re=new Set(["__proto__","constructor","prototype"]),At=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let n=r.error,s=n?.details?.[0]?.message||n?.message||r.message||e.errors;if(s)return {ok:!1,error:s};if(n)return {ok:!1,error:n}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var De=e=>e===null?"null":Array.isArray(e)?"array":e instanceof Map?"map":e instanceof Set?"set":e instanceof Date?"date":typeof e=="function"?"function":typeof e,zr=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null},jt=e=>{let t=De(e);return t==="function"?($(Mr()),false):t==="map"||t==="set"?(p(Er()),true):(t==="date"&&p(Fr()),true)},Nt=(e,t)=>{let r=zr(e);if(r)throw new Error(`${r} values are not supported`);let o=De(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return true}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date"||o==="map"||o==="set")return false;if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n=Object.keys(e);for(let s of n){let i=Number(s);if(!Number.isInteger(i))return false}for(let s=0;s<e.length;s+=1)if(s in e&&!Nt(e[s],t))return false;return true}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");if(t.add(e),Object.getOwnPropertySymbols(e).length>0)return false;let n=Object.getOwnPropertyDescriptors(e);for(let[s,i]of Object.entries(n)){if(!i.enumerable||re.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Nt(i.value,t))return false}return true}return true},Pt=e=>Nt(e,new WeakSet),Ve=(e,t)=>{let r=zr(e);if(r)throw new Error(`${r} values are not supported`);let o=De(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date")return v()&&p(Tr()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),v()&&p(Or());let n={};for(let[s,i]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");n[String(s)]=Ve(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),v()&&p(Vr()),Array.from(e,n=>Ve(n,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n={},s=Object.getOwnPropertyDescriptors(e);for(let[i,c]of Object.entries(s))if(c.enumerable&&!re.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=Ve(c.value,t);}return n}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(n=>Ve(n,t))}return e},ce=e=>Ve(e,new WeakSet),It=e=>typeof e!="string"||e.trim()===""?($(Pr(e)),false):re.has(e)?($($r(e)),false):e.includes(" ")?($(Ir(e)),false):true;var $t=null,Sn=()=>{if($t)return $t;let e,t=[];for(let r=0;r<256;r++){e=r;for(let o=0;o<8;o++)e=e&1?3988292384^e>>>1:e>>>1;t[r]=e>>>0;}return $t=t,t},Wr=e=>{let t=Sn(),r=-1;for(let o=0;o<e.length;o++)r=r>>>0,r=r>>>8^t[(r^e.charCodeAt(o))&255];return (r^-1)>>>0},mn=2166136261,hn=2654435761,bn=1e5,oe=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},le=(e,t)=>{oe(e,t.length);for(let r=0;r<t.length;r++)oe(e,t.charCodeAt(r));},E=(e,t)=>{le(e,t);},_r=(e,t)=>{if(Number.isNaN(t)){E(e,"NaN");return}if(!Number.isFinite(t)){E(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){E(e,"-0");return}let r=t|0;if(t===r){E(e,"int"),oe(e,r);return}E(e,"num"),le(e,String(t));},me=(e,t)=>{if(e.nodes++>bn){E(e,"[max]");return}if(t===null){E(e,"null");return}let r=typeof t;if(r==="string"){E(e,"string"),le(e,t);return}if(r==="number"){E(e,"number"),_r(e,t);return}if(r==="boolean"){E(e,t?"true":"false");return}if(r==="undefined"){E(e,"undefined");return}if(r==="bigint"){E(e,"bigint"),le(e,t.toString());return}if(r==="symbol"){E(e,"symbol");let a=t;le(e,Symbol.keyFor(a)??a.description??String(a));return}if(r==="function"){E(e,"function"),le(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){E(e,"ref"),oe(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){E(e,"array"),oe(e,o.length);for(let a=0;a<o.length;a++)Object.prototype.hasOwnProperty.call(o,a)?me(e,o[a]):E(e,"hole");return}if(o instanceof Date){E(e,"date"),_r(e,o.getTime());return}if(o instanceof Map){E(e,"map"),oe(e,o.size),o.forEach((a,d)=>{me(e,d),me(e,a);});return}if(o instanceof Set){E(e,"set"),oe(e,o.size),o.forEach(a=>{me(e,a);});return}E(e,"object");let i=Object.getOwnPropertyDescriptors(o),c=[];Object.entries(i).forEach(([a,d])=>{d?.enumerable&&(re.has(a)||"get"in d||"set"in d||c.push([a,d]));}),oe(e,c.length);for(let[a,d]of c)le(e,a),me(e,d.value);},Ne=e=>{if(typeof e=="string")return Wr(JSON.stringify(e));let t={h1:mn,h2:hn,seen:new WeakMap,nextId:1,nodes:0};me(t,e);let r=t.h1>>>0,o=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,o^=o>>>16,o=Math.imul(o,668265261),o^=o>>>15,o=Math.imul(o,374761393),o^=o>>>16,(r&2097151)*4294967296+(o>>>0)};var wn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Ae=e=>{if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map)return new Map(e);if(e instanceof Set)return new Set(e);if(Array.isArray(e))return e.slice();let t={},r=Object.getOwnPropertyDescriptors(e);return Object.entries(r).forEach(([o,n])=>{n.enumerable&&(re.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},zt=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=[["WeakMap",globalThis.WeakMap],["WeakSet",globalThis.WeakSet],["WeakRef",globalThis.WeakRef],["Promise",globalThis.Promise],["ReadableStream",globalThis.ReadableStream],["WritableStream",globalThis.WritableStream],["TransformStream",globalThis.TransformStream],["EventTarget",globalThis.EventTarget]];for(let[o,n]of t)if(typeof n=="function"&&e instanceof n)return o;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},vn=e=>zt(e)===null,xn=e=>{let t=zt(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},ue=(e,t=new WeakMap)=>{if(xn(e),e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let n=new Map;return t.set(e,n),e.forEach((s,i)=>{n.set(ue(i,t),ue(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(ue(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=ue(s,t);}),n}let r={};t.set(e,r);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch(n){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${n?.message??n}`)}return Object.entries(o).forEach(([n,s])=>{!s.enumerable||re.has(n)||"get"in s||"set"in s||(r[n]=ue(s.value,t));}),r},V=e=>{if(wn)try{return structuredClone(e)}catch(t){if(!vn(e)){let r=zt(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return p(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),ue(e)}return ue(e)};var Lt=new Set,Cn=()=>{Lt.clear();};x("options.legacy-warnings",Cn,30);var et=(()=>{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"}})(),Ht=e=>{try{return typeof window>"u"?et:e==="session"||e==="sessionStorage"?window.sessionStorage??et:window.localStorage??et}catch{return et}},je=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),he=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Br=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}},Mn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Lr=e=>{try{e[Mn]=!0;}catch{}return e},En={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"},Fn=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Lr(g=>g),decrypt:Lr(g=>g),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Ht("localStorage"),...r};if(typeof e=="string")return {driver:Ht(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,a=e.allowPlaintext===true,d=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,f=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(c&&Br(o)&&!s)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||Ht("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:o,decrypt:n,encryptAsync:s,decryptAsync:i,allowPlaintext:a,sensitiveData:c,maxSize:d,checksum:f,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},qr=e=>{if(!je(e))return [];let t=[];return Object.entries(En).forEach(([r,o])=>{he(e,r)&&(Lt.has(r)||(Lt.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},Ur=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=je(e.lifecycle)?e.lifecycle:void 0,c=je(e.persist)?e.persist:void 0,a=je(e.devtools)?e.devtools:void 0,d=e.validate??e.validator??e.schema,f=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",g=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,S=je(e.features)?{...e.features}:void 0,b=he(e,"persist"),h=he(e,"sync"),l=he(e,"devtools")||he(e,"historyLimit")||he(e,"redactor"),k=o==="global"?true:e.allowSSRGlobalStore??false,{persist:w=false,devtools:F=false,onError:j,sync:P}=e;if(c?.sensitiveData===true){let O=c.encrypt,m=c.encryptAsync;if((!O||Br(O))&&!m)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:o,lazy:n,pathCreate:s,persist:o==="temp"&&!b?null:Fn(w,t),devtools:o==="temp"&&!l?false:typeof F=="boolean"?F:a?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:j,validate:d,migrations:c?.migrations??e.migrations??{},version:c?.version??e.version??1,redactor:o==="temp"&&!l?void 0:a?.redactor??e.redactor,historyLimit:o==="temp"&&!l?0:a?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!h?false:P??false,features:S,allowSSRGlobalStore:k,snapshot:f,snapshotSafety:g,explicitPersist:b,explicitSync:h,explicitDevtools:l}};var tt=Symbol("stroid.middleware.abort"),Gr=({name:e,payload:t,middlewares:r,reportIssue:o,warn:n})=>{if(!Array.isArray(r)||r.length===0)return t.next;let s=new WeakSet,i=V(t.next);for(let c of r){if(typeof c!="function")continue;let a,d=i;try{a=c({action:t.action,name:e,prev:t.prev,next:d,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(f){let g=`Middleware for "${e}" failed: ${f?.message??f}`;return o(g,"dev"),tt}if(a&&typeof a.then=="function"){let f=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(f,"dev"),tt}a===void 0?(v()&&!s.has(c)&&(s.add(c),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=d):i=a;}return i},rt=({name:e,label:t,fn:r,args:o,reportIssue:n})=>{if(typeof r=="function")try{r(...o);}catch(s){let i=`${t} for "${e}" failed: ${s?.message??s}`;n(i,"always");}};var X=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;L(`${t} callback threw: ${String(n)}`);}},de=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(X(n,"onError",e),r==="critical"){o==="dev"&&p(e),ae(e);return}if(o==="always"){L(e);return}p(e);};var ot=null,Kr=e=>{ot=e;},Yr=e=>ot?ot(e):[];x("computed.order-resolver",()=>{ot=null;},105);var Jr=()=>J(Se(ye)),Q=()=>Jr().computedEntries,Pe=()=>Jr().computedDependents,Tn=(e,t)=>{let r=Q(),o=new Set,n=[],s=i=>{if(i===e)return true;if(o.has(i))return false;o.add(i),n.push(i);let c=r[i]?.deps??[];for(let a of c)if(s(a))return true;return n.pop(),false};for(let i of t)if(n.length=0,s(i))return [e,...n,e].join(" -> ");return null},Xr=(e,t)=>{let r=Pe();for(let o of t){let n=r[o];n&&(n.delete(e),n.size===0&&delete r[o]);}},Qr=(e,t,r)=>{let o=Tn(e,t);if(o)return $(`[stroid] createComputed("${e}") rejected: circular dependency detected -> ${o}
9
+ Define relationships without cycles.`),false;let n=Q(),s=Pe();n[e]&&Xr(e,n[e].deps),n[e]={deps:t,compute:r,stale:true};for(let i of t)s[i]||(s[i]=new Set),s[i].add(e);return true},Zr=e=>{let t=Q(),r=t[e];r&&(Xr(e,r.deps),delete t[e]);},Bt=e=>{let t=Q();t[e]&&(t[e].stale=true);},nt=e=>Object.prototype.hasOwnProperty.call(Q(),e),qt=e=>Q()[e],On=e=>{let t=Q(),r=Pe(),o=new Set,n=[...e];for(;n.length>0;){let f=n.shift(),g=r[f];if(g)for(let S of g)o.has(S)||(o.add(S),n.push(S));}if(o.size===0)return [];let s=f=>{let g=t[f];if(g)for(let S of g.deps)t[S]&&(o.has(S)||(o.add(S),s(S)));};Array.from(o).forEach(f=>s(f));let i=new Map,c=new Map;for(let f of o){let g=t[f];if(!g)continue;let S=0;for(let b of g.deps)o.has(b)&&(S++,c.has(b)||c.set(b,[]),c.get(b).push(f));i.set(f,S);}let a=[];for(let[f,g]of i)g===0&&a.push(f);a.sort();let d=[];for(;a.length>0;){let f=a.shift();d.push(f);let g=c.get(f)??[];for(let S of g){let b=(i.get(S)??1)-1;if(i.set(S,b),b===0){let h=a.findIndex(l=>l>S);h===-1?a.push(S):a.splice(h,0,S);}}}return d};Kr(On);var Vn=()=>{let e=Q(),t=Pe(),r=Object.keys(e),o=[];for(let[n,s]of Object.entries(e))for(let i of s.deps)o.push({from:i,to:n});return {nodes:r,edges:o,dependencies:Object.fromEntries(Object.entries(e).map(([n,s])=>[n,[...s.deps]])),dependents:Object.fromEntries(Object.entries(t).map(([n,s])=>[n,[...s]]))}},Ut=e=>{let t=Q()[e];if(!t)return null;let r=Pe()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var eo=new Map;var Gt=e=>{let t=eo.get(e);return !!t&&t.size>0},Ie=(e,t,r)=>{let o=eo.get(e);!o||o.size===0||o.forEach(n=>{try{n(t,r);}catch(s){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,s);}});};var to=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,a=e.deletingStores,d=(l,k)=>{de(k,{onError:s[l]?.options?.onError,severity:"warn",visibility:"dev"});},f=({name:l,prev:k,options:w,initialState:F,getMeta:j,getStoreValue:P,hasStore:O})=>({name:l,options:w,prev:k,getMeta:j,getStoreValue:P,getAllStores:()=>t,getInitialState:()=>F,hasStore:O,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:m=>{de(m,{onError:w.onError,severity:"warn",visibility:"dev"});},warn:p,warnAlways:L,log:z,hashState:Ne,deepClone:V,sanitize:ce,validate:()=>({ok:true,value:k}),isDev:v}),g=({name:l,prev:k,options:w,initialState:F,phase:j})=>{let P=f({name:l,prev:k,options:w,initialState:F,getMeta:()=>s[l],getStoreValue:()=>t[l],hasStore:()=>ie(e,l)}),O=f({name:l,prev:k,options:w,initialState:F,getMeta:()=>{},getStoreValue:()=>k,hasStore:()=>false});ge().forEach(m=>{let I=c.get(m);j==="before"?I?.beforeStoreDelete?.(P):I?.afterStoreDelete?.(O);});},S=l=>{if(!ie(e,l))return;let k=t[l],w=s[l].options,F=o[l],j=r[l];a.add(l);try{j?.forEach(m=>{try{m(null);}catch(I){p(`Subscriber for "${l}" threw during delete: ${I?.message??I}`);}}),rt({name:l,label:"onDelete",fn:w.onDelete,args:[k],reportIssue:(m,I)=>{de(m,{onError:w.onError,severity:"warn",visibility:I});}}),g({name:l,prev:k,options:w,initialState:F,phase:"before"}),delete t[l],delete r[l],delete o[l],delete n[l],delete s[l],delete i[l],nt(l)&&ro(l);let O=e.computedDependents[l];if(O)for(let m of [...O]){let I=Ut(m);if(I&&oo(m,e)&&I.deps.every(Re=>!ie(e,Re))){S(m);continue}p(`[stroid] source store "${l}" was deleted. Computed store "${m}" depends on it and will return stale data. Call deleteComputed("${m}") to clean up.`);}g({name:l,prev:k,options:w,initialState:F,phase:"after"}),Ie("afterStoreDelete",l,{type:"afterStoreDelete",prev:k}),Xe(e,{type:"deleted",name:l}),z(`Store "${l}" deleted`);}finally{a.delete(l);}};return {deleteExistingStore:S,clearAllStores:()=>{let l=[],w=0,F=Number.POSITIVE_INFINITY;for(;w<20;){let P=Object.keys(t);if(P.length===0)break;P.forEach(m=>{ie(e,m)&&(S(m),l.push(m));}),w+=1;let O=Object.keys(t).length;if(O===0||O>=F)break;F=O;}let j=Object.keys(t).length;return j>0?p(`clearAllStores stopped after ${w} pass${w===1?"":"es"}; ${j} store(s) still registered (likely recreated during deletion).`):z(`All stores cleared (${l.length} stores removed)`),l},clearStores:l=>{let k=Object.keys(t).filter(w=>l?l.endsWith("*")?w.startsWith(l.slice(0,-1)):w===l:true);return k.forEach(w=>S(w)),k},reportStoreError:d}};var st=null;var Dn=()=>{st=null;};x("transaction.runner",Dn,120);var $e=e=>{let t=st?.get();return t||(e??J()).transaction},Nn=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var _=()=>st?(st.get()?.depth??0)>0:$e().depth>0,it=(e,t)=>{let r=$e(t);r.failed=true,r.error||(r.error=Nn(e));},at=e=>{let t=J();$e(t).pending.push(()=>Qe(t,e));},ct=(e,t)=>{let r=$e();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},be=e=>{let t=$e();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Kt=ye,so=Se(Kt),io=null,A=()=>{let e=J(so);return Et(e),e};var R=()=>A();var ao=(e,t)=>{Xe(e,t);};function co(e){io=e;}var we=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,o)=>(e()[r]=o,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let o=Object.getOwnPropertyDescriptor(e(),r);if(o)return {...o,configurable:true}}}),An=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 n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),jn=e=>new Proxy({},{get:(t,r)=>{let o=e(),n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),ze=we(()=>A().stores);we(()=>A().subscribers);var lo=we(()=>A().initialStates);we(()=>A().initialFactories);var T=we(()=>A().metaEntries);we(()=>A().snapshotCache);var q=An(()=>A().featureRuntimes),no=new WeakMap,Pn=e=>{let t=no.get(e);return t||(t=to(e),no.set(e,t)),t};jn(()=>Pn(A()));var In=e=>{let t=q.get(e);if(t)return t;let r=Je(e);if(!r)return;let o=r();return q.set(e,o),o},lt=()=>{ge().forEach(e=>{In(e);});};lt();var Z=(e,t)=>ie(t??A(),e),_e=(e,t=A())=>{if(_()){let o=be(e);if(o.has)return o.value}let r=Te();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},U=(e,t,r=A())=>{r.stores[e]=t;},uo=(e,t,r=Date.now())=>{U(e,t),T[e]&&(T[e].updatedAt=new Date(r).toISOString(),T[e].updatedAtMs=r,T[e].lastCorrelationId=null,T[e].lastCorrelationAt=null,T[e].lastCorrelationAtMs=null,T[e].lastTraceContext=null,T[e].updateCount>=Number.MAX_SAFE_INTEGER?T[e].updateCount=0:T[e].updateCount+=1,io?.(e));},Yt=(e,t=A())=>{let r=t.metaEntries[e];if(!r)return;r.readCount=(r.readCount??0)+1;let o=Date.now();r.lastReadAtMs=o,r.lastReadAt=new Date(o).toISOString();},$n=()=>{br(A());},zn=()=>{q.forEach(e=>{try{e.resetAll?.();}catch{}}),q.clear();};x("features.reset",zn,10);x("registries.clear",$n,20);x("registry.default",()=>{Kt=ye,so=Se(Kt);},115);var po=e=>hr(A(),e);var ut=new Set,go=e=>e?ut.has(e):ut.size>0,yo=e=>{e&&ut.add(e);},_n=()=>{ut.clear();};x("ssr.warnings",_n,60);var fo=new Set,Wn=e=>{let t=Rr();return !t||e.includes("::")?e:(v()&&!fo.has(e)&&(fo.add(e),p(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},dt=e=>Wn(typeof e=="string"?e:e.name),pt=e=>Z(e)&&!po(e)?true:(Dt(e,Object.keys(ze)),false),So=(e,t,r={})=>{de(t,{...r,onError:T[e]?.options?.onError});},mo=(e,t,r={})=>{de(e,{...r,onError:t});},pe=(e,t,r="dev")=>{So(e,t,{severity:"warn",visibility:r});},Hn=(e,t,r="dev")=>{mo(e,t,{severity:"warn",visibility:r});},We=(e,t)=>So(e,t,{severity:"critical",visibility:"always"}),He=(e,t)=>mo(e,t,{severity:"critical",visibility:"always"}),ft=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
10
+ Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Hn(o,r,"always"),C().strictMissingFeatures)throw new Error(o)};var ho=new WeakMap,bo=new WeakMap;var gt=e=>{let t=ho.get(e);return t||(t=new Map,ho.set(e,t)),t},wo=e=>{let t=bo.get(e);return t||(t=new Map,bo.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=gt(R());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let o=r[t];return typeof o=="function"?o.bind(r):o},set:(e,t,r)=>(gt(R())[t]=r,true)});var ve=(e,t,r,o)=>{try{return o?.reuseInput&&Pt(t)?{ok:!0,value:t}:{ok:!0,value:ce(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return X(T[e]?.options?.onError,`onError(${e})`,s),X(r,`onError(${e})`,s),p(s),{ok:false}}},Ln=(e,t)=>{let r=new Set,o=T[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Jt=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=Ln(e,o),s=(c,a)=>{n.forEach(d=>X(d,`onError(${e})`,c)),a==="critical"?ae(c):p(c);};if(typeof r=="function")try{let c=r(t);return c===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:c===!0?t:c}}catch(c){return s(`Validation for "${e}" failed: ${c?.message??c}`,"critical"),{ok:false}}let i=At(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Le=(e,t,r,o,n)=>{let s=ve(e,t,o,n);if(!s.ok)return {ok:false};let i=Jt(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},ee=e=>{let t=R();gt(t).delete(e),wo(t).delete(e);},Bn=()=>{let e=R();gt(e).clear(),wo(e).clear();};x("validation.path-cache",Bn,50);co(ee);var vo=(e,t=R())=>{if((_()?be(e):{has:false}).has||t.stores[e]!==void 0)return true;let o=t.initialFactories[e];if(!o)return true;try{let n=o(),s=ve(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,c=Le(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!c.ok)return !1;if(_()){let a=c.value;ct(e,a),at(()=>{U(e,a,t),t.initialStates[e]=V(a),delete t.initialFactories[e],ee(e);});}else U(e,c.value,t),t.initialStates[e]=V(c.value),delete t.initialFactories[e],ee(e);return !0}catch(n){return We(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var xo=new WeakMap,ko=e=>{let t=xo.get(e);return t||(t=new Map,xo.set(e,t)),t},qn=()=>{ko(R()).clear();};x("features.contexts",qn,100);var Ro=e=>{let t=R(),r=ko(t),o=r.get(e);if(o)return o;let n=T[e];if(!n)return p(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>T[e],getStoreValue:()=>ze[e],getAllStores:()=>ze,getInitialState:()=>lo[e],hasStore:()=>Z(e),setStoreValue:i=>{U(e,i);},applyFeatureState:(i,c)=>{uo(e,i,c),ee(e);},notify:()=>{},reportStoreError:i=>{We(e,i);},warn:p,warnAlways:L,log:z,hashState:Ne,deepClone:V,sanitize:ce,validate:i=>Jt(e,i,T[e]?.options?.validate),isDev:v};return r.set(e,s),s},Co=(e,t)=>{let r=C();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 n=`Feature hook context missing fields for "${e}": ${o.join(", ")}.`;if(We(e,n),r.assertRuntime)throw new Error(n)},Mo=(e,t)=>{lt();let r=Ro(e);r&&(r.notify=()=>t(e),Co(e,r),q.forEach(o=>{o.onStoreCreate?.(r);}));},Eo=(e,t,r,o,n)=>{lt();let s=Ro(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});Co(e,i),q.forEach(c=>{c.onStoreWrite?.(i);});};var Fo=(e,t)=>Gr({name:e,payload:t,middlewares:(()=>{let r=T[e]?.options?.middleware||[],o=C().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{pe(e,r,o);},warn:p}),yt=(e,t,r,o)=>rt({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{pe(e,n,s);}}),To=(e,t)=>{let r={...t};return r.persist&&!Ye("persist")&&(r.explicitPersist&&ft(e,"persist",r.onError),r.persist=null),r.sync&&!Ye("sync")&&(r.explicitSync&&ft(e,"sync",r.onError),r.sync=false),Ye("devtools")||(r.explicitDevtools&&ft(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var St=null,Oo=e=>(St=e,()=>{St===e&&(St=null);}),xe=e=>{St?.(e);};var mt=new Set,Un=e=>{mt.clear();};x("store-create.ssr-global-warned",()=>Un(),65);function Xt(e,t,r={}){if(_()){let m=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;He(m,r.onError),it(m);return}if(!It(e)){He(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!jt(t)){He(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&v()&&p(`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.`),qr(r).forEach(m=>{p(m);});let n=To(e,Ur(r,e,C().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let m=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;X(n.onError,`onError(${e})`,m),v()||L(m),$(m);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=s&&i==="production",a=n.allowSSRGlobalStore??false,d=R(),f=d.stores,g=d.subscribers,S=d.initialStates,b=d.initialFactories,h=d.metaEntries,l=d.scope==="request";if(c&&!a&&!l){let m=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
11
+ Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;He(m,r.onError);return}if(c&&a&&!l&&!mt.has(e)&&(mt.add(e),L(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
12
+ This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),Z(e,d)){let m=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return pe(e,m),{name:e}}s&&!a&&!l&&!go(e)&&v()&&(yo(e),p(`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 k=ve(e,t,n.onError);if(!k.ok)return;let w=k.value,F=n.lazy===true&&typeof t=="function",j=(g[e]?.size??0)>0;if(F)f[e]=void 0,b[e]=t;else {let m=Le(e,w,n.validate,n.onError);if(!m.ok)return;U(e,m.value,d),S[e]=V(m.value);}let P=Date.now(),O=new Date(P).toISOString();return h[e]={createdAt:O,updatedAt:O,updatedAtMs:P,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},ee(e),Mo(e,xe),yt(e,"onCreate",h[e].options.onCreate,[w]),ao(d,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),j&&xe(e),z(`Store "${e}" created -> ${JSON.stringify(w)}`),{name:e}}var Vo=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 !(r&&r!=="Object"&&r!=="Array")},Qt=e=>(Vo(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Do=e=>{if(!Vo(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 n of Object.keys(o)){let s=o[n];typeof s=="object"&&s!==null&&!r.has(s)&&t.push(s);}}}return e};var No=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Zt=(e,t)=>{if(t==="ref"){if(!v())return e;try{return Qt(e)}catch{return e}}if(t==="shallow"){let o=Ae(e);if(!v())return o;try{return Qt(o)}catch{return o}}let r=V(e);if(!v())return r;try{return Do(r)}catch{return r}};var Ao=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:o}=e,n=C().flush,s=n.priorityStores||[],i=s.length?new Set(s):null;o.length=0,r.length=0;let c=new Set;if(i){for(let h of t)r.push(h),c.add(h);for(let h of s)c.has(h)&&o.push(h);for(let h of r)i.has(h)||o.push(h);}else for(let h of t)r.push(h),c.add(h),o.push(h);t.clear();let a=Yr(o),d=new Set(o);for(let h of a)d.has(h)||(o.push(h),d.add(h));let f=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,g=n.chunkDelayMs,S=f===Number.POSITIVE_INFINITY&&g===0;return {names:o,sliceSize:f,chunkDelayMs:g,runInline:S,prioritySet:i}};var er=e=>({notifyCount:e?.notifyCount??0,totalNotifyMs:e?.totalNotifyMs??0,lastNotifyMs:e?.lastNotifyMs??0,resetCount:e?.resetCount??0,totalResetMs:e?.totalResetMs??0,lastResetMs:e?.lastResetMs??0}),tr=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),rr=(e,t)=>{e&&(e.metrics=t);};var Be=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},jo=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>Qe(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var qe=null,ht=null;var Gn=()=>{qe=null,ht=null;};x("write-context.runner",Gn,121);var bt=()=>ht?.get()??qe,or=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(ht)return ht.run(e,t);let r=qe;qe=e;try{return t()}finally{qe=r;}};var Po=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)},Io=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:c,runInline:a,prioritySet:d}=t,g=e.stores,S=e.subscribers,b=e.metaEntries,h=e.snapshotCache,l=C().defaultSnapshotMode,k=y=>No(b[y],l),w=y=>g[y],F=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),j=Gt("beforeFlush"),P=Gt("afterFlush"),O=y=>{j&&Ie("beforeFlush",y,{type:"beforeFlush"});},m=(y,D)=>{P&&Ie("afterFlush",y,{type:"afterFlush",elapsedMs:D});},I=y=>{let D=b[y];if(!D)return null;let M=D.lastCorrelationId??void 0,u=D.lastTraceContext??void 0;return !M&&!u?null:{correlationId:M,traceContext:u}},Re=()=>{o();};if(a){for(let y of s){let D=S[y];if(!D||D.size===0)continue;let M=b[y]?.updateCount??0,u=k(y),fe=w(y),W=h[y],H=W&&W.source===fe&&W.mode===u?W.snapshot:(()=>{let N=Zt(fe,u);return h[y]={version:r,snapshot:N,source:fe,mode:u},N})(),G=er(b[y]?.metrics);O(y);let ne=F(),te=Array.from(D),Ce=I(y),Me=()=>{for(let N of te)try{N(H);}catch(se){let K=b[y]?.options?.snapshotSafety??"warn";if(v()&&(u==="ref"||u==="shallow")&&Po(se)){if(K==="throw")throw se;if(K==="auto-clone")try{let Fe=V(H);p(`Snapshot mutation detected for "${y}". Delivered a cloned snapshot to the subscriber.`);try{N(Fe);}catch(Rt){p(`Subscriber for "${y}" threw on cloned snapshot: ${Rt?.message??Rt}`);}continue}catch{}p(`Snapshot mutation detected for "${y}": ${se?.message??se}`);continue}p(`Subscriber for "${y}" threw: ${se?.message??se}`);}};Ce?or(Ce,Me):Me();let Ee=F()-ne;m(y,Ee),tr(G,Ee),rr(b[y],G),(b[y]?.updateCount??M)!==M&&n.pendingNotifications.add(y);}Re();return}let ir=y=>{let D=[];for(let M of s){if(y&&!y(M))continue;let u=S[M];if(!u||u.size===0)continue;let fe=b[M]?.updateCount??0,W=k(M),H=w(M),G=h[M],ne=G&&G.source===H&&G.mode===W?G.snapshot:(()=>{let te=Zt(H,W);return h[M]={version:r,snapshot:te,source:H,mode:W},te})();D.push({name:M,snapshot:ne,version:fe,subscribers:Array.from(u),subscriberSet:new Set(u),notified:new Set,metrics:er(b[M]?.metrics),totalMs:0,beforeHooked:false});}return D},ar=d?ir(y=>d.has(y)):[],cr=ir(y=>!d||!d.has(y)),xt=(y,D)=>{let M=()=>{if(y.length===0){D();return}let u=y.shift();if((b[u.name]?.updateCount??u.version)!==u.version){if(n.pendingNotifications.add(u.name),y.length===0){D();return}Be(M,c);return}let W=()=>{let B=S[u.name];if(!(!B||B.size===0))for(let N of B)u.subscriberSet.has(N)||(u.subscriberSet.add(N),u.subscribers.push(N));};W();let H=u.subscribers;if(H.length===0){if(y.length===0){D();return}Be(M,c);return}u.beforeHooked||(u.beforeHooked=true,O(u.name));let G=F(),ne=0,te=false,Ce=I(u.name),Me=()=>{for(let B=0;B<H.length&&ne<i;B+=1){let N=H[B];if(u.notified.has(N))continue;u.notified.add(N);try{N(u.snapshot);}catch(K){let kt=b[u.name]?.options?.snapshotSafety??"warn",Fe=k(u.name);if(v()&&(Fe==="ref"||Fe==="shallow")&&Po(K)){if(kt==="throw")throw K;if(kt==="auto-clone")try{let lr=V(u.snapshot);p(`Snapshot mutation detected for "${u.name}". Delivered a cloned snapshot to the subscriber.`);try{N(lr);}catch(ur){p(`Subscriber for "${u.name}" threw on cloned snapshot: ${ur?.message??ur}`);}if(u.notified.add(N),ne+=1,(b[u.name]?.updateCount??u.version)!==u.version){te=!0,n.pendingNotifications.add(u.name);break}continue}catch{}p(`Snapshot mutation detected for "${u.name}": ${K?.message??K}`);continue}p(`Subscriber for "${u.name}" threw: ${K?.message??K}`);}if(ne+=1,(b[u.name]?.updateCount??u.version)!==u.version){te=true,n.pendingNotifications.add(u.name);break}}};if(Ce?or(Ce,Me):Me(),u.totalMs+=F()-G,te){if(y.length===0){D();return}Be(M,c);return}W();let Ee=false;for(let B of H)if(!u.notified.has(B)){Ee=true;break}if(Ee?y.push(u):(tr(u.metrics,u.totalMs),rr(b[u.name],u.metrics),m(u.name,u.totalMs)),y.length===0){D();return}Be(M,c);};M();};ar.length>0?xt(ar,()=>xt(cr,Re)):xt(cr,Re);};var Kn=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=Ao(t);Io(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&nr(e);});},nr=e=>{jo(e,Kn);};var Yn=e=>{let t=R(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&nr(t);};Oo(Yn);var sr=(e,t)=>{let o=R().subscribers;return o[e]||(o[e]=new Set),o[e].add(t),()=>{o[e]?.delete(t),o[e]?.size===0&&delete o[e];}};var Jn=()=>{let e=R().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};x("notify.reset",Jn,40);var Xn=new Set;x("store-write.slow-mutator-warned",()=>Xn.clear(),65);var Qn=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var zo=e=>bt(),$o=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:c})=>{let a=e.metaEntries;U(t,o,e),ee(t);let d=Date.now();a[t].updatedAt=new Date(d).toISOString(),a[t].updatedAtMs=d;let f=c??bt();f&&(f.correlationId||f.traceContext)?(a[t].lastCorrelationId=f.correlationId??null,a[t].lastCorrelationAt=new Date(d).toISOString(),a[t].lastCorrelationAtMs=d,a[t].lastTraceContext=f.traceContext??null):(a[t].lastCorrelationId=null,a[t].lastCorrelationAt=null,a[t].lastCorrelationAtMs=null,a[t].lastTraceContext=null),Qn(a[t]),Eo(t,n,r,o,xe),yt(t,s,a[t].options[s],[r,o]),xe(t),z(i);},_o=(e,t)=>{let r=t.context??bt();if(_()){ct(t.name,t.next),at(()=>$o(e,{...t,context:r}));return}$o(e,{...t,context:r});};function Ue(e,t){let r=dt(e);if(!r)return {ok:false,reason:"invalid-args"};let o=R(),n=Zn(o,r,t,"replace");return n.ok?{ok:true}:n.reason==="not-found"?{ok:false,reason:"not-found"}:n.reason==="middleware"?{ok:false,reason:"middleware"}:{ok:false,reason:"validate"}}var Zn=(e,t,r,o="hydrate",n)=>{let s=(h,l)=>(_()&&it(l??h),{ok:false,reason:h});if(!pt(t))return s("not-found",`replaceStore("${t}") called before createStore().`);let i=_()?be(t):{has:false,value:void 0},c=i.has?i.value:_e(t,e),a=ve(t,r);if(!a.ok)return s("sanitize",`replaceStore("${t}") failed sanitize`);let d=a.value;if(d===void 0){let h=`Whole-store undefined replacement is blocked for "${t}". Use null for intentional empty state.`;return pe(t,h),s("undefined",h)}let f=e.metaEntries[t]?.options?.validate,g=zo(),S=Fo(t,{action:o,prev:c,next:d,path:null,correlationId:g?.correlationId,traceContext:g?.traceContext});if(S===tt)return s("middleware",`replaceStore("${t}") aborted by middleware`);let b=Le(t,S,f);return b.ok?(_o(e,{name:t,prev:c,next:b.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:g}),{ok:true}):s("validate",`replaceStore("${t}") failed validation`)};var es=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Wo=(e,t)=>t==="ref"?e:t==="shallow"?Ae(e):V(e);function ke(e,t){let r=dt(e);if(!pt(r))return null;let o=R();if(!vo(r,o))return null;Yt(r,o);let n=_e(r,o),s=es(o.metaEntries[r],C().defaultSnapshotMode);return n===null||typeof n!="object"?n:Wo(n,s);}var Ge=e=>Z(e);var Ke=e=>({name:e});var wt=()=>R().computedCleanups,Ho=new WeakMap,Lo=new WeakMap,vt=e=>{let t=Ho.get(e);return t||(t=new Map,Ho.set(e,t)),t},ts=e=>{let t=Lo.get(e);return t||(t=new Map,Lo.set(e,t)),t};function vc(e,t,r,o={}){if(!e||typeof e!="string"){p("createComputed requires a store name as first argument");return}if(!Array.isArray(t)||t.length===0){p(`createComputed("${e}") requires at least one dependency`);return}if(typeof r!="function"){p(`createComputed("${e}") requires a compute function as third argument`);return}let n=wt(),s=n.get(e);s&&(s(),n.delete(e));let i=t.map(g=>typeof g=="string"?g:g?.name);if(i.some(g=>!g||typeof g!="string")){p(`createComputed("${e}") dependencies must be store names or store handles.`);return}if(v()){let g=i.filter(S=>!Ge(S));g.length>0&&p(`createComputed("${e}") dependencies not found at registration: ${g.join(", ")}. Computed values will receive null until those stores are created.`);}if(!Qr(e,i,r))return;vt(R()).set(e,{...o});let a=Bo(e,t,r,o.onError),d=Ke(e);Ge(e)?Ue(d,a):Xt(e,a);let f=[];for(let g of i){let S=sr(g,()=>{qo(e,i,r,o.onError);});f.push(S);}return wt().set(e,()=>{f.forEach(g=>g()),Zr(e),vt(R()).delete(e);}),v()&&z(`computed store "${e}" created, deps: [${i.join(", ")}]`),d}var Bo=(e,t,r,o)=>{let n=t.map(s=>typeof s=="string"?ke(Ke(s)):ke(s));try{return r(...n)}catch(s){p(`createComputed("${e}") compute function threw: ${s?.message??s}`),X(o,`computed.onError(${e})`,s);let i=Ke(e);return Ge(e)?ke(i):null}},qo=(e,t,r,o)=>{if(!qt(e))return;let s=R();if(s.notify.isFlushing){let d=s.notify.flushId,f=ts(s);if(f.get(e)===d)return;f.set(e,d);}let i=Bo(e,t,r,o),c=Ke(e),a=ke(c);Object.is(i,a)||(Ue(c,i),Bt(e));},xc=e=>{let t=qt(e);if(!t){p(`invalidateComputed("${e}") -- "${e}" is not a computed store`);return}Bt(e),qo(e,t.deps,t.compute);},ro=e=>{let t=wt(),r=t.get(e);if(!r){v()&&p(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);},kc=e=>nt(e),oo=(e,t=R())=>vt(t).get(e)?.autoDispose===true,Rc=()=>{let e=wt();e.forEach(t=>t()),e.clear(),vt(R()).clear();};export{Rc as _resetComputedForTests,vc as createComputed,ro as deleteComputed,Ut as getComputedDepsFor,Vn as getFullComputedGraph,xc as invalidateComputed,kc as isComputedStore,oo as shouldAutoDisposeComputed};//# sourceMappingURL=computed.js.map
13
13
  //# sourceMappingURL=computed.js.map