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
package/dist/index.d.cts CHANGED
@@ -10,6 +10,7 @@ export { createComputed, deleteComputed, invalidateComputed, isComputedStore } f
10
10
  import { F as FetchInput } from './cache.js';
11
11
  import { F as FetchOptions } from './registry.js';
12
12
  import './feature.js';
13
+ import './store-registry.js';
13
14
 
14
15
  declare const setStoreBatch: (fn: () => unknown) => void;
15
16
 
package/dist/index.d.ts CHANGED
@@ -10,6 +10,7 @@ export { createComputed, deleteComputed, invalidateComputed, isComputedStore } f
10
10
  import { F as FetchInput } from './cache.js';
11
11
  import { F as FetchOptions } from './registry.js';
12
12
  import './feature.js';
13
+ import './store-registry.js';
13
14
 
14
15
  declare const setStoreBatch: (fn: () => unknown) => void;
15
16
 
package/dist/index.js CHANGED
@@ -1,36 +1,36 @@
1
- var Ds=Object.defineProperty;var Ps=(e,t)=>{for(var r in t)Ds(e,r,{get:t[r],enumerable:true});};var Vs=new Map,P=(e,t,r=0)=>{!e||typeof t!="function"||Vs.set(e,{name:e,order:r,fn:t});};var wr=new Map;var Bt=e=>wr.has(e),qt=e=>wr.get(e),Qe=()=>Array.from(wr.keys());var uo=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),fo=()=>({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:uo(),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}}),po=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(),uo().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 vr=new Map,go=new WeakSet,xr=e=>{go.has(e)||(go.add(e),Qe().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=qt(t);r&&e.featureRuntimes.set(t,r());}}));},Ns=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,So,Rr=e=>(So||Ns||e).replace(/\.ts(\?|$)/,".js$1"),Ce=Rr(new URL("../../store.js",import.meta.url).href),yo=()=>ke(Ce);var Is=()=>{So=void 0,vr.clear();};P("registry.scope-override",Is,110);var $s=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),_s=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;},Cr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),zs=(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:Cr(),async:fo(),notify:$s(),lifecycleListener:null};return xr(t),t},ke=e=>{let t=Rr(e),r=vr.get(t);if(r)return r;let o=zs();return vr.set(t,o),o},Oe=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),mo=(e,t)=>e.deletingStores.has(t),ho=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,_s(e.notify),po(e.async),e.lifecycleListener=null;};var Kt=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var xt=()=>null,Re=[],wo={run:(e,t)=>{Re.push(e);try{return t()}finally{Re.pop();}},get:()=>Re.length>0?Re[Re.length-1]:null,enterWith:e=>{if(Re.length>0){Re[Re.length-1]=e;return}Re.push(e);}};var Ze=(e,t)=>(wo).run(e,t),Z=e=>(wo).get()||e||ke(Ce);var Hs={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}`));}},vo={logSink:Hs,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},Gt=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}),Ut=new WeakMap,Mr=Gt(vo),xo=e=>{let t=Ut.get(e);return t||(t=Gt(Mr),Ut.set(e,t)),t},Ro,kr=false,Bs=()=>Ro,k=()=>xo(Z());var Co=e=>{if(!e)return;let t=Z(),r=xo(t);if(e.logSink&&(r={...r,logSink:{log:e.logSink.log??r.logSink.log,warn:e.logSink.warn??r.logSink.warn,critical:e.logSink.critical??r.logSink.critical}}),e.flush&&(r={...r,flush:{chunkSize:Number.isFinite(e.flush.chunkSize??r.flush.chunkSize)?e.flush.chunkSize:r.flush.chunkSize,chunkDelayMs:Number.isFinite(e.flush.chunkDelayMs??r.flush.chunkDelayMs)?e.flush.chunkDelayMs:r.flush.chunkDelayMs,priorityStores:Array.isArray(e.flush.priorityStores)?e.flush.priorityStores:r.flush.priorityStores}}),e.revalidateOnFocus&&(r={...r,revalidateOnFocus:{debounceMs:Number.isFinite(e.revalidateOnFocus.debounceMs??r.revalidateOnFocus.debounceMs)?e.revalidateOnFocus.debounceMs:r.revalidateOnFocus.debounceMs,maxConcurrent:Number.isFinite(e.revalidateOnFocus.maxConcurrent??r.revalidateOnFocus.maxConcurrent)?Math.max(1,e.revalidateOnFocus.maxConcurrent):r.revalidateOnFocus.maxConcurrent,staggerMs:Number.isFinite(e.revalidateOnFocus.staggerMs??r.revalidateOnFocus.staggerMs)?Math.max(0,e.revalidateOnFocus.staggerMs):r.revalidateOnFocus.staggerMs}}),typeof e.namespace=="string"&&(r={...r,namespace:e.namespace.trim()}),typeof e.strictMissingFeatures=="boolean"&&(r={...r,strictMissingFeatures:e.strictMissingFeatures}),typeof e.strictFeatures=="boolean"&&(r={...r,strictMissingFeatures:e.strictFeatures}),typeof e.assertRuntime=="boolean"&&(r={...r,assertRuntime:e.assertRuntime}),typeof e.strictMutatorReturns=="boolean"&&(r={...r,strictMutatorReturns:e.strictMutatorReturns}),typeof e.asyncAutoCreate=="boolean"&&(r={...r,asyncAutoCreate:e.asyncAutoCreate}),typeof e.strictAsyncUsageErrors=="boolean"&&(r={...r,strictAsyncUsageErrors:e.strictAsyncUsageErrors}),typeof e.autoCorrelationIds=="boolean"&&(r={...r,autoCorrelationIds:e.autoCorrelationIds}),(e.asyncCloneResult==="none"||e.asyncCloneResult==="shallow"||e.asyncCloneResult==="deep")&&(r={...r,asyncCloneResult:e.asyncCloneResult}),typeof e.acknowledgeLooseTypes=="boolean"&&(r={...r,acknowledgeLooseTypes:e.acknowledgeLooseTypes}),typeof e.pathCacheSize=="number"&&Number.isFinite(e.pathCacheSize)&&(r={...r,pathCacheSize:Math.max(0,Math.floor(e.pathCacheSize))}),(e.snapshotStrategy==="shallow"||e.snapshotStrategy==="ref"||e.snapshotStrategy==="deep")&&(r={...r,defaultSnapshotMode:e.snapshotStrategy}),(e.defaultSnapshotMode==="shallow"||e.defaultSnapshotMode==="ref"||e.defaultSnapshotMode==="deep")&&(r={...r,defaultSnapshotMode:e.defaultSnapshotMode}),Array.isArray(e.middleware)&&(r={...r,middleware:e.middleware}),typeof e.allowUntrustedHydration=="boolean"&&(r={...r,allowUntrustedHydration:e.allowUntrustedHydration}),typeof e.allowHydration=="boolean"&&(r={...r,allowUntrustedHydration:e.allowHydration}),typeof e.allowTrustedHydration=="boolean"&&(r={...r,allowUntrustedHydration:e.allowTrustedHydration}),typeof e.mutatorProduce=="function")r={...r,mutatorProduce:e.mutatorProduce};else if(e.mutatorProduce==="immer"){let o=Bs();o?r={...r,mutatorProduce:o}:kr||(kr=true,I(`configureStroid({ mutatorProduce: "immer" }) requires Immer's produce function.
2
- Call registerMutatorProduce(produce) or pass mutatorProduce: produce directly.`));}typeof e.selectorCloneFrozen=="boolean"&&(r={...r,selectorCloneFrozen:e.selectorCloneFrozen}),Ut.set(t,r),t===yo()&&(Mr=Gt(r));},ko=()=>{Ut=new WeakMap,Mr=Gt(vo),Ro=void 0,kr=false;};P("config.reset",ko,90);var Mo=()=>k().namespace;var qs=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Ks=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,To=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,Us="production",Gs=qs??Ks??Us,Rt=typeof To=="boolean"?To:Gs!=="production",R=()=>Rt,Tr=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Ys=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},Xs=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},B=(e,t)=>{if((k().logSink.critical??Ys)(e,t),k().assertRuntime)throw new Error(e)},d=(e,t)=>{if(!Rt)return;if((k().logSink.warn??Tr)(e,t),k().assertRuntime)throw new Error(e)},I=(e,t)=>{if((k().logSink.warn??Tr)(e,t),k().assertRuntime)throw new Error(e)},$=(e,t)=>{if(Rt&&(k().logSink.warn??Tr)(e,t),B(e,t),k().assertRuntime)throw new Error(e)},ue=(e,t)=>{if(!Rt)return;(k().logSink.log??Xs)(e,t);},Eo=()=>`Functions cannot be stored in stroid.
3
- Store data only - handle functions outside the store.`,Fo=()=>`Map/Set detected. stroid converts these to plain objects.
4
- Use arrays or plain objects for best results.`,Ao=()=>`Date object detected. stroid stores it as ISO string.
5
- Use new Date(value) to convert back when reading.`,Oo=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Do=()=>"Map detected; converting to plain object.",Po=()=>"Set detected; converting to array.",Vo=(e,t,r)=>`Path depth of ${e} exceeded maximum of ${t}.
1
+ var Is=Object.defineProperty;var $s=(e,t)=>{for(var r in t)Is(e,r,{get:t[r],enumerable:true});};var _s=new Map,D=(e,t,r=0)=>{!e||typeof t!="function"||_s.set(e,{name:e,order:r,fn:t});};var wr=new Map;var Bt=e=>wr.has(e),qt=e=>wr.get(e),et=()=>Array.from(wr.keys());var go=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),So=()=>({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:go(),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}}),yo=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(),go().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 xr=new Map,mo=new WeakSet,vr=e=>{mo.has(e)||(mo.add(e),et().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=qt(t);r&&e.featureRuntimes.set(t,r());}}));},zs=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,ho,Rr=e=>(ho||zs||e).replace(/\.ts(\?|$)/,".js$1"),Ce=Rr("stroid:default-registry"),bo=()=>ke(Ce);var Hs=()=>{ho=void 0,xr.clear();};D("registry.scope-override",Hs,110);var Ls=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Bs=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},Cr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),qs=(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:Cr(),async:So(),notify:Ls(),lifecycleListener:null};return vr(t),t},ke=e=>{let t=Rr(e),r=xr.get(t);if(r)return r;let o=qs();return xr.set(t,o),o},Me=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),wo=(e,t)=>e.deletingStores.has(t),xo=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,Bs(e.notify),yo(e.async),e.lifecycleListener=null;};var Kt=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var xt=()=>null,Re=[],Ro={run:(e,t)=>{Re.push(e);try{return t()}finally{Re.pop();}},get:()=>Re.length>0?Re[Re.length-1]:null,enterWith:e=>{if(Re.length>0){Re[Re.length-1]=e;return}Re.push(e);}};var tt=(e,t)=>(Ro).run(e,t),Q=e=>(Ro).get()||e||ke(Ce);var Us={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}`));}},Co={logSink:Us,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},Gt=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}),Ut=new WeakMap,Mr=Gt(Co),ko=e=>{let t=Ut.get(e);return t||(t=Gt(Mr),Ut.set(e,t)),t},Mo,kr=false,Ys=()=>Mo,C=()=>ko(Q());var To=e=>{if(!e)return;let t=Q(),r=ko(t);if(e.logSink&&(r={...r,logSink:{log:e.logSink.log??r.logSink.log,warn:e.logSink.warn??r.logSink.warn,critical:e.logSink.critical??r.logSink.critical}}),e.flush&&(r={...r,flush:{chunkSize:Number.isFinite(e.flush.chunkSize??r.flush.chunkSize)?e.flush.chunkSize:r.flush.chunkSize,chunkDelayMs:Number.isFinite(e.flush.chunkDelayMs??r.flush.chunkDelayMs)?e.flush.chunkDelayMs:r.flush.chunkDelayMs,priorityStores:Array.isArray(e.flush.priorityStores)?e.flush.priorityStores:r.flush.priorityStores}}),e.revalidateOnFocus&&(r={...r,revalidateOnFocus:{debounceMs:Number.isFinite(e.revalidateOnFocus.debounceMs??r.revalidateOnFocus.debounceMs)?e.revalidateOnFocus.debounceMs:r.revalidateOnFocus.debounceMs,maxConcurrent:Number.isFinite(e.revalidateOnFocus.maxConcurrent??r.revalidateOnFocus.maxConcurrent)?Math.max(1,e.revalidateOnFocus.maxConcurrent):r.revalidateOnFocus.maxConcurrent,staggerMs:Number.isFinite(e.revalidateOnFocus.staggerMs??r.revalidateOnFocus.staggerMs)?Math.max(0,e.revalidateOnFocus.staggerMs):r.revalidateOnFocus.staggerMs}}),typeof e.namespace=="string"&&(r={...r,namespace:e.namespace.trim()}),typeof e.strictMissingFeatures=="boolean"&&(r={...r,strictMissingFeatures:e.strictMissingFeatures}),typeof e.strictFeatures=="boolean"&&(r={...r,strictMissingFeatures:e.strictFeatures}),typeof e.assertRuntime=="boolean"&&(r={...r,assertRuntime:e.assertRuntime}),typeof e.strictMutatorReturns=="boolean"&&(r={...r,strictMutatorReturns:e.strictMutatorReturns}),typeof e.asyncAutoCreate=="boolean"&&(r={...r,asyncAutoCreate:e.asyncAutoCreate}),typeof e.strictAsyncUsageErrors=="boolean"&&(r={...r,strictAsyncUsageErrors:e.strictAsyncUsageErrors}),typeof e.autoCorrelationIds=="boolean"&&(r={...r,autoCorrelationIds:e.autoCorrelationIds}),(e.asyncCloneResult==="none"||e.asyncCloneResult==="shallow"||e.asyncCloneResult==="deep")&&(r={...r,asyncCloneResult:e.asyncCloneResult}),typeof e.acknowledgeLooseTypes=="boolean"&&(r={...r,acknowledgeLooseTypes:e.acknowledgeLooseTypes}),typeof e.pathCacheSize=="number"&&Number.isFinite(e.pathCacheSize)&&(r={...r,pathCacheSize:Math.max(0,Math.floor(e.pathCacheSize))}),(e.snapshotStrategy==="shallow"||e.snapshotStrategy==="ref"||e.snapshotStrategy==="deep")&&(r={...r,defaultSnapshotMode:e.snapshotStrategy}),(e.defaultSnapshotMode==="shallow"||e.defaultSnapshotMode==="ref"||e.defaultSnapshotMode==="deep")&&(r={...r,defaultSnapshotMode:e.defaultSnapshotMode}),Array.isArray(e.middleware)&&(r={...r,middleware:e.middleware}),typeof e.allowUntrustedHydration=="boolean"&&(r={...r,allowUntrustedHydration:e.allowUntrustedHydration}),typeof e.allowHydration=="boolean"&&(r={...r,allowUntrustedHydration:e.allowHydration}),typeof e.allowTrustedHydration=="boolean"&&(r={...r,allowUntrustedHydration:e.allowTrustedHydration}),typeof e.mutatorProduce=="function")r={...r,mutatorProduce:e.mutatorProduce};else if(e.mutatorProduce==="immer"){let o=Ys();o?r={...r,mutatorProduce:o}:kr||(kr=true,I(`configureStroid({ mutatorProduce: "immer" }) requires Immer's produce function.
2
+ Call registerMutatorProduce(produce) or pass mutatorProduce: produce directly.`));}typeof e.selectorCloneFrozen=="boolean"&&(r={...r,selectorCloneFrozen:e.selectorCloneFrozen}),Ut.set(t,r),t===bo()&&(Mr=Gt(r));},Eo=()=>{Ut=new WeakMap,Mr=Gt(Co),Mo=void 0,kr=false;};D("config.reset",Eo,90);var Fo=()=>C().namespace;var Xs=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Js=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,Ao=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,Qs="production",Zs=Xs??Js??Qs,vt=typeof Ao=="boolean"?Ao:Zs!=="production",R=()=>vt,Tr=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},ei=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},ti=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},B=(e,t)=>{if((C().logSink.critical??ei)(e,t),C().assertRuntime)throw new Error(e)},d=(e,t)=>{if(!vt)return;if((C().logSink.warn??Tr)(e,t),C().assertRuntime)throw new Error(e)},I=(e,t)=>{if((C().logSink.warn??Tr)(e,t),C().assertRuntime)throw new Error(e)},$=(e,t)=>{if(vt&&(C().logSink.warn??Tr)(e,t),B(e,t),C().assertRuntime)throw new Error(e)},ce=(e,t)=>{if(!vt)return;(C().logSink.log??ti)(e,t);},Oo=()=>`Functions cannot be stored in stroid.
3
+ Store data only - handle functions outside the store.`,Do=()=>`Map/Set detected. stroid converts these to plain objects.
4
+ Use arrays or plain objects for best results.`,Po=()=>`Date object detected. stroid stores it as ISO string.
5
+ Use new Date(value) to convert back when reading.`,Vo=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",jo=()=>"Map detected; converting to plain object.",No=()=>"Set detected; converting to array.",Io=(e,t,r)=>`Path depth of ${e} exceeded maximum of ${t}.
6
6
  "${r.join(".")}"
7
7
  This is a data design issue. Split into separate stores:
8
- createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,jo=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
9
- Consider splitting into separate stores for better readability.`,No=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,Io=e=>`Cannot go deeper at "${e}" - value is not an object`,$o=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,_o=e=>`Store name "${e}" contains spaces.
10
- Use camelCase or kebab-case: "userName" or "user-name"`,zo=e=>`Store name "${e}" is not allowed.
11
- Reserved names: "__proto__", "constructor", "prototype".`,Js=128,Qs=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=Js,Zs=(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]},Ct=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||Qs(n,s)&&Zs(n,s)<=2});if(r){d(`Store "${e}" not found. Did you mean "${r}"?`);return}$(`Store "${e}" not found.
8
+ createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,$o=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
9
+ Consider splitting into separate stores for better readability.`,_o=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,Wo=e=>`Cannot go deeper at "${e}" - value is not an object`,zo=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Ho=e=>`Store name "${e}" contains spaces.
10
+ Use camelCase or kebab-case: "userName" or "user-name"`,Lo=e=>`Store name "${e}" is not allowed.
11
+ Reserved names: "__proto__", "constructor", "prototype".`,ri=128,oi=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=ri,ni=(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]},Rt=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||oi(n,s)&&ni(n,s)<=2});if(r){d(`Store "${e}" not found. Did you mean "${r}"?`);return}$(`Store "${e}" not found.
12
12
  Available stores: [${t.join(", ")}]
