stroid 0.1.4-beta.0 → 0.1.4

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