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/server.js CHANGED
@@ -1,13 +1,13 @@
1
- import {AsyncLocalStorage}from'async_hooks';var Lo=new Map,v=(e,t,r=0)=>{!e||typeof t!="function"||Lo.set(e,{name:e,order:r,fn:t});};var ht=new Map;var qe=e=>ht.has(e),Be=e=>ht.get(e),fe=()=>Array.from(ht.keys());var ur=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),lr=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,warnedOnce:ur(),storeCleanups:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}}),dr=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(o=>{try{o();}catch{}});});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.storeCleanups).forEach(t=>delete e.storeCleanups[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),ur().forEach((t,r)=>{e.warnedOnce.set(r,t);}),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var bt=new Map,pr=new WeakSet,wt=e=>{pr.has(e)||(pr.add(e),fe().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Be(t);r&&e.featureRuntimes.set(t,r());}}));},Bo=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,fr,vt=e=>(fr||Bo||e).replace(/\.ts(\?|$)/,".js$1"),ge=vt(new URL("../../store.js",import.meta.url).href);var Uo=()=>{fr=void 0,bt.clear();};v("registry.scope-override",Uo,110);var Ko=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Go=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;},gr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),kt=(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:gr(),async:lr(),notify:Ko(),lifecycleListener:null};return wt(t),t},Se=e=>{let t=vt(e),r=bt.get(t);if(r)return r;let o=kt();return bt.set(t,o),o},ye=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),Sr=(e,t)=>e.deletingStores.has(t),yr=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,Go(e.notify),dr(e.async),e.lifecycleListener=null;};var Ue=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var mr=null,hr=e=>{mr=e;},Te=()=>mr?.get()||null,Rt=null,J=[],br={run:(e,t)=>{J.push(e);try{return t()}finally{J.pop();}},get:()=>J.length>0?J[J.length-1]:null,enterWith:e=>{if(J.length>0){J[J.length-1]=e;return}J.push(e);}},wr=e=>{Rt=e;},Ke=(e,t)=>(Rt??br).run(e,t),X=e=>(Rt??br).get()||e||Se(ge);var Yo={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}`));}},vr={logSink:Yo,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},Ct=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}),xt=new WeakMap,kr=Ct(vr),Jo=e=>{let t=xt.get(e);return t||(t=Ct(kr),xt.set(e,t)),t};var k=()=>Jo(X());var en=()=>{xt=new WeakMap,kr=Ct(vr);};v("config.reset",en,90);var Rr=()=>k().namespace;var tn=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,rn=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,xr=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,on="production",nn=tn??rn??on,Fe=typeof xr=="boolean"?xr:nn!=="production",w=()=>Fe,Mt=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},sn=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},an=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},se=(e,t)=>{if((k().logSink.critical??sn)(e,t),k().assertRuntime)throw new Error(e)},f=(e,t)=>{if(!Fe)return;if((k().logSink.warn??Mt)(e,t),k().assertRuntime)throw new Error(e)},V=(e,t)=>{if((k().logSink.warn??Mt)(e,t),k().assertRuntime)throw new Error(e)},W=(e,t)=>{if(Fe&&(k().logSink.warn??Mt)(e,t),se(e,t),k().assertRuntime)throw new Error(e)},L=(e,t)=>{if(!Fe)return;(k().logSink.log??an)(e,t);},Cr=()=>`Functions cannot be stored in stroid.
2
- Store data only - handle functions outside the store.`,Mr=()=>`Map/Set detected. stroid converts these to plain objects.
3
- Use arrays or plain objects for best results.`,Er=()=>`Date object detected. stroid stores it as ISO string.
4
- Use new Date(value) to convert back when reading.`,Tr=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Fr=()=>"Map detected; converting to plain object.",Or=()=>"Set detected; converting to array.",Nr=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Pr=e=>`Store name "${e}" contains spaces.
5
- Use camelCase or kebab-case: "userName" or "user-name"`,Ir=e=>`Store name "${e}" is not allowed.
6
- Reserved names: "__proto__", "constructor", "prototype".`,cn=128,un=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=cn,ln=(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]},Et=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||un(n,s)&&ln(n,s)<=2});if(r){f(`Store "${e}" not found. Did you mean "${r}"?`);return}W(`Store "${e}" not found.
1
+ import {AsyncLocalStorage}from'async_hooks';var Go=new Map,x=(e,t,r=0)=>{!e||typeof t!="function"||Go.set(e,{name:e,order:r,fn:t});};var wt=new Map;var Ke=e=>wt.has(e),Ge=e=>wt.get(e),Se=()=>Array.from(wt.keys());var dr=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),pr=()=>({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:dr(),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}}),fr=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(),dr().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 vt=new Map,gr=new WeakSet,xt=e=>{gr.has(e)||(gr.add(e),Se().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Ge(t);r&&e.featureRuntimes.set(t,r());}}));},Jo=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,Sr,Rt=e=>(Sr||Jo||e).replace(/\.ts(\?|$)/,".js$1"),ye=Rt("stroid:default-registry");var Xo=()=>{Sr=void 0,vt.clear();};x("registry.scope-override",Xo,110);var Qo=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Zo=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},yr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),kt=(e="default")=>{let t={scope:e,stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:yr(),async:pr(),notify:Qo(),lifecycleListener:null};return xt(t),t},me=e=>{let t=Rt(e),r=vt.get(t);if(r)return r;let o=kt();return vt.set(t,o),o},ie=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),mr=(e,t)=>e.deletingStores.has(t),hr=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,Zo(e.notify),fr(e.async),e.lifecycleListener=null;};var Ye=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var br=null,wr=e=>{br=e;},Oe=()=>br?.get()||null,Ct=null,J=[],vr={run:(e,t)=>{J.push(e);try{return t()}finally{J.pop();}},get:()=>J.length>0?J[J.length-1]:null,enterWith:e=>{if(J.length>0){J[J.length-1]=e;return}J.push(e);}},xr=e=>{Ct=e;},Je=(e,t)=>(Ct??vr).run(e,t),X=e=>(Ct??vr).get()||e||me(ye);var en={log:(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},warn:(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},critical:(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));}},Rr={logSink:en,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",autoCorrelationIds:false,acknowledgeLooseTypes:false,pathCacheSize:500,defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0,selectorCloneFrozen:true},Et=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}),Mt=new WeakMap,kr=Et(Rr),tn=e=>{let t=Mt.get(e);return t||(t=Et(kr),Mt.set(e,t)),t};var k=()=>tn(X());var sn=()=>{Mt=new WeakMap,kr=Et(Rr);};x("config.reset",sn,90);var Cr=()=>k().namespace;var an=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,cn=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,Mr=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,un="production",ln=an??cn??un,Ve=typeof Mr=="boolean"?Mr:ln!=="production",v=()=>Ve,Tt=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},dn=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},pn=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},ae=(e,t)=>{if((k().logSink.critical??dn)(e,t),k().assertRuntime)throw new Error(e)},g=(e,t)=>{if(!Ve)return;if((k().logSink.warn??Tt)(e,t),k().assertRuntime)throw new Error(e)},T=(e,t)=>{if((k().logSink.warn??Tt)(e,t),k().assertRuntime)throw new Error(e)},L=(e,t)=>{if(Ve&&(k().logSink.warn??Tt)(e,t),ae(e,t),k().assertRuntime)throw new Error(e)},_=(e,t)=>{if(!Ve)return;(k().logSink.log??pn)(e,t);},Er=()=>`Functions cannot be stored in stroid.
2
+ Store data only - handle functions outside the store.`,Tr=()=>`Map/Set detected. stroid converts these to plain objects.
3
+ Use arrays or plain objects for best results.`,Fr=()=>`Date object detected. stroid stores it as ISO string.
4
+ Use new Date(value) to convert back when reading.`,Or=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Vr=()=>"Map detected; converting to plain object.",Dr=()=>"Set detected; converting to array.",Ir=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,$r=e=>`Store name "${e}" contains spaces.
5
+ Use camelCase or kebab-case: "userName" or "user-name"`,zr=e=>`Store name "${e}" is not allowed.
6
+ Reserved names: "__proto__", "constructor", "prototype".`,fn=128,gn=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=fn,Sn=(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]},Ft=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||gn(n,s)&&Sn(n,s)<=2});if(r){g(`Store "${e}" not found. Did you mean "${r}"?`);return}L(`Store "${e}" not found.
7
7
  Available stores: [${t.join(", ")}]
8
- Call createStore("${e}", data) first.`);};var ee=new Set(["__proto__","constructor","prototype"]),Ft=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let n=r.error,s=n?.details?.[0]?.message||n?.message||r.message||e.errors;if(s)return {ok:!1,error:s};if(n)return {ok:!1,error:n}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var Ve=e=>e===null?"null":Array.isArray(e)?"array":e instanceof Map?"map":e instanceof Set?"set":e instanceof Date?"date":typeof e=="function"?"function":typeof e,$r=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},Ot=e=>{let t=Ve(e);return t==="function"?(W(Cr()),false):t==="map"||t==="set"?(f(Mr()),true):(t==="date"&&f(Er()),true)},Tt=(e,t)=>{let r=$r(e);if(r)throw new Error(`${r} values are not supported`);let o=Ve(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return true}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date"||o==="map"||o==="set")return false;if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n=Object.keys(e);for(let s of n){let i=Number(s);if(!Number.isInteger(i))return false}for(let s=0;s<e.length;s+=1)if(s in e&&!Tt(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||ee.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Tt(i.value,t))return false}return true}return true},Vt=e=>Tt(e,new WeakSet),Oe=(e,t)=>{let r=$r(e);if(r)throw new Error(`${r} values are not supported`);let o=Ve(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date")return w()&&f(Tr()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),w()&&f(Fr());let n={};for(let[s,i]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");n[String(s)]=Oe(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),w()&&f(Or()),Array.from(e,n=>Oe(n,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n={},s=Object.getOwnPropertyDescriptors(e);for(let[i,c]of Object.entries(s))if(c.enumerable&&!ee.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=Oe(c.value,t);}return n}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(n=>Oe(n,t))}return e},ie=e=>Oe(e,new WeakSet),De=e=>typeof e!="string"||e.trim()===""?(W(Nr(e)),false):ee.has(e)?(W(Ir(e)),false):e.includes(" ")?(W(Pr(e)),false):true;var Dt=null,dn=()=>{if(Dt)return Dt;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 Dt=t,t},_r=e=>{let t=dn(),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},pn=2166136261,fn=2654435761,gn=1e5,te=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},ae=(e,t)=>{te(e,t.length);for(let r=0;r<t.length;r++)te(e,t.charCodeAt(r));},T=(e,t)=>{ae(e,t);},zr=(e,t)=>{if(Number.isNaN(t)){T(e,"NaN");return}if(!Number.isFinite(t)){T(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){T(e,"-0");return}let r=t|0;if(t===r){T(e,"int"),te(e,r);return}T(e,"num"),ae(e,String(t));},me=(e,t)=>{if(e.nodes++>gn){T(e,"[max]");return}if(t===null){T(e,"null");return}let r=typeof t;if(r==="string"){T(e,"string"),ae(e,t);return}if(r==="number"){T(e,"number"),zr(e,t);return}if(r==="boolean"){T(e,t?"true":"false");return}if(r==="undefined"){T(e,"undefined");return}if(r==="bigint"){T(e,"bigint"),ae(e,t.toString());return}if(r==="symbol"){T(e,"symbol");let a=t;ae(e,Symbol.keyFor(a)??a.description??String(a));return}if(r==="function"){T(e,"function"),ae(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){T(e,"ref"),te(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){T(e,"array"),te(e,o.length);for(let a=0;a<o.length;a++)Object.prototype.hasOwnProperty.call(o,a)?me(e,o[a]):T(e,"hole");return}if(o instanceof Date){T(e,"date"),zr(e,o.getTime());return}if(o instanceof Map){T(e,"map"),te(e,o.size),o.forEach((a,u)=>{me(e,u),me(e,a);});return}if(o instanceof Set){T(e,"set"),te(e,o.size),o.forEach(a=>{me(e,a);});return}T(e,"object");let i=Object.getOwnPropertyDescriptors(o),c=[];Object.entries(i).forEach(([a,u])=>{u?.enumerable&&(ee.has(a)||"get"in u||"set"in u||c.push([a,u]));}),te(e,c.length);for(let[a,u]of c)ae(e,a),me(e,u.value);},je=e=>{if(typeof e=="string")return _r(JSON.stringify(e));let t={h1:pn,h2:fn,seen:new WeakMap,nextId:1,nodes:0};me(t,e);let r=t.h1>>>0,o=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,o^=o>>>16,o=Math.imul(o,668265261),o^=o>>>15,o=Math.imul(o,374761393),o^=o>>>16,(r&2097151)*4294967296+(o>>>0)};var Sn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Ae=e=>{if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map)return new Map(e);if(e instanceof Set)return new Set(e);if(Array.isArray(e))return e.slice();let t={},r=Object.getOwnPropertyDescriptors(e);return Object.entries(r).forEach(([o,n])=>{n.enumerable&&(ee.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},jt=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},yn=e=>jt(e)===null,mn=e=>{let t=jt(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},ce=(e,t=new WeakMap)=>{if(mn(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(ce(i,t),ce(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(ce(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=ce(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||ee.has(n)||"get"in s||"set"in s||(r[n]=ce(s.value,t));}),r},R=e=>{if(Sn)try{return structuredClone(e)}catch(t){if(!yn(e)){let r=jt(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return f(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),ce(e)}return ce(e)};var At=(e,t)=>{try{let r=R(e);return t(r),r}catch(r){throw new Error(`produceClone failed (possible circular reference or unserializable data): ${r?.message??r}`)}};var Wr=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")},It=e=>(Wr(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Lr=e=>{if(!Wr(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 re=null,qr=e=>{if(!e){re=null;return}if(re&&re!==e){V("injectTransactionRunner(...) was called more than once. The existing runner will be kept to avoid cross-request transaction leaks. If you need to replace it in tests, call injectTransactionRunner(null) first.");return}re=e;},wn=()=>{re=null;};v("transaction.runner",wn,120);var Ne=e=>{let t=re?.get();return t||(e??X()).transaction},vn=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var $=()=>re?(re.get()?.depth??0)>0:Ne().depth>0,he=(e,t)=>{let r=Ne(t);r.failed=true,r.error||(r.error=vn(e));},Ye=e=>{let t=X();Ne(t).pending.push(()=>Ke(t,e));},Je=(e,t)=>{let r=Ne();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},be=e=>{let t=Ne();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Xe=Symbol("stroid.middleware.abort"),Br=({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=R(t.next);for(let c of r){if(typeof c!="function")continue;let a,u=i;try{a=c({action:t.action,name:e,prev:t.prev,next:u,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(d){let m=`Middleware for "${e}" failed: ${d?.message??d}`;return o(m,"dev"),Xe}if(a&&typeof a.then=="function"){let d=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(d,"dev"),Xe}a===void 0?(w()&&!s.has(c)&&(s.add(c),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=u):i=a;}return i},Qe=({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 ue=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;V(`${t} callback threw: ${String(n)}`);}},le=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(ue(n,"onError",e),r==="critical"){o==="dev"&&f(e),se(e);return}if(o==="always"){V(e);return}f(e);};var Ze=null,Ur=e=>{Ze=e;},Kr=e=>Ze?Ze(e):[];v("computed.order-resolver",()=>{Ze=null;},105);var Gr=()=>X(Se(ge)),Yr=()=>Gr().computedEntries,kn=()=>Gr().computedDependents;var Jr=e=>Object.prototype.hasOwnProperty.call(Yr(),e);var $t=e=>{let t=Yr(),r=kn(),o=new Set,n=[...e];for(;n.length>0;){let d=n.shift(),m=r[d];if(m)for(let g of m)o.has(g)||(o.add(g),n.push(g));}if(o.size===0)return [];let s=d=>{let m=t[d];if(m)for(let g of m.deps)t[g]&&(o.has(g)||(o.add(g),s(g)));};Array.from(o).forEach(d=>s(d));let i=new Map,c=new Map;for(let d of o){let m=t[d];if(!m)continue;let g=0;for(let C of m.deps)o.has(C)&&(g++,c.has(C)||c.set(C,[]),c.get(C).push(d));i.set(d,g);}let a=[];for(let[d,m]of i)m===0&&a.push(d);a.sort();let u=[];for(;a.length>0;){let d=a.shift();u.push(d);let m=c.get(d)??[];for(let g of m){let C=(i.get(g)??1)-1;if(i.set(g,C),C===0){let S=a.findIndex(l=>l>g);S===-1?a.push(g):a.splice(S,0,g);}}}return u};Ur($t);var _t=new Set,Rn=()=>{_t.clear();};v("options.legacy-warnings",Rn,30);var et=(()=>{let e=new Map;return {getItem:t=>e.has(t)?e.get(t):null,setItem:(t,r)=>{e.set(t,r);},removeItem:t=>{e.delete(t);},type:"memory"}})(),zt=e=>{try{return typeof window>"u"?et:e==="session"||e==="sessionStorage"?window.sessionStorage??et:window.localStorage??et}catch{return et}},Pe=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),we=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Qr=e=>{try{let t=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`,r=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`;return e(t)!==t?!1:e(r)===r}catch{return false}},xn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Xr=e=>{try{e[xn]=!0;}catch{}return e},Cn={allowSSRGlobalStore:'scope: "global"',schema:"validate",validator:"validate",version:"persist.version",migrations:"persist.migrations",historyLimit:"devtools.historyLimit",redactor:"devtools.redactor",middleware:"lifecycle.middleware",onCreate:"lifecycle.onCreate",onSet:"lifecycle.onSet",onReset:"lifecycle.onReset",onDelete:"lifecycle.onDelete"},Mn=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Xr(m=>m),decrypt:Xr(m=>m),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:zt("localStorage"),...r};if(typeof e=="string")return {driver:zt(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,a=e.allowPlaintext===true,u=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,d=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(c&&Qr(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||zt("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:o,decrypt:n,encryptAsync:s,decryptAsync:i,allowPlaintext:a,sensitiveData:c,maxSize:u,checksum:d,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Zr=e=>{if(!Pe(e))return [];let t=[];return Object.entries(Cn).forEach(([r,o])=>{we(e,r)&&(_t.has(r)||(_t.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},eo=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=Pe(e.lifecycle)?e.lifecycle:void 0,c=Pe(e.persist)?e.persist:void 0,a=Pe(e.devtools)?e.devtools:void 0,u=e.validate??e.validator??e.schema,d=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",m=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,g=Pe(e.features)?{...e.features}:void 0,C=we(e,"persist"),S=we(e,"sync"),l=we(e,"devtools")||we(e,"historyLimit")||we(e,"redactor"),x=o==="global"?true:e.allowSSRGlobalStore??false,{persist:b=false,devtools:D=false,onError:A,sync:I}=e;if(c?.sensitiveData===true){let j=c.encrypt,h=c.encryptAsync;if((!j||Qr(j))&&!h)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:o,lazy:n,pathCreate:s,persist:o==="temp"&&!C?null:Mn(b,t),devtools:o==="temp"&&!l?false:typeof D=="boolean"?D:a?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:A,validate:u,migrations:c?.migrations??e.migrations??{},version:c?.version??e.version??1,redactor:o==="temp"&&!l?void 0:a?.redactor??e.redactor,historyLimit:o==="temp"&&!l?0:a?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!S?false:I??false,features:g,allowSSRGlobalStore:x,snapshot:d,snapshotSafety:m,explicitPersist:C,explicitSync:S,explicitDevtools:l}};var tt=new Set,ro=e=>e?tt.has(e):tt.size>0,oo=e=>{e&&tt.add(e);},En=()=>{tt.clear();};v("ssr.warnings",En,60);var to=new Set,Tn=e=>{let t=Rr();return !t||e.includes("::")?e:(w()&&!to.has(e)&&(to.add(e),f(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},rt=e=>Tn(typeof e=="string"?e:e.name),ot=e=>U(e)&&!io(e)?true:(Et(e,Object.keys(ze)),false),no=(e,t,r={})=>{le(t,{...r,onError:O[e]?.options?.onError});},so=(e,t,r={})=>{le(e,{...r,onError:t});},de=(e,t,r="dev")=>{no(e,t,{severity:"warn",visibility:r});},Fn=(e,t,r="dev")=>{so(e,t,{severity:"warn",visibility:r});},Ie=(e,t)=>no(e,t,{severity:"critical",visibility:"always"}),$e=(e,t)=>so(e,t,{severity:"critical",visibility:"always"}),nt=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
9
- Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Fn(o,r,"always"),k().strictMissingFeatures)throw new Error(o)};var ao=new WeakMap,co=new WeakMap;var st=e=>{let t=ao.get(e);return t||(t=new Map,ao.set(e,t)),t},uo=e=>{let t=co.get(e);return t||(t=new Map,co.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=st(M());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)=>(st(M())[t]=r,true)});var ve=(e,t,r,o)=>{try{return o?.reuseInput&&Vt(t)?{ok:!0,value:t}:{ok:!0,value:ie(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return ue(O[e]?.options?.onError,`onError(${e})`,s),ue(r,`onError(${e})`,s),f(s),{ok:false}}},On=(e,t)=>{let r=new Set,o=O[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Ht=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=On(e,o),s=(c,a)=>{n.forEach(u=>ue(u,`onError(${e})`,c)),a==="critical"?se(c):f(c);};if(typeof r=="function")try{let c=r(t);return c===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:c===!0?t:c}}catch(c){return s(`Validation for "${e}" failed: ${c?.message??c}`,"critical"),{ok:false}}let i=Ft(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},_e=(e,t,r,o,n)=>{let s=ve(e,t,o,n);if(!s.ok)return {ok:false};let i=Ht(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},Q=e=>{let t=M();st(t).delete(e),uo(t).delete(e);},Vn=()=>{let e=M();st(e).clear(),uo(e).clear();};v("validation.path-cache",Vn,50);po(Q);var lo=(e,t=M())=>{if(($()?be(e):{has:false}).has||t.stores[e]!==void 0)return true;let o=t.initialFactories[e];if(!o)return true;try{let n=o(),s=ve(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,c=_e(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!c.ok)return !1;if($()){let a=c.value;Je(e,a),Ye(()=>{K(e,a,t),t.initialStates[e]=R(a),delete t.initialFactories[e],Q(e);});}else K(e,c.value,t),t.initialStates[e]=R(c.value),delete t.initialFactories[e],Q(e);return !0}catch(n){return Ie(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var fo=new WeakMap,go=e=>{let t=fo.get(e);return t||(t=new Map,fo.set(e,t)),t},Dn=()=>{go(M()).clear();};v("features.contexts",Dn,100);var So=e=>{let t=M(),r=go(t),o=r.get(e);if(o)return o;let n=O[e];if(!n)return f(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>O[e],getStoreValue:()=>ze[e],getAllStores:()=>ze,getInitialState:()=>vo[e],hasStore:()=>U(e),setStoreValue:i=>{K(e,i);},applyFeatureState:(i,c)=>{ko(e,i,c),Q(e);},notify:()=>{},reportStoreError:i=>{Ie(e,i);},warn:f,warnAlways:V,log:L,hashState:je,deepClone:R,sanitize:ie,validate:i=>Ht(e,i,O[e]?.options?.validate),isDev:w};return r.set(e,s),s},yo=(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(Ie(e,n),r.assertRuntime)throw new Error(n)},mo=(e,t)=>{at();let r=So(e);r&&(r.notify=()=>t(e),yo(e,r),B.forEach(o=>{o.onStoreCreate?.(r);}));},ho=(e,t,r,o,n)=>{at();let s=So(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});yo(e,i),B.forEach(c=>{c.onStoreWrite?.(i);});};var bo=(e,t)=>Br({name:e,payload:t,middlewares:(()=>{let r=O[e]?.options?.middleware||[],o=k().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{de(e,r,o);},warn:f}),it=(e,t,r,o)=>Qe({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{de(e,n,s);}}),wo=(e,t)=>{let r={...t};return r.persist&&!qe("persist")&&(r.explicitPersist&&nt(e,"persist",r.onError),r.persist=null),r.sync&&!qe("sync")&&(r.explicitSync&&nt(e,"sync",r.onError),r.sync=false),qe("devtools")||(r.explicitDevtools&&nt(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var ct=null,Ro=e=>(ct=e,()=>{ct===e&&(ct=null);}),ke=e=>{ct?.(e);};var ut=new Set,jn=e=>{ut.clear();};v("store-create.ssr-global-warned",()=>jn(),65);function xo(e,t,r={}){if($()){let h=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;$e(h,r.onError),he(h);return}if(!De(e)){$e(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Ot(t)){$e(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&w()&&f(`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.`),Zr(r).forEach(h=>{f(h);});let n=wo(e,eo(r,e,k().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let h=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;ue(n.onError,`onError(${e})`,h),w()||V(h),W(h);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=s&&i==="production",a=n.allowSSRGlobalStore??false,u=M(),d=u.stores,m=u.subscribers,g=u.initialStates,C=u.initialFactories,S=u.metaEntries,l=u.scope==="request";if(c&&!a&&!l){let h=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
10
- Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;$e(h,r.onError);return}if(c&&a&&!l&&!ut.has(e)&&(ut.add(e),V(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
11
- This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),U(e,u)){let h=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return de(e,h),{name:e}}s&&!a&&!l&&!ro(e)&&w()&&(oo(e),f(`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 x=ve(e,t,n.onError);if(!x.ok)return;let b=x.value,D=n.lazy===true&&typeof t=="function",A=(m[e]?.size??0)>0;if(D)d[e]=void 0,C[e]=t;else {let h=_e(e,b,n.validate,n.onError);if(!h.ok)return;K(e,h.value,u),g[e]=R(h.value);}let I=Date.now(),j=new Date(I).toISOString();return S[e]={createdAt:j,updatedAt:j,updatedAtMs:I,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},Q(e),mo(e,ke),it(e,"onCreate",S[e].options.onCreate,[b]),Co(u,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),A&&ke(e),L(`Store "${e}" created -> ${JSON.stringify(b)}`),{name:e}}var An=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Mo=(e,t)=>t==="ref"?e:t==="shallow"?Ae(e):R(e);function Wt(e,t){let r=rt(e);if(!ot(r))return null;let o=M();if(!lo(r,o))return null;Lt(r,o);let n=He(r,o),s=An(o.metaEntries[r],k().defaultSnapshotMode);return n===null||typeof n!="object"?n:Mo(n,s);}var lt=null,dt=()=>lt,qt=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();let r=lt;lt=e;try{return t()}finally{lt=r;}};var Nn=new Set;v("store-write.slow-mutator-warned",()=>Nn.clear(),65);var Pn=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var To=e=>dt(),Eo=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:c})=>{let a=e.metaEntries;K(t,o,e),Q(t);let u=Date.now();a[t].updatedAt=new Date(u).toISOString(),a[t].updatedAtMs=u;let d=c??dt();d&&(d.correlationId||d.traceContext)?(a[t].lastCorrelationId=d.correlationId??null,a[t].lastCorrelationAt=new Date(u).toISOString(),a[t].lastCorrelationAtMs=u,a[t].lastTraceContext=d.traceContext??null):(a[t].lastCorrelationId=null,a[t].lastCorrelationAt=null,a[t].lastCorrelationAtMs=null,a[t].lastTraceContext=null),Pn(a[t]),ho(t,n,r,o,ke),it(t,s,a[t].options[s],[r,o]),ke(t),L(i);},Fo=(e,t)=>{let r=t.context??dt();if($()){Je(t.name,t.next),Ye(()=>Eo(e,{...t,context:r}));return}Eo(e,{...t,context:r});};function Oo(e,t){let r=rt(e);if(!r)return {ok:false,reason:"invalid-args"};let o=M(),n=Bt(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 Bt=(e,t,r,o="hydrate",n)=>{let s=(S,l)=>($()&&he(l??S),{ok:false,reason:S});if(!ot(t))return s("not-found",`replaceStore("${t}") called before createStore().`);let i=$()?be(t):{has:false,value:void 0},c=i.has?i.value:He(t,e),a=ve(t,r);if(!a.ok)return s("sanitize",`replaceStore("${t}") failed sanitize`);let u=a.value;if(u===void 0){let S=`Whole-store undefined replacement is blocked for "${t}". Use null for intentional empty state.`;return de(t,S),s("undefined",S)}let d=e.metaEntries[t]?.options?.validate,m=To(),g=bo(t,{action:o,prev:c,next:u,path:null,correlationId:m?.correlationId,traceContext:m?.traceContext});if(g===Xe)return s("middleware",`replaceStore("${t}") aborted by middleware`);let C=_e(t,g,d);return C.ok?(Fo(e,{name:t,prev:c,next:C.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:m}),{ok:true}):s("validate",`replaceStore("${t}") failed validation`)};var In=()=>M().computedCleanups;var Vo=e=>{let t=In(),r=t.get(e);if(!r){w()&&f(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Do=new Map;var Ut=e=>{let t=Do.get(e);return !!t&&t.size>0},We=(e,t,r)=>{let o=Do.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 jo=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,a=e.deletingStores,u=(l,x)=>{le(x,{onError:s[l]?.options?.onError,severity:"warn",visibility:"dev"});},d=({name:l,prev:x,options:b,initialState:D,getMeta:A,getStoreValue:I,hasStore:j})=>({name:l,options:b,prev:x,getMeta:A,getStoreValue:I,getAllStores:()=>t,getInitialState:()=>D,hasStore:j,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:h=>{le(h,{onError:b.onError,severity:"warn",visibility:"dev"});},warn:f,warnAlways:V,log:L,hashState:je,deepClone:R,sanitize:ie,validate:()=>({ok:true,value:x}),isDev:w}),m=({name:l,prev:x,options:b,initialState:D,phase:A})=>{let I=d({name:l,prev:x,options:b,initialState:D,getMeta:()=>s[l],getStoreValue:()=>t[l],hasStore:()=>ye(e,l)}),j=d({name:l,prev:x,options:b,initialState:D,getMeta:()=>{},getStoreValue:()=>x,hasStore:()=>false});fe().forEach(h=>{let z=c.get(h);A==="before"?z?.beforeStoreDelete?.(I):z?.afterStoreDelete?.(j);});},g=l=>{if(!ye(e,l))return;let x=t[l],b=s[l].options,D=o[l],A=r[l];a.add(l);try{A?.forEach(h=>{try{h(null);}catch(z){f(`Subscriber for "${l}" threw during delete: ${z?.message??z}`);}}),Qe({name:l,label:"onDelete",fn:b.onDelete,args:[x],reportIssue:(h,z)=>{le(h,{onError:b.onError,severity:"warn",visibility:z});}}),m({name:l,prev:x,options:b,initialState:D,phase:"before"}),delete t[l],delete r[l],delete o[l],delete n[l],delete s[l],delete i[l],Jr(l)&&Vo(l);let j=e.computedDependents[l];if(j)for(let h of j)f(`[stroid] source store "${l}" was deleted. Computed store "${h}" depends on it and will return stale data. Call deleteComputed("${h}") to clean up.`);m({name:l,prev:x,options:b,initialState:D,phase:"after"}),We("afterStoreDelete",l,{type:"afterStoreDelete",prev:x}),Ue(e,{type:"deleted",name:l}),L(`Store "${l}" deleted`);}finally{a.delete(l);}};return {deleteExistingStore:g,clearAllStores:()=>{let l=[],b=0,D=Number.POSITIVE_INFINITY;for(;b<20;){let I=Object.keys(t);if(I.length===0)break;I.forEach(h=>{ye(e,h)&&(g(h),l.push(h));}),b+=1;let j=Object.keys(t).length;if(j===0||j>=D)break;D=j;}let A=Object.keys(t).length;return A>0?f(`clearAllStores stopped after ${b} pass${b===1?"":"es"}; ${A} store(s) still registered (likely recreated during deletion).`):f(`All stores cleared (${l.length} stores removed)`),l},clearStores:l=>{let x=Object.keys(t).filter(b=>l?l.endsWith("*")?b.startsWith(l.slice(0,-1)):b===l:true);return x.forEach(b=>g(b)),x},reportStoreError:u}};var Kt=ge,No=Se(Kt),Po=null,P=()=>{let e=X(No);return wt(e),e};var M=()=>P();var Co=(e,t)=>{Ue(e,t);};function po(e){Po=e;}var Re=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}}}),$n=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)}),zn=e=>new Proxy({},{get:(t,r)=>{let o=e(),n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),ze=Re(()=>P().stores);Re(()=>P().subscribers);var vo=Re(()=>P().initialStates);Re(()=>P().initialFactories);var O=Re(()=>P().metaEntries);Re(()=>P().snapshotCache);var B=$n(()=>P().featureRuntimes),Ao=new WeakMap,_n=e=>{let t=Ao.get(e);return t||(t=jo(e),Ao.set(e,t)),t};zn(()=>_n(P()));var Hn=e=>{let t=B.get(e);if(t)return t;let r=Be(e);if(!r)return;let o=r();return B.set(e,o),o},at=()=>{fe().forEach(e=>{Hn(e);});};at();var U=(e,t)=>ye(t??P(),e),He=(e,t=P())=>{if($()){let o=be(e);if(o.has)return o.value}let r=Te();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},K=(e,t,r=P())=>{let o=Te();o?(o[e]=t,Object.prototype.hasOwnProperty.call(r.stores,e)||(r.stores[e]=void 0)):r.stores[e]=t;},ko=(e,t,r=Date.now())=>{K(e,t),O[e]&&(O[e].updatedAt=new Date(r).toISOString(),O[e].updatedAtMs=r,O[e].lastCorrelationId=null,O[e].lastCorrelationAt=null,O[e].lastCorrelationAtMs=null,O[e].lastTraceContext=null,O[e].updateCount>=Number.MAX_SAFE_INTEGER?O[e].updateCount=0:O[e].updateCount+=1,Po?.(e));},Lt=(e,t=P())=>{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();},Wn=()=>{yr(P());},Ln=()=>{B.forEach(e=>{try{e.resetAll?.();}catch{}}),B.clear();};v("features.reset",Ln,10);v("registries.clear",Wn,20);v("registry.default",()=>{Kt=ge,No=Se(Kt);},115);var io=e=>Sr(P(),e);var Io=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Gt=(e,t)=>{if(t==="ref"){if(!w())return e;try{return It(e)}catch{return e}}if(t==="shallow"){let o=Ae(e);if(!w())return o;try{return It(o)}catch{return o}}let r=R(e);if(!w())return r;try{return Lr(r)}catch{return r}};var $o=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 c=new Set;if(i){for(let S of t)r.push(S),c.add(S);for(let S of s)c.has(S)&&o.push(S);for(let S of r)i.has(S)||o.push(S);}else for(let S of t)r.push(S),c.add(S),o.push(S);t.clear();let a=Kr(o),u=new Set(o);for(let S of a)u.has(S)||(o.push(S),u.add(S));let d=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,m=n.chunkDelayMs,g=d===Number.POSITIVE_INFINITY&&m===0;return {names:o,sliceSize:d,chunkDelayMs:m,runInline:g,prioritySet:i}};var Yt=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}),Jt=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),Xt=(e,t)=>{e&&(e.metrics=t);};var Le=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},zo=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>Ke(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var _o=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)},Ho=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:c,runInline:a,prioritySet:u}=t,d=Te(),m=n.subscriberBuffer,g=e.stores,C=e.subscribers,S=e.metaEntries,l=e.snapshotCache,x=k().defaultSnapshotMode,b=y=>Io(S[y],x),D=y=>d&&Object.prototype.hasOwnProperty.call(d,y)?d[y]:g[y],A=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),I=Ut("beforeFlush"),j=Ut("afterFlush"),h=y=>{I&&We("beforeFlush",y,{type:"beforeFlush"});},z=(y,F)=>{j&&We("afterFlush",y,{type:"afterFlush",elapsedMs:F});},rr=y=>{let F=S[y];if(!F)return null;let E=F.lastCorrelationId??void 0,p=F.lastTraceContext??void 0;return !E&&!p?null:{correlationId:E,traceContext:p}},Wo=y=>{m.length=0;for(let F of y)m.push(F);return m},gt=()=>{o();};if(a){for(let y of s){let F=C[y];if(!F||F.size===0)continue;let E=S[y]?.updateCount??0,p=b(y),pe=D(y),_=l[y],H=_&&_.source===pe&&_.mode===p?_.snapshot:(()=>{let N=Gt(pe,p);return l[y]={version:r,snapshot:N,source:pe,mode:p},N})(),G=Yt(S[y]?.metrics);h(y);let oe=A(),Z=Wo(F),xe=rr(y),Ce=()=>{for(let N of Z)try{N(H);}catch(ne){let Y=S[y]?.options?.snapshotSafety??"warn";if(w()&&(p==="ref"||p==="shallow")&&_o(ne)){if(Y==="throw")throw ne;if(Y==="auto-clone")try{let Ee=R(H);f(`Snapshot mutation detected for "${y}". Delivered a cloned snapshot to the subscriber.`);try{N(Ee);}catch(mt){f(`Subscriber for "${y}" threw on cloned snapshot: ${mt?.message??mt}`);}continue}catch{}f(`Snapshot mutation detected for "${y}": ${ne?.message??ne}`);continue}f(`Subscriber for "${y}" threw: ${ne?.message??ne}`);}};xe?qt(xe,Ce):Ce();let Me=A()-oe;z(y,Me),Jt(G,Me),Xt(S[y],G),(S[y]?.updateCount??E)!==E&&n.pendingNotifications.add(y);}gt();return}let or=y=>{let F=[];for(let E of s){if(y&&!y(E))continue;let p=C[E];if(!p||p.size===0)continue;let pe=S[E]?.updateCount??0,_=b(E),H=D(E),G=l[E],oe=G&&G.source===H&&G.mode===_?G.snapshot:(()=>{let Z=Gt(H,_);return l[E]={version:r,snapshot:Z,source:H,mode:_},Z})();F.push({name:E,snapshot:oe,version:pe,subscribers:Array.from(p),subscriberSet:new Set(p),notified:new Set,metrics:Yt(S[E]?.metrics),totalMs:0,beforeHooked:false});}return F},nr=u?or(y=>u.has(y)):[],sr=or(y=>!u||!u.has(y)),St=(y,F)=>{let E=()=>{if(y.length===0){F();return}let p=y.shift();if((S[p.name]?.updateCount??p.version)!==p.version){if(n.pendingNotifications.add(p.name),y.length===0){F();return}Le(E,c);return}let _=()=>{let q=C[p.name];if(!(!q||q.size===0))for(let N of q)p.subscriberSet.has(N)||(p.subscriberSet.add(N),p.subscribers.push(N));};_();let H=p.subscribers;if(H.length===0){if(y.length===0){F();return}Le(E,c);return}p.beforeHooked||(p.beforeHooked=true,h(p.name));let G=A(),oe=0,Z=false,xe=rr(p.name),Ce=()=>{for(let q=0;q<H.length&&oe<i;q+=1){let N=H[q];if(p.notified.has(N))continue;p.notified.add(N);try{N(p.snapshot);}catch(Y){let yt=S[p.name]?.options?.snapshotSafety??"warn",Ee=b(p.name);if(w()&&(Ee==="ref"||Ee==="shallow")&&_o(Y)){if(yt==="throw")throw Y;if(yt==="auto-clone")try{let ir=R(p.snapshot);f(`Snapshot mutation detected for "${p.name}". Delivered a cloned snapshot to the subscriber.`);try{N(ir);}catch(ar){f(`Subscriber for "${p.name}" threw on cloned snapshot: ${ar?.message??ar}`);}if(p.notified.add(N),oe+=1,(S[p.name]?.updateCount??p.version)!==p.version){Z=!0,n.pendingNotifications.add(p.name);break}continue}catch{}f(`Snapshot mutation detected for "${p.name}": ${Y?.message??Y}`);continue}f(`Subscriber for "${p.name}" threw: ${Y?.message??Y}`);}if(oe+=1,(S[p.name]?.updateCount??p.version)!==p.version){Z=true,n.pendingNotifications.add(p.name);break}}};if(xe?qt(xe,Ce):Ce(),p.totalMs+=A()-G,Z){if(y.length===0){F();return}Le(E,c);return}_();let Me=false;for(let q of H)if(!p.notified.has(q)){Me=true;break}if(Me?y.push(p):(Jt(p.metrics,p.totalMs),Xt(S[p.name],p.metrics),z(p.name,p.totalMs)),y.length===0){F();return}Le(E,c);};E();};nr.length>0?St(nr,()=>St(sr,gt)):St(sr,gt);};var qn=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=$o(t);Ho(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&Qt(e);});},Qt=e=>{zo(e,qn);};var Bn=e=>{let t=M(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&Qt(t);};Ro(Bn);var Un=()=>{let e=M().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0;};v("notify.reset",Un,40);var pt=(e,t={},r)=>{if($()){let a="hydrateStores(...) cannot be called inside setStoreBatch.";return f(a),he(a),{hydrated:[],created:[],failed:[],blocked:{reason:"transaction"}}}let o={hydrated:[],created:[],failed:[]};if(!e||typeof e!="object")return o;let n=M(),s=r??{};if(!(s.allowTrusted===true||s.allowHydration===true||s.allowUntrusted===true||k().allowUntrustedHydration===true))return V("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 a=false;try{a=!!s.validate(e);}catch(u){let d=`hydrateStores() trust.validate threw: ${u?.message??u}`;if(w())throw new Error(`hydrateStores() trust.validate threw an error. Fix your validator before this becomes a silent production failure.
12
- Original error: ${u?.message??u}`);let m=t?.default?.onError;if(typeof m=="function")try{m(d);}catch(g){V(`hydrateStores(...) onError threw: ${g?.message??g}`);}if(V(d),typeof s.onValidationError=="function")try{if(!!s.onValidationError(u,e))a=!0;else return o.blocked={reason:"validation-error",cause:u},o}catch(g){return V(`hydrateStores(...) onValidationError threw: ${g?.message??g}`),o.blocked={reason:"validation-error",cause:g},o}else return o.blocked={reason:"validation-error",cause:u},o}if(!a)return V("hydrateStores(...) rejected by trust validation."),o.blocked={reason:"validation-failed"},o}let c=[];return Object.entries(e).forEach(([a,u])=>{if(!De(a)){o.failed.push({name:a,reason:"invalid-name"});return}if(U(a,n)){let d=Bt(n,a,u,"hydrate");d.ok?(o.hydrated.push(a),c.push(a)):o.failed.push({name:a,reason:"merge-failed",cause:d.reason,received:u});}else {let d=t;xo(a,u,d[a]||d.default||{})?(o.created.push(a),c.push(a)):o.failed.push({name:a,reason:"create-failed",received:u});}}),c.length>0&&$t(c).forEach(u=>{let d=n.computedEntries[u];if(!d)return;let m=d.deps.map(g=>Wt(g));try{let g=d.compute(...m);if(g&&typeof g.then=="function"){f(`hydrateStores recompute for "${u}" returned a Promise; skipping.`);return}let C=Wt(u);if(Object.is(g,C))return;Oo(u,g);}catch(g){f(`hydrateStores recompute for "${u}" failed: ${g?.message??g}`);}}),o};var er=new AsyncLocalStorage,ft=new AsyncLocalStorage,Zt=new AsyncLocalStorage;hr({run:(e,t)=>er.run(e,t),get:()=>er.getStore()||null});wr({run:(e,t)=>ft.run(e,t),get:()=>ft.getStore()||null,enterWith:e=>ft.enterWith(e)});qr({run:(e,t)=>Zt.run(e,t),get:()=>Zt.getStore()||null,enterWith:e=>Zt.enterWith(e)});var hc=e=>{let t=kt("request"),r={},o={},n=i=>Object.prototype.hasOwnProperty.call(r,i);return typeof e=="function"&&e({create:(i,c,a={})=>(r[i]=R(c),o[i]={...a},r[i]),set:(i,c)=>{if(!n(i))throw new Error(`createStoreForRequest.set("${i}") requires create("${i}", initialState) first.`);return r[i]=typeof c=="function"?At(r[i],c):c,r[i]},get:i=>n(i)?R(r[i]):void 0}),{registry:t,snapshot:()=>R(r),hydrate:(i,c={})=>{let a={...c,default:c.default};return Object.keys(r).forEach(u=>{let d=u,m={...c.default||{},...c[d]||{},...o[u]||{}};a[d]=m;}),ft.run(t,()=>er.run(R(r),()=>(pt(r,a,{allowTrusted:true}),i())))}}};export{hc as createStoreForRequest};//# sourceMappingURL=server.js.map
8
+ Call createStore("${e}", data) first.`);};var ee=new Set(["__proto__","constructor","prototype"]),Vt=(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 je=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,_r=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},Dt=e=>{let t=je(e);return t==="function"?(L(Er()),false):t==="map"||t==="set"?(g(Tr()),true):(t==="date"&&g(Fr()),true)},Ot=(e,t)=>{let r=_r(e);if(r)throw new Error(`${r} values are not supported`);let o=je(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&&!Ot(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||ee.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Ot(i.value,t))return false}return true}return true},jt=e=>Ot(e,new WeakSet),De=(e,t)=>{let r=_r(e);if(r)throw new Error(`${r} values are not supported`);let o=je(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date")return v()&&g(Or()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),v()&&g(Vr());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)]=De(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),v()&&g(Dr()),Array.from(e,n=>De(n,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n={},s=Object.getOwnPropertyDescriptors(e);for(let[i,c]of Object.entries(s))if(c.enumerable&&!ee.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=De(c.value,t);}return n}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(n=>De(n,t))}return e},ce=e=>De(e,new WeakSet),Ae=e=>typeof e!="string"||e.trim()===""?(L(Ir(e)),false):ee.has(e)?(L(zr(e)),false):e.includes(" ")?(L($r(e)),false):true;var At=null,yn=()=>{if(At)return At;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 At=t,t},Hr=e=>{let t=yn(),r=-1;for(let o=0;o<e.length;o++)r=r>>>0,r=r>>>8^t[(r^e.charCodeAt(o))&255];return (r^-1)>>>0},mn=2166136261,hn=2654435761,bn=1e5,te=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},ue=(e,t)=>{te(e,t.length);for(let r=0;r<t.length;r++)te(e,t.charCodeAt(r));},F=(e,t)=>{ue(e,t);},Wr=(e,t)=>{if(Number.isNaN(t)){F(e,"NaN");return}if(!Number.isFinite(t)){F(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){F(e,"-0");return}let r=t|0;if(t===r){F(e,"int"),te(e,r);return}F(e,"num"),ue(e,String(t));},he=(e,t)=>{if(e.nodes++>bn){F(e,"[max]");return}if(t===null){F(e,"null");return}let r=typeof t;if(r==="string"){F(e,"string"),ue(e,t);return}if(r==="number"){F(e,"number"),Wr(e,t);return}if(r==="boolean"){F(e,t?"true":"false");return}if(r==="undefined"){F(e,"undefined");return}if(r==="bigint"){F(e,"bigint"),ue(e,t.toString());return}if(r==="symbol"){F(e,"symbol");let a=t;ue(e,Symbol.keyFor(a)??a.description??String(a));return}if(r==="function"){F(e,"function"),ue(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){F(e,"ref"),te(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){F(e,"array"),te(e,o.length);for(let a=0;a<o.length;a++)Object.prototype.hasOwnProperty.call(o,a)?he(e,o[a]):F(e,"hole");return}if(o instanceof Date){F(e,"date"),Wr(e,o.getTime());return}if(o instanceof Map){F(e,"map"),te(e,o.size),o.forEach((a,u)=>{he(e,u),he(e,a);});return}if(o instanceof Set){F(e,"set"),te(e,o.size),o.forEach(a=>{he(e,a);});return}F(e,"object");let i=Object.getOwnPropertyDescriptors(o),c=[];Object.entries(i).forEach(([a,u])=>{u?.enumerable&&(ee.has(a)||"get"in u||"set"in u||c.push([a,u]));}),te(e,c.length);for(let[a,u]of c)ue(e,a),he(e,u.value);},Ne=e=>{if(typeof e=="string")return Hr(JSON.stringify(e));let t={h1:mn,h2:hn,seen:new WeakMap,nextId:1,nodes:0};he(t,e);let r=t.h1>>>0,o=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,o^=o>>>16,o=Math.imul(o,668265261),o^=o>>>15,o=Math.imul(o,374761393),o^=o>>>16,(r&2097151)*4294967296+(o>>>0)};var wn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Pe=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&&(ee.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},Nt=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=[["WeakMap",globalThis.WeakMap],["WeakSet",globalThis.WeakSet],["WeakRef",globalThis.WeakRef],["Promise",globalThis.Promise],["ReadableStream",globalThis.ReadableStream],["WritableStream",globalThis.WritableStream],["TransformStream",globalThis.TransformStream],["EventTarget",globalThis.EventTarget]];for(let[o,n]of t)if(typeof n=="function"&&e instanceof n)return o;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},vn=e=>Nt(e)===null,xn=e=>{let t=Nt(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(xn(e),e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let n=new Map;return t.set(e,n),e.forEach((s,i)=>{n.set(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||ee.has(n)||"get"in s||"set"in s||(r[n]=le(s.value,t));}),r},C=e=>{if(wn)try{return structuredClone(e)}catch(t){if(!vn(e)){let r=Nt(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return g(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),le(e)}return le(e)};var Pt=(e,t)=>{try{let r=C(e);return t(r),r}catch(r){throw new Error(`produceClone failed (possible circular reference or unserializable data): ${r?.message??r}`)}};var qr=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")},zt=e=>(qr(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Br=e=>{if(!qr(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 re=null,Ur=e=>{if(!e){re=null;return}if(re&&re!==e){T("injectTransactionRunner(...) was called more than once. The existing runner will be kept to avoid cross-request transaction leaks. If you need to replace it in tests, call injectTransactionRunner(null) first.");return}re=e;},Cn=()=>{re=null;};x("transaction.runner",Cn,120);var Ie=e=>{let t=re?.get();return t||(e??X()).transaction},Mn=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var z=()=>re?(re.get()?.depth??0)>0:Ie().depth>0,be=(e,t)=>{let r=Ie(t);r.failed=true,r.error||(r.error=Mn(e));},Qe=e=>{let t=X();Ie(t).pending.push(()=>Je(t,e));},Ze=(e,t)=>{let r=Ie();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},we=e=>{let t=Ie();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var et=Symbol("stroid.middleware.abort"),Kr=({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=C(t.next);for(let c of r){if(typeof c!="function")continue;let a,u=i;try{a=c({action:t.action,name:e,prev:t.prev,next:u,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(l){let y=`Middleware for "${e}" failed: ${l?.message??l}`;return o(y,"dev"),et}if(a&&typeof a.then=="function"){let l=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(l,"dev"),et}a===void 0?(v()&&!s.has(c)&&(s.add(c),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=u):i=a;}return i},tt=({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 de=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;T(`${t} callback threw: ${String(n)}`);}},pe=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(de(n,"onError",e),r==="critical"){o==="dev"&&g(e),ae(e);return}if(o==="always"){T(e);return}g(e);};var rt=null,Gr=e=>{rt=e;},Yr=e=>rt?rt(e):[];x("computed.order-resolver",()=>{rt=null;},105);var Jr=()=>X(me(ye)),_t=()=>Jr().computedEntries,Xr=()=>Jr().computedDependents;var Qr=e=>Object.prototype.hasOwnProperty.call(_t(),e);var Wt=e=>{let t=_t(),r=Xr(),o=new Set,n=[...e];for(;n.length>0;){let l=n.shift(),y=r[l];if(y)for(let f of y)o.has(f)||(o.add(f),n.push(f));}if(o.size===0)return [];let s=l=>{let y=t[l];if(y)for(let f of y.deps)t[f]&&(o.has(f)||(o.add(f),s(f)));};Array.from(o).forEach(l=>s(l));let i=new Map,c=new Map;for(let l of o){let y=t[l];if(!y)continue;let f=0;for(let b of y.deps)o.has(b)&&(f++,c.has(b)||c.set(b,[]),c.get(b).push(l));i.set(l,f);}let a=[];for(let[l,y]of i)y===0&&a.push(l);a.sort();let u=[];for(;a.length>0;){let l=a.shift();u.push(l);let y=c.get(l)??[];for(let f of y){let b=(i.get(f)??1)-1;if(i.set(f,b),b===0){let h=a.findIndex(d=>d>f);h===-1?a.push(f):a.splice(h,0,f);}}}return u};Gr(Wt);var Ht=e=>{let t=_t()[e];if(!t)return null;let r=Xr()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var qt=new Set,En=()=>{qt.clear();};x("options.legacy-warnings",En,30);var ot=(()=>{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"}})(),Lt=e=>{try{return typeof window>"u"?ot:e==="session"||e==="sessionStorage"?window.sessionStorage??ot:window.localStorage??ot}catch{return ot}},$e=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),ve=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),eo=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}},Tn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Zr=e=>{try{e[Tn]=!0;}catch{}return e},Fn={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"},On=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Zr(y=>y),decrypt:Zr(y=>y),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Lt("localStorage"),...r};if(typeof e=="string")return {driver:Lt(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,a=e.allowPlaintext===true,u=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,l=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(c&&eo(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||Lt("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:o,decrypt:n,encryptAsync:s,decryptAsync:i,allowPlaintext:a,sensitiveData:c,maxSize:u,checksum:l,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},to=e=>{if(!$e(e))return [];let t=[];return Object.entries(Fn).forEach(([r,o])=>{ve(e,r)&&(qt.has(r)||(qt.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},ro=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=$e(e.lifecycle)?e.lifecycle:void 0,c=$e(e.persist)?e.persist:void 0,a=$e(e.devtools)?e.devtools:void 0,u=e.validate??e.validator??e.schema,l=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",y=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,f=$e(e.features)?{...e.features}:void 0,b=ve(e,"persist"),h=ve(e,"sync"),d=ve(e,"devtools")||ve(e,"historyLimit")||ve(e,"redactor"),R=o==="global"?true:e.allowSSRGlobalStore??false,{persist:w=false,devtools:O=false,onError:P,sync:I}=e;if(c?.sensitiveData===true){let D=c.encrypt,m=c.encryptAsync;if((!D||eo(D))&&!m)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:o,lazy:n,pathCreate:s,persist:o==="temp"&&!b?null:On(w,t),devtools:o==="temp"&&!d?false:typeof O=="boolean"?O:a?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:P,validate:u,migrations:c?.migrations??e.migrations??{},version:c?.version??e.version??1,redactor:o==="temp"&&!d?void 0:a?.redactor??e.redactor,historyLimit:o==="temp"&&!d?0:a?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!h?false:I??false,features:f,allowSSRGlobalStore:R,snapshot:l,snapshotSafety:y,explicitPersist:b,explicitSync:h,explicitDevtools:d}};var nt=new Set,no=e=>e?nt.has(e):nt.size>0,so=e=>{e&&nt.add(e);},Vn=()=>{nt.clear();};x("ssr.warnings",Vn,60);var oo=new Set,Dn=e=>{let t=Cr();return !t||e.includes("::")?e:(v()&&!oo.has(e)&&(oo.add(e),g(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},st=e=>Dn(typeof e=="string"?e:e.name),it=e=>U(e)&&!co(e)?true:(Ft(e,Object.keys(We)),false),io=(e,t,r={})=>{pe(t,{...r,onError:V[e]?.options?.onError});},ao=(e,t,r={})=>{pe(e,{...r,onError:t});},fe=(e,t,r="dev")=>{io(e,t,{severity:"warn",visibility:r});},jn=(e,t,r="dev")=>{ao(e,t,{severity:"warn",visibility:r});},ze=(e,t)=>io(e,t,{severity:"critical",visibility:"always"}),_e=(e,t)=>ao(e,t,{severity:"critical",visibility:"always"}),at=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
9
+ Import "stroid/${t}" before calling createStore("${e}", ...).`;if(jn(o,r,"always"),k().strictMissingFeatures)throw new Error(o)};var uo=new WeakMap,lo=new WeakMap;var ct=e=>{let t=uo.get(e);return t||(t=new Map,uo.set(e,t)),t},po=e=>{let t=lo.get(e);return t||(t=new Map,lo.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=ct(M());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)=>(ct(M())[t]=r,true)});var xe=(e,t,r,o)=>{try{return o?.reuseInput&&jt(t)?{ok:!0,value:t}:{ok:!0,value:ce(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return de(V[e]?.options?.onError,`onError(${e})`,s),de(r,`onError(${e})`,s),g(s),{ok:false}}},An=(e,t)=>{let r=new Set,o=V[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Bt=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=An(e,o),s=(c,a)=>{n.forEach(u=>de(u,`onError(${e})`,c)),a==="critical"?ae(c):g(c);};if(typeof r=="function")try{let c=r(t);return c===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:c===!0?t:c}}catch(c){return s(`Validation for "${e}" failed: ${c?.message??c}`,"critical"),{ok:false}}let i=Vt(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},He=(e,t,r,o,n)=>{let s=xe(e,t,o,n);if(!s.ok)return {ok:false};let i=Bt(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},Q=e=>{let t=M();ct(t).delete(e),po(t).delete(e);},Nn=()=>{let e=M();ct(e).clear(),po(e).clear();};x("validation.path-cache",Nn,50);go(Q);var fo=(e,t=M())=>{if((z()?we(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=xe(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,c=He(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!c.ok)return !1;if(z()){let a=c.value;Ze(e,a),Qe(()=>{K(e,a,t),t.initialStates[e]=C(a),delete t.initialFactories[e],Q(e);});}else K(e,c.value,t),t.initialStates[e]=C(c.value),delete t.initialFactories[e],Q(e);return !0}catch(n){return ze(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var So=new WeakMap,yo=e=>{let t=So.get(e);return t||(t=new Map,So.set(e,t)),t},Pn=()=>{yo(M()).clear();};x("features.contexts",Pn,100);var mo=e=>{let t=M(),r=yo(t),o=r.get(e);if(o)return o;let n=V[e];if(!n)return g(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>V[e],getStoreValue:()=>We[e],getAllStores:()=>We,getInitialState:()=>Ro[e],hasStore:()=>U(e),setStoreValue:i=>{K(e,i);},applyFeatureState:(i,c)=>{ko(e,i,c),Q(e);},notify:()=>{},reportStoreError:i=>{ze(e,i);},warn:g,warnAlways:T,log:_,hashState:Ne,deepClone:C,sanitize:ce,validate:i=>Bt(e,i,V[e]?.options?.validate),isDev:v};return r.set(e,s),s},ho=(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(ze(e,n),r.assertRuntime)throw new Error(n)},bo=(e,t)=>{lt();let r=mo(e);r&&(r.notify=()=>t(e),ho(e,r),B.forEach(o=>{o.onStoreCreate?.(r);}));},wo=(e,t,r,o,n)=>{lt();let s=mo(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});ho(e,i),B.forEach(c=>{c.onStoreWrite?.(i);});};var vo=(e,t)=>Kr({name:e,payload:t,middlewares:(()=>{let r=V[e]?.options?.middleware||[],o=k().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{fe(e,r,o);},warn:g}),ut=(e,t,r,o)=>tt({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{fe(e,n,s);}}),xo=(e,t)=>{let r={...t};return r.persist&&!Ke("persist")&&(r.explicitPersist&&at(e,"persist",r.onError),r.persist=null),r.sync&&!Ke("sync")&&(r.explicitSync&&at(e,"sync",r.onError),r.sync=false),Ke("devtools")||(r.explicitDevtools&&at(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var dt=null,Co=e=>(dt=e,()=>{dt===e&&(dt=null);}),Re=e=>{dt?.(e);};var pt=new Set,In=e=>{pt.clear();};x("store-create.ssr-global-warned",()=>In(),65);function Mo(e,t,r={}){if(z()){let m=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;_e(m,r.onError),be(m);return}if(!Ae(e)){_e(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Dt(t)){_e(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&v()&&g(`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.`),to(r).forEach(m=>{g(m);});let n=xo(e,ro(r,e,k().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let m=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;de(n.onError,`onError(${e})`,m),v()||T(m),L(m);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=s&&i==="production",a=n.allowSSRGlobalStore??false,u=M(),l=u.stores,y=u.subscribers,f=u.initialStates,b=u.initialFactories,h=u.metaEntries,d=u.scope==="request";if(c&&!a&&!d){let m=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
10
+ Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;_e(m,r.onError);return}if(c&&a&&!d&&!pt.has(e)&&(pt.add(e),T(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
11
+ This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),U(e,u)){let m=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return fe(e,m),{name:e}}s&&!a&&!d&&!no(e)&&v()&&(so(e),g(`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 R=xe(e,t,n.onError);if(!R.ok)return;let w=R.value,O=n.lazy===true&&typeof t=="function",P=(y[e]?.size??0)>0;if(O)l[e]=void 0,b[e]=t;else {let m=He(e,w,n.validate,n.onError);if(!m.ok)return;K(e,m.value,u),f[e]=C(m.value);}let I=Date.now(),D=new Date(I).toISOString();return h[e]={createdAt:D,updatedAt:D,updatedAtMs:I,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},Q(e),bo(e,Re),ut(e,"onCreate",h[e].options.onCreate,[w]),Eo(u,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),P&&Re(e),_(`Store "${e}" created -> ${JSON.stringify(w)}`),{name:e}}var $n=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},To=(e,t)=>t==="ref"?e:t==="shallow"?Pe(e):C(e);function Ut(e,t){let r=st(e);if(!it(r))return null;let o=M();if(!fo(r,o))return null;Kt(r,o);let n=Le(r,o),s=$n(o.metaEntries[r],k().defaultSnapshotMode);return n===null||typeof n!="object"?n:To(n,s);}var qe=null,oe=null,Fo=e=>{if(!e){oe=null;return}if(oe&&oe!==e){T("injectWriteContextRunner(...) was called more than once. The existing runner will be kept to avoid cross-request write-context leaks. If you need to replace it in tests, call injectWriteContextRunner(null) first.");return}oe=e;},zn=()=>{qe=null,oe=null;};x("write-context.runner",zn,121);var ft=()=>oe?.get()??qe,Gt=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(oe)return oe.run(e,t);let r=qe;qe=e;try{return t()}finally{qe=r;}};var _n=new Set;x("store-write.slow-mutator-warned",()=>_n.clear(),65);var Wn=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var Vo=e=>ft(),Oo=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:c})=>{let a=e.metaEntries;K(t,o,e),Q(t);let u=Date.now();a[t].updatedAt=new Date(u).toISOString(),a[t].updatedAtMs=u;let l=c??ft();l&&(l.correlationId||l.traceContext)?(a[t].lastCorrelationId=l.correlationId??null,a[t].lastCorrelationAt=new Date(u).toISOString(),a[t].lastCorrelationAtMs=u,a[t].lastTraceContext=l.traceContext??null):(a[t].lastCorrelationId=null,a[t].lastCorrelationAt=null,a[t].lastCorrelationAtMs=null,a[t].lastTraceContext=null),Wn(a[t]),wo(t,n,r,o,Re),ut(t,s,a[t].options[s],[r,o]),Re(t),_(i);},Do=(e,t)=>{let r=t.context??ft();if(z()){Ze(t.name,t.next),Qe(()=>Oo(e,{...t,context:r}));return}Oo(e,{...t,context:r});};function jo(e,t){let r=st(e);if(!r)return {ok:false,reason:"invalid-args"};let o=M(),n=Yt(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 Yt=(e,t,r,o="hydrate",n)=>{let s=(h,d)=>(z()&&be(d??h),{ok:false,reason:h});if(!it(t))return s("not-found",`replaceStore("${t}") called before createStore().`);let i=z()?we(t):{has:false,value:void 0},c=i.has?i.value:Le(t,e),a=xe(t,r);if(!a.ok)return s("sanitize",`replaceStore("${t}") failed sanitize`);let u=a.value;if(u===void 0){let h=`Whole-store undefined replacement is blocked for "${t}". Use null for intentional empty state.`;return fe(t,h),s("undefined",h)}let l=e.metaEntries[t]?.options?.validate,y=Vo(),f=vo(t,{action:o,prev:c,next:u,path:null,correlationId:y?.correlationId,traceContext:y?.traceContext});if(f===et)return s("middleware",`replaceStore("${t}") aborted by middleware`);let b=He(t,f,l);return b.ok?(Do(e,{name:t,prev:c,next:b.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:y}),{ok:true}):s("validate",`replaceStore("${t}") failed validation`)};var Hn=()=>M().computedCleanups,Ao=new WeakMap;var Ln=e=>{let t=Ao.get(e);return t||(t=new Map,Ao.set(e,t)),t};var No=e=>{let t=Hn(),r=t.get(e);if(!r){v()&&g(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Po=(e,t=M())=>Ln(t).get(e)?.autoDispose===true;var Io=new Map;var Jt=e=>{let t=Io.get(e);return !!t&&t.size>0},Be=(e,t,r)=>{let o=Io.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 $o=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,a=e.deletingStores,u=(d,R)=>{pe(R,{onError:s[d]?.options?.onError,severity:"warn",visibility:"dev"});},l=({name:d,prev:R,options:w,initialState:O,getMeta:P,getStoreValue:I,hasStore:D})=>({name:d,options:w,prev:R,getMeta:P,getStoreValue:I,getAllStores:()=>t,getInitialState:()=>O,hasStore:D,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:m=>{pe(m,{onError:w.onError,severity:"warn",visibility:"dev"});},warn:g,warnAlways:T,log:_,hashState:Ne,deepClone:C,sanitize:ce,validate:()=>({ok:true,value:R}),isDev:v}),y=({name:d,prev:R,options:w,initialState:O,phase:P})=>{let I=l({name:d,prev:R,options:w,initialState:O,getMeta:()=>s[d],getStoreValue:()=>t[d],hasStore:()=>ie(e,d)}),D=l({name:d,prev:R,options:w,initialState:O,getMeta:()=>{},getStoreValue:()=>R,hasStore:()=>false});Se().forEach(m=>{let $=c.get(m);P==="before"?$?.beforeStoreDelete?.(I):$?.afterStoreDelete?.(D);});},f=d=>{if(!ie(e,d))return;let R=t[d],w=s[d].options,O=o[d],P=r[d];a.add(d);try{P?.forEach(m=>{try{m(null);}catch($){g(`Subscriber for "${d}" threw during delete: ${$?.message??$}`);}}),tt({name:d,label:"onDelete",fn:w.onDelete,args:[R],reportIssue:(m,$)=>{pe(m,{onError:w.onError,severity:"warn",visibility:$});}}),y({name:d,prev:R,options:w,initialState:O,phase:"before"}),delete t[d],delete r[d],delete o[d],delete n[d],delete s[d],delete i[d],Qr(d)&&No(d);let D=e.computedDependents[d];if(D)for(let m of [...D]){let $=Ht(m);if($&&Po(m,e)&&$.deps.every(Ce=>!ie(e,Ce))){f(m);continue}g(`[stroid] source store "${d}" was deleted. Computed store "${m}" depends on it and will return stale data. Call deleteComputed("${m}") to clean up.`);}y({name:d,prev:R,options:w,initialState:O,phase:"after"}),Be("afterStoreDelete",d,{type:"afterStoreDelete",prev:R}),Ye(e,{type:"deleted",name:d}),_(`Store "${d}" deleted`);}finally{a.delete(d);}};return {deleteExistingStore:f,clearAllStores:()=>{let d=[],w=0,O=Number.POSITIVE_INFINITY;for(;w<20;){let I=Object.keys(t);if(I.length===0)break;I.forEach(m=>{ie(e,m)&&(f(m),d.push(m));}),w+=1;let D=Object.keys(t).length;if(D===0||D>=O)break;O=D;}let P=Object.keys(t).length;return P>0?g(`clearAllStores stopped after ${w} pass${w===1?"":"es"}; ${P} store(s) still registered (likely recreated during deletion).`):_(`All stores cleared (${d.length} stores removed)`),d},clearStores:d=>{let R=Object.keys(t).filter(w=>d?d.endsWith("*")?w.startsWith(d.slice(0,-1)):w===d:true);return R.forEach(w=>f(w)),R},reportStoreError:u}};var Xt=ye,_o=me(Xt),Wo=null,N=()=>{let e=X(_o);return xt(e),e};var M=()=>N();var Eo=(e,t)=>{Ye(e,t);};function go(e){Wo=e;}var ke=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}}}),qn=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)}),Bn=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)}),We=ke(()=>N().stores);ke(()=>N().subscribers);var Ro=ke(()=>N().initialStates);ke(()=>N().initialFactories);var V=ke(()=>N().metaEntries);ke(()=>N().snapshotCache);var B=qn(()=>N().featureRuntimes),zo=new WeakMap,Un=e=>{let t=zo.get(e);return t||(t=$o(e),zo.set(e,t)),t};Bn(()=>Un(N()));var Kn=e=>{let t=B.get(e);if(t)return t;let r=Ge(e);if(!r)return;let o=r();return B.set(e,o),o},lt=()=>{Se().forEach(e=>{Kn(e);});};lt();var U=(e,t)=>ie(t??N(),e),Le=(e,t=N())=>{if(z()){let o=we(e);if(o.has)return o.value}let r=Oe();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},K=(e,t,r=N())=>{let o=Oe();o?(o[e]=t,Object.prototype.hasOwnProperty.call(r.stores,e)||(r.stores[e]=void 0)):r.stores[e]=t;},ko=(e,t,r=Date.now())=>{K(e,t),V[e]&&(V[e].updatedAt=new Date(r).toISOString(),V[e].updatedAtMs=r,V[e].lastCorrelationId=null,V[e].lastCorrelationAt=null,V[e].lastCorrelationAtMs=null,V[e].lastTraceContext=null,V[e].updateCount>=Number.MAX_SAFE_INTEGER?V[e].updateCount=0:V[e].updateCount+=1,Wo?.(e));},Kt=(e,t=N())=>{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();},Gn=()=>{hr(N());},Yn=()=>{B.forEach(e=>{try{e.resetAll?.();}catch{}}),B.clear();};x("features.reset",Yn,10);x("registries.clear",Gn,20);x("registry.default",()=>{Xt=ye,_o=me(Xt);},115);var co=e=>mr(N(),e);var Ho=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Qt=(e,t)=>{if(t==="ref"){if(!v())return e;try{return zt(e)}catch{return e}}if(t==="shallow"){let o=Pe(e);if(!v())return o;try{return zt(o)}catch{return o}}let r=C(e);if(!v())return r;try{return Br(r)}catch{return r}};var Lo=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 c=new Set;if(i){for(let h of t)r.push(h),c.add(h);for(let h of s)c.has(h)&&o.push(h);for(let h of r)i.has(h)||o.push(h);}else for(let h of t)r.push(h),c.add(h),o.push(h);t.clear();let a=Yr(o),u=new Set(o);for(let h of a)u.has(h)||(o.push(h),u.add(h));let l=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,y=n.chunkDelayMs,f=l===Number.POSITIVE_INFINITY&&y===0;return {names:o,sliceSize:l,chunkDelayMs:y,runInline:f,prioritySet:i}};var Zt=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}),er=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),tr=(e,t)=>{e&&(e.metrics=t);};var Ue=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},qo=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>Je(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var Bo=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)},Uo=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:c,runInline:a,prioritySet:u}=t,l=Oe(),y=e.stores,f=e.subscribers,b=e.metaEntries,h=e.snapshotCache,d=k().defaultSnapshotMode,R=S=>Ho(b[S],d),w=S=>l&&Object.prototype.hasOwnProperty.call(l,S)?l[S]:y[S],O=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),P=Jt("beforeFlush"),I=Jt("afterFlush"),D=S=>{P&&Be("beforeFlush",S,{type:"beforeFlush"});},m=(S,j)=>{I&&Be("afterFlush",S,{type:"afterFlush",elapsedMs:j});},$=S=>{let j=b[S];if(!j)return null;let E=j.lastCorrelationId??void 0,p=j.lastTraceContext??void 0;return !E&&!p?null:{correlationId:E,traceContext:p}},Ce=()=>{o();};if(a){for(let S of s){let j=f[S];if(!j||j.size===0)continue;let E=b[S]?.updateCount??0,p=R(S),ge=w(S),W=h[S],H=W&&W.source===ge&&W.mode===p?W.snapshot:(()=>{let A=Qt(ge,p);return h[S]={version:r,snapshot:A,source:ge,mode:p},A})(),G=Zt(b[S]?.metrics);D(S);let ne=O(),Z=Array.from(j),Me=$(S),Ee=()=>{for(let A of Z)try{A(H);}catch(se){let Y=b[S]?.options?.snapshotSafety??"warn";if(v()&&(p==="ref"||p==="shallow")&&Bo(se)){if(Y==="throw")throw se;if(Y==="auto-clone")try{let Fe=C(H);g(`Snapshot mutation detected for "${S}". Delivered a cloned snapshot to the subscriber.`);try{A(Fe);}catch(bt){g(`Subscriber for "${S}" threw on cloned snapshot: ${bt?.message??bt}`);}continue}catch{}g(`Snapshot mutation detected for "${S}": ${se?.message??se}`);continue}g(`Subscriber for "${S}" threw: ${se?.message??se}`);}};Me?Gt(Me,Ee):Ee();let Te=O()-ne;m(S,Te),er(G,Te),tr(b[S],G),(b[S]?.updateCount??E)!==E&&n.pendingNotifications.add(S);}Ce();return}let sr=S=>{let j=[];for(let E of s){if(S&&!S(E))continue;let p=f[E];if(!p||p.size===0)continue;let ge=b[E]?.updateCount??0,W=R(E),H=w(E),G=h[E],ne=G&&G.source===H&&G.mode===W?G.snapshot:(()=>{let Z=Qt(H,W);return h[E]={version:r,snapshot:Z,source:H,mode:W},Z})();j.push({name:E,snapshot:ne,version:ge,subscribers:Array.from(p),subscriberSet:new Set(p),notified:new Set,metrics:Zt(b[E]?.metrics),totalMs:0,beforeHooked:false});}return j},ir=u?sr(S=>u.has(S)):[],ar=sr(S=>!u||!u.has(S)),mt=(S,j)=>{let E=()=>{if(S.length===0){j();return}let p=S.shift();if((b[p.name]?.updateCount??p.version)!==p.version){if(n.pendingNotifications.add(p.name),S.length===0){j();return}Ue(E,c);return}let W=()=>{let q=f[p.name];if(!(!q||q.size===0))for(let A of q)p.subscriberSet.has(A)||(p.subscriberSet.add(A),p.subscribers.push(A));};W();let H=p.subscribers;if(H.length===0){if(S.length===0){j();return}Ue(E,c);return}p.beforeHooked||(p.beforeHooked=true,D(p.name));let G=O(),ne=0,Z=false,Me=$(p.name),Ee=()=>{for(let q=0;q<H.length&&ne<i;q+=1){let A=H[q];if(p.notified.has(A))continue;p.notified.add(A);try{A(p.snapshot);}catch(Y){let ht=b[p.name]?.options?.snapshotSafety??"warn",Fe=R(p.name);if(v()&&(Fe==="ref"||Fe==="shallow")&&Bo(Y)){if(ht==="throw")throw Y;if(ht==="auto-clone")try{let cr=C(p.snapshot);g(`Snapshot mutation detected for "${p.name}". Delivered a cloned snapshot to the subscriber.`);try{A(cr);}catch(ur){g(`Subscriber for "${p.name}" threw on cloned snapshot: ${ur?.message??ur}`);}if(p.notified.add(A),ne+=1,(b[p.name]?.updateCount??p.version)!==p.version){Z=!0,n.pendingNotifications.add(p.name);break}continue}catch{}g(`Snapshot mutation detected for "${p.name}": ${Y?.message??Y}`);continue}g(`Subscriber for "${p.name}" threw: ${Y?.message??Y}`);}if(ne+=1,(b[p.name]?.updateCount??p.version)!==p.version){Z=true,n.pendingNotifications.add(p.name);break}}};if(Me?Gt(Me,Ee):Ee(),p.totalMs+=O()-G,Z){if(S.length===0){j();return}Ue(E,c);return}W();let Te=false;for(let q of H)if(!p.notified.has(q)){Te=true;break}if(Te?S.push(p):(er(p.metrics,p.totalMs),tr(b[p.name],p.metrics),m(p.name,p.totalMs)),S.length===0){j();return}Ue(E,c);};E();};ir.length>0?mt(ir,()=>mt(ar,Ce)):mt(ar,Ce);};var Jn=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=Lo(t);Uo(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&rr(e);});},rr=e=>{qo(e,Jn);};var Xn=e=>{let t=M(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&rr(t);};Co(Xn);var Qn=()=>{let e=M().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};x("notify.reset",Qn,40);var gt=(e,t={},r)=>{if(z()){let a="hydrateStores(...) cannot be called inside setStoreBatch.";return g(a),be(a),{hydrated:[],created:[],failed:[],blocked:{reason:"transaction"}}}let o={hydrated:[],created:[],failed:[]};if(!e||typeof e!="object")return o;let n=M(),s=r??{};if(!(s.allowTrusted===true||s.allowHydration===true||s.allowUntrusted===true||k().allowUntrustedHydration===true))return T("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 a=false;try{a=!!s.validate(e);}catch(u){let l=`hydrateStores() trust.validate threw: ${u?.message??u}`;if(v())throw new Error(`hydrateStores() trust.validate threw an error. Fix your validator before this becomes a silent production failure.
12
+ Original error: ${u?.message??u}`);let y=t?.default?.onError;if(typeof y=="function")try{y(l);}catch(f){T(`hydrateStores(...) onError threw: ${f?.message??f}`);}if(T(l),typeof s.onValidationError=="function")try{if(!!s.onValidationError(u,e))a=!0;else return o.blocked={reason:"validation-error",cause:u},o}catch(f){return T(`hydrateStores(...) onValidationError threw: ${f?.message??f}`),o.blocked={reason:"validation-error",cause:f},o}else return o.blocked={reason:"validation-error",cause:u},o}if(!a)return T("hydrateStores(...) rejected by trust validation."),o.blocked={reason:"validation-failed"},o}let c=[];return Object.entries(e).forEach(([a,u])=>{if(!Ae(a)){o.failed.push({name:a,reason:"invalid-name"});return}if(U(a,n)){let l=Yt(n,a,u,"hydrate");l.ok?(o.hydrated.push(a),c.push(a)):o.failed.push({name:a,reason:"merge-failed",cause:l.reason,received:u});}else {let l=t;Mo(a,u,l[a]||l.default||{})?(o.created.push(a),c.push(a)):o.failed.push({name:a,reason:"create-failed",received:u});}}),c.length>0&&Wt(c).forEach(u=>{let l=n.computedEntries[u];if(!l)return;let y=l.deps.map(f=>Ut(f));try{let f=l.compute(...y);if(f&&typeof f.then=="function"){g(`hydrateStores recompute for "${u}" returned a Promise; skipping.`);return}let b=Ut(u);if(Object.is(f,b))return;jo(u,f);}catch(f){g(`hydrateStores recompute for "${u}" failed: ${f?.message??f}`);}}),o};var nr=new AsyncLocalStorage,St=new AsyncLocalStorage,or=new AsyncLocalStorage,Ko=new AsyncLocalStorage;wr({run:(e,t)=>nr.run(e,t),get:()=>nr.getStore()||null});xr({run:(e,t)=>St.run(e,t),get:()=>St.getStore()||null,enterWith:e=>St.enterWith(e)});Ur({run:(e,t)=>or.run(e,t),get:()=>or.getStore()||null,enterWith:e=>or.enterWith(e)});Fo({run:(e,t)=>Ko.run(e,t),get:()=>Ko.getStore()||null});var Fc=e=>{let t=kt("request"),r={},o={},n=i=>Object.prototype.hasOwnProperty.call(r,i);return typeof e=="function"&&e({create:(i,c,a={})=>(r[i]=C(c),o[i]={...a},r[i]),set:(i,c)=>{if(!n(i))throw new Error(`createStoreForRequest.set("${i}") requires create("${i}", initialState) first.`);return r[i]=typeof c=="function"?Pt(r[i],c):c,r[i]},get:i=>n(i)?C(r[i]):void 0}),{registry:t,snapshot:()=>C(r),hydrate:(i,c={})=>{let a={...c,default:c.default};return Object.keys(r).forEach(u=>{let l=u,y={...c.default||{},...c[l]||{},...o[u]||{}};a[l]=y;}),St.run(t,()=>nr.run(C(r),()=>(gt(r,a,{allowTrusted:true}),i())))}}};export{Fc as createStoreForRequest};//# sourceMappingURL=server.js.map
13
13
  //# sourceMappingURL=server.js.map