13
- Call createStore("${e}", data) first.`);};var de=new Set(["__proto__","constructor","prototype"]),Fr=(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,Wo=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},et=e=>{let t=De(e);return t==="function"?($(Eo()),false):t==="map"||t==="set"?(d(Fo()),true):(t==="date"&&d(Ao()),true)},Er=(e,t)=>{let r=Wo(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&&!Er(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||de.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Er(i.value,t))return false}return true}return true},Ar=e=>Er(e,new WeakSet),kt=(e,t)=>{let r=Wo(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 R()&&d(Oo()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),R()&&d(Do());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)]=kt(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),R()&&d(Po()),Array.from(e,n=>kt(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,a]of Object.entries(s))if(a.enumerable&&!de.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=kt(a.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=>kt(n,t))}return e},$e=e=>kt(e,new WeakSet),Mt=e=>typeof e!="string"||e.trim()===""?($($o(e)),false):de.has(e)?($(zo(e)),false):e.includes(" ")?($(_o(e)),false):true;var Or=null,ei=()=>{if(Or)return Or;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 Or=t,t},Lo=e=>{let t=ei(),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},ti=2166136261,ri=2654435761,oi=1e5,Pe=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},_e=(e,t)=>{Pe(e,t.length);for(let r=0;r<t.length;r++)Pe(e,t.charCodeAt(r));},z=(e,t)=>{_e(e,t);},Ho=(e,t)=>{if(Number.isNaN(t)){z(e,"NaN");return}if(!Number.isFinite(t)){z(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){z(e,"-0");return}let r=t|0;if(t===r){z(e,"int"),Pe(e,r);return}z(e,"num"),_e(e,String(t));},tt=(e,t)=>{if(e.nodes++>oi){z(e,"[max]");return}if(t===null){z(e,"null");return}let r=typeof t;if(r==="string"){z(e,"string"),_e(e,t);return}if(r==="number"){z(e,"number"),Ho(e,t);return}if(r==="boolean"){z(e,t?"true":"false");return}if(r==="undefined"){z(e,"undefined");return}if(r==="bigint"){z(e,"bigint"),_e(e,t.toString());return}if(r==="symbol"){z(e,"symbol");let c=t;_e(e,Symbol.keyFor(c)??c.description??String(c));return}if(r==="function"){z(e,"function"),_e(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){z(e,"ref"),Pe(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){z(e,"array"),Pe(e,o.length);for(let c=0;c<o.length;c++)Object.prototype.hasOwnProperty.call(o,c)?tt(e,o[c]):z(e,"hole");return}if(o instanceof Date){z(e,"date"),Ho(e,o.getTime());return}if(o instanceof Map){z(e,"map"),Pe(e,o.size),o.forEach((c,l)=>{tt(e,l),tt(e,c);});return}if(o instanceof Set){z(e,"set"),Pe(e,o.size),o.forEach(c=>{tt(e,c);});return}z(e,"object");let i=Object.getOwnPropertyDescriptors(o),a=[];Object.entries(i).forEach(([c,l])=>{l?.enumerable&&(de.has(c)||"get"in l||"set"in l||a.push([c,l]));}),Pe(e,a.length);for(let[c,l]of a)_e(e,c),tt(e,l.value);},Tt=e=>{if(typeof e=="string")return Lo(JSON.stringify(e));let t={h1:ti,h2:ri,seen:new WeakMap,nextId:1,nodes:0};tt(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 ni=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",ee=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&&(de.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},Dr=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},si=e=>Dr(e)===null,ii=e=>{let t=Dr(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},ze=(e,t=new WeakMap)=>{if(ii(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(ze(i,t),ze(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(ze(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=ze(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||de.has(n)||"get"in s||"set"in s||(r[n]=ze(s.value,t));}),r},V=e=>{if(ni)try{return structuredClone(e)}catch(t){if(!si(e)){let r=Dr(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}`),ze(e)}return ze(e)},Pr=(e,t)=>{if(Object.is(e,t))return true;if(!e||!t||typeof e!="object"||typeof t!="object")return false;let r=e,o=t,n=Object.keys(r),s=Object.keys(o);if(n.length!==s.length)return false;for(let i of n)if(!Object.prototype.hasOwnProperty.call(o,i)||!Object.is(r[i],o[i]))return false;return true};var Bo=10,ai=5,ci=e=>{let t=[],r="",o=false;for(let n of e){if(o){r+=n,o=false;continue}if(n==="\\"){o=true;continue}if(n==="."){t.push(r),r="";continue}r+=n;}return o&&(r+="\\"),t.push(r),t},rt=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?ci(e):[String(e)],Et=e=>{let t=rt(e),r=t.length;return r>Bo?($(Vo(r,Bo,t)),false):(r>ai&&d(jo(r,t)),true)},Vr=(e,t)=>{let r=rt(t),o=e;for(let n of r){if(o==null){d(No(r,n));return}if(typeof o!="object"){d(Io(n));return}o=o[n];}return o},jr=(e,t,r)=>{let o=rt(t);if(o.length===0)return e;for(let s of o)if(de.has(s))return B(`Blocked forbidden path segment "${String(s)}" in setStore path "${o.join(".")}".`),e;let n=(s,i)=>{let a=o[i],c=i===o.length-1;if(Array.isArray(s)){let l=Number(a);if(!Number.isInteger(l))return s;let u=[...s];return c?(u[l]=r,u):(u[l]=n(u[l],i+1),u)}if(s&&typeof s=="object"){if(de.has(a))return B(`Blocked unsafe path segment "${String(a)}" while setting "${o.join(".")}".`),s;let l={...s};return c?(l[a]=r,l):(l[a]=n(l[a],i+1),l)}if(s==null&&!c){let l=Number.isInteger(Number(a)),u=l?[]:{};if(l){let g=u,p=Number(a);return g[p]=n(void 0,i+1),g}return u[a]=n(void 0,i+1),u}return c?r:s};return n(e,0)};var qo=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")},Nr=e=>(qo(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Ko=e=>{if(!qo(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 We=null;var li=()=>{We=null;};P("transaction.runner",li,120);var He=e=>{let t=We?.get();return t||(e??Z()).transaction},Uo=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted"),Go=e=>{let t=e??Z(),r=We?.get();return !r&&We?.enterWith&&(r=Cr(),We.enterWith(r)),r||(r=He(t)),r.depth+=1,r.depth===1&&(r.pending=[],r.stagedValues.clear(),r.snapshotCache.clear(),r.failed=false,r.error=void 0),t},M=()=>We?(We.get()?.depth??0)>0:He().depth>0,j=(e,t)=>{let r=He(t);r.failed=true,r.error||(r.error=Uo(e));},Yt=e=>{let t=Z();He(t).pending.push(()=>Ze(t,e));},Xt=(e,t)=>{let r=He();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},be=e=>{let t=He();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}},Yo=(e,t)=>{let r=He(t);if(r.depth===0||(e&&j(e,t),r.depth=Math.max(0,r.depth-1),r.depth>0))return null;let o=r.failed?r.error??new Error("setStoreBatch aborted"):null;if(!o){for(let n of r.pending)try{n();}catch(s){j(s,t),o||(o=r.error??Uo(s));}!o&&r.failed&&(o=r.error??new Error("setStoreBatch aborted"));}return r.pending=[],r.stagedValues.clear(),r.snapshotCache.clear(),r.failed=false,r.error=void 0,o};var ot=Symbol("stroid.middleware.abort"),Xo=({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 a of r){if(typeof a!="function")continue;let c,l=i;try{c=a({action:t.action,name:e,prev:t.prev,next:l,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(u){let g=`Middleware for "${e}" failed: ${u?.message??u}`;return o(g,"dev"),ot}if(c&&typeof c.then=="function"){let u=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(u,"dev"),ot}c===void 0?(R()&&!s.has(a)&&(s.add(a),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=l):i=c;}return i},Jt=({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 re=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;I(`${t} callback threw: ${String(n)}`);}},Le=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(re(n,"onError",e),r==="critical"){o==="dev"&&d(e),B(e);return}if(o==="always"){I(e);return}d(e);};var Qt=null,Jo=e=>{Qt=e;},Qo=e=>Qt?Qt(e):[];P("computed.order-resolver",()=>{Qt=null;},105);var Zo=()=>Z(ke(Ce)),Be=()=>Zo().computedEntries,Ir=()=>Zo().computedDependents,ui=(e,t)=>{let r=Be(),o=new Set,n=[],s=i=>{if(i===e)return true;if(o.has(i))return false;o.add(i),n.push(i);let a=r[i]?.deps??[];for(let c of a)if(s(c))return true;return n.pop(),false};for(let i of t)if(n.length=0,s(i))return [e,...n,e].join(" -> ");return null},en=(e,t)=>{let r=Ir();for(let o of t){let n=r[o];n&&(n.delete(e),n.size===0&&delete r[o]);}},tn=(e,t,r)=>{let o=ui(e,t);if(o)return $(`[stroid] createComputed("${e}") rejected: circular dependency detected -> ${o}
14
- Define relationships without cycles.`),false;let n=Be(),s=Ir();n[e]&&en(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},rn=e=>{let t=Be(),r=t[e];r&&(en(e,r.deps),delete t[e]);},$r=e=>{let t=Be();t[e]&&(t[e].stale=true);},Zt=e=>Object.prototype.hasOwnProperty.call(Be(),e),_r=e=>Be()[e],zr=e=>{let t=Be(),r=Ir(),o=new Set,n=[...e];for(;n.length>0;){let u=n.shift(),g=r[u];if(g)for(let p of g)o.has(p)||(o.add(p),n.push(p));}if(o.size===0)return [];let s=u=>{let g=t[u];if(g)for(let p of g.deps)t[p]&&(o.has(p)||(o.add(p),s(p)));};Array.from(o).forEach(u=>s(u));let i=new Map,a=new Map;for(let u of o){let g=t[u];if(!g)continue;let p=0;for(let x of g.deps)o.has(x)&&(p++,a.has(x)||a.set(x,[]),a.get(x).push(u));i.set(u,p);}let c=[];for(let[u,g]of i)g===0&&c.push(u);c.sort();let l=[];for(;c.length>0;){let u=c.shift();l.push(u);let g=a.get(u)??[];for(let p of g){let x=(i.get(p)??1)-1;if(i.set(p,x),x===0){let h=c.findIndex(f=>f>p);h===-1?c.push(p):c.splice(h,0,p);}}}return l};Jo(zr);var Hr=new Set,di=()=>{Hr.clear();};P("options.legacy-warnings",di,30);var er=(()=>{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"}})(),Wr=e=>{try{return typeof window>"u"?er:e==="session"||e==="sessionStorage"?window.sessionStorage??er:window.localStorage??er}catch{return er}},Ft=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),nt=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),nn=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}},fi=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",on=e=>{try{e[fi]=!0;}catch{}return e},pi={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"},gi=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:on(g=>g),decrypt:on(g=>g),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Wr("localStorage"),...r};if(typeof e=="string")return {driver:Wr(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,a=e.sensitiveData===true,c=e.allowPlaintext===true,l=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,u=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(a&&nn(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||Wr("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:c,sensitiveData:a,maxSize:l,checksum:u,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},sn=e=>{if(!Ft(e))return [];let t=[];return Object.entries(pi).forEach(([r,o])=>{nt(e,r)&&(Hr.has(r)||(Hr.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},an=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=Ft(e.lifecycle)?e.lifecycle:void 0,a=Ft(e.persist)?e.persist:void 0,c=Ft(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,u=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,p=Ft(e.features)?{...e.features}:void 0,x=nt(e,"persist"),h=nt(e,"sync"),f=nt(e,"devtools")||nt(e,"historyLimit")||nt(e,"redactor"),y=o==="global"?true:e.allowSSRGlobalStore??false,{persist:m=false,devtools:T=false,onError:C,sync:A}=e;if(a?.sensitiveData===true){let D=a.encrypt,b=a.encryptAsync;if((!D||nn(D))&&!b)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"&&!x?null:gi(m,t),devtools:o==="temp"&&!f?false:typeof T=="boolean"?T:c?.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:C,validate:l,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:o==="temp"&&!f?void 0:c?.redactor??e.redactor,historyLimit:o==="temp"&&!f?0:c?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!h?false:A??false,features:p,allowSSRGlobalStore:y,snapshot:u,snapshotSafety:g,explicitPersist:x,explicitSync:h,explicitDevtools:f}};var tr=new Set,ln=e=>e?tr.has(e):tr.size>0,un=e=>{e&&tr.add(e);},Si=()=>{tr.clear();};P("ssr.warnings",Si,60);var cn=new Set,yi=e=>{let t=Mo();return !t||e.includes("::")?e:(R()&&!cn.has(e)&&(cn.add(e),d(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},fe=e=>yi(typeof e=="string"?e:e.name),qe=e=>oe(e)&&!pn(e)?true:(Ct(e,Object.keys(Ot)),false),dn=(e,t,r={})=>{Le(t,{...r,onError:W[e]?.options?.onError});},fn=(e,t,r={})=>{Le(e,{...r,onError:t});},pe=(e,t,r="dev")=>{dn(e,t,{severity:"warn",visibility:r});},mi=(e,t,r="dev")=>{fn(e,t,{severity:"warn",visibility:r});},Me=(e,t)=>dn(e,t,{severity:"critical",visibility:"always"}),At=(e,t)=>fn(e,t,{severity:"critical",visibility:"always"}),rr=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
15
- Import "stroid/${t}" before calling createStore("${e}", ...).`;if(mi(o,r,"always"),k().strictMissingFeatures)throw new Error(o)},or=e=>ge.get(e)?.api;var gn=new WeakMap,Sn=new WeakMap,hi=500,bi="",Dt=e=>{let t=gn.get(e);return t||(t=new Map,gn.set(e,t)),t},Lr=e=>{let t=Sn.get(e);return t||(t=new Map,Sn.set(e,t)),t},wi=(e,t)=>{let r=Lr(e),o=r.get(t);return o||(o=new Map,r.set(t,o)),o},vi=()=>{let e=k().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?hi:Math.max(0,Math.floor(e))},yn=(e,t,r,o)=>{if(o<=0){e.has(t)&&e.delete(t);return}for(e.has(t)&&e.delete(t),e.set(t,r);e.size>o;){let n=e.keys().next().value;if(!n)break;let s=e.get(n);e.delete(n),s?.node.verdicts&&(s.node.verdicts.delete(s.type),s.node.verdicts.size===0&&delete s.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=Dt(F());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)=>(Dt(F())[t]=r,true)});var mn=(e,t,r,o)=>{let n=W[e];if(!n)return {ok:true};let s=rt(r);if(s.length===0)return {ok:true};let i=De(o),a=vi(),c=F(),l=Dt(c),u=wi(c,e),g=s.join(bi),p=l.get(e);p||(p={children:new Map},l.set(e,p));let x=p;for(let C of s){let A=x.children.get(C);A||(A={children:new Map},x.children.set(C,A)),x=A;}let h=x.verdicts?.get(i);if(h){let C=`${g}|${i}`;return yn(u,C,{node:x,type:i},a),h}let f=n.options?.pathCreate===true,y=t,m={ok:true};for(let C=0;C<s.length;C++){let A=s[C],D=C===s.length-1;if(y==null){let v=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,C).join(".")||"root"}" is ${y===null?"null":"undefined"}.`;B(v),m={ok:false,reason:v};break}if(typeof y!="object"){let v=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,C).join(".")||"root"}" is not an object.`;B(v),m={ok:false,reason:v};break}if(Array.isArray(y)){let v=Number(A);if(!Number.isInteger(v)||v<0){let E=`Path "${s.join(".")}" targets non-numeric index "${A}" on an array in "${e}".`;B(E),m={ok:false,reason:E};break}let J=y;if(v>=J.length){let E=`Path "${s.join(".")}" is invalid for "${e}" - index ${v} is out of bounds (length ${J.length}).`;B(E),m={ok:false,reason:E};break}if(D){let E=J[v];if(E!=null){let L=De(E);if(L!==i){let Ee=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${L}, received ${i}.`;B(Ee),m={ok:false,reason:Ee};break}}m={ok:true};break}y=J[v];continue}if(!Object.prototype.hasOwnProperty.call(y,A)){if(f&&D){m={ok:true};break}let v=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${A}" at "${s.slice(0,C).join(".")||"root"}".`;B(v),m={ok:false,reason:v};break}if(D){let v=y[A];if(v!=null){let J=De(v);if(J!==i){let E=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${J}, received ${i}.`;B(E),m={ok:false,reason:E};break}}m={ok:true};break}y=y[A];}x.verdicts||(x.verdicts=new Map);let T=x.verdicts.has(i);if(x.verdicts.set(i,m),!T){let C=`${g}|${i}`;yn(u,C,{node:x,type:i},a);}return m},Te=(e,t,r,o)=>{try{return o?.reuseInput&&Ar(t)?{ok:!0,value:t}:{ok:!0,value:$e(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return re(W[e]?.options?.onError,`onError(${e})`,s),re(r,`onError(${e})`,s),d(s),{ok:false}}},xi=(e,t)=>{let r=new Set,o=W[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Br=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=xi(e,o),s=(a,c)=>{n.forEach(l=>re(l,`onError(${e})`,a)),c==="critical"?B(a):d(a);};if(typeof r=="function")try{let a=r(t);return a===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:a===!0?t:a}}catch(a){return s(`Validation for "${e}" failed: ${a?.message??a}`,"critical"),{ok:false}}let i=Fr(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Ke=(e,t,r,o,n)=>{let s=Te(e,t,o,n);if(!s.ok)return {ok:false};let i=Br(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},Se=e=>{let t=F();Dt(t).delete(e),Lr(t).delete(e);},Ri=()=>{let e=F();Dt(e).clear(),Lr(e).clear();};P("validation.path-cache",Ri,50);hn(Se);var Ue=(e,t=F())=>{if((M()?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=Te(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=Ke(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(M()){let c=a.value;Xt(e,c),Yt(()=>{we(e,c,t),t.initialStates[e]=V(c),delete t.initialFactories[e],Se(e);});}else we(e,a.value,t),t.initialStates[e]=V(a.value),delete t.initialFactories[e],Se(e);return !0}catch(n){return Me(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var bn=new WeakMap,wn=e=>{let t=bn.get(e);return t||(t=new Map,bn.set(e,t)),t},Ci=()=>{wn(F()).clear();};P("features.contexts",Ci,100);var vn=e=>{let t=F(),r=wn(t),o=r.get(e);if(o)return o;let n=W[e];if(!n)return d(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>W[e],getStoreValue:()=>Ot[e],getAllStores:()=>Ot,getInitialState:()=>Mn[e],hasStore:()=>oe(e),setStoreValue:i=>{we(e,i);},applyFeatureState:(i,a)=>{Tn(e,i,a),Se(e);},notify:()=>{},reportStoreError:i=>{Me(e,i);},warn:d,warnAlways:I,log:ue,hashState:Tt,deepClone:V,sanitize:$e,validate:i=>Br(e,i,W[e]?.options?.validate),isDev:R};return r.set(e,s),s},xn=(e,t)=>{let r=k();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(Me(e,n),r.assertRuntime)throw new Error(n)},Rn=(e,t)=>{ir();let r=vn(e);r&&(r.notify=()=>t(e),xn(e,r),ge.forEach(o=>{o.onStoreCreate?.(r);}));},Cn=(e,t,r,o,n)=>{ir();let s=vn(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});xn(e,i),ge.forEach(a=>{a.onStoreWrite?.(i);});};var nr=(e,t)=>Xo({name:e,payload:t,middlewares:(()=>{let r=W[e]?.options?.middleware||[],o=k().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{pe(e,r,o);},warn:d}),sr=(e,t,r,o)=>Jt({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{pe(e,n,s);}}),kn=(e,t)=>{let r={...t};return r.persist&&!Bt("persist")&&(r.explicitPersist&&rr(e,"persist",r.onError),r.persist=null),r.sync&&!Bt("sync")&&(r.explicitSync&&rr(e,"sync",r.onError),r.sync=false),Bt("devtools")||(r.explicitDevtools&&rr(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var ar=null,En=e=>(ar=e,()=>{ar===e&&(ar=null);}),st=e=>{ar?.(e);};var cr=new Set,qr=e=>{if(e){cr.delete(e);return}cr.clear();};P("store-create.ssr-global-warned",()=>qr(),65);function ce(e,t,r={}){if(M()){let b=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;At(b,r.onError),j(b);return}if(!Mt(e)){At(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!et(t)){At(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&R()&&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.`),sn(r).forEach(b=>{d(b);});let n=kn(e,an(r,e,k().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let b=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;re(n.onError,`onError(${e})`,b),R()||I(b),$(b);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",c=n.allowSSRGlobalStore??false,l=F(),u=l.stores,g=l.subscribers,p=l.initialStates,x=l.initialFactories,h=l.metaEntries,f=l.scope==="request";if(a&&!c&&!f){let b=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
16
- Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;At(b,r.onError);return}if(a&&c&&!f&&!cr.has(e)&&(cr.add(e),I(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
17
- This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),oe(e,l)){let b=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return pe(e,b),{name:e}}s&&!c&&!f&&!ln(e)&&R()&&(un(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 y=Te(e,t,n.onError);if(!y.ok)return;let m=y.value,T=n.lazy===true&&typeof t=="function",C=(g[e]?.size??0)>0;if(T)u[e]=void 0,x[e]=t;else {let b=Ke(e,m,n.validate,n.onError);if(!b.ok)return;we(e,b.value,l),p[e]=V(b.value);}let A=Date.now(),D=new Date(A).toISOString();return h[e]={createdAt:D,updatedAt:D,updatedAtMs:A,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},Se(e),Rn(e,st),sr(e,"onCreate",h[e].options.onCreate,[m]),Fn(l,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),C&&st(e),ue(`Store "${e}" created -> ${JSON.stringify(m)}`),{name:e}}function lr(e,t,r={}){let o=(r.lazy===true,ce(e,t,r));if(o)return o;throw new Error(`createStoreStrict("${String(e)}") failed. See earlier warnings/errors or onError callbacks for the cause.`)}var ki=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},An=(e,t)=>t==="ref"?e:t==="shallow"?ee(e):V(e);function Y(e,t){let r=fe(e);if(!qe(r))return null;let o=F();if(!Ue(r,o))return null;Kr(r,o);let n=Ve(r,o),s=ki(o.metaEntries[r],k().defaultSnapshotMode);if(t===void 0)return n===null||typeof n!="object"?n:An(n,s);if(!Et(t))return null;let i=Vr(n,t);return i===null||typeof i!="object"?i:An(i,s)}var ne=e=>oe(e);var On=e=>{let r=F().metaEntries[e];return r?.metrics?{...r.metrics}:null};var je=e=>({name:e}),Dn=e=>{let t=`${e}::`,r=n=>n.includes("::")?n:`${t}${n}`,o=n=>typeof n=="string"?je(r(n)):{...n,name:r(n.name)};return {store:n=>({name:r(n)}),create:(n,s,i)=>ce(r(n),s,i),createStrict:(n,s,i)=>lr(r(n),s,i),set:(n,...s)=>{let i=s;return Ge(o(n),...i)},get:(n,...s)=>{let i=s;return Y(o(n),...i)},delete:n=>it(o(n)),reset:n=>at(o(n))}};var ur=null,dr=()=>ur,ct=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();let r=ur;ur=e;try{return t()}finally{ur=r;}};var Mi=32,fr=new Set;P("store-write.slow-mutator-warned",()=>fr.clear(),65);var Ti=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var Vn=e=>{fr.delete(e);},jn=(e,t)=>{R()&&(t<Mi||fr.has(e)||(fr.add(e),d(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},pr=e=>e??dr(),Pn=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:a})=>{let c=e.metaEntries;we(t,o,e),Se(t);let l=Date.now();c[t].updatedAt=new Date(l).toISOString(),c[t].updatedAtMs=l;let u=a??dr();u&&(u.correlationId||u.traceContext)?(c[t].lastCorrelationId=u.correlationId??null,c[t].lastCorrelationAt=new Date(l).toISOString(),c[t].lastCorrelationAtMs=l,c[t].lastTraceContext=u.traceContext??null):(c[t].lastCorrelationId=null,c[t].lastCorrelationAt=null,c[t].lastCorrelationAtMs=null,c[t].lastTraceContext=null),Ti(c[t]),Cn(t,n,r,o,st),sr(t,s,c[t].options[s],[r,o]),st(t),ue(i);},lt=(e,t)=>{let r=t.context??dr();if(M()){Xt(t.name,t.next),Yt(()=>Pn(e,{...t,context:r}));return}Pn(e,{...t,context:r});};function Ne(e,t){let r=fe(e);if(!r)return {ok:false,reason:"invalid-args"};let o=F(),n=Ur(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 Ur=(e,t,r,o="hydrate",n)=>{let s=(h,f)=>(M()&&j(f??h),{ok:false,reason:h});if(!qe(t))return s("not-found",`replaceStore("${t}") called before createStore().`);let i=M()?be(t):{has:false,value:void 0},a=i.has?i.value:Ve(t,e),c=Te(t,r);if(!c.ok)return s("sanitize",`replaceStore("${t}") failed sanitize`);let l=c.value;if(l===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 u=e.metaEntries[t]?.options?.validate,g=pr(n),p=nr(t,{action:o,prev:a,next:l,path:null,correlationId:g?.correlationId,traceContext:g?.traceContext});if(p===ot)return s("middleware",`replaceStore("${t}") aborted by middleware`);let x=Ke(t,p,u);return x.ok?(lt(e,{name:t,prev:a,next:x.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:g}),{ok:true}):s("validate",`replaceStore("${t}") failed validation`)};function Ge(e,t,r){return Nn(e,t,r)}var Nn=(e,t,r,o)=>{let n=fe(e),s=F(),i=s.metaEntries;if(!Ue(n,s))return {ok:false,reason:"validate"};if(!oe(n,s)){let y=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return Me(n,y),M()&&j(y),{ok:false,reason:"not-found"}}let a,c=M()?be(n):{has:false,value:void 0},l=c.has?c.value:Ve(n,s),u=typeof t=="function"&&r===void 0;if(u){let y=R()?Date.now():0;try{let m=k().mutatorProduce,T=!1,C,A=b=>{let v=t(b);return v!==void 0&&(T=!0,C=v),v},D=m?m(l,A):(()=>{let b=V(l);return A(b),b})();if(T&&k().strictMutatorReturns){let b=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return Me(n,b),M()&&j(b),{ok:!1,reason:"validate"}}T&&R()&&!k().strictMutatorReturns&&d(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=T&&!k().strictMutatorReturns?C:D;}catch(m){return Me(n,`Mutator for "${n}" failed: ${m?.message??m}`),M()&&j(m),{ok:false,reason:"validate"}}finally{y&&jn(n,Date.now()-y);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!et(t))return M()&&j(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof l!="object"||l===null||Array.isArray(l))return $(`setStore("${n}", data) only merges into object stores.
18
- Use setStore("${n}", "path", value) or recreate the store with an object shape.`),M()&&j(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let y=Te(n,t);if(!y.ok)return M()&&j(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};a={...l,...y.value};}else if(typeof t=="string"||Array.isArray(t)){if(!Et(t))return M()&&j(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let y=Te(n,r);if(!y.ok)return M()&&j(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let m=y.value,T=mn(n,l,t,m);if(!T.ok)return re(i[n]?.options?.onError,`onError(${n})`,T.reason??`Invalid path for "${n}".`),M()&&j(T.reason),{ok:false,reason:"path"};a=jr(l,t,m);}else {let y=`setStore("${n}") - invalid arguments.
13
+ Call createStore("${e}", data) first.`);};var de=new Set(["__proto__","constructor","prototype"]),Fr=(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 Pe=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,Bo=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},rt=e=>{let t=Pe(e);return t==="function"?($(Oo()),false):t==="map"||t==="set"?(d(Do()),true):(t==="date"&&d(Po()),true)},Er=(e,t)=>{let r=Bo(e);if(r)throw new Error(`${r} values are not supported`);let o=Pe(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&&!Er(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||de.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Er(i.value,t))return false}return true}return true},Ar=e=>Er(e,new WeakSet),Ct=(e,t)=>{let r=Bo(e);if(r)throw new Error(`${r} values are not supported`);let o=Pe(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 R()&&d(Vo()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),R()&&d(jo());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)]=Ct(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),R()&&d(No()),Array.from(e,n=>Ct(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,a]of Object.entries(s))if(a.enumerable&&!de.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=Ct(a.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=>Ct(n,t))}return e},ze=e=>Ct(e,new WeakSet),kt=e=>typeof e!="string"||e.trim()===""?($(zo(e)),false):de.has(e)?($(Lo(e)),false):e.includes(" ")?($(Ho(e)),false):true;var Or=null,si=()=>{if(Or)return Or;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 Or=t,t},Ko=e=>{let t=si(),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},ii=2166136261,ai=2654435761,ci=1e5,Ve=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},He=(e,t)=>{Ve(e,t.length);for(let r=0;r<t.length;r++)Ve(e,t.charCodeAt(r));},_=(e,t)=>{He(e,t);},qo=(e,t)=>{if(Number.isNaN(t)){_(e,"NaN");return}if(!Number.isFinite(t)){_(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){_(e,"-0");return}let r=t|0;if(t===r){_(e,"int"),Ve(e,r);return}_(e,"num"),He(e,String(t));},ot=(e,t)=>{if(e.nodes++>ci){_(e,"[max]");return}if(t===null){_(e,"null");return}let r=typeof t;if(r==="string"){_(e,"string"),He(e,t);return}if(r==="number"){_(e,"number"),qo(e,t);return}if(r==="boolean"){_(e,t?"true":"false");return}if(r==="undefined"){_(e,"undefined");return}if(r==="bigint"){_(e,"bigint"),He(e,t.toString());return}if(r==="symbol"){_(e,"symbol");let c=t;He(e,Symbol.keyFor(c)??c.description??String(c));return}if(r==="function"){_(e,"function"),He(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){_(e,"ref"),Ve(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){_(e,"array"),Ve(e,o.length);for(let c=0;c<o.length;c++)Object.prototype.hasOwnProperty.call(o,c)?ot(e,o[c]):_(e,"hole");return}if(o instanceof Date){_(e,"date"),qo(e,o.getTime());return}if(o instanceof Map){_(e,"map"),Ve(e,o.size),o.forEach((c,l)=>{ot(e,l),ot(e,c);});return}if(o instanceof Set){_(e,"set"),Ve(e,o.size),o.forEach(c=>{ot(e,c);});return}_(e,"object");let i=Object.getOwnPropertyDescriptors(o),a=[];Object.entries(i).forEach(([c,l])=>{l?.enumerable&&(de.has(c)||"get"in l||"set"in l||a.push([c,l]));}),Ve(e,a.length);for(let[c,l]of a)He(e,c),ot(e,l.value);},Mt=e=>{if(typeof e=="string")return Ko(JSON.stringify(e));let t={h1:ii,h2:ai,seen:new WeakMap,nextId:1,nodes:0};ot(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 li=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Z=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&&(de.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},Dr=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},ui=e=>Dr(e)===null,di=e=>{let t=Dr(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(di(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||de.has(n)||"get"in s||"set"in s||(r[n]=Le(s.value,t));}),r},V=e=>{if(li)try{return structuredClone(e)}catch(t){if(!ui(e)){let r=Dr(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)},Pr=(e,t)=>{if(Object.is(e,t))return true;if(!e||!t||typeof e!="object"||typeof t!="object")return false;let r=e,o=t,n=Object.keys(r),s=Object.keys(o);if(n.length!==s.length)return false;for(let i of n)if(!Object.prototype.hasOwnProperty.call(o,i)||!Object.is(r[i],o[i]))return false;return true};var Uo=10,fi=5,pi=e=>{let t=[],r="",o=false;for(let n of e){if(o){r+=n,o=false;continue}if(n==="\\"){o=true;continue}if(n==="."){t.push(r),r="";continue}r+=n;}return o&&(r+="\\"),t.push(r),t},nt=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?pi(e):[String(e)],Tt=e=>{let t=nt(e),r=t.length;return r>Uo?($(Io(r,Uo,t)),false):(r>fi&&d($o(r,t)),true)},Vr=(e,t)=>{let r=nt(t),o=e;for(let n of r){if(o==null){d(_o(r,n));return}if(typeof o!="object"){d(Wo(n));return}o=o[n];}return o},jr=(e,t,r)=>{let o=nt(t);if(o.length===0)return e;for(let s of o)if(de.has(s))return B(`Blocked forbidden path segment "${String(s)}" in setStore path "${o.join(".")}".`),e;let n=(s,i)=>{let a=o[i],c=i===o.length-1;if(Array.isArray(s)){let l=Number(a);if(!Number.isInteger(l))return s;let u=[...s];return c?(u[l]=r,u):(u[l]=n(u[l],i+1),u)}if(s&&typeof s=="object"){if(de.has(a))return B(`Blocked unsafe path segment "${String(a)}" while setting "${o.join(".")}".`),s;let l={...s};return c?(l[a]=r,l):(l[a]=n(l[a],i+1),l)}if(s==null&&!c){let l=Number.isInteger(Number(a)),u=l?[]:{};if(l){let g=u,f=Number(a);return g[f]=n(void 0,i+1),g}return u[a]=n(void 0,i+1),u}return c?r:s};return n(e,0)};var Go=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")},Nr=e=>(Go(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Yo=e=>{if(!Go(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 Be=null;var gi=()=>{Be=null;};D("transaction.runner",gi,120);var qe=e=>{let t=Be?.get();return t||(e??Q()).transaction},Xo=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted"),Jo=e=>{let t=e??Q(),r=Be?.get();return !r&&Be?.enterWith&&(r=Cr(),Be.enterWith(r)),r||(r=qe(t)),r.depth+=1,r.depth===1&&(r.pending=[],r.stagedValues.clear(),r.snapshotCache.clear(),r.failed=false,r.error=void 0),t},E=()=>Be?(Be.get()?.depth??0)>0:qe().depth>0,j=(e,t)=>{let r=qe(t);r.failed=true,r.error||(r.error=Xo(e));},Yt=e=>{let t=Q();qe(t).pending.push(()=>tt(t,e));},Xt=(e,t)=>{let r=qe();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},be=e=>{let t=qe();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}},Qo=(e,t)=>{let r=qe(t);if(r.depth===0||(e&&j(e,t),r.depth=Math.max(0,r.depth-1),r.depth>0))return null;let o=r.failed?r.error??new Error("setStoreBatch aborted"):null;if(!o){for(let n of r.pending)try{n();}catch(s){j(s,t),o||(o=r.error??Xo(s));}!o&&r.failed&&(o=r.error??new Error("setStoreBatch aborted"));}return r.pending=[],r.stagedValues.clear(),r.snapshotCache.clear(),r.failed=false,r.error=void 0,o};var st=Symbol("stroid.middleware.abort"),Zo=({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 a of r){if(typeof a!="function")continue;let c,l=i;try{c=a({action:t.action,name:e,prev:t.prev,next:l,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(u){let g=`Middleware for "${e}" failed: ${u?.message??u}`;return o(g,"dev"),st}if(c&&typeof c.then=="function"){let u=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(u,"dev"),st}c===void 0?(R()&&!s.has(a)&&(s.add(a),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=l):i=c;}return i},Jt=({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 re=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;I(`${t} callback threw: ${String(n)}`);}},Ke=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(re(n,"onError",e),r==="critical"){o==="dev"&&d(e),B(e);return}if(o==="always"){I(e);return}d(e);};var Qt=null,en=e=>{Qt=e;},tn=e=>Qt?Qt(e):[];D("computed.order-resolver",()=>{Qt=null;},105);var rn=()=>Q(ke(Ce)),je=()=>rn().computedEntries,Zt=()=>rn().computedDependents,Si=(e,t)=>{let r=je(),o=new Set,n=[],s=i=>{if(i===e)return true;if(o.has(i))return false;o.add(i),n.push(i);let a=r[i]?.deps??[];for(let c of a)if(s(c))return true;return n.pop(),false};for(let i of t)if(n.length=0,s(i))return [e,...n,e].join(" -> ");return null},on=(e,t)=>{let r=Zt();for(let o of t){let n=r[o];n&&(n.delete(e),n.size===0&&delete r[o]);}},nn=(e,t,r)=>{let o=Si(e,t);if(o)return $(`[stroid] createComputed("${e}") rejected: circular dependency detected -> ${o}
14
+ Define relationships without cycles.`),false;let n=je(),s=Zt();n[e]&&on(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},sn=e=>{let t=je(),r=t[e];r&&(on(e,r.deps),delete t[e]);},Ir=e=>{let t=je();t[e]&&(t[e].stale=true);},er=e=>Object.prototype.hasOwnProperty.call(je(),e),$r=e=>je()[e],_r=e=>{let t=je(),r=Zt(),o=new Set,n=[...e];for(;n.length>0;){let u=n.shift(),g=r[u];if(g)for(let f of g)o.has(f)||(o.add(f),n.push(f));}if(o.size===0)return [];let s=u=>{let g=t[u];if(g)for(let f of g.deps)t[f]&&(o.has(f)||(o.add(f),s(f)));};Array.from(o).forEach(u=>s(u));let i=new Map,a=new Map;for(let u of o){let g=t[u];if(!g)continue;let f=0;for(let h of g.deps)o.has(h)&&(f++,a.has(h)||a.set(h,[]),a.get(h).push(u));i.set(u,f);}let c=[];for(let[u,g]of i)g===0&&c.push(u);c.sort();let l=[];for(;c.length>0;){let u=c.shift();l.push(u);let g=a.get(u)??[];for(let f of g){let h=(i.get(f)??1)-1;if(i.set(f,h),h===0){let v=c.findIndex(p=>p>f);v===-1?c.push(f):c.splice(v,0,f);}}}return l};en(_r);var Wr=e=>{let t=je()[e];if(!t)return null;let r=Zt()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Hr=new Set,yi=()=>{Hr.clear();};D("options.legacy-warnings",yi,30);var tr=(()=>{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"}})(),zr=e=>{try{return typeof window>"u"?tr:e==="session"||e==="sessionStorage"?window.sessionStorage??tr:window.localStorage??tr}catch{return tr}},Et=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),it=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),cn=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}},mi=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",an=e=>{try{e[mi]=!0;}catch{}return e},hi={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"},bi=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:an(g=>g),decrypt:an(g=>g),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:zr("localStorage"),...r};if(typeof e=="string")return {driver:zr(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,a=e.sensitiveData===true,c=e.allowPlaintext===true,l=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,u=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(a&&cn(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||zr("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:c,sensitiveData:a,maxSize:l,checksum:u,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},ln=e=>{if(!Et(e))return [];let t=[];return Object.entries(hi).forEach(([r,o])=>{it(e,r)&&(Hr.has(r)||(Hr.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},un=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=Et(e.lifecycle)?e.lifecycle:void 0,a=Et(e.persist)?e.persist:void 0,c=Et(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,u=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,f=Et(e.features)?{...e.features}:void 0,h=it(e,"persist"),v=it(e,"sync"),p=it(e,"devtools")||it(e,"historyLimit")||it(e,"redactor"),S=o==="global"?true:e.allowSSRGlobalStore??false,{persist:m=false,devtools:M=false,onError:k,sync:A}=e;if(a?.sensitiveData===true){let O=a.encrypt,b=a.encryptAsync;if((!O||cn(O))&&!b)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"&&!h?null:bi(m,t),devtools:o==="temp"&&!p?false:typeof M=="boolean"?M:c?.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:k,validate:l,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:o==="temp"&&!p?void 0:c?.redactor??e.redactor,historyLimit:o==="temp"&&!p?0:c?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!v?false:A??false,features:f,allowSSRGlobalStore:S,snapshot:u,snapshotSafety:g,explicitPersist:h,explicitSync:v,explicitDevtools:p}};var rr=new Set,fn=e=>e?rr.has(e):rr.size>0,pn=e=>{e&&rr.add(e);},wi=()=>{rr.clear();};D("ssr.warnings",wi,60);var dn=new Set,xi=e=>{let t=Fo();return !t||e.includes("::")?e:(R()&&!dn.has(e)&&(dn.add(e),d(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},fe=e=>xi(typeof e=="string"?e:e.name),Ue=e=>oe(e)&&!yn(e)?true:(Rt(e,Object.keys(At)),false),gn=(e,t,r={})=>{Ke(t,{...r,onError:W[e]?.options?.onError});},Sn=(e,t,r={})=>{Ke(e,{...r,onError:t});},pe=(e,t,r="dev")=>{gn(e,t,{severity:"warn",visibility:r});},vi=(e,t,r="dev")=>{Sn(e,t,{severity:"warn",visibility:r});},Te=(e,t)=>gn(e,t,{severity:"critical",visibility:"always"}),Ft=(e,t)=>Sn(e,t,{severity:"critical",visibility:"always"}),or=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
15
+ Import "stroid/${t}" before calling createStore("${e}", ...).`;if(vi(o,r,"always"),C().strictMissingFeatures)throw new Error(o)},nr=e=>ge.get(e)?.api;var mn=new WeakMap,hn=new WeakMap,Ri=500,Ci="",Ot=e=>{let t=mn.get(e);return t||(t=new Map,mn.set(e,t)),t},Lr=e=>{let t=hn.get(e);return t||(t=new Map,hn.set(e,t)),t},ki=(e,t)=>{let r=Lr(e),o=r.get(t);return o||(o=new Map,r.set(t,o)),o},Mi=()=>{let e=C().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?Ri:Math.max(0,Math.floor(e))},bn=(e,t,r,o)=>{if(o<=0){e.has(t)&&e.delete(t);return}for(e.has(t)&&e.delete(t),e.set(t,r);e.size>o;){let n=e.keys().next().value;if(!n)break;let s=e.get(n);e.delete(n),s?.node.verdicts&&(s.node.verdicts.delete(s.type),s.node.verdicts.size===0&&delete s.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=Ot(F());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)=>(Ot(F())[t]=r,true)});var wn=(e,t,r,o)=>{let n=W[e];if(!n)return {ok:true};let s=nt(r);if(s.length===0)return {ok:true};let i=Pe(o),a=Mi(),c=F(),l=Ot(c),u=ki(c,e),g=s.join(Ci),f=l.get(e);f||(f={children:new Map},l.set(e,f));let h=f;for(let k of s){let A=h.children.get(k);A||(A={children:new Map},h.children.set(k,A)),h=A;}let v=h.verdicts?.get(i);if(v){let k=`${g}|${i}`;return bn(u,k,{node:h,type:i},a),v}let p=n.options?.pathCreate===true,S=t,m={ok:true};for(let k=0;k<s.length;k++){let A=s[k],O=k===s.length-1;if(S==null){let w=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,k).join(".")||"root"}" is ${S===null?"null":"undefined"}.`;B(w),m={ok:false,reason:w};break}if(typeof S!="object"){let w=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,k).join(".")||"root"}" is not an object.`;B(w),m={ok:false,reason:w};break}if(Array.isArray(S)){let w=Number(A);if(!Number.isInteger(w)||w<0){let T=`Path "${s.join(".")}" targets non-numeric index "${A}" on an array in "${e}".`;B(T),m={ok:false,reason:T};break}let q=S;if(w>=q.length){let T=`Path "${s.join(".")}" is invalid for "${e}" - index ${w} is out of bounds (length ${q.length}).`;B(T),m={ok:false,reason:T};break}if(O){let T=q[w];if(T!=null){let K=Pe(T);if(K!==i){let Fe=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${K}, received ${i}.`;B(Fe),m={ok:false,reason:Fe};break}}m={ok:true};break}S=q[w];continue}if(!Object.prototype.hasOwnProperty.call(S,A)){if(p&&O){m={ok:true};break}let w=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${A}" at "${s.slice(0,k).join(".")||"root"}".`;B(w),m={ok:false,reason:w};break}if(O){let w=S[A];if(w!=null){let q=Pe(w);if(q!==i){let T=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${q}, received ${i}.`;B(T),m={ok:false,reason:T};break}}m={ok:true};break}S=S[A];}h.verdicts||(h.verdicts=new Map);let M=h.verdicts.has(i);if(h.verdicts.set(i,m),!M){let k=`${g}|${i}`;bn(u,k,{node:h,type:i},a);}return m},Ee=(e,t,r,o)=>{try{return o?.reuseInput&&Ar(t)?{ok:!0,value:t}:{ok:!0,value:ze(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return re(W[e]?.options?.onError,`onError(${e})`,s),re(r,`onError(${e})`,s),d(s),{ok:false}}},Ti=(e,t)=>{let r=new Set,o=W[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Br=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=Ti(e,o),s=(a,c)=>{n.forEach(l=>re(l,`onError(${e})`,a)),c==="critical"?B(a):d(a);};if(typeof r=="function")try{let a=r(t);return a===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:a===!0?t:a}}catch(a){return s(`Validation for "${e}" failed: ${a?.message??a}`,"critical"),{ok:false}}let i=Fr(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Ge=(e,t,r,o,n)=>{let s=Ee(e,t,o,n);if(!s.ok)return {ok:false};let i=Br(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},Se=e=>{let t=F();Ot(t).delete(e),Lr(t).delete(e);},Ei=()=>{let e=F();Ot(e).clear(),Lr(e).clear();};D("validation.path-cache",Ei,50);xn(Se);var Ye=(e,t=F())=>{if((E()?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=Ee(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=Ge(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(E()){let c=a.value;Xt(e,c),Yt(()=>{we(e,c,t),t.initialStates[e]=V(c),delete t.initialFactories[e],Se(e);});}else we(e,a.value,t),t.initialStates[e]=V(a.value),delete t.initialFactories[e],Se(e);return !0}catch(n){return Te(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var vn=new WeakMap,Rn=e=>{let t=vn.get(e);return t||(t=new Map,vn.set(e,t)),t},Fi=()=>{Rn(F()).clear();};D("features.contexts",Fi,100);var Cn=e=>{let t=F(),r=Rn(t),o=r.get(e);if(o)return o;let n=W[e];if(!n)return d(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>W[e],getStoreValue:()=>At[e],getAllStores:()=>At,getInitialState:()=>Fn[e],hasStore:()=>oe(e),setStoreValue:i=>{we(e,i);},applyFeatureState:(i,a)=>{An(e,i,a),Se(e);},notify:()=>{},reportStoreError:i=>{Te(e,i);},warn:d,warnAlways:I,log:ce,hashState:Mt,deepClone:V,sanitize:ze,validate:i=>Br(e,i,W[e]?.options?.validate),isDev:R};return r.set(e,s),s},kn=(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(Te(e,n),r.assertRuntime)throw new Error(n)},Mn=(e,t)=>{ar();let r=Cn(e);r&&(r.notify=()=>t(e),kn(e,r),ge.forEach(o=>{o.onStoreCreate?.(r);}));},Tn=(e,t,r,o,n)=>{ar();let s=Cn(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});kn(e,i),ge.forEach(a=>{a.onStoreWrite?.(i);});};var sr=(e,t)=>Zo({name:e,payload:t,middlewares:(()=>{let r=W[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:d}),ir=(e,t,r,o)=>Jt({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{pe(e,n,s);}}),En=(e,t)=>{let r={...t};return r.persist&&!Bt("persist")&&(r.explicitPersist&&or(e,"persist",r.onError),r.persist=null),r.sync&&!Bt("sync")&&(r.explicitSync&&or(e,"sync",r.onError),r.sync=false),Bt("devtools")||(r.explicitDevtools&&or(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var cr=null,On=e=>(cr=e,()=>{cr===e&&(cr=null);}),at=e=>{cr?.(e);};var lr=new Set,qr=e=>{if(e){lr.delete(e);return}lr.clear();};D("store-create.ssr-global-warned",()=>qr(),65);function le(e,t,r={}){if(E()){let b=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;Ft(b,r.onError),j(b);return}if(!kt(e)){Ft(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!rt(t)){Ft(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&R()&&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.`),ln(r).forEach(b=>{d(b);});let n=En(e,un(r,e,C().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let b=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;re(n.onError,`onError(${e})`,b),R()||I(b),$(b);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",c=n.allowSSRGlobalStore??false,l=F(),u=l.stores,g=l.subscribers,f=l.initialStates,h=l.initialFactories,v=l.metaEntries,p=l.scope==="request";if(a&&!c&&!p){let b=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
16
+ Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;Ft(b,r.onError);return}if(a&&c&&!p&&!lr.has(e)&&(lr.add(e),I(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
17
+ This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),oe(e,l)){let b=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return pe(e,b),{name:e}}s&&!c&&!p&&!fn(e)&&R()&&(pn(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 S=Ee(e,t,n.onError);if(!S.ok)return;let m=S.value,M=n.lazy===true&&typeof t=="function",k=(g[e]?.size??0)>0;if(M)u[e]=void 0,h[e]=t;else {let b=Ge(e,m,n.validate,n.onError);if(!b.ok)return;we(e,b.value,l),f[e]=V(b.value);}let A=Date.now(),O=new Date(A).toISOString();return v[e]={createdAt:O,updatedAt:O,updatedAtMs:A,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},Se(e),Mn(e,at),ir(e,"onCreate",v[e].options.onCreate,[m]),Dn(l,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),k&&at(e),ce(`Store "${e}" created -> ${JSON.stringify(m)}`),{name:e}}function ur(e,t,r={}){let o=(r.lazy===true,le(e,t,r));if(o)return o;throw new Error(`createStoreStrict("${String(e)}") failed. See earlier warnings/errors or onError callbacks for the cause.`)}var Ai=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Pn=(e,t)=>t==="ref"?e:t==="shallow"?Z(e):V(e);function G(e,t){let r=fe(e);if(!Ue(r))return null;let o=F();if(!Ye(r,o))return null;Kr(r,o);let n=Ne(r,o),s=Ai(o.metaEntries[r],C().defaultSnapshotMode);if(t===void 0)return n===null||typeof n!="object"?n:Pn(n,s);if(!Tt(t))return null;let i=Vr(n,t);return i===null||typeof i!="object"?i:Pn(i,s)}var ne=e=>oe(e);var Vn=e=>{let r=F().metaEntries[e];return r?.metrics?{...r.metrics}:null};var Ie=e=>({name:e}),jn=e=>{let t=`${e}::`,r=n=>n.includes("::")?n:`${t}${n}`,o=n=>typeof n=="string"?Ie(r(n)):{...n,name:r(n.name)};return {store:n=>({name:r(n)}),create:(n,s,i)=>le(r(n),s,i),createStrict:(n,s,i)=>ur(r(n),s,i),set:(n,...s)=>{let i=s;return Xe(o(n),...i)},get:(n,...s)=>{let i=s;return G(o(n),...i)},delete:n=>ct(o(n)),reset:n=>lt(o(n))}};var Dt=null,dr=null;var Oi=()=>{Dt=null,dr=null;};D("write-context.runner",Oi,121);var fr=()=>dr?.get()??Dt,ut=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(dr)return dr.run(e,t);let r=Dt;Dt=e;try{return t()}finally{Dt=r;}};var Di=32,pr=new Set;D("store-write.slow-mutator-warned",()=>pr.clear(),65);var Pi=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var In=e=>{pr.delete(e);},$n=(e,t)=>{R()&&(t<Di||pr.has(e)||(pr.add(e),d(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},gr=e=>e??fr(),Nn=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:a})=>{let c=e.metaEntries;we(t,o,e),Se(t);let l=Date.now();c[t].updatedAt=new Date(l).toISOString(),c[t].updatedAtMs=l;let u=a??fr();u&&(u.correlationId||u.traceContext)?(c[t].lastCorrelationId=u.correlationId??null,c[t].lastCorrelationAt=new Date(l).toISOString(),c[t].lastCorrelationAtMs=l,c[t].lastTraceContext=u.traceContext??null):(c[t].lastCorrelationId=null,c[t].lastCorrelationAt=null,c[t].lastCorrelationAtMs=null,c[t].lastTraceContext=null),Pi(c[t]),Tn(t,n,r,o,at),ir(t,s,c[t].options[s],[r,o]),at(t),ce(i);},dt=(e,t)=>{let r=t.context??fr();if(E()){Xt(t.name,t.next),Yt(()=>Nn(e,{...t,context:r}));return}Nn(e,{...t,context:r});};function $e(e,t){let r=fe(e);if(!r)return {ok:false,reason:"invalid-args"};let o=F(),n=Ur(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 Ur=(e,t,r,o="hydrate",n)=>{let s=(v,p)=>(E()&&j(p??v),{ok:false,reason:v});if(!Ue(t))return s("not-found",`replaceStore("${t}") called before createStore().`);let i=E()?be(t):{has:false,value:void 0},a=i.has?i.value:Ne(t,e),c=Ee(t,r);if(!c.ok)return s("sanitize",`replaceStore("${t}") failed sanitize`);let l=c.value;if(l===void 0){let v=`Whole-store undefined replacement is blocked for "${t}". Use null for intentional empty state.`;return pe(t,v),s("undefined",v)}let u=e.metaEntries[t]?.options?.validate,g=gr(n),f=sr(t,{action:o,prev:a,next:l,path:null,correlationId:g?.correlationId,traceContext:g?.traceContext});if(f===st)return s("middleware",`replaceStore("${t}") aborted by middleware`);let h=Ge(t,f,u);return h.ok?(dt(e,{name:t,prev:a,next:h.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:g}),{ok:true}):s("validate",`replaceStore("${t}") failed validation`)};function Xe(e,t,r){return _n(e,t,r)}var _n=(e,t,r,o)=>{let n=fe(e),s=F(),i=s.metaEntries;if(!Ye(n,s))return {ok:false,reason:"validate"};if(!oe(n,s)){let S=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return Te(n,S),E()&&j(S),{ok:false,reason:"not-found"}}let a,c=E()?be(n):{has:false,value:void 0},l=c.has?c.value:Ne(n,s),u=typeof t=="function"&&r===void 0;if(u){let S=R()?Date.now():0;try{let m=C().mutatorProduce,M=!1,k,A=b=>{let w=t(b);return w!==void 0&&(M=!0,k=w),w},O=m?m(l,A):(()=>{let b=V(l);return A(b),b})();if(M&&C().strictMutatorReturns){let b=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return Te(n,b),E()&&j(b),{ok:!1,reason:"validate"}}M&&R()&&!C().strictMutatorReturns&&d(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=M&&!C().strictMutatorReturns?k:O;}catch(m){return Te(n,`Mutator for "${n}" failed: ${m?.message??m}`),E()&&j(m),{ok:false,reason:"validate"}}finally{S&&$n(n,Date.now()-S);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!rt(t))return E()&&j(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof l!="object"||l===null||Array.isArray(l))return $(`setStore("${n}", data) only merges into object stores.
18
+ Use setStore("${n}", "path", value) or recreate the store with an object shape.`),E()&&j(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let S=Ee(n,t);if(!S.ok)return E()&&j(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};a={...l,...S.value};}else if(typeof t=="string"||Array.isArray(t)){if(!Tt(t))return E()&&j(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let S=Ee(n,r);if(!S.ok)return E()&&j(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let m=S.value,M=wn(n,l,t,m);if(!M.ok)return re(i[n]?.options?.onError,`onError(${n})`,M.reason??`Invalid path for "${n}".`),E()&&j(M.reason),{ok:false,reason:"path"};a=jr(l,t,m);}else {let S=`setStore("${n}") - invalid arguments.
19
19
  Usage:
20
20
  setStore("${n}", "field", value)
21
21
  setStore("${n}", "nested.field", value)
22
22
  setStore("${n}", { field: value })
23
23
  setStore(storeDef, draft => { draft.field = value })
24
- replaceStore("${n}", value) // full-store replace`;return $(y),re(i[n]?.options?.onError,`onError(${n})`,y),M()&&j(y),{ok:false,reason:"invalid-args"}}if(!et(a))return M()&&j(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let g=i[n]?.options?.validate,p=pr(o),x=nr(n,{action:"set",prev:l,next:a,path:t,correlationId:p?.correlationId,traceContext:p?.traceContext});if(x===ot)return M()&&j(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let f=Ke(n,x,g,void 0,u&&x===a?{reuseInput:true}:void 0);if(!f.ok)return M()&&j(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};try{if(Pr(l,f.value))return {ok:!0}}catch{}return lt(s,{name:n,prev:l,next:f.value,action:"set",hookLabel:"onSet",logMessage:`Store "${n}" updated`,context:p}),{ok:true}},ut=(e,t,r,o)=>Nn(e,t,r,o);var Gr=()=>F().computedCleanups,In=new WeakMap,Ei=e=>{let t=In.get(e);return t||(t=new Map,In.set(e,t)),t};function Fi(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=Gr(),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")){d(`createComputed("${e}") dependencies must be store names or store handles.`);return}if(R()){let g=i.filter(p=>!ne(p));g.length>0&&d(`createComputed("${e}") dependencies not found at registration: ${g.join(", ")}. Computed values will receive null until those stores are created.`);}if(!tn(e,i,r))return;let c=$n(e,t,r,o.onError),l=je(e);ne(e)?Ne(l,c):ce(e,c);let u=[];for(let g of i){let p=Pt(g,()=>{_n(e,i,r,o.onError);});u.push(p);}return Gr().set(e,()=>{u.forEach(g=>g()),rn(e);}),R()&&ue(`computed store "${e}" created, deps: [${i.join(", ")}]`),l}var $n=(e,t,r,o)=>{let n=t.map(s=>typeof s=="string"?Y(je(s)):Y(s));try{return r(...n)}catch(s){d(`createComputed("${e}") compute function threw: ${s?.message??s}`),re(o,`computed.onError(${e})`,s);let i=je(e);return ne(e)?Y(i):null}},_n=(e,t,r,o)=>{if(!_r(e))return;let s=F();if(s.notify.isFlushing){let l=s.notify.flushId,u=Ei(s);if(u.get(e)===l)return;u.set(e,l);}let i=$n(e,t,r,o),a=je(e),c=Y(a);Object.is(i,c)||(Ne(a,i),$r(e));},Ai=e=>{let t=_r(e);if(!t){d(`invalidateComputed("${e}") -- "${e}" is not a computed store`);return}$r(e),_n(e,t.deps,t.compute);},Yr=e=>{let t=Gr(),r=t.get(e);if(!r){R()&&d(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);},Oi=e=>Zt(e);var dt=new Map,zn=(e,t)=>{let r=dt.get(e);return r||(r=new Set,dt.set(e,r)),r.add(t),()=>{let o=dt.get(e);o&&(o.delete(t),o.size===0&&dt.delete(e));}},Xr=e=>{let t=dt.get(e);return !!t&&t.size>0},Vt=(e,t,r)=>{let o=dt.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 Wn=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,a=e.featureRuntimes,c=e.deletingStores,l=(f,y)=>{Le(y,{onError:s[f]?.options?.onError,severity:"warn",visibility:"dev"});},u=({name:f,prev:y,options:m,initialState:T,getMeta:C,getStoreValue:A,hasStore:D})=>({name:f,options:m,prev:y,getMeta:C,getStoreValue:A,getAllStores:()=>t,getInitialState:()=>T,hasStore:D,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:b=>{Le(b,{onError:m.onError,severity:"warn",visibility:"dev"});},warn:d,warnAlways:I,log:ue,hashState:Tt,deepClone:V,sanitize:$e,validate:()=>({ok:true,value:y}),isDev:R}),g=({name:f,prev:y,options:m,initialState:T,phase:C})=>{let A=u({name:f,prev:y,options:m,initialState:T,getMeta:()=>s[f],getStoreValue:()=>t[f],hasStore:()=>Oe(e,f)}),D=u({name:f,prev:y,options:m,initialState:T,getMeta:()=>{},getStoreValue:()=>y,hasStore:()=>false});Qe().forEach(b=>{let v=a.get(b);C==="before"?v?.beforeStoreDelete?.(A):v?.afterStoreDelete?.(D);});},p=f=>{if(!Oe(e,f))return;let y=t[f],m=s[f].options,T=o[f],C=r[f];c.add(f);try{C?.forEach(b=>{try{b(null);}catch(v){d(`Subscriber for "${f}" threw during delete: ${v?.message??v}`);}}),Jt({name:f,label:"onDelete",fn:m.onDelete,args:[y],reportIssue:(b,v)=>{Le(b,{onError:m.onError,severity:"warn",visibility:v});}}),g({name:f,prev:y,options:m,initialState:T,phase:"before"}),delete t[f],delete r[f],delete o[f],delete n[f],delete s[f],delete i[f],Zt(f)&&Yr(f);let D=e.computedDependents[f];if(D)for(let b of D)d(`[stroid] source store "${f}" was deleted. Computed store "${b}" depends on it and will return stale data. Call deleteComputed("${b}") to clean up.`);g({name:f,prev:y,options:m,initialState:T,phase:"after"}),Vt("afterStoreDelete",f,{type:"afterStoreDelete",prev:y}),Kt(e,{type:"deleted",name:f}),ue(`Store "${f}" deleted`);}finally{c.delete(f);}};return {deleteExistingStore:p,clearAllStores:()=>{let f=[],m=0,T=Number.POSITIVE_INFINITY;for(;m<20;){let A=Object.keys(t);if(A.length===0)break;A.forEach(b=>{Oe(e,b)&&(p(b),f.push(b));}),m+=1;let D=Object.keys(t).length;if(D===0||D>=T)break;T=D;}let C=Object.keys(t).length;return C>0?d(`clearAllStores stopped after ${m} pass${m===1?"":"es"}; ${C} store(s) still registered (likely recreated during deletion).`):d(`All stores cleared (${f.length} stores removed)`),f},clearStores:f=>{let y=Object.keys(t).filter(m=>f?f.endsWith("*")?m.startsWith(f.slice(0,-1)):m===f:true);return y.forEach(m=>p(m)),y},reportStoreError:l}};var Jr=Ce,Ln=ke(Jr),Bn=null,X=()=>{let e=Z(Ln);return xr(e),e};var F=()=>X();var Fn=(e,t)=>{Kt(e,t);};function hn(e){Bn=e;}var ft=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}}}),Di=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)}),Pi=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)}),Ot=ft(()=>X().stores),qn=ft(()=>X().subscribers),Mn=ft(()=>X().initialStates);ft(()=>X().initialFactories);var W=ft(()=>X().metaEntries);ft(()=>X().snapshotCache);var ge=Di(()=>X().featureRuntimes),Hn=new WeakMap,Kn=e=>{let t=Hn.get(e);return t||(t=Wn(e),Hn.set(e,t)),t};Pi(()=>Kn(X()));var Un=()=>Kn(X()),Vi=e=>{let t=ge.get(e);if(t)return t;let r=qt(e);if(!r)return;let o=r();return ge.set(e,o),o},ir=()=>{Qe().forEach(e=>{Vi(e);});};ir();var oe=(e,t)=>Oe(t??X(),e),Ve=(e,t=X())=>{if(M()){let o=be(e);if(o.has)return o.value}let r=xt();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},we=(e,t,r=X())=>{r.stores[e]=t;},Tn=(e,t,r=Date.now())=>{we(e,t),W[e]&&(W[e].updatedAt=new Date(r).toISOString(),W[e].updatedAtMs=r,W[e].lastCorrelationId=null,W[e].lastCorrelationAt=null,W[e].lastCorrelationAtMs=null,W[e].lastTraceContext=null,W[e].updateCount>=Number.MAX_SAFE_INTEGER?W[e].updateCount=0:W[e].updateCount+=1,Bn?.(e));},Kr=(e,t=X())=>{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();},ji=()=>{ho(X());},Ni=()=>{ge.forEach(e=>{try{e.resetAll?.();}catch{}}),ge.clear();};P("features.reset",Ni,10);P("registries.clear",ji,20);P("registry.default",()=>{Jr=Ce,Ln=ke(Jr);},115);var pn=e=>mo(X(),e);var Gn=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Qr=(e,t)=>{if(t==="ref"){if(!R())return e;try{return Nr(e)}catch{return e}}if(t==="shallow"){let o=ee(e);if(!R())return o;try{return Nr(o)}catch{return o}}let r=V(e);if(!R())return r;try{return Ko(r)}catch{return r}};var Yn=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:o}=e,n=k().flush,s=n.priorityStores||[],i=s.length?new Set(s):null;o.length=0,r.length=0;let a=new Set;if(i){for(let h of t)r.push(h),a.add(h);for(let h of s)a.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),a.add(h),o.push(h);t.clear();let c=Qo(o),l=new Set(o);for(let h of c)l.has(h)||(o.push(h),l.add(h));let u=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,g=n.chunkDelayMs,p=u===Number.POSITIVE_INFINITY&&g===0;return {names:o,sliceSize:u,chunkDelayMs:g,runInline:p,prioritySet:i}};var Zr=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}),eo=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),to=(e,t)=>{e&&(e.metrics=t);};var jt=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Xn=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>Ze(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var Jn=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)},Qn=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:c,prioritySet:l}=t,g=n.subscriberBuffer,p=e.stores,x=e.subscribers,h=e.metaEntries,f=e.snapshotCache,y=k().defaultSnapshotMode,m=w=>Gn(h[w],y),T=w=>p[w],C=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),A=Xr("beforeFlush"),D=Xr("afterFlush"),b=w=>{A&&Vt("beforeFlush",w,{type:"beforeFlush"});},v=(w,_)=>{D&&Vt("afterFlush",w,{type:"afterFlush",elapsedMs:_});},J=w=>{let _=h[w];if(!_)return null;let N=_.lastCorrelationId??void 0,S=_.lastTraceContext??void 0;return !N&&!S?null:{correlationId:N,traceContext:S}},E=w=>{g.length=0;for(let _ of w)g.push(_);return g},L=()=>{o();};if(c){for(let w of s){let _=x[w];if(!_||_.size===0)continue;let N=h[w]?.updateCount??0,S=m(w),Q=T(w),U=f[w],te=U&&U.source===Q&&U.mode===S?U.snapshot:(()=>{let q=Qr(Q,S);return f[w]={version:r,snapshot:q,source:Q,mode:S},q})(),H=Zr(h[w]?.metrics);b(w);let ve=C(),ie=E(_),ae=J(w),me=()=>{for(let q of ie)try{q(te);}catch(he){let le=h[w]?.options?.snapshotSafety??"warn";if(R()&&(S==="ref"||S==="shallow")&&Jn(he)){if(le==="throw")throw he;if(le==="auto-clone")try{let O=V(te);d(`Snapshot mutation detected for "${w}". Delivered a cloned snapshot to the subscriber.`);try{q(O);}catch(K){d(`Subscriber for "${w}" threw on cloned snapshot: ${K?.message??K}`);}continue}catch{}d(`Snapshot mutation detected for "${w}": ${he?.message??he}`);continue}d(`Subscriber for "${w}" threw: ${he?.message??he}`);}};ae?ct(ae,me):me();let Ie=C()-ve;v(w,Ie),eo(H,Ie),to(h[w],H),(h[w]?.updateCount??N)!==N&&n.pendingNotifications.add(w);}L();return}let Ee=w=>{let _=[];for(let N of s){if(w&&!w(N))continue;let S=x[N];if(!S||S.size===0)continue;let Q=h[N]?.updateCount??0,U=m(N),te=T(N),H=f[N],ve=H&&H.source===te&&H.mode===U?H.snapshot:(()=>{let ie=Qr(te,U);return f[N]={version:r,snapshot:ie,source:te,mode:U},ie})();_.push({name:N,snapshot:ve,version:Q,subscribers:Array.from(S),subscriberSet:new Set(S),notified:new Set,metrics:Zr(h[N]?.metrics),totalMs:0,beforeHooked:false});}return _},Xe=l?Ee(w=>l.has(w)):[],ht=Ee(w=>!l||!l.has(w)),bt=(w,_)=>{let N=()=>{if(w.length===0){_();return}let S=w.shift();if((h[S.name]?.updateCount??S.version)!==S.version){if(n.pendingNotifications.add(S.name),w.length===0){_();return}jt(N,a);return}let U=()=>{let G=x[S.name];if(!(!G||G.size===0))for(let q of G)S.subscriberSet.has(q)||(S.subscriberSet.add(q),S.subscribers.push(q));};U();let te=S.subscribers;if(te.length===0){if(w.length===0){_();return}jt(N,a);return}S.beforeHooked||(S.beforeHooked=true,b(S.name));let H=C(),ve=0,ie=false,ae=J(S.name),me=()=>{for(let G=0;G<te.length&&ve<i;G+=1){let q=te[G];if(S.notified.has(q))continue;S.notified.add(q);try{q(S.snapshot);}catch(le){let wt=h[S.name]?.options?.snapshotSafety??"warn",O=m(S.name);if(R()&&(O==="ref"||O==="shallow")&&Jn(le)){if(wt==="throw")throw le;if(wt==="auto-clone")try{let xe=V(S.snapshot);d(`Snapshot mutation detected for "${S.name}". Delivered a cloned snapshot to the subscriber.`);try{q(xe);}catch(vt){d(`Subscriber for "${S.name}" threw on cloned snapshot: ${vt?.message??vt}`);}if(S.notified.add(q),ve+=1,(h[S.name]?.updateCount??S.version)!==S.version){ie=!0,n.pendingNotifications.add(S.name);break}continue}catch{}d(`Snapshot mutation detected for "${S.name}": ${le?.message??le}`);continue}d(`Subscriber for "${S.name}" threw: ${le?.message??le}`);}if(ve+=1,(h[S.name]?.updateCount??S.version)!==S.version){ie=true,n.pendingNotifications.add(S.name);break}}};if(ae?ct(ae,me):me(),S.totalMs+=C()-H,ie){if(w.length===0){_();return}jt(N,a);return}U();let Ie=false;for(let G of te)if(!S.notified.has(G)){Ie=true;break}if(Ie?w.push(S):(eo(S.metrics,S.totalMs),to(h[S.name],S.metrics),v(S.name,S.totalMs)),w.length===0){_();return}jt(N,a);};N();};Xe.length>0?bt(Xe,()=>bt(ht,L)):bt(ht,L);};var Ii=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=Yn(t);Qn(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&gr(e);});},gr=e=>{Xn(e,Ii);};var $i=e=>{let t=F(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&gr(t);};En($i);var Zn=e=>{if(typeof e!="function"){d("setStoreBatch requires a synchronous function callback.");return}let t=Object.prototype.toString.call(e);if(t==="[object AsyncFunction]"||t==="[object AsyncGeneratorFunction]"){I("setStoreBatch does not support async functions. Move async work outside and batch only synchronous mutations.");return}if(t==="[object GeneratorFunction]"){I("setStoreBatch does not support generator functions. Move generator logic outside and batch only synchronous mutations.");return}let r=F(),o=typeof window>"u",n=typeof process<"u"?process.env?.NODE_ENV:void 0;if(o&&n==="production"&&r.scope!=="request")throw new Error("setStoreBatch() called in a global SSR context. Use createStoreForRequest() to ensure transaction isolation.");let s=r.notify;s.batchDepth=Math.max(0,s.batchDepth+1),Go(r);let i;try{let a=Ze(r,e);a&&typeof a.then=="function"&&(i=new Error("setStoreBatch does not support promise-returning callbacks. Move async work outside and batch only synchronous mutations."));}catch(a){i=a;}finally{let a=Yo(i,r);s.batchDepth=Math.max(0,s.batchDepth-1),(i||a)&&(s.pendingNotifications.clear(),s.notifyScheduled=false),s.batchDepth===0&&s.pendingNotifications.size>0&&gr(r),a&&!i&&(i=a);}if(i){let a=i instanceof Error?i.message:String(i);I(`setStoreBatch failed: ${a}`);}},Pt=(e,t)=>{let o=F().subscribers;return o[e]||(o[e]=new Set),o[e].add(t),()=>{o[e]?.delete(t),o[e]?.size===0&&delete o[e];}};var _i=()=>{let e=F().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0;};P("notify.reset",_i,40);var Sr=(e,t={},r)=>{if(M()){let c="hydrateStores(...) cannot be called inside setStoreBatch.";return d(c),j(c),{hydrated:[],created:[],failed:[],blocked:{reason:"transaction"}}}let o={hydrated:[],created:[],failed:[]};if(!e||typeof e!="object")return o;let n=F(),s=r??{};if(!(s.allowTrusted===true||s.allowHydration===true||s.allowUntrusted===true||k().allowUntrustedHydration===true))return I("hydrateStores(...) requires explicit trust. Pass { allowTrusted: true } (or { allowHydration: true }) as the third argument or configureStroid({ allowTrustedHydration: true })."),o.blocked={reason:"untrusted"},o;if(typeof s.validate=="function"){let c=false;try{c=!!s.validate(e);}catch(l){let u=`hydrateStores() trust.validate threw: ${l?.message??l}`;if(R())throw new Error(`hydrateStores() trust.validate threw an error. Fix your validator before this becomes a silent production failure.
25
- Original error: ${l?.message??l}`);let g=t?.default?.onError;if(typeof g=="function")try{g(u);}catch(p){I(`hydrateStores(...) onError threw: ${p?.message??p}`);}if(I(u),typeof s.onValidationError=="function")try{if(!!s.onValidationError(l,e))c=!0;else return o.blocked={reason:"validation-error",cause:l},o}catch(p){return I(`hydrateStores(...) onValidationError threw: ${p?.message??p}`),o.blocked={reason:"validation-error",cause:p},o}else return o.blocked={reason:"validation-error",cause:l},o}if(!c)return I("hydrateStores(...) rejected by trust validation."),o.blocked={reason:"validation-failed"},o}let a=[];return Object.entries(e).forEach(([c,l])=>{if(!Mt(c)){o.failed.push({name:c,reason:"invalid-name"});return}if(oe(c,n)){let u=Ur(n,c,l,"hydrate");u.ok?(o.hydrated.push(c),a.push(c)):o.failed.push({name:c,reason:"merge-failed",cause:u.reason,received:l});}else {let u=t;ce(c,l,u[c]||u.default||{})?(o.created.push(c),a.push(c)):o.failed.push({name:c,reason:"create-failed",received:l});}}),a.length>0&&zr(a).forEach(l=>{let u=n.computedEntries[l];if(!u)return;let g=u.deps.map(p=>Y(p));try{let p=u.compute(...g);if(p&&typeof p.then=="function"){d(`hydrateStores recompute for "${l}" returned a Promise; skipping.`);return}let x=Y(l);if(Object.is(p,x))return;Ne(l,p);}catch(p){d(`hydrateStores recompute for "${l}" failed: ${p?.message??p}`);}}),o};function it(e){let t=fe(e);if(!qe(t))return;let r=F();if(!Ue(t,r))return;if(M()){let n=`deleteStore("${t}") cannot be called inside setStoreBatch. Move deleteStore outside the batch to preserve transaction semantics.`;pe(t,n),j(n);return}Un().deleteExistingStore(t),Se(t),Vn(t),qr(t);}function at(e){let t=fe(e);if(!qe(t))return {ok:false,reason:"not-found"};let r=F();if(r.metaEntries[t]?.options?.lazy===true&&!!r.initialFactories[t]){let u=`resetStore("${t}") cannot run on a lazy store before it is initialized. Read the store once (getStore) to materialize it before resetting.`;return pe(t,u),M()&&j(u),{ok:false,reason:"lazy-uninitialized"}}if(!Ue(t,r))return {ok:false,reason:"validate"};if(!r.initialStates[t]){let u=`resetStore("${t}") has no initial state to reset to. If this is a lazy store, ensure it has been initialized before calling resetStore.`;return pe(t,u),M()&&j(u),{ok:false,reason:"not-found"}}let n=M()?be(t):{has:false,value:void 0},s=n.has?n.value:r.stores[t],i=typeof performance<"u"&&performance.now?performance.now():Date.now(),a=V(r.initialStates[t]),c=(typeof performance<"u"&&performance.now?performance.now():Date.now())-i,l=r.metaEntries[t]?.metrics;return l&&(l.resetCount=(l.resetCount??0)+1,l.totalResetMs=(l.totalResetMs??0)+c,l.lastResetMs=c),lt(r,{name:t,prev:s,next:a,action:"reset",hookLabel:"onReset",logMessage:`Store "${t}" reset to initial state/value`}),{ok:true}}var se=()=>Z().async;var es=100,ro=100,Hi=1e3,oo=()=>se().fetchRegistry,Ye=()=>se().inflight,pt=()=>se().requestVersion,Nt=()=>se().cacheMeta,no=()=>se().rateWindowStart,so=()=>se().rateCount;var yr=()=>se().storeCleanups,os=()=>se().warnedOnce;var It=()=>se().asyncMetrics,Li=e=>{let t=os(),r=t.get(e);return r||(r=new Set,t.set(e,r)),r},Bi=(e,t)=>{if(e.has(t)||(e.add(t),e.size<=Hi))return;let r=e.values().next().value;r!==void 0&&e.delete(r);},$t=(e,t,r)=>{let o=Li(e);o.has(t)||(Bi(o,t),r());},ts=null,rs=e=>{e&&Array.from(e).forEach(t=>{try{t();}catch{}});},qi=e=>{let t=yr(),r=t[e];return r||(r=Object.create(null),t[e]=r),r},Ki=(e,t)=>{Object.keys(t).length===0&&delete yr()[e];},Ui=(e,t)=>{Object.keys(e).forEach(r=>{rs(e[r]),delete e[r];});},Gi=e=>{let t=yr(),r=t[e];r&&(Ui(r),delete t[e]);};var ns=()=>{ts||(ts=zn("afterStoreDelete",e=>{Gi(e),Yi(e);}));};var ss=(e,t)=>{if(!t)return false;let r=Nt(),o=r[e];return o?o.expiresAt!==null&&o.expiresAt<=Date.now()?(delete r[e],false):Date.now()-o.timestamp<t:false},Yi=e=>{let t=oo(),r=Nt(),o=Ye(),n=pt(),s=no(),i=so(),a=os();delete t[e],a.get("noSignal")?.delete(e),a.get("shape")?.delete(e),a.get("autoCreate")?.delete(e),a.get("mutableResult")?.delete(e);let c=l=>l===e||l.startsWith(`${e}:`);Object.keys(o).forEach(l=>{c(l)&&delete o[l];}),Object.keys(n).forEach(l=>{c(l)&&delete n[l];}),Object.keys(r).forEach(l=>{c(l)&&delete r[l];}),Object.keys(s).forEach(l=>{c(l)&&delete s[l];}),Object.keys(i).forEach(l=>{c(l)&&delete i[l];});},is=e=>{let t=`${e}:`,r=Nt(),o=pt(),n=Object.entries(r).filter(([i,a])=>i!==e&&!i.startsWith(t)?false:a.expiresAt!==null&&a.expiresAt<=Date.now()?(delete r[i],false):true).sort((i,a)=>i[1].timestamp-a[1].timestamp);if(n.length<=es)return;let s=n.length-es;n.slice(0,s).forEach(([i])=>{delete r[i],delete o[i];});},mr=e=>{let t=`${e}:`,r=Ye(),o=0;return Object.keys(r).forEach(n=>{(n===e||n.startsWith(t))&&(o+=1);}),o},as=(e,t,r="store")=>{ns();let o=qi(e),n=o[r];n||(n=new Set,o[r]=n),n.add(t);},cs=(e,t,r)=>{let n=yr()[e];if(!n)return;let s=i=>{let a=n[i];a&&(a.delete(t),a.size===0&&delete n[i]);};Object.keys(n).forEach(s),Ki(e,n);},ls=e=>{ns();};var us=10,Xi=10,io=3e4,Ji=8,fs=(e,t)=>new Promise(r=>{if(t?.aborted){r();return}let o=setTimeout(()=>{t?.removeEventListener("abort",n),r();},e),n=()=>{clearTimeout(o),t?.removeEventListener("abort",n),r();};t?.addEventListener("abort",n,{once:true});}),ds=(e,t,r,o)=>Number.isFinite(r)?r:(d(`fetchStore("${e}") received non-finite ${t}; using ${o}.`),o),ps=(e,t,r,o)=>{let n=Number.isFinite(t)?t:t>0?us:0,s=Math.min(us,Math.max(0,Math.trunc(n)));Number.isFinite(t)||d(`fetchStore("${e}") received non-finite retry; using ${s}.`);let i=Math.min(io,Math.max(Xi,ds(e,"retryDelay",r,400))),a=Math.min(Ji,Math.max(1,ds(e,"retryBackoff",o,1.7)));return s!==t&&d(`fetchStore("${e}") clamped retry attempts to ${s}.`),i!==r&&d(`fetchStore("${e}") clamped retryDelay to ${i}ms.`),a!==o&&d(`fetchStore("${e}") clamped retryBackoff to ${a}.`),{retry:s,retryDelay:i,retryBackoff:a}};var gs=(e,t)=>!t||t==="none"||e===null||typeof e!="object"?e:t==="shallow"?ee(e):V(e);var gt=(e,t,r,o)=>{if(typeof r=="function")try{r(o);}catch(n){d(`fetchStore("${e}") ${t} callback failed: ${n?.message??n}`);}},ye=(e,t,r)=>k().strictAsyncUsageErrors?Qi(e,t,r):(gt(e,"onError",r,t),R()?($(t),null):(B(t),null)),Qi=(e,t,r)=>{throw gt(e,"onError",r,t),R()?$(t):B(t),new Error(t)};var _t=(e,t)=>(pt()[e]??0)===t,Ss=e=>{let t=pt(),r=(t[e]??0)+1;return t[e]=r,r},ys=(e,t)=>{let r=pt();r[e]===t&&delete r[e];},ms=(e,t)=>{let r=Ye();r[e]=t;},hs=e=>{let t=Ye();delete t[e];},bs=e=>!!Ye()[e],ws=(e,t,r,o)=>{let n=Ye()[t];if(n)return It().dedupes+=1,r&&n.transform&&n.transform!==r?(ye(e,`fetchStore("${e}") cannot dedupe callers that use different transform functions for cacheSlot "${t}".`,o),null):!r||n.transform===r?n.promise:n.raw.then(s=>r(s))};var St=1e3,ao=100,vs=(e,t)=>{t-e.ratePruneState.lastAt<St||(e.ratePruneState.lastAt=t,Object.keys(e.rateWindowStart).forEach(r=>{t-(e.rateWindowStart[r]??0)>St&&(delete e.rateWindowStart[r],delete e.rateCount[r]);}));},xs=e=>{vs(se(),e);},Rs=(e=St)=>{let t=se();t.ratePruneTimer||typeof setTimeout=="function"&&(t.ratePruneTimer=setTimeout(()=>{t.ratePruneTimer=null,vs(t,Date.now());},e));},Cs=(e,t)=>{let r=no(),o=so(),n=r[e],s=o[e]??0;return n!==void 0&&t-n<St?s>=ao?true:(o[e]=s+1,false):(r[e]=t,o[e]=1,false)};var ks=e=>{let t={};return e.method&&(t.method=e.method.toUpperCase()),e.headers?t.headers=e.headers:t.headers={"Content-Type":"application/json"},e.body&&(t.body=typeof e.body=="string"?e.body:JSON.stringify(e.body)),e.signal&&(t.signal=e.signal),t},Ms=async(e,t)=>{let r=t??"auto";if(r==="json")return e.json();if(r==="text")return e.text();if(r==="arrayBuffer")return e.arrayBuffer();if(r==="blob")return e.blob();if(r==="formData")return e.formData();let o=e.headers.get("content-type")||"";return o.includes("application/json")||o.includes("+json")?e.json():o.startsWith("text/")||o.includes("xml")||o.includes("html")?e.text():o.includes("form-data")?e.formData():e.arrayBuffer()};var Zi=e=>{if(!e||typeof e!="object")return false;let t=e;return "data"in t&&"loading"in t&&"error"in t&&"status"in t},ea=(e,t,r,o,n)=>{if(!ne(e))return;let s=o.stateAdapter;if(s){try{let i=Y({name:e}),a=c=>{ut(t,c,void 0,n);};ct(n,()=>{s({name:e,prev:i,next:r,set:a});});}catch(i){d(`fetchStore("${e}") stateAdapter failed: ${i?.message??i}`);}return}ct(n,()=>{ut(t,r,void 0,n);});},yt=(e,t,r,o)=>(d(`fetchStore("${e}") aborted`),_t(t,r)&&ne(e)&&o({loading:false,error:"aborted",status:"aborted",revalidating:false}),null);async function mt(e,t,r={}){let o=fe(e);if(!o||typeof o!="string"){$("fetchStore requires a store name as first argument");return}let n={name:o};if(!t){$(`fetchStore("${o}") requires a URL, Promise, or Promise factory as second argument`);return}let{transform:s,onSuccess:i,onError:a,stateAdapter:c,method:l,headers:u,body:g,ttl:p,staleWhileRevalidate:x=false,dedupe:h=true,retry:f=0,retryDelay:y=400,retryBackoff:m=1.7,signal:T,cacheKey:C,responseType:A="auto"}=r,D=Nt(),b=oo(),v=It(),J=(()=>{let O=r.correlationId,K=r.traceContext;return O||K?{correlationId:O,traceContext:K}:k().autoCorrelationIds?{correlationId:`stroid-${o}-${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,traceContext:K}:null})();!T&&R()&&$t("noSignal",o,()=>{d(`fetchStore("${o}") called without an AbortSignal. Provide "signal" to enable cancellation (recommended).`);});let E=C?`${o}:${C}`:o,L=O=>ea(o,n,J?{...O,correlationId:J.correlationId,traceContext:J.traceContext}:O,r,J),Ee=typeof t!="string"&&typeof t!="function"&&typeof t?.then=="function",Xe=ps(o,f,y,m),ht=false,bt=Ee&&f>0,w=typeof window>"u"&&(typeof process<"u"?process.env?.NODE_ENV:void 0)==="production",_=r.autoCreate??k().asyncAutoCreate,N=r.cloneResult??k().asyncCloneResult;if(c&&!ne(o))return ye(o,`fetchStore("${o}") with stateAdapter requires an existing backing store.
26
- Call createStore("${o}", ...) first or omit stateAdapter to use the default AsyncState shape.`,a);if(!ne(o)&&w)return ye(o,`fetchStore("${o}") cannot create a backing store on the server in production.
27
- Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,a);if(!ne(o)){if(!_)return ye(o,`fetchStore("${o}") requires an existing backing store when autoCreate is disabled.
28
- Call createStore("${o}", ...) first or enable autoCreate.`,a);if(R()&&$t("autoCreate",o,()=>{let O=`fetchStore("${o}") auto-created its backing store.
29
- Call createStore("${o}", ...) first to avoid typos creating phantom stores.`;re(a,`fetchStore.onError(${o})`,O),d(O);}),ce(o,{data:null,loading:false,error:null,status:"idle"}),!ne(o))return ye(o,`fetchStore("${o}") could not initialize its backing store.
30
- On the server in production, use createStoreForRequest(...) inside the request scope or create the store with { allowSSRGlobalStore: true } before calling fetchStore.`,a)}if(!c){let O=Y({name:o});if(O&&!Zi(O))return $t("shape",o,()=>{}),ye(o,`fetchStore("${o}") cannot write AsyncState into an existing non-async store. Provide a stateAdapter or create the store with the async shape to avoid overwriting fields.`,a)}ls();let S=null,Q=false,U=()=>D[E]?.data??null;if(ss(E,p)){if(v.cacheHits+=1,S=U(),L({data:S,loading:x,error:null,status:"success",cached:true,revalidating:x}),!x)return S;Q=true;}else v.cacheMisses+=1;if(h){let O=ws(o,E,s,a);if(O!==void 0)return O}let te=Date.now();if(xs(te),Rs(),Cs(o,te))return ye(o,`fetchStore("${o}") rate limited: ${ao} requests per ${St}ms window for store "${o}".`,a);if(!bs(E)&&mr(o)>=ro)return ye(o,`fetchStore("${o}") exceeded ${ro} concurrent request slots. Reuse cacheKey values, wait for pending requests, or delete the store to clear async state.`,a);let H=Ss(E);Q||L({loading:true,error:null,status:"loading",cached:false,revalidating:false}),v.requests+=1;let ve=Date.now(),ie=!T&&typeof AbortController<"u"?new AbortController:null,ae=T||ie?.signal,me=ie?()=>{ie.signal.aborted||ie.abort();}:null;me&&as(o,me);let Ie=async()=>{let O=0,K=Xe.retryDelay;for(;;){if(ae?.aborted)return yt(o,E,H,L);let xe=typeof t=="function"?t():t,br=Ee||typeof xe!="string"&&typeof xe?.then=="function",vt=br?{...Xe,retry:0}:Xe;br&&(f>0||bt)&&!ht&&(d(`fetchStore("${o}") ignores retry settings for direct Promise inputs; pass a URL string or factory to use retries.`),ht=true);try{let Fe;if(typeof xe=="string"){let Ht=ks({method:l,headers:u,body:g,signal:ae,...r}),Lt=await fetch(xe,Ht);if(!Lt.ok)throw new Error(`HTTP ${Lt.status}: ${Lt.statusText}`);Fe=await Ms(Lt,A);}else if(typeof xe.then=="function")Fe=await xe;else return $(`fetchStore("${o}") - second argument must be a URL string, Promise, or Promise factory.
24
+ replaceStore("${n}", value) // full-store replace`;return $(S),re(i[n]?.options?.onError,`onError(${n})`,S),E()&&j(S),{ok:false,reason:"invalid-args"}}if(!rt(a))return E()&&j(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let g=i[n]?.options?.validate,f=gr(o),h=sr(n,{action:"set",prev:l,next:a,path:t,correlationId:f?.correlationId,traceContext:f?.traceContext});if(h===st)return E()&&j(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let p=Ge(n,h,g,void 0,u&&h===a?{reuseInput:true}:void 0);if(!p.ok)return E()&&j(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};try{if(Pr(l,p.value))return {ok:!0}}catch{}return dt(s,{name:n,prev:l,next:p.value,action:"set",hookLabel:"onSet",logMessage:`Store "${n}" updated`,context:f}),{ok:true}},ft=(e,t,r,o)=>_n(e,t,r,o);var Gr=()=>F().computedCleanups,Wn=new WeakMap,zn=new WeakMap,Yr=e=>{let t=Wn.get(e);return t||(t=new Map,Wn.set(e,t)),t},Vi=e=>{let t=zn.get(e);return t||(t=new Map,zn.set(e,t)),t};function ji(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=Gr(),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")){d(`createComputed("${e}") dependencies must be store names or store handles.`);return}if(R()){let g=i.filter(f=>!ne(f));g.length>0&&d(`createComputed("${e}") dependencies not found at registration: ${g.join(", ")}. Computed values will receive null until those stores are created.`);}if(!nn(e,i,r))return;Yr(F()).set(e,{...o});let c=Hn(e,t,r,o.onError),l=Ie(e);ne(e)?$e(l,c):le(e,c);let u=[];for(let g of i){let f=Pt(g,()=>{Ln(e,i,r,o.onError);});u.push(f);}return Gr().set(e,()=>{u.forEach(g=>g()),sn(e),Yr(F()).delete(e);}),R()&&ce(`computed store "${e}" created, deps: [${i.join(", ")}]`),l}var Hn=(e,t,r,o)=>{let n=t.map(s=>typeof s=="string"?G(Ie(s)):G(s));try{return r(...n)}catch(s){d(`createComputed("${e}") compute function threw: ${s?.message??s}`),re(o,`computed.onError(${e})`,s);let i=Ie(e);return ne(e)?G(i):null}},Ln=(e,t,r,o)=>{if(!$r(e))return;let s=F();if(s.notify.isFlushing){let l=s.notify.flushId,u=Vi(s);if(u.get(e)===l)return;u.set(e,l);}let i=Hn(e,t,r,o),a=Ie(e),c=G(a);Object.is(i,c)||($e(a,i),Ir(e));},Ni=e=>{let t=$r(e);if(!t){d(`invalidateComputed("${e}") -- "${e}" is not a computed store`);return}Ir(e),Ln(e,t.deps,t.compute);},Xr=e=>{let t=Gr(),r=t.get(e);if(!r){R()&&d(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);},Ii=e=>er(e),Bn=(e,t=F())=>Yr(t).get(e)?.autoDispose===true;var pt=new Map,qn=(e,t)=>{let r=pt.get(e);return r||(r=new Set,pt.set(e,r)),r.add(t),()=>{let o=pt.get(e);o&&(o.delete(t),o.size===0&&pt.delete(e));}},Jr=e=>{let t=pt.get(e);return !!t&&t.size>0},Vt=(e,t,r)=>{let o=pt.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 Kn=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,a=e.featureRuntimes,c=e.deletingStores,l=(p,S)=>{Ke(S,{onError:s[p]?.options?.onError,severity:"warn",visibility:"dev"});},u=({name:p,prev:S,options:m,initialState:M,getMeta:k,getStoreValue:A,hasStore:O})=>({name:p,options:m,prev:S,getMeta:k,getStoreValue:A,getAllStores:()=>t,getInitialState:()=>M,hasStore:O,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:b=>{Ke(b,{onError:m.onError,severity:"warn",visibility:"dev"});},warn:d,warnAlways:I,log:ce,hashState:Mt,deepClone:V,sanitize:ze,validate:()=>({ok:true,value:S}),isDev:R}),g=({name:p,prev:S,options:m,initialState:M,phase:k})=>{let A=u({name:p,prev:S,options:m,initialState:M,getMeta:()=>s[p],getStoreValue:()=>t[p],hasStore:()=>Me(e,p)}),O=u({name:p,prev:S,options:m,initialState:M,getMeta:()=>{},getStoreValue:()=>S,hasStore:()=>false});et().forEach(b=>{let w=a.get(b);k==="before"?w?.beforeStoreDelete?.(A):w?.afterStoreDelete?.(O);});},f=p=>{if(!Me(e,p))return;let S=t[p],m=s[p].options,M=o[p],k=r[p];c.add(p);try{k?.forEach(b=>{try{b(null);}catch(w){d(`Subscriber for "${p}" threw during delete: ${w?.message??w}`);}}),Jt({name:p,label:"onDelete",fn:m.onDelete,args:[S],reportIssue:(b,w)=>{Ke(b,{onError:m.onError,severity:"warn",visibility:w});}}),g({name:p,prev:S,options:m,initialState:M,phase:"before"}),delete t[p],delete r[p],delete o[p],delete n[p],delete s[p],delete i[p],er(p)&&Xr(p);let O=e.computedDependents[p];if(O)for(let b of [...O]){let w=Wr(b);if(w&&Bn(b,e)&&w.deps.every(q=>!Me(e,q))){f(b);continue}d(`[stroid] source store "${p}" was deleted. Computed store "${b}" depends on it and will return stale data. Call deleteComputed("${b}") to clean up.`);}g({name:p,prev:S,options:m,initialState:M,phase:"after"}),Vt("afterStoreDelete",p,{type:"afterStoreDelete",prev:S}),Kt(e,{type:"deleted",name:p}),ce(`Store "${p}" deleted`);}finally{c.delete(p);}};return {deleteExistingStore:f,clearAllStores:()=>{let p=[],m=0,M=Number.POSITIVE_INFINITY;for(;m<20;){let A=Object.keys(t);if(A.length===0)break;A.forEach(b=>{Me(e,b)&&(f(b),p.push(b));}),m+=1;let O=Object.keys(t).length;if(O===0||O>=M)break;M=O;}let k=Object.keys(t).length;return k>0?d(`clearAllStores stopped after ${m} pass${m===1?"":"es"}; ${k} store(s) still registered (likely recreated during deletion).`):ce(`All stores cleared (${p.length} stores removed)`),p},clearStores:p=>{let S=Object.keys(t).filter(m=>p?p.endsWith("*")?m.startsWith(p.slice(0,-1)):m===p:true);return S.forEach(m=>f(m)),S},reportStoreError:l}};var Qr=Ce,Gn=ke(Qr),Yn=null,Y=()=>{let e=Q(Gn);return vr(e),e};var F=()=>Y();var Dn=(e,t)=>{Kt(e,t);};function xn(e){Yn=e;}var gt=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}}}),$i=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)}),_i=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)}),At=gt(()=>Y().stores),Xn=gt(()=>Y().subscribers),Fn=gt(()=>Y().initialStates);gt(()=>Y().initialFactories);var W=gt(()=>Y().metaEntries);gt(()=>Y().snapshotCache);var ge=$i(()=>Y().featureRuntimes),Un=new WeakMap,Jn=e=>{let t=Un.get(e);return t||(t=Kn(e),Un.set(e,t)),t};_i(()=>Jn(Y()));var Qn=()=>Jn(Y()),Wi=e=>{let t=ge.get(e);if(t)return t;let r=qt(e);if(!r)return;let o=r();return ge.set(e,o),o},ar=()=>{et().forEach(e=>{Wi(e);});};ar();var oe=(e,t)=>Me(t??Y(),e),Ne=(e,t=Y())=>{if(E()){let o=be(e);if(o.has)return o.value}let r=xt();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},we=(e,t,r=Y())=>{r.stores[e]=t;},An=(e,t,r=Date.now())=>{we(e,t),W[e]&&(W[e].updatedAt=new Date(r).toISOString(),W[e].updatedAtMs=r,W[e].lastCorrelationId=null,W[e].lastCorrelationAt=null,W[e].lastCorrelationAtMs=null,W[e].lastTraceContext=null,W[e].updateCount>=Number.MAX_SAFE_INTEGER?W[e].updateCount=0:W[e].updateCount+=1,Yn?.(e));},Kr=(e,t=Y())=>{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();},zi=()=>{xo(Y());},Hi=()=>{ge.forEach(e=>{try{e.resetAll?.();}catch{}}),ge.clear();};D("features.reset",Hi,10);D("registries.clear",zi,20);D("registry.default",()=>{Qr=Ce,Gn=ke(Qr);},115);var yn=e=>wo(Y(),e);var Zn=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Zr=(e,t)=>{if(t==="ref"){if(!R())return e;try{return Nr(e)}catch{return e}}if(t==="shallow"){let o=Z(e);if(!R())return o;try{return Nr(o)}catch{return o}}let r=V(e);if(!R())return r;try{return Yo(r)}catch{return r}};var es=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 a=new Set;if(i){for(let v of t)r.push(v),a.add(v);for(let v of s)a.has(v)&&o.push(v);for(let v of r)i.has(v)||o.push(v);}else for(let v of t)r.push(v),a.add(v),o.push(v);t.clear();let c=tn(o),l=new Set(o);for(let v of c)l.has(v)||(o.push(v),l.add(v));let u=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,g=n.chunkDelayMs,f=u===Number.POSITIVE_INFINITY&&g===0;return {names:o,sliceSize:u,chunkDelayMs:g,runInline:f,prioritySet:i}};var eo=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}),to=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),ro=(e,t)=>{e&&(e.metrics=t);};var jt=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},ts=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>tt(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var rs=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)},os=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:c,prioritySet:l}=t,g=e.stores,f=e.subscribers,h=e.metaEntries,v=e.snapshotCache,p=C().defaultSnapshotMode,S=x=>Zn(h[x],p),m=x=>g[x],M=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),k=Jr("beforeFlush"),A=Jr("afterFlush"),O=x=>{k&&Vt("beforeFlush",x,{type:"beforeFlush"});},b=(x,z)=>{A&&Vt("afterFlush",x,{type:"afterFlush",elapsedMs:z});},w=x=>{let z=h[x];if(!z)return null;let N=z.lastCorrelationId??void 0,y=z.lastTraceContext??void 0;return !N&&!y?null:{correlationId:N,traceContext:y}},q=()=>{o();};if(c){for(let x of s){let z=f[x];if(!z||z.size===0)continue;let N=h[x]?.updateCount??0,y=S(x),xe=m(x),X=v[x],H=X&&X.source===xe&&X.mode===y?X.snapshot:(()=>{let U=Zr(xe,y);return v[x]={version:r,snapshot:U,source:xe,mode:y},U})(),ee=eo(h[x]?.metrics);O(x);let me=M(),L=Array.from(z),We=w(x),he=()=>{for(let U of L)try{U(H);}catch(ae){let ue=h[x]?.options?.snapshotSafety??"warn";if(R()&&(y==="ref"||y==="shallow")&&rs(ae)){if(ue==="throw")throw ae;if(ue==="auto-clone")try{let Ae=V(H);d(`Snapshot mutation detected for "${x}". Delivered a cloned snapshot to the subscriber.`);try{U(Ae);}catch(wt){d(`Subscriber for "${x}" threw on cloned snapshot: ${wt?.message??wt}`);}continue}catch{}d(`Snapshot mutation detected for "${x}": ${ae?.message??ae}`);continue}d(`Subscriber for "${x}" threw: ${ae?.message??ae}`);}};We?ut(We,he):he();let ie=M()-me;b(x,ie),to(ee,ie),ro(h[x],ee),(h[x]?.updateCount??N)!==N&&n.pendingNotifications.add(x);}q();return}let T=x=>{let z=[];for(let N of s){if(x&&!x(N))continue;let y=f[N];if(!y||y.size===0)continue;let xe=h[N]?.updateCount??0,X=S(N),H=m(N),ee=v[N],me=ee&&ee.source===H&&ee.mode===X?ee.snapshot:(()=>{let L=Zr(H,X);return v[N]={version:r,snapshot:L,source:H,mode:X},L})();z.push({name:N,snapshot:me,version:xe,subscribers:Array.from(y),subscriberSet:new Set(y),notified:new Set,metrics:eo(h[N]?.metrics),totalMs:0,beforeHooked:false});}return z},K=l?T(x=>l.has(x)):[],Fe=T(x=>!l||!l.has(x)),_e=(x,z)=>{let N=()=>{if(x.length===0){z();return}let y=x.shift();if((h[y.name]?.updateCount??y.version)!==y.version){if(n.pendingNotifications.add(y.name),x.length===0){z();return}jt(N,a);return}let X=()=>{let J=f[y.name];if(!(!J||J.size===0))for(let U of J)y.subscriberSet.has(U)||(y.subscriberSet.add(U),y.subscribers.push(U));};X();let H=y.subscribers;if(H.length===0){if(x.length===0){z();return}jt(N,a);return}y.beforeHooked||(y.beforeHooked=true,O(y.name));let ee=M(),me=0,L=false,We=w(y.name),he=()=>{for(let J=0;J<H.length&&me<i;J+=1){let U=H[J];if(y.notified.has(U))continue;y.notified.add(U);try{U(y.snapshot);}catch(ue){let Qe=h[y.name]?.options?.snapshotSafety??"warn",Ae=S(y.name);if(R()&&(Ae==="ref"||Ae==="shallow")&&rs(ue)){if(Qe==="throw")throw ue;if(Qe==="auto-clone")try{let P=V(y.snapshot);d(`Snapshot mutation detected for "${y.name}". Delivered a cloned snapshot to the subscriber.`);try{U(P);}catch(ve){d(`Subscriber for "${y.name}" threw on cloned snapshot: ${ve?.message??ve}`);}if(y.notified.add(U),me+=1,(h[y.name]?.updateCount??y.version)!==y.version){L=!0,n.pendingNotifications.add(y.name);break}continue}catch{}d(`Snapshot mutation detected for "${y.name}": ${ue?.message??ue}`);continue}d(`Subscriber for "${y.name}" threw: ${ue?.message??ue}`);}if(me+=1,(h[y.name]?.updateCount??y.version)!==y.version){L=true,n.pendingNotifications.add(y.name);break}}};if(We?ut(We,he):he(),y.totalMs+=M()-ee,L){if(x.length===0){z();return}jt(N,a);return}X();let ie=false;for(let J of H)if(!y.notified.has(J)){ie=true;break}if(ie?x.push(y):(to(y.metrics,y.totalMs),ro(h[y.name],y.metrics),b(y.name,y.totalMs)),x.length===0){z();return}jt(N,a);};N();};K.length>0?_e(K,()=>_e(Fe,q)):_e(Fe,q);};var Li=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=es(t);os(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&Sr(e);});},Sr=e=>{ts(e,Li);};var Bi=e=>{let t=F(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&Sr(t);};On(Bi);var ns=e=>{if(typeof e!="function"){d("setStoreBatch requires a synchronous function callback.");return}let t=Object.prototype.toString.call(e);if(t==="[object AsyncFunction]"||t==="[object AsyncGeneratorFunction]"){I("setStoreBatch does not support async functions. Move async work outside and batch only synchronous mutations.");return}if(t==="[object GeneratorFunction]"){I("setStoreBatch does not support generator functions. Move generator logic outside and batch only synchronous mutations.");return}let r=F(),o=typeof window>"u",n=typeof process<"u"?process.env?.NODE_ENV:void 0;if(o&&n==="production"&&r.scope!=="request")throw new Error("setStoreBatch() called in a global SSR context. Use createStoreForRequest() to ensure transaction isolation.");let s=r.notify;s.batchDepth=Math.max(0,s.batchDepth+1),Jo(r);let i;try{let a=tt(r,e);a&&typeof a.then=="function"&&(i=new Error("setStoreBatch does not support promise-returning callbacks. Move async work outside and batch only synchronous mutations."));}catch(a){i=a;}finally{let a=Qo(i,r);s.batchDepth=Math.max(0,s.batchDepth-1),s.batchDepth===0&&s.pendingNotifications.size>0&&Sr(r),a&&!i&&(i=a);}if(i){let a=i instanceof Error?i.message:String(i);I(`setStoreBatch failed: ${a}`);}},Pt=(e,t)=>{let o=F().subscribers;return o[e]||(o[e]=new Set),o[e].add(t),()=>{o[e]?.delete(t),o[e]?.size===0&&delete o[e];}};var qi=()=>{let e=F().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};D("notify.reset",qi,40);var yr=(e,t={},r)=>{if(E()){let c="hydrateStores(...) cannot be called inside setStoreBatch.";return d(c),j(c),{hydrated:[],created:[],failed:[],blocked:{reason:"transaction"}}}let o={hydrated:[],created:[],failed:[]};if(!e||typeof e!="object")return o;let n=F(),s=r??{};if(!(s.allowTrusted===true||s.allowHydration===true||s.allowUntrusted===true||C().allowUntrustedHydration===true))return I("hydrateStores(...) requires explicit trust. Pass { allowTrusted: true } (or { allowHydration: true }) as the third argument or configureStroid({ allowTrustedHydration: true })."),o.blocked={reason:"untrusted"},o;if(typeof s.validate=="function"){let c=false;try{c=!!s.validate(e);}catch(l){let u=`hydrateStores() trust.validate threw: ${l?.message??l}`;if(R())throw new Error(`hydrateStores() trust.validate threw an error. Fix your validator before this becomes a silent production failure.
25
+ Original error: ${l?.message??l}`);let g=t?.default?.onError;if(typeof g=="function")try{g(u);}catch(f){I(`hydrateStores(...) onError threw: ${f?.message??f}`);}if(I(u),typeof s.onValidationError=="function")try{if(!!s.onValidationError(l,e))c=!0;else return o.blocked={reason:"validation-error",cause:l},o}catch(f){return I(`hydrateStores(...) onValidationError threw: ${f?.message??f}`),o.blocked={reason:"validation-error",cause:f},o}else return o.blocked={reason:"validation-error",cause:l},o}if(!c)return I("hydrateStores(...) rejected by trust validation."),o.blocked={reason:"validation-failed"},o}let a=[];return Object.entries(e).forEach(([c,l])=>{if(!kt(c)){o.failed.push({name:c,reason:"invalid-name"});return}if(oe(c,n)){let u=Ur(n,c,l,"hydrate");u.ok?(o.hydrated.push(c),a.push(c)):o.failed.push({name:c,reason:"merge-failed",cause:u.reason,received:l});}else {let u=t;le(c,l,u[c]||u.default||{})?(o.created.push(c),a.push(c)):o.failed.push({name:c,reason:"create-failed",received:l});}}),a.length>0&&_r(a).forEach(l=>{let u=n.computedEntries[l];if(!u)return;let g=u.deps.map(f=>G(f));try{let f=u.compute(...g);if(f&&typeof f.then=="function"){d(`hydrateStores recompute for "${l}" returned a Promise; skipping.`);return}let h=G(l);if(Object.is(f,h))return;$e(l,f);}catch(f){d(`hydrateStores recompute for "${l}" failed: ${f?.message??f}`);}}),o};function ct(e){let t=fe(e);if(!Ue(t))return;let r=F();if(!Ye(t,r))return;if(E()){let n=`deleteStore("${t}") cannot be called inside setStoreBatch. Move deleteStore outside the batch to preserve transaction semantics.`;pe(t,n),j(n);return}Qn().deleteExistingStore(t),Se(t),In(t),qr(t);}function lt(e){let t=fe(e);if(!Ue(t))return {ok:false,reason:"not-found"};let r=F();if(r.metaEntries[t]?.options?.lazy===true&&!!r.initialFactories[t]){let u=`resetStore("${t}") cannot run on a lazy store before it is initialized. Read the store once (getStore) to materialize it before resetting.`;return pe(t,u),E()&&j(u),{ok:false,reason:"lazy-uninitialized"}}if(!Ye(t,r))return {ok:false,reason:"validate"};if(!Object.prototype.hasOwnProperty.call(r.initialStates,t)){let u=`resetStore("${t}") has no initial state to reset to. If this is a lazy store, ensure it has been initialized before calling resetStore.`;return pe(t,u),E()&&j(u),{ok:false,reason:"not-found"}}let n=E()?be(t):{has:false,value:void 0},s=n.has?n.value:r.stores[t],i=typeof performance<"u"&&performance.now?performance.now():Date.now(),a=V(r.initialStates[t]),c=(typeof performance<"u"&&performance.now?performance.now():Date.now())-i,l=r.metaEntries[t]?.metrics;return l&&(l.resetCount=(l.resetCount??0)+1,l.totalResetMs=(l.totalResetMs??0)+c,l.lastResetMs=c),dt(r,{name:t,prev:s,next:a,action:"reset",hookLabel:"onReset",logMessage:`Store "${t}" reset to initial state/value`}),{ok:true}}var se=()=>Q().async;var ss=100,oo=100,Gi=1e3,no=()=>se().fetchRegistry,Je=()=>se().inflight,St=()=>se().requestVersion,Nt=()=>se().cacheMeta,so=()=>se().rateWindowStart,io=()=>se().rateCount;var mr=()=>se().storeCleanups,cs=()=>se().warnedOnce;var It=()=>se().asyncMetrics,Yi=e=>{let t=cs(),r=t.get(e);return r||(r=new Set,t.set(e,r)),r},Xi=(e,t)=>{if(e.has(t)||(e.add(t),e.size<=Gi))return;let r=e.values().next().value;r!==void 0&&e.delete(r);},$t=(e,t,r)=>{let o=Yi(e);o.has(t)||(Xi(o,t),r());},is=null,as=e=>{e&&Array.from(e).forEach(t=>{try{t();}catch{}});},Ji=e=>{let t=mr(),r=t[e];return r||(r=Object.create(null),t[e]=r),r},Qi=(e,t)=>{Object.keys(t).length===0&&delete mr()[e];},Zi=(e,t)=>{Object.keys(e).forEach(r=>{as(e[r]),delete e[r];});},ea=e=>{let t=mr(),r=t[e];r&&(Zi(r),delete t[e]);};var ls=()=>{is||(is=qn("afterStoreDelete",e=>{ea(e),ta(e);}));};var us=(e,t)=>{if(!t)return false;let r=Nt(),o=r[e];return o?o.expiresAt!==null&&o.expiresAt<=Date.now()?(delete r[e],false):Date.now()-o.timestamp<t:false},ta=e=>{let t=no(),r=Nt(),o=Je(),n=St(),s=so(),i=io(),a=cs();delete t[e],a.get("noSignal")?.delete(e),a.get("shape")?.delete(e),a.get("autoCreate")?.delete(e),a.get("mutableResult")?.delete(e);let c=l=>l===e||l.startsWith(`${e}:`);Object.keys(o).forEach(l=>{c(l)&&delete o[l];}),Object.keys(n).forEach(l=>{c(l)&&delete n[l];}),Object.keys(r).forEach(l=>{c(l)&&delete r[l];}),Object.keys(s).forEach(l=>{c(l)&&delete s[l];}),Object.keys(i).forEach(l=>{c(l)&&delete i[l];});},ds=e=>{let t=`${e}:`,r=Nt(),o=St(),n=Object.entries(r).filter(([i,a])=>i!==e&&!i.startsWith(t)?false:a.expiresAt!==null&&a.expiresAt<=Date.now()?(delete r[i],false):true).sort((i,a)=>i[1].timestamp-a[1].timestamp);if(n.length<=ss)return;let s=n.length-ss;n.slice(0,s).forEach(([i])=>{delete r[i],delete o[i];});},hr=e=>{let t=`${e}:`,r=Je(),o=0;return Object.keys(r).forEach(n=>{(n===e||n.startsWith(t))&&(o+=1);}),o},fs=(e,t,r="store")=>{ls();let o=Ji(e),n=o[r];n||(n=new Set,o[r]=n),n.add(t);},ps=(e,t,r)=>{let n=mr()[e];if(!n)return;let s=i=>{let a=n[i];a&&(a.delete(t),a.size===0&&delete n[i]);};Object.keys(n).forEach(s),Qi(e,n);},gs=e=>{ls();};var Ss=10,ra=10,ao=3e4,oa=8,ms=(e,t)=>new Promise(r=>{if(t?.aborted){r();return}let o=setTimeout(()=>{t?.removeEventListener("abort",n),r();},e),n=()=>{clearTimeout(o),t?.removeEventListener("abort",n),r();};t?.addEventListener("abort",n,{once:true});}),ys=(e,t,r,o)=>Number.isFinite(r)?r:(d(`fetchStore("${e}") received non-finite ${t}; using ${o}.`),o),hs=(e,t,r,o)=>{let n=Number.isFinite(t)?t:t>0?Ss:0,s=Math.min(Ss,Math.max(0,Math.trunc(n)));Number.isFinite(t)||d(`fetchStore("${e}") received non-finite retry; using ${s}.`);let i=Math.min(ao,Math.max(ra,ys(e,"retryDelay",r,400))),a=Math.min(oa,Math.max(1,ys(e,"retryBackoff",o,1.7)));return s!==t&&d(`fetchStore("${e}") clamped retry attempts to ${s}.`),i!==r&&d(`fetchStore("${e}") clamped retryDelay to ${i}ms.`),a!==o&&d(`fetchStore("${e}") clamped retryBackoff to ${a}.`),{retry:s,retryDelay:i,retryBackoff:a}};var bs=(e,t)=>!t||t==="none"||e===null||typeof e!="object"?e:t==="shallow"?Z(e):V(e);var yt=(e,t,r,o)=>{if(typeof r=="function")try{r(o);}catch(n){d(`fetchStore("${e}") ${t} callback failed: ${n?.message??n}`);}},ye=(e,t,r)=>C().strictAsyncUsageErrors?na(e,t,r):(yt(e,"onError",r,t),R()?($(t),null):(B(t),null)),na=(e,t,r)=>{throw yt(e,"onError",r,t),R()?$(t):B(t),new Error(t)};var _t=(e,t)=>(St()[e]??0)===t,ws=e=>{let t=St(),r=(t[e]??0)+1;return t[e]=r,r},xs=(e,t)=>{let r=St();r[e]===t&&delete r[e];},vs=(e,t)=>{let r=Je();r[e]=t;},Rs=e=>{let t=Je();delete t[e];},Cs=e=>!!Je()[e],ks=(e,t,r,o)=>{let n=Je()[t];if(n)return It().dedupes+=1,r&&n.transform&&n.transform!==r?(ye(e,`fetchStore("${e}") cannot dedupe callers that use different transform functions for cacheSlot "${t}".`,o),null):!r||n.transform===r?n.promise:n.raw.then(s=>r(s))};var mt=1e3,co=100,Ms=(e,t)=>{t-e.ratePruneState.lastAt<mt||(e.ratePruneState.lastAt=t,Object.keys(e.rateWindowStart).forEach(r=>{t-(e.rateWindowStart[r]??0)>mt&&(delete e.rateWindowStart[r],delete e.rateCount[r]);}));},Ts=e=>{Ms(se(),e);},Es=(e=mt)=>{let t=se();t.ratePruneTimer||typeof setTimeout=="function"&&(t.ratePruneTimer=setTimeout(()=>{t.ratePruneTimer=null,Ms(t,Date.now());},e));},Fs=(e,t)=>{let r=so(),o=io(),n=r[e],s=o[e]??0;return n!==void 0&&t-n<mt?s>=co?true:(o[e]=s+1,false):(r[e]=t,o[e]=1,false)};var As=e=>{let t={},r=(e.method??"GET").toUpperCase(),o=e.body!==void 0&&e.body!==null;return e.method&&(t.method=r),e.headers?t.headers=e.headers:(o||!["GET","HEAD","DELETE"].includes(r))&&(t.headers={"Content-Type":"application/json"}),o&&(t.body=typeof e.body=="string"?e.body:JSON.stringify(e.body)),e.signal&&(t.signal=e.signal),t},Os=async(e,t)=>{let r=t??"auto";if(r==="json")return e.json();if(r==="text")return e.text();if(r==="arrayBuffer")return e.arrayBuffer();if(r==="blob")return e.blob();if(r==="formData")return e.formData();let o=e.headers.get("content-type")||"";return o.includes("application/json")||o.includes("+json")?e.json():o.startsWith("text/")||o.includes("xml")||o.includes("html")?e.text():o.includes("form-data")?e.formData():e.arrayBuffer()};var sa=e=>{if(!e||typeof e!="object")return false;let t=e;return "data"in t&&"loading"in t&&"error"in t&&"status"in t},ia=(e,t,r,o,n)=>{if(!ne(e))return;let s=o.stateAdapter;if(s){try{let i=G({name:e}),a=c=>{ft(t,c,void 0,n);};ut(n,()=>{s({name:e,prev:i,next:r,set:a});});}catch(i){d(`fetchStore("${e}") stateAdapter failed: ${i?.message??i}`);}return}ut(n,()=>{ft(t,r,void 0,n);});},ht=(e,t,r,o)=>(d(`fetchStore("${e}") aborted`),_t(t,r)&&ne(e)&&o({loading:false,error:"aborted",status:"aborted",revalidating:false}),null);async function bt(e,t,r={}){let o=fe(e);if(!o||typeof o!="string"){$("fetchStore requires a store name as first argument");return}let n={name:o};if(!t){$(`fetchStore("${o}") requires a URL, Promise, or Promise factory as second argument`);return}let{transform:s,onSuccess:i,onError:a,stateAdapter:c,method:l,headers:u,body:g,ttl:f,staleWhileRevalidate:h=false,dedupe:v=true,retry:p=0,retryDelay:S=400,retryBackoff:m=1.7,signal:M,cacheKey:k,responseType:A="auto"}=r,O=Nt(),b=no(),w=It(),q=(()=>{let P=r.correlationId,te=r.traceContext;return P||te?{correlationId:P,traceContext:te}:C().autoCorrelationIds?{correlationId:`stroid-${o}-${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,traceContext:te}:null})();!M&&R()&&$t("noSignal",o,()=>{d(`fetchStore("${o}") called without an AbortSignal. Provide "signal" to enable cancellation (recommended).`);});let T=k?`${o}:${k}`:o,K=P=>ia(o,n,q?{...P,correlationId:q.correlationId,traceContext:q.traceContext}:P,r,q),Fe=typeof t!="string"&&typeof t!="function"&&typeof t?.then=="function",_e=hs(o,p,S,m),x=false,z=Fe&&p>0,N=typeof window>"u"&&(typeof process<"u"?process.env?.NODE_ENV:void 0)==="production",y=r.autoCreate??C().asyncAutoCreate,xe=r.cloneResult??C().asyncCloneResult;if(c&&!ne(o))return ye(o,`fetchStore("${o}") with stateAdapter requires an existing backing store.
26
+ Call createStore("${o}", ...) first or omit stateAdapter to use the default AsyncState shape.`,a);if(!ne(o)&&N)return ye(o,`fetchStore("${o}") cannot create a backing store on the server in production.
27
+ Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,a);if(!ne(o)){if(!y)return ye(o,`fetchStore("${o}") requires an existing backing store when autoCreate is disabled.
28
+ Call createStore("${o}", ...) first or enable autoCreate.`,a);if(R()&&$t("autoCreate",o,()=>{let P=`fetchStore("${o}") auto-created its backing store.
29
+ Call createStore("${o}", ...) first to avoid typos creating phantom stores.`;re(a,`fetchStore.onError(${o})`,P),d(P);}),le(o,{data:null,loading:false,error:null,status:"idle"}),!ne(o))return ye(o,`fetchStore("${o}") could not initialize its backing store.
30
+ On the server in production, use createStoreForRequest(...) inside the request scope or create the store with { allowSSRGlobalStore: true } before calling fetchStore.`,a)}if(!c){let P=G({name:o});if(P&&!sa(P))return $t("shape",o,()=>{}),ye(o,`fetchStore("${o}") cannot write AsyncState into an existing non-async store. Provide a stateAdapter or create the store with the async shape to avoid overwriting fields.`,a)}gs();let X=null,H=false,ee=()=>O[T]?.data??null;if(us(T,f)){if(w.cacheHits+=1,X=ee(),K({data:X,loading:h,error:null,status:"success",cached:true,revalidating:h}),!h)return X;H=true;}else w.cacheMisses+=1;if(v){let P=ks(o,T,s,a);if(P!==void 0)return P}let me=Date.now();if(Ts(me),Es(),Fs(T,me))return ye(o,`fetchStore("${o}") rate limited: ${co} requests per ${mt}ms window for store "${o}".`,a);if(!Cs(T)&&hr(o)>=oo)return ye(o,`fetchStore("${o}") exceeded ${oo} concurrent request slots. Reuse cacheKey values, wait for pending requests, or delete the store to clear async state.`,a);let L=ws(T);H||K({loading:true,error:null,status:"loading",cached:false,revalidating:false}),w.requests+=1;let We=Date.now(),he=!M&&typeof AbortController<"u"?new AbortController:null,ie=M||he?.signal,J=he?()=>{he.signal.aborted||he.abort();}:null;J&&fs(o,J);let U=async()=>{let P=0,te=_e.retryDelay;for(;;){if(ie?.aborted)return ht(o,T,L,K);let ve=typeof t=="function"?t():t,lo=Fe||typeof ve!="string"&&typeof ve?.then=="function",uo=lo?{..._e,retry:0}:_e;lo&&(p>0||z)&&!x&&(d(`fetchStore("${o}") ignores retry settings for direct Promise inputs; pass a URL string or factory to use retries.`),x=true);try{let Oe;if(typeof ve=="string"){let Ht=As({method:l,headers:u,body:g,signal:ie,...r}),Lt=await fetch(ve,Ht);if(!Lt.ok)throw new Error(`HTTP ${Lt.status}: ${Lt.statusText}`);Oe=await Os(Lt,A);}else if(typeof ve.then=="function")Oe=await ve;else return $(`fetchStore("${o}") - second argument must be a URL string, Promise, or Promise factory.
31
31
  Examples:
32
32
  fetchStore("users", "https://api.example.com/users")
33
- fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(ae?.aborted)return yt(o,E,H,L);let Je=s?s(Fe):Fe;if(Je&&typeof Je.then=="function"){let Ht=`fetchStore("${o}") transform must be synchronous. Return the transformed value directly instead of a Promise.`;return _t(E,H)&&L({data:Q?U():null,loading:!1,error:Ht,status:"error",cached:Q,revalidating:!1}),ye(o,Ht,a)}N==="none"&&R()&&Je&&typeof Je=="object"&&$t("mutableResult",o,()=>{d(`fetchStore("${o}") received a mutable object while asyncCloneResult is "none".
33
+ fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(ie?.aborted)return ht(o,T,L,K);let Ze=s?s(Oe):Oe;if(Ze&&typeof Ze.then=="function"){let Ht=`fetchStore("${o}") transform must be synchronous. Return the transformed value directly instead of a Promise.`;return _t(T,L)&&K({data:H?ee():null,loading:!1,error:Ht,status:"error",cached:H,revalidating:!1}),ye(o,Ht,a)}xe==="none"&&R()&&Ze&&typeof Ze=="object"&&$t("mutableResult",o,()=>{d(`fetchStore("${o}") received a mutable object while asyncCloneResult is "none".
34
34
  Async data is stored by reference; mutations will affect cache and subscribers.
35
- Set cloneResult: "deep" (per call) or configureStroid({ asyncCloneResult: "deep" }).`);});let Ae=gs(Je,N);if(ae?.aborted)return yt(o,E,H,L);if(!_t(E,H))return null;D[E]={timestamp:Date.now(),expiresAt:p?Date.now()+p:null,data:Ae},is(o),L({data:Ae,loading:!1,error:null,status:"success",cached:!1,revalidating:!1}),gt(o,"onSuccess",i,Ae);let co=Date.now()-ve;return v.lastMs=co,v.avgMs=(v.avgMs*(v.requests-1)+co)/v.requests,{raw:Fe,transformed:Ae}}catch(Fe){if(O+=1,Fe?.name==="AbortError")return yt(o,E,H,L);if(O<=vt.retry){if(ae?.aborted||(await fs(K,ae),ae?.aborted))return yt(o,E,H,L);K=Math.min(io,K*vt.retryBackoff);continue}if(!_t(E,H))return null;let Ae=Fe?.message||"Something went wrong";return L({data:Q?U():null,loading:false,error:Ae,status:"error",cached:Q,revalidating:false}),gt(o,"onError",a,Ae),v.failures+=1,d(`fetchStore("${o}") failed: ${Ae}`),null}}},G=null,q=new Promise((O,K)=>{T||(G=setTimeout(()=>{G=null,K(new Error("Timeout: async request hung for 60 seconds without an AbortSignal"));},6e4));}),he=Promise.race([Ie().finally(()=>{G&&(clearTimeout(G),G=null);}),q]).catch(O=>{let K=O?.message||"Request timed out";return L({data:Q?U():null,loading:false,error:K,status:"error",cached:Q,revalidating:false}),gt(o,"onError",a,K),v.failures+=1,d(`fetchStore("${o}") failed: ${K}`),null}),le=he.then(O=>O?.transformed??null).finally(()=>{hs(E),ys(E,H),me&&cs(o,me);}),wt=he.then(O=>O?.raw);return ms(E,{promise:le,raw:wt,transform:s}),typeof t=="function"?b[o]={kind:"factory",factory:t,options:{...r,cacheKey:C}}:typeof t=="string"?b[o]={kind:"url",url:t,options:{...r,cacheKey:C}}:delete b[o],le}var hr=()=>({...It()});var zt=()=>Z(ke(Ce)),Wt=e=>{let t=zt();return Oe(t,e)?true:(Ct(e,Object.keys(t.stores)),false)},ta=(e,t)=>{return true;},Ts=e=>{let t=zt();return Object.keys(t.stores).filter(r=>ta())},ra=e=>{if(!Wt(e))return null;let t=zt().metaEntries[e],r=ee(t);r.metrics=ee(t.metrics);let o=ee(t.options),n=o;return n.persist&&typeof n.persist=="object"&&(n.persist=ee(n.persist)),n.sync&&typeof n.sync=="object"&&(n.sync=ee(n.sync)),n.devtools&&typeof n.devtools=="object"&&(n.devtools=ee(n.devtools)),n.lifecycle&&typeof n.lifecycle=="object"&&(n.lifecycle=ee(n.lifecycle)),r.options=o,r};var oa=e=>{let t=zt().metaEntries[e];return t?.metrics?{...t.metrics}:null},na=e=>Wt(e)?qn[e]?.size??0:0,sa=e=>Wt(e)?mr(e):0,Es=(e={})=>{let t=e.unreadThresholdMs??6e4,r=Date.now();return Ts().map(o=>{let n=zt().metaEntries[o],s=n?.createdAt?new Date(n.createdAt).getTime():r,i=n?.lastReadAtMs??null,a=Math.max(0,r-s),c;return (n?.readCount??0)===0&&(n?.updateCount??0)===0?c="cold":(n?.readCount??0)===0?c="write-only":i&&r-i>t?c="stale":c="active",{name:o,createdAt:n?.createdAt??new Date(s).toISOString(),lastReadAt:n?.lastReadAt??null,updateCount:n?.updateCount??0,readCount:n?.readCount??0,subscriberCount:na(o),ageMs:a,verdict:c}}).filter(o=>o.verdict==="cold"||o.verdict==="stale"||e.includeWriteOnly&&o.verdict==="write-only")},Fs=e=>{if(e){if(!Wt(e))return null;let r=ra(e);return {name:e,meta:r,metrics:oa(e),async:{inflight:sa(e),lastCorrelationId:r?.lastCorrelationId??null,traceContext:r?.lastTraceContext??null},persist:{queueDepth:ia(e)}}}let t=Ts().map(r=>Fs(r));return {stores:t,async:hr(),registry:{totalStores:t.length,coldStores:Es({})}}},ia=e=>{if(!Wt(e))return 0;let t=or("persist");return t?.getPersistQueueDepth?t.getPersistQueueDepth(e)??0:0};var Os={};Ps(Os,{createReactQueryFetcher:()=>ca,createSwrFetcher:()=>ua,reactQueryKey:()=>As,swrKey:()=>la});var aa=e=>typeof e=="string"?e:e.name,As=(e,t)=>{let r=aa(e);return t!==void 0?["stroid",r,t]:["stroid",r]},ca=(e,t,r={})=>async()=>typeof e=="string"?mt(e,t,r):mt(e,t,r),la=As,ua=(e,t,r={})=>async()=>typeof e=="string"?mt(e,t,r):mt(e,t,r);export{Co as configureStroid,Fi as createComputed,ce as createStore,lr as createStoreStrict,Yr as deleteComputed,it as deleteStore,Es as findColdStores,hr as getAsyncMetrics,On as getMetrics,Y as getStore,Fs as getStoreHealth,ne as hasStore,Sr as hydrateStores,Ai as invalidateComputed,Oi as isComputedStore,Dn as namespace,Os as queryIntegrations,at as resetStore,Ge as setStore,Zn as setStoreBatch,je as store};//# sourceMappingURL=index.js.map
35
+ Set cloneResult: "deep" (per call) or configureStroid({ asyncCloneResult: "deep" }).`);});let De=bs(Ze,xe);if(ie?.aborted)return ht(o,T,L,K);if(!_t(T,L))return null;O[T]={timestamp:Date.now(),expiresAt:f?Date.now()+f:null,data:De},ds(o),K({data:De,loading:!1,error:null,status:"success",cached:!1,revalidating:!1}),yt(o,"onSuccess",i,De);let fo=Date.now()-We;return w.lastMs=fo,w.avgMs=(w.avgMs*(w.requests-1)+fo)/w.requests,{raw:Oe,transformed:De}}catch(Oe){if(P+=1,Oe?.name==="AbortError")return ht(o,T,L,K);if(P<=uo.retry){if(ie?.aborted||(await ms(te,ie),ie?.aborted))return ht(o,T,L,K);te=Math.min(ao,te*uo.retryBackoff);continue}if(!_t(T,L))return null;let De=Oe?.message||"Something went wrong";return K({data:H?ee():null,loading:false,error:De,status:"error",cached:H,revalidating:false}),yt(o,"onError",a,De),w.failures+=1,d(`fetchStore("${o}") failed: ${De}`),null}}},ae=null,ue=new Promise((P,te)=>{M||(ae=setTimeout(()=>{ae=null,te(new Error("Timeout: async request hung for 60 seconds without an AbortSignal"));},6e4));}),Qe=Promise.race([U().finally(()=>{ae&&(clearTimeout(ae),ae=null);}),ue]).catch(P=>{let te=P?.message||"Request timed out";return K({data:H?ee():null,loading:false,error:te,status:"error",cached:H,revalidating:false}),yt(o,"onError",a,te),w.failures+=1,d(`fetchStore("${o}") failed: ${te}`),null}),Ae=Qe.then(P=>P?.transformed??null).finally(()=>{Rs(T),xs(T,L),J&&ps(o,J);}),wt=Qe.then(P=>P?.raw);return vs(T,{promise:Ae,raw:wt,transform:s}),typeof t=="function"?b[o]={kind:"factory",factory:t,options:{...r,cacheKey:k}}:typeof t=="string"?b[o]={kind:"url",url:t,options:{...r,cacheKey:k}}:delete b[o],Ae}var br=()=>({...It()});var Wt=()=>Q(ke(Ce)),zt=e=>{let t=Wt();return Me(t,e)?true:(Rt(e,Object.keys(t.stores)),false)},aa=(e,t)=>{return true;},Ds=e=>{let t=Wt();return Object.keys(t.stores).filter(r=>aa())},ca=e=>{if(!zt(e))return null;let t=Wt().metaEntries[e],r=Z(t);r.metrics=Z(t.metrics);let o=Z(t.options),n=o;return n.persist&&typeof n.persist=="object"&&(n.persist=Z(n.persist)),n.sync&&typeof n.sync=="object"&&(n.sync=Z(n.sync)),n.devtools&&typeof n.devtools=="object"&&(n.devtools=Z(n.devtools)),n.lifecycle&&typeof n.lifecycle=="object"&&(n.lifecycle=Z(n.lifecycle)),r.options=o,r};var la=e=>{let t=Wt().metaEntries[e];return t?.metrics?{...t.metrics}:null},ua=e=>zt(e)?Xn[e]?.size??0:0,da=e=>zt(e)?hr(e):0,Ps=(e={})=>{let t=e.unreadThresholdMs??6e4,r=Date.now();return Ds().map(o=>{let n=Wt().metaEntries[o],s=n?.createdAt?new Date(n.createdAt).getTime():r,i=n?.lastReadAtMs??null,a=Math.max(0,r-s),c;return (n?.readCount??0)===0&&(n?.updateCount??0)===0?c="cold":(n?.readCount??0)===0?c="write-only":i&&r-i>t?c="stale":c="active",{name:o,createdAt:n?.createdAt??new Date(s).toISOString(),lastReadAt:n?.lastReadAt??null,updateCount:n?.updateCount??0,readCount:n?.readCount??0,subscriberCount:ua(o),ageMs:a,verdict:c}}).filter(o=>o.verdict==="cold"||o.verdict==="stale"||e.includeWriteOnly&&o.verdict==="write-only")},Vs=e=>{if(e){if(!zt(e))return null;let r=ca(e);return {name:e,meta:r,metrics:la(e),async:{inflight:da(e),lastCorrelationId:r?.lastCorrelationId??null,traceContext:r?.lastTraceContext??null},persist:{queueDepth:fa(e)}}}let t=Ds().map(r=>Vs(r));return {stores:t,async:br(),registry:{totalStores:t.length,coldStores:Ps({})}}},fa=e=>{if(!zt(e))return 0;let t=nr("persist");return t?.getPersistQueueDepth?t.getPersistQueueDepth(e)??0:0};var Ns={};$s(Ns,{createReactQueryFetcher:()=>ga,createSwrFetcher:()=>ya,reactQueryKey:()=>js,swrKey:()=>Sa});var pa=e=>typeof e=="string"?e:e.name,js=(e,t)=>{let r=pa(e);return t!==void 0?["stroid",r,t]:["stroid",r]},ga=(e,t,r={})=>async()=>typeof e=="string"?bt(e,t,r):bt(e,t,r),Sa=js,ya=(e,t,r={})=>async()=>typeof e=="string"?bt(e,t,r):bt(e,t,r);export{To as configureStroid,ji as createComputed,le as createStore,ur as createStoreStrict,Xr as deleteComputed,ct as deleteStore,Ps as findColdStores,br as getAsyncMetrics,Vn as getMetrics,G as getStore,Vs as getStoreHealth,ne as hasStore,yr as hydrateStores,Ni as invalidateComputed,Ii as isComputedStore,jn as namespace,Ns as queryIntegrations,lt as resetStore,Xe as setStore,ns as setStoreBatch,Ie as store};//# sourceMappingURL=index.js.map
36
36
  //# sourceMappingURL=index.js.map