stroid 0.1.1 → 0.1.2

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 (180) hide show
  1. package/CHANGELOG.md +210 -119
  2. package/README.md +104 -431
  3. package/dist/async.d.ts +42 -9
  4. package/dist/async.js +26 -26
  5. package/dist/async.js.map +1 -1
  6. package/dist/cache.d.ts +12 -0
  7. package/dist/computed.d.ts +40 -7
  8. package/dist/computed.js +11 -11
  9. package/dist/computed.js.map +1 -1
  10. package/dist/core.d.ts +5 -15
  11. package/dist/core.js +14 -15
  12. package/dist/core.js.map +1 -1
  13. package/dist/devtools.d.ts +30 -5
  14. package/dist/devtools.js +1 -1
  15. package/dist/devtools.js.map +1 -1
  16. package/dist/feature.d.ts +92 -14
  17. package/dist/feature.js +1 -1
  18. package/dist/feature.js.map +1 -1
  19. package/dist/helpers.d.ts +37 -3
  20. package/dist/helpers.js +14 -15
  21. package/dist/helpers.js.map +1 -1
  22. package/dist/index-internal.d.ts +44 -0
  23. package/dist/index.d.cts +169 -33
  24. package/dist/index.d.ts +169 -33
  25. package/dist/index.js +24 -23
  26. package/dist/index.js.map +1 -1
  27. package/dist/install.d.ts +6 -4
  28. package/dist/install.js +1 -1
  29. package/dist/install.js.map +1 -1
  30. package/dist/options.d.ts +295 -0
  31. package/dist/persist.d.ts +1 -1
  32. package/dist/persist.js +1 -1
  33. package/dist/persist.js.map +1 -1
  34. package/dist/react/index.d.ts +70 -0
  35. package/dist/react/index.js +38 -0
  36. package/dist/react/index.js.map +1 -0
  37. package/dist/registry.d.ts +117 -0
  38. package/dist/runtime-admin.d.ts +4 -2
  39. package/dist/runtime-admin.js +1 -1
  40. package/dist/runtime-admin.js.map +1 -1
  41. package/dist/runtime-tools.d.ts +66 -9
  42. package/dist/runtime-tools.js +2 -2
  43. package/dist/runtime-tools.js.map +1 -1
  44. package/dist/selectors.d.ts +4 -2
  45. package/dist/selectors.js +1 -1
  46. package/dist/selectors.js.map +1 -1
  47. package/dist/server.d.ts +30 -2
  48. package/dist/server.js +11 -10
  49. package/dist/server.js.map +1 -1
  50. package/dist/store-registry.d.ts +80 -0
  51. package/dist/sync.d.ts +1 -1
  52. package/dist/sync.js +1 -1
  53. package/dist/sync.js.map +1 -1
  54. package/dist/testing.d.ts +16 -4
  55. package/dist/testing.js +14 -15
  56. package/dist/testing.js.map +1 -1
  57. package/dist/tsdoc-metadata.json +11 -0
  58. package/dist/types/adapters/options.d.ts +335 -0
  59. package/dist/types/async/cache.d.ts +39 -0
  60. package/dist/types/async/clone.d.ts +10 -0
  61. package/dist/types/async/errors.d.ts +3 -0
  62. package/dist/types/async/fetch.d.ts +37 -0
  63. package/dist/types/async/inflight.d.ts +13 -0
  64. package/dist/types/async/rate.d.ts +5 -0
  65. package/dist/types/async/registry.d.ts +116 -0
  66. package/dist/types/async/request.d.ts +11 -0
  67. package/dist/types/async/retry.d.ts +10 -0
  68. package/dist/types/async.d.ts +10 -0
  69. package/dist/types/computed/computed-graph.d.ts +29 -0
  70. package/dist/types/computed/index.d.ts +16 -0
  71. package/dist/types/config.d.ts +10 -0
  72. package/dist/types/core/index.d.ts +11 -0
  73. package/dist/types/core/lifecycle-hooks.d.ts +16 -0
  74. package/dist/types/core/store-admin-impl.d.ts +9 -0
  75. package/dist/types/core/store-admin.d.ts +9 -0
  76. package/dist/types/core/store-core.d.ts +13 -0
  77. package/dist/types/core/store-create.d.ts +16 -0
  78. package/dist/types/core/store-hydrate-impl.d.ts +35 -0
  79. package/dist/types/core/store-hydrate.d.ts +9 -0
  80. package/dist/types/core/store-lifecycle/hooks.d.ts +19 -0
  81. package/dist/types/core/store-lifecycle/identity.d.ts +23 -0
  82. package/dist/types/core/store-lifecycle/registry.d.ts +53 -0
  83. package/dist/types/core/store-lifecycle/types.d.ts +67 -0
  84. package/dist/types/core/store-lifecycle/validation.d.ts +53 -0
  85. package/dist/types/core/store-name.d.ts +28 -0
  86. package/dist/types/core/store-notify.d.ts +12 -0
  87. package/dist/types/core/store-read.d.ts +18 -0
  88. package/dist/types/core/store-registry.d.ts +108 -0
  89. package/dist/types/core/store-replace-impl.d.ts +11 -0
  90. package/dist/types/core/store-replace.d.ts +9 -0
  91. package/dist/types/core/store-set-impl.d.ts +13 -0
  92. package/dist/types/core/store-set.d.ts +9 -0
  93. package/dist/types/core/store-shared/core.d.ts +13 -0
  94. package/dist/types/core/store-shared/notify.d.ts +12 -0
  95. package/dist/types/core/store-transaction.d.ts +26 -0
  96. package/dist/types/core/store-write-shared.d.ts +19 -0
  97. package/dist/types/core/store-write.d.ts +13 -0
  98. package/dist/types/features/feature-registry.d.ts +91 -0
  99. package/dist/types/features/lifecycle.d.ts +40 -0
  100. package/dist/types/index.d.ts +17 -0
  101. package/dist/types/integrations/query.d.ts +8 -0
  102. package/dist/types/internals/computed-order.d.ts +3 -0
  103. package/dist/types/internals/config.d.ts +116 -0
  104. package/dist/types/internals/diagnostics.d.ts +21 -0
  105. package/dist/types/internals/reporting.d.ts +9 -0
  106. package/dist/types/internals/store-admin.d.ts +7 -0
  107. package/dist/types/internals/store-ops.d.ts +13 -0
  108. package/dist/types/internals/test-reset.d.ts +2 -0
  109. package/dist/types/internals/write-context.d.ts +15 -0
  110. package/dist/types/notification/delivery.d.ts +3 -0
  111. package/dist/types/notification/index.d.ts +10 -0
  112. package/dist/types/notification/metrics.d.ts +12 -0
  113. package/dist/types/notification/priority.d.ts +9 -0
  114. package/dist/types/notification/scheduler.d.ts +11 -0
  115. package/dist/types/notification/snapshot.d.ts +8 -0
  116. package/dist/types/runtime-admin/index.d.ts +2 -0
  117. package/dist/types/runtime-tools/index.d.ts +58 -0
  118. package/dist/types/store.d.ts +16 -0
  119. package/dist/types/types/utility.d.ts +17 -0
  120. package/dist/types/utils/clone.d.ts +4 -0
  121. package/dist/types/utils/devfreeze.d.ts +2 -0
  122. package/dist/types/utils/hash.d.ts +8 -0
  123. package/dist/types/utils/path.d.ts +5 -0
  124. package/dist/types/utils/validation.d.ts +14 -0
  125. package/dist/types/utils.d.ts +13 -0
  126. package/dist/types.d.ts +65 -0
  127. package/dist/utility.d.ts +15 -0
  128. package/package.json +26 -11
  129. package/dist/_tsup-dts-rollup.d.cts +0 -2411
  130. package/dist/_tsup-dts-rollup.d.ts +0 -2411
  131. package/dist/async.cjs +0 -34
  132. package/dist/async.cjs.map +0 -1
  133. package/dist/async.d.cts +0 -9
  134. package/dist/computed.cjs +0 -13
  135. package/dist/computed.cjs.map +0 -1
  136. package/dist/computed.d.cts +0 -7
  137. package/dist/core.cjs +0 -24
  138. package/dist/core.cjs.map +0 -1
  139. package/dist/core.d.cts +0 -15
  140. package/dist/devtools.cjs +0 -2
  141. package/dist/devtools.cjs.map +0 -1
  142. package/dist/devtools.d.cts +0 -5
  143. package/dist/feature.cjs +0 -2
  144. package/dist/feature.cjs.map +0 -1
  145. package/dist/feature.d.cts +0 -14
  146. package/dist/helpers.cjs +0 -24
  147. package/dist/helpers.cjs.map +0 -1
  148. package/dist/helpers.d.cts +0 -3
  149. package/dist/index.cjs +0 -35
  150. package/dist/index.cjs.map +0 -1
  151. package/dist/install.cjs +0 -2
  152. package/dist/install.cjs.map +0 -1
  153. package/dist/install.d.cts +0 -4
  154. package/dist/persist.cjs +0 -2
  155. package/dist/persist.cjs.map +0 -1
  156. package/dist/persist.d.cts +0 -1
  157. package/dist/react.cjs +0 -36
  158. package/dist/react.cjs.map +0 -1
  159. package/dist/react.d.cts +0 -7
  160. package/dist/react.d.ts +0 -7
  161. package/dist/react.js +0 -36
  162. package/dist/react.js.map +0 -1
  163. package/dist/runtime-admin.cjs +0 -2
  164. package/dist/runtime-admin.cjs.map +0 -1
  165. package/dist/runtime-admin.d.cts +0 -2
  166. package/dist/runtime-tools.cjs +0 -4
  167. package/dist/runtime-tools.cjs.map +0 -1
  168. package/dist/runtime-tools.d.cts +0 -9
  169. package/dist/selectors.cjs +0 -2
  170. package/dist/selectors.cjs.map +0 -1
  171. package/dist/selectors.d.cts +0 -2
  172. package/dist/server.cjs +0 -12
  173. package/dist/server.cjs.map +0 -1
  174. package/dist/server.d.cts +0 -2
  175. package/dist/sync.cjs +0 -2
  176. package/dist/sync.cjs.map +0 -1
  177. package/dist/sync.d.cts +0 -1
  178. package/dist/testing.cjs +0 -24
  179. package/dist/testing.cjs.map +0 -1
  180. package/dist/testing.d.cts +0 -4
package/dist/core.d.ts CHANGED
@@ -1,15 +1,5 @@
1
- export { createStore } from './_tsup-dts-rollup.js';
2
- export { setStore } from './_tsup-dts-rollup.js';
3
- export { deleteStore } from './_tsup-dts-rollup.js';
4
- export { getStore } from './_tsup-dts-rollup.js';
5
- export { Path } from './_tsup-dts-rollup.js';
6
- export { PathValue } from './_tsup-dts-rollup.js';
7
- export { PartialDeep } from './_tsup-dts-rollup.js';
8
- export { StoreDefinition } from './_tsup-dts-rollup.js';
9
- export { StoreValue } from './_tsup-dts-rollup.js';
10
- export { StoreKey } from './_tsup-dts-rollup.js';
11
- export { StoreName } from './_tsup-dts-rollup.js';
12
- export { StateFor } from './_tsup-dts-rollup.js';
13
- export { StoreStateMap } from './_tsup-dts-rollup.js';
14
- export { StrictStoreMap } from './_tsup-dts-rollup.js';
15
- export { WriteResult } from './_tsup-dts-rollup.js';
1
+ export { c as createStore, d as deleteStore, b as getStore, h as hasStore, r as resetStore, s as setStore } from './index-internal.js';
2
+ import './options.js';
3
+ import './utility.js';
4
+ import './types.js';
5
+ import './feature.js';
package/dist/core.js CHANGED
@@ -1,24 +1,23 @@
1
- var Er=new Map,O=(e,t,r=0)=>{!e||typeof t!="function"||Er.set(e,{name:e,order:r,fn:t});};var ft=()=>({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,noSignalWarned:new Set,shapeWarned:new Set,autoCreateWarned:new Set,mutableResultWarned:new Set,cleanupSubs:Object.create(null),storeCleanupFns: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}}),pt=e=>{Object.values(e.revalidateHandlers).forEach(t=>{try{t();}catch{}}),Object.values(e.cleanupSubs).forEach(t=>{try{t();}catch{}}),Object.values(e.storeCleanupFns).forEach(t=>{t.forEach(r=>{try{r();}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.cleanupSubs).forEach(t=>delete e.cleanupSubs[t]),Object.keys(e.storeCleanupFns).forEach(t=>delete e.storeCleanupFns[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.noSignalWarned.clear(),e.shapeWarned.clear(),e.autoCreateWarned.clear(),e.mutableResultWarned.clear(),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 Be=new Map,Fr=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,gt,Ue=e=>(gt||Fr||e).replace(/\.ts(\?|$)/,".js$1"),pe=Ue(new URL("./store.js",import.meta.url).href);var Vr=()=>{gt=void 0,Be.clear();};O("registry.scope-override",Vr,110);var Or=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0}),Tr=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;},Dr=()=>({stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:{depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0},async:ft(),notify:Or()}),ge=e=>{let t=Ue(e),r=Be.get(t);if(r)return r;let n=Dr();return Be.set(t,n),n},re=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),St=(e,t)=>e.deletingStores.has(t),yt=e=>{e.computedCleanups.forEach(t=>{try{t();}catch{}}),e.computedCleanups.clear(),[e.stores,e.subscribers,e.initialStates,e.initialFactories,e.metaEntries,e.snapshotCache,e.computedEntries,e.computedDependents].forEach(t=>{Object.keys(t).forEach(r=>{delete t[r];});}),e.deletingStores.clear(),e.transaction.depth=0,e.transaction.pending=[],e.transaction.stagedValues.clear(),e.transaction.snapshotCache.clear(),e.transaction.failed=false,e.transaction.error=void 0,Tr(e.notify),pt(e.async);};var qe=()=>null;var Oe=(e,t)=>t(),B=e=>e||ge(pe);var Nr={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}`));}},mt={logSink:Nr,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",defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0},Ge=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,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce}),Ke=new WeakMap,ht=Ge(mt),Ar=e=>{let t=Ke.get(e);return t||(t=Ge(ht),Ke.set(e,t)),t};var R=()=>Ar(B());var _r=()=>{Ke=new WeakMap,ht=Ge(mt);};O("config.reset",_r,90);var bt=()=>R().namespace;var Ir=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,zr=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,vt=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,Wr="production",Hr=Ir??zr??Wr,Se=typeof vt=="boolean"?vt:Hr!=="production",x=()=>Se,Ye=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Br=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},Lr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},P=(e,t)=>{if((R().logSink.critical??Br)(e,t),R().assertRuntime)throw new Error(e)},b=(e,t)=>{if(!Se)return;if((R().logSink.warn??Ye)(e,t),R().assertRuntime)throw new Error(e)},z=(e,t)=>{if((R().logSink.warn??Ye)(e,t),R().assertRuntime)throw new Error(e)},$=(e,t)=>{if(Se&&(R().logSink.warn??Ye)(e,t),P(e,t),R().assertRuntime)throw new Error(e)},W=(e,t)=>{if(!Se)return;(R().logSink.log??Lr)(e,t);},wt=()=>`Functions cannot be stored in stroid.
2
- Store data only - handle functions outside the store.`,kt=()=>`Map/Set detected. stroid converts these to plain objects.
3
- Use arrays or plain objects for best results.`,Rt=()=>`Date object detected. stroid stores it as ISO string.
4
- Use new Date(value) to convert back when reading.`,xt=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Ct=()=>"Map detected; converting to plain object.",Mt=()=>"Set detected; converting to array.",Et=(e,t,r)=>`Path depth of ${e} exceeded maximum of ${t}.
1
+ var _o=new Map,F=(e,t,r=0)=>{!e||typeof t!="function"||_o.set(e,{name:e,order:r,fn:t});};var kt=new Map;var Ze=e=>kt.has(e),et=e=>kt.get(e),xe=()=>Array.from(kt.keys());var lr=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),ur=()=>({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:lr(),storeCleanups:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}}),dr=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(o=>{try{o();}catch{}});});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.storeCleanups).forEach(t=>delete e.storeCleanups[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),lr().forEach((t,r)=>{e.warnedOnce.set(r,t);}),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var Rt=new Map,fr=new WeakSet,Ct=e=>{fr.has(e)||(fr.add(e),xe().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=et(t);r&&e.featureRuntimes.set(t,r());}}));},Ho=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,pr,Mt=e=>(pr||Ho||e).replace(/\.ts(\?|$)/,".js$1"),ke=Mt(new URL("../../store.js",import.meta.url).href);var Lo=()=>{pr=void 0,Rt.clear();};F("registry.scope-override",Lo,110);var Bo=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Uo=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},gr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),qo=(e="default")=>{let t={scope:e,stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:gr(),async:ur(),notify:Bo(),lifecycleListener:null};return Ct(t),t},Re=e=>{let t=Mt(e),r=Rt.get(t);if(r)return r;let o=qo();return Rt.set(t,o),o},Ce=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),Sr=(e,t)=>e.deletingStores.has(t),yr=e=>{e.computedCleanups.forEach(t=>{try{t();}catch{}}),e.computedCleanups.clear(),[e.stores,e.subscribers,e.initialStates,e.initialFactories,e.metaEntries,e.snapshotCache,e.computedEntries,e.computedDependents].forEach(t=>{Object.keys(t).forEach(r=>{delete t[r];});}),e.deletingStores.clear(),e.transaction.depth=0,e.transaction.pending=[],e.transaction.stagedValues.clear(),e.transaction.snapshotCache.clear(),e.transaction.failed=false,e.transaction.error=void 0,Uo(e.notify),dr(e.async),e.lifecycleListener=null;};var tt=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var Ie=()=>null,oe=[],hr={run:(e,t)=>{oe.push(e);try{return t()}finally{oe.pop();}},get:()=>oe.length>0?oe[oe.length-1]:null,enterWith:e=>{if(oe.length>0){oe[oe.length-1]=e;return}oe.push(e);}};var rt=(e,t)=>(hr).run(e,t),ne=e=>(hr).get()||e||Re(ke);var Go={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}`));}},br={logSink:Go,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",autoCorrelationIds:false,acknowledgeLooseTypes:false,pathCacheSize:500,defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0,selectorCloneFrozen:true},Et=e=>({logSink:{...e.logSink},flush:{...e.flush},revalidateOnFocus:{...e.revalidateOnFocus},namespace:e.namespace,strictMissingFeatures:e.strictMissingFeatures,assertRuntime:e.assertRuntime,strictMutatorReturns:e.strictMutatorReturns,asyncAutoCreate:e.asyncAutoCreate,asyncCloneResult:e.asyncCloneResult,autoCorrelationIds:e.autoCorrelationIds,acknowledgeLooseTypes:e.acknowledgeLooseTypes,pathCacheSize:e.pathCacheSize,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce,selectorCloneFrozen:e.selectorCloneFrozen}),Tt=new WeakMap,wr=Et(br),Yo=e=>{let t=Tt.get(e);return t||(t=Et(wr),Tt.set(e,t)),t};var R=()=>Yo(ne());var Zo=()=>{Tt=new WeakMap,wr=Et(br);};F("config.reset",Zo,90);var vr=()=>R().namespace;var en=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,tn=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,xr=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,rn="production",on=en??tn??rn,$e=typeof xr=="boolean"?xr:on!=="production",C=()=>$e,Ft=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},nn=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},sn=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},$=(e,t)=>{if((R().logSink.critical??nn)(e,t),R().assertRuntime)throw new Error(e)},S=(e,t)=>{if(!$e)return;if((R().logSink.warn??Ft)(e,t),R().assertRuntime)throw new Error(e)},U=(e,t)=>{if((R().logSink.warn??Ft)(e,t),R().assertRuntime)throw new Error(e)},H=(e,t)=>{if($e&&(R().logSink.warn??Ft)(e,t),$(e,t),R().assertRuntime)throw new Error(e)},q=(e,t)=>{if(!$e)return;(R().logSink.log??sn)(e,t);},kr=()=>`Functions cannot be stored in stroid.
2
+ Store data only - handle functions outside the store.`,Rr=()=>`Map/Set detected. stroid converts these to plain objects.
3
+ Use arrays or plain objects for best results.`,Cr=()=>`Date object detected. stroid stores it as ISO string.
4
+ Use new Date(value) to convert back when reading.`,Mr=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Tr=()=>"Map detected; converting to plain object.",Er=()=>"Set detected; converting to array.",Fr=(e,t,r)=>`Path depth of ${e} exceeded maximum of ${t}.
5
5
  "${r.join(".")}"
6
6
  This is a data design issue. Split into separate stores:
7
- createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,Ft=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
8
- Consider splitting into separate stores for better readability.`,Vt=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,Ot=e=>`Cannot go deeper at "${e}" - value is not an object`,Tt=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Dt=e=>`Store name "${e}" contains spaces.
9
- Use camelCase or kebab-case: "userName" or "user-name"`,Pt=e=>`Store name "${e}" is not allowed.
10
- Reserved names: "__proto__", "constructor", "prototype".`,Ur=128,qr=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=Ur,Kr=(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},(s,o)=>o),n=new Array(e.length+1);for(let s=1;s<=t.length;s++){n[0]=s;for(let o=1;o<=e.length;o++)n[o]=t[s-1]===e[o-1]?r[o-1]:Math.min(r[o-1],n[o-1],r[o])+1;[r,n]=[n,r];}return r[e.length]},Je=(e,t)=>{let r=t.find(n=>{let s=n.toLowerCase(),o=e.toLowerCase();return s.includes(o)||o.includes(s)||qr(s,o)&&Kr(s,o)<=2});if(r){b(`Store "${e}" not found. Did you mean "${r}"?`);return}$(`Store "${e}" not found.
7
+ createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,Vr=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
8
+ Consider splitting into separate stores for better readability.`,Dr=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,Or=e=>`Cannot go deeper at "${e}" - value is not an object`,Ar=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Pr=e=>`Store name "${e}" contains spaces.
9
+ Use camelCase or kebab-case: "userName" or "user-name"`,Nr=e=>`Store name "${e}" is not allowed.
10
+ Reserved names: "__proto__", "constructor", "prototype".`,an=128,cn=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=an,ln=(e,t)=>{if(e===t)return 0;if(e.length===0)return t.length;if(t.length===0)return e.length;let r=Array.from({length:e.length+1},(n,s)=>s),o=new Array(e.length+1);for(let n=1;n<=t.length;n++){o[0]=n;for(let s=1;s<=e.length;s++)o[s]=t[n-1]===e[s-1]?r[s-1]:Math.min(r[s-1],o[s-1],r[s])+1;[r,o]=[o,r];}return r[e.length]},Vt=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||cn(n,s)&&ln(n,s)<=2});if(r){S(`Store "${e}" not found. Did you mean "${r}"?`);return}H(`Store "${e}" not found.
11
11
  Available stores: [${t.join(", ")}]
12
- Call createStore("${e}", data) first.`);};var I=new Set(["__proto__","constructor","prototype"]),Qe=(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 s=r.error,o=s?.details?.[0]?.message||s?.message||r.message||e.errors;if(o)return {ok:!1,error:o};if(s)return {ok:!1,error:s}}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 K=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,Nt=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},me=e=>{let t=K(e);return t==="function"?($(wt()),false):t==="map"||t==="set"?(b(kt()),true):(t==="date"&&b(Rt()),true)},Xe=(e,t)=>{let r=Nt(e);if(r)throw new Error(`${r} values are not supported`);let n=K(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return true}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date"||n==="map"||n==="set")return false;if(n==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s=Object.keys(e);for(let o of s){let i=Number(o);if(!Number.isInteger(i))return false}for(let o=0;o<e.length;o+=1)if(o in e&&!Xe(e[o],t))return false;return true}if(n==="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 s=Object.getOwnPropertyDescriptors(e);for(let[o,i]of Object.entries(s)){if(!i.enumerable||I.has(o))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${o}")`);if(!Xe(i.value,t))return false}return true}return true},Ze=e=>Xe(e,new WeakSet),ye=(e,t)=>{let r=Nt(e);if(r)throw new Error(`${r} values are not supported`);let n=K(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date")return x()&&b(xt()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),x()&&b(Ct());let s={};for(let[o,i]of e){if(typeof o!="string")throw new Error("Map keys must be strings to remain JSON-safe");s[String(o)]=ye(i,t);}return s}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),x()&&b(Mt()),Array.from(e,s=>ye(s,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s={},o=Object.getOwnPropertyDescriptors(e);for(let[i,c]of Object.entries(o))if(c.enumerable&&!I.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);s[i]=ye(c.value,t);}return s}if(n==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(s=>ye(s,t))}return e},X=e=>ye(e,new WeakSet),et=e=>typeof e!="string"||e.trim()===""?($(Tt(e)),false):I.has(e)?($(Pt(e)),false):e.includes(" ")?($(Dt(e)),false):true;var tt=null,Gr=()=>{if(tt)return tt;let e,t=[];for(let r=0;r<256;r++){e=r;for(let n=0;n<8;n++)e=e&1?3988292384^e>>>1:e>>>1;t[r]=e>>>0;}return tt=t,t},jt=e=>{let t=Gr(),r=-1;for(let n=0;n<e.length;n++)r=r>>>0,r=r>>>8^t[(r^e.charCodeAt(n))&255];return (r^-1)>>>0},Yr=2166136261,Jr=2654435761,Xr=1e5,G=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},Q=(e,t)=>{G(e,t.length);for(let r=0;r<t.length;r++)G(e,t.charCodeAt(r));},V=(e,t)=>{Q(e,t);},At=(e,t)=>{if(Number.isNaN(t)){V(e,"NaN");return}if(!Number.isFinite(t)){V(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){V(e,"-0");return}let r=t|0;if(t===r){V(e,"int"),G(e,r);return}V(e,"num"),Q(e,String(t));},ne=(e,t)=>{if(e.nodes++>Xr){V(e,"[max]");return}if(t===null){V(e,"null");return}let r=typeof t;if(r==="string"){V(e,"string"),Q(e,t);return}if(r==="number"){V(e,"number"),At(e,t);return}if(r==="boolean"){V(e,t?"true":"false");return}if(r==="undefined"){V(e,"undefined");return}if(r==="bigint"){V(e,"bigint"),Q(e,t.toString());return}if(r==="symbol"){V(e,"symbol");let d=t;Q(e,Symbol.keyFor(d)??d.description??String(d));return}if(r==="function"){V(e,"function"),Q(e,t.name||"anonymous");return}let n=t,s=e.seen.get(n);if(s!==void 0){V(e,"ref"),G(e,s);return}let o=e.nextId++;if(e.seen.set(n,o),Array.isArray(n)){V(e,"array"),G(e,n.length);for(let d=0;d<n.length;d++)Object.prototype.hasOwnProperty.call(n,d)?ne(e,n[d]):V(e,"hole");return}if(n instanceof Date){V(e,"date"),At(e,n.getTime());return}if(n instanceof Map){V(e,"map"),G(e,n.size),n.forEach((d,g)=>{ne(e,g),ne(e,d);});return}if(n instanceof Set){V(e,"set"),G(e,n.size),n.forEach(d=>{ne(e,d);});return}V(e,"object");let i=Object.getOwnPropertyDescriptors(n),c=[];Object.entries(i).forEach(([d,g])=>{g?.enumerable&&(I.has(d)||"get"in g||"set"in g||c.push([d,g]));}),G(e,c.length);for(let[d,g]of c)Q(e,d),ne(e,g.value);},he=e=>{if(typeof e=="string")return jt(JSON.stringify(e));let t={h1:Yr,h2:Jr,seen:new WeakMap,nextId:1,nodes:0};ne(t,e);let r=t.h1>>>0,n=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,n^=n>>>16,n=Math.imul(n,668265261),n^=n>>>15,n=Math.imul(n,374761393),n^=n>>>16,(r&2097151)*4294967296+(n>>>0)};var Qr=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",rt=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(([n,s])=>{s.enumerable&&(I.has(n)||"get"in s||"set"in s||(t[n]=s.value));}),t},oe=(e,t=new WeakMap)=>{if(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 o=new Map;return t.set(e,o),e.forEach((i,c)=>{o.set(oe(c,t),oe(i,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(i=>{o.add(oe(i,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((i,c)=>{o[c]=oe(i,t);}),o}let r=globalThis?.WeakRef;if(r&&e instanceof r)return z("WeakRef values cannot be deep-cloned. Returning the original reference."),e;let n={};t.set(e,n);let s;try{s=Object.getOwnPropertyDescriptors(e);}catch{return z("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(s).forEach(([o,i])=>{!i.enumerable||I.has(o)||"get"in i||"set"in i||(n[o]=oe(i.value,t));}),n},D=e=>{try{if(Qr)return structuredClone(e)}catch{}return oe(e)};var $t=10,Zr=5,en=e=>{let t=[],r="",n=false;for(let s of e){if(n){r+=s,n=false;continue}if(s==="\\"){n=true;continue}if(s==="."){t.push(r),r="";continue}r+=s;}return n&&(r+="\\"),t.push(r),t},se=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?en(e):[String(e)],be=e=>{let t=se(e),r=t.length;return r>$t?($(Et(r,$t,t)),false):(r>Zr&&b(Ft(r,t)),true)},nt=(e,t)=>{let r=se(t),n=e;for(let s of r){if(n==null){b(Vt(r,s));return}if(typeof n!="object"){b(Ot(s));return}n=n[s];}return n},ot=(e,t,r)=>{let n=se(t);if(n.length===0)return e;for(let o of n)if(I.has(o))return P(`Blocked forbidden path segment "${String(o)}" in setStore path "${n.join(".")}".`),e;let s=(o,i)=>{let c=n[i],d=i===n.length-1;if(Array.isArray(o)){let g=Number(c);if(!Number.isInteger(g))return o;let S=[...o];return d?(S[g]=r,S):(S[g]=s(S[g],i+1),S)}if(o&&typeof o=="object"){if(I.has(c))return P(`Blocked unsafe path segment "${String(c)}" while setting "${n.join(".")}".`),o;let g={...o};return d?(g[c]=r,g):(g[c]=s(g[c],i+1),g)}if(o==null&&!d){let g=Number.isInteger(Number(c)),S=g?[]:{};if(g){let v=S,p=Number(c);return v[p]=s(void 0,i+1),v}return S[c]=s(void 0,i+1),S}return d?r:o};return s(e,0)};var it=new Set,tn=()=>{it.clear();};O("options.legacy-warnings",tn,30);var Te=(()=>{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"}})(),st=e=>{try{return typeof window>"u"?Te:e==="session"||e==="sessionStorage"?window.sessionStorage??Te:window.localStorage??Te}catch{return Te}},ve=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),ie=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),It=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}},rn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",_t=e=>{try{e[rn]=!0;}catch{}return e},nn={allowSSRGlobalStore:'scope: "global"',schema:"validate",validator:"validate",version:"persist.version",migrations:"persist.migrations",historyLimit:"devtools.historyLimit",redactor:"devtools.redactor",middleware:"lifecycle.middleware",onCreate:"lifecycle.onCreate",onSet:"lifecycle.onSet",onReset:"lifecycle.onReset",onDelete:"lifecycle.onDelete"},on=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:_t(S=>S),decrypt:_t(S=>S),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:st("localStorage"),...r};if(typeof e=="string")return {driver:st(e),...r};let n=e.encrypt||r.encrypt,s=e.decrypt||r.decrypt,o=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,d=e.allowPlaintext===true,g=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(o&&!i||!o&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(c&&It(n)&&!o)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||st("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:n,decrypt:s,encryptAsync:o,decryptAsync:i,allowPlaintext:d,sensitiveData:c,checksum:g,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},zt=e=>{if(!ve(e))return [];let t=[];return Object.entries(nn).forEach(([r,n])=>{ie(e,r)&&(it.has(r)||(it.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},Wt=(e={},t,r="deep")=>{let n=e.scope??"request",s=e.lazy===true,o=e.pathCreate===true,i=ve(e.lifecycle)?e.lifecycle:void 0,c=ve(e.persist)?e.persist:void 0,d=ve(e.devtools)?e.devtools:void 0,g=e.validate??e.validator??e.schema,S=e.snapshot==="shallow"||e.snapshot==="ref"?e.snapshot:r==="shallow"||r==="ref"?r:"deep",v=ve(e.features)?{...e.features}:void 0,p=ie(e,"persist"),w=ie(e,"sync"),u=ie(e,"devtools")||ie(e,"historyLimit")||ie(e,"redactor"),a=n==="global"?true:e.allowSSRGlobalStore??false,{persist:f=false,devtools:l=false,onError:m,sync:k}=e;if(c?.sensitiveData===true){let C=c.encrypt,F=c.encryptAsync;if((!C||It(C))&&!F)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:n,lazy:s,pathCreate:o,persist:n==="temp"&&!p?null:on(f,t),devtools:n==="temp"&&!u?false:typeof l=="boolean"?l:d?.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:m,validate:g,migrations:c?.migrations??e.migrations??{},version:c?.version??e.version??1,redactor:n==="temp"&&!u?void 0:d?.redactor??e.redactor,historyLimit:n==="temp"&&!u?0:d?.historyLimit??e.historyLimit??50,sync:n==="temp"&&!w?false:k??false,features:v,allowSSRGlobalStore:a,snapshot:S,explicitPersist:p,explicitSync:w,explicitDevtools:u}};var Ht=e=>{if(typeof e!="object"||e===null||e.$$typeof||typeof window<"u"&&e instanceof Element||e.constructor&&e.constructor.name!=="Object"&&e.constructor.name!=="Array")return e;let t=[e],r=new WeakSet;for(;t.length>0;){let n=t.pop();if(!r.has(n)){r.add(n),Object.isFrozen(n)||Object.freeze(n);for(let s of Object.keys(n)){let o=n[s];typeof o=="object"&&o!==null&&!r.has(o)&&t.push(o);}}}return e};var at=new Map;var De=e=>at.has(e),ct=e=>at.get(e),we=()=>Array.from(at.keys());var Pe=Symbol("stroid.middleware.abort"),Lt=({name:e,payload:t,middlewares:r,reportIssue:n,warn:s})=>{if(!Array.isArray(r)||r.length===0)return t.next;let o=new WeakSet,i=D(t.next);for(let c of r){if(typeof c!="function")continue;let d,g=i;try{d=c({action:t.action,name:e,prev:t.prev,next:g,path:t.path});}catch(S){let v=`Middleware for "${e}" failed: ${S?.message??S}`;return n(v,"dev"),Pe}if(d&&typeof d.then=="function"){let S=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(S,"dev"),Pe}d===void 0?(x()&&!o.has(c)&&(o.add(c),s(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=g):i=d;}return i},Ne=({name:e,label:t,fn:r,args:n,reportIssue:s})=>{if(typeof r=="function")try{r(...n);}catch(o){let i=`${t} for "${e}" failed: ${o?.message??o}`;s(i,"always");}};var Z=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:s}=t;if(s?.(e),r==="critical"){n==="dev"&&b(e),P(e);return}if(n==="always"){z(e);return}b(e);};var Ae=null,Ut=e=>{Ae=e;},qt=e=>Ae?Ae(e):[];O("computed.order-resolver",()=>{Ae=null;},105);var Kt=()=>B(ge(pe)),Gt=()=>Kt().computedEntries,an=()=>Kt().computedDependents;var Yt=e=>Object.prototype.hasOwnProperty.call(Gt(),e);var cn=e=>{let t=Gt(),r=an(),n=new Set,s=[...e];for(;s.length>0;){let S=s.shift(),v=r[S];if(v)for(let p of v)n.has(p)||(n.add(p),s.push(p));}if(n.size===0)return [];let o=S=>{let v=t[S];if(v)for(let p of v.deps)t[p]&&(n.has(p)||(n.add(p),o(p)));};Array.from(n).forEach(S=>o(S));let i=new Map,c=new Map;for(let S of n){let v=t[S];if(!v)continue;let p=0;for(let w of v.deps)n.has(w)&&(p++,c.has(w)||c.set(w,[]),c.get(w).push(S));i.set(S,p);}let d=[];for(let[S,v]of i)v===0&&d.push(S);d.sort();let g=[];for(;d.length>0;){let S=d.shift();g.push(S);let v=c.get(S)??[];for(let p of v){let w=(i.get(p)??1)-1;if(i.set(p,w),w===0){let u=d.findIndex(a=>a>p);u===-1?d.push(p):d.splice(u,0,p);}}}return g};Ut(cn);var je=new Set,Xt=e=>e?je.has(e):je.size>0,Qt=e=>{e&&je.add(e);},un=()=>{je.clear();};O("ssr.warnings",un,60);var Jt=new Set,ln=e=>{let t=bt();return !t||e.includes("::")?e:(x()&&!Jt.has(e)&&(Jt.add(e),b(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},ke=e=>ln(typeof e=="string"?e:e.name),$e=e=>L(e)&&!tr(e)?true:(Je(e,Object.keys(N)),false),Zt=(e,t,r={})=>{Z(t,{...r,onError:h[e]?.options?.onError});},er=(e,t,r={})=>{Z(e,{...r,onError:t});},ae=(e,t,r="dev")=>{Zt(e,t,{severity:"warn",visibility:r});},dn=(e,t,r="dev")=>{er(e,t,{severity:"warn",visibility:r});},Y=(e,t)=>Zt(e,t,{severity:"critical",visibility:"always"}),Re=(e,t)=>er(e,t,{severity:"critical",visibility:"always"}),_e=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
13
- Import "stroid/${t}" before calling createStore("${e}", ...).`;if(dn(n,r,"always"),R().strictMissingFeatures)throw new Error(n)};var xe=e=>(e??B()).transaction,fn=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 E=()=>xe().depth>0,A=(e,t)=>{let r=xe(t);r.failed=true,r.error||(r.error=fn(e));},Ie=e=>{let t=B();xe(t).pending.push(()=>Oe(t,e));},ze=(e,t)=>{let r=xe();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},ce=e=>{let t=xe();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var rr=new WeakMap,nr=new WeakMap,pn=500,gn="",Ce=e=>{let t=rr.get(e);return t||(t=new Map,rr.set(e,t)),t},ut=e=>{let t=nr.get(e);return t||(t=new Map,nr.set(e,t)),t},Sn=(e,t)=>{let r=ut(e),n=r.get(t);return n||(n=new Map,r.set(t,n)),n},or=(e,t,r)=>{for(e.has(t)&&e.delete(t),e.set(t,r);e.size>pn;){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=Ce(j());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let n=r[t];return typeof n=="function"?n.bind(r):n},set:(e,t,r)=>(Ce(j())[t]=r,true)});var sr=(e,t,r,n)=>{let s=h[e];if(!s)return {ok:true};let o=se(r);if(o.length===0)return {ok:true};let i=K(n),c=j(),d=Ce(c),g=Sn(c,e),S=o.join(gn),v=d.get(e);v||(v={children:new Map},d.set(e,v));let p=v;for(let m of o){let k=p.children.get(m);k||(k={children:new Map},p.children.set(m,k)),p=k;}let w=p.verdicts?.get(i);if(w){let m=`${S}|${i}`;return or(g,m,{node:p,type:i}),w}let u=s.options?.pathCreate===true,a=t,f={ok:true};for(let m=0;m<o.length;m++){let k=o[m],C=m===o.length-1;if(a==null){let y=`Path "${o.join(".")}" is invalid for "${e}" - "${o.slice(0,m).join(".")||"root"}" is ${a===null?"null":"undefined"}.`;P(y),f={ok:false,reason:y};break}if(typeof a!="object"){let y=`Path "${o.join(".")}" is invalid for "${e}" - "${o.slice(0,m).join(".")||"root"}" is not an object.`;P(y),f={ok:false,reason:y};break}if(Array.isArray(a)){let y=Number(k);if(!Number.isInteger(y)||y<0){let M=`Path "${o.join(".")}" targets non-numeric index "${k}" on an array in "${e}".`;P(M),f={ok:false,reason:M};break}let T=a;if(y>=T.length){let M=`Path "${o.join(".")}" is invalid for "${e}" - index ${y} is out of bounds (length ${T.length}).`;P(M),f={ok:false,reason:M};break}if(C){let M=T[y];if(M!=null){let te=K(M);if(te!==i){let fe=`Type mismatch setting "${o.join(".")}" on "${e}": expected ${te}, received ${i}.`;P(fe),f={ok:false,reason:fe};break}}f={ok:true};break}a=T[y];continue}if(!Object.prototype.hasOwnProperty.call(a,k)){if(u&&C){f={ok:true};break}let y=`Path "${o.join(".")}" is invalid for "${e}" - unknown key "${k}" at "${o.slice(0,m).join(".")||"root"}".`;P(y),f={ok:false,reason:y};break}if(C){let y=a[k];if(y!=null){let T=K(y);if(T!==i){let M=`Type mismatch setting "${o.join(".")}" on "${e}": expected ${T}, received ${i}.`;P(M),f={ok:false,reason:M};break}}f={ok:true};break}a=a[k];}p.verdicts||(p.verdicts=new Map);let l=p.verdicts.has(i);if(p.verdicts.set(i,f),!l){let m=`${S}|${i}`;or(g,m,{node:p,type:i});}return f},le=(e,t,r,n)=>{try{return n?.reuseInput&&Ze(t)?{ok:!0,value:t}:{ok:!0,value:X(t)}}catch(s){let o=`Sanitize failed for "${e}": ${s?.message??s}`;return h[e]?.options?.onError?.(o),r?.(o),b(o),{ok:false}}},yn=(e,t)=>{let r=new Set,n=h[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},lt=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let s=yn(e,n),o=(c,d)=>{s.forEach(g=>g(c)),d==="critical"?P(c):b(c);};if(typeof r=="function")try{let c=r(t);return c===!1?(o(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:c===!0?t:c}}catch(c){return o(`Validation for "${e}" failed: ${c?.message??c}`,"critical"),{ok:false}}let i=Qe(r,t);return i.ok?{ok:true,value:i.data??t}:(o(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},We=(e,t,r,n,s)=>{let o=le(e,t,n,s);if(!o.ok)return {ok:false};let i=lt(e,o.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},U=e=>{let t=j();Ce(t).delete(e),ut(t).delete(e);},mn=()=>{let e=j();Ce(e).clear(),ut(e).clear();};O("validation.path-cache",mn,50);ir(U);var Me=e=>{if((E()?ce(e):{has:false}).has||N[e]!==void 0)return true;let r=ue[e];if(!r)return true;try{let n=r(),s=le(e,n,h[e]?.options?.onError);if(!s.ok)return !1;let o=h[e]?.options?.validate,i=We(e,s.value,o,h[e]?.options?.onError);if(!i.ok)return !1;if(E()){let c=i.value;ze(e,c),Ie(()=>{q(e,c),J[e]=D(c),delete ue[e],U(e);});}else q(e,i.value),J[e]=D(i.value),delete ue[e],U(e);return !0}catch(n){return Y(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};function hn(e,t){let r=ke(e);if(!$e(r)||!Me(r))return null;let n=Ee(r);if(t===void 0)return n===null||typeof n!="object"?n:D(n);if(!be(t))return null;let s=nt(n,t);return s===null||typeof s!="object"?s:D(s)}var ar=e=>{let t=h[e]?.options?.snapshot??R().defaultSnapshotMode;return t==="shallow"||t==="ref"?t:"deep"},cr=(e,t)=>t==="ref"?e:t==="shallow"?rt(e):D(e);var He=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},bn=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:n}=e;r.length=0;for(let u of t)r.push(u);t.clear();let s=R().flush,o=s.priorityStores||[],i=new Set(r),c=o.length?new Set(o):null;if(n.length=0,c){for(let u of o)i.has(u)&&n.push(u);for(let u of r)c.has(u)||n.push(u);}else n.push(...r);let d=qt(n),g=new Set(n);for(let u of d)i.has(u)&&!g.has(u)&&(n.push(u),g.add(u));let S=Number.isFinite(s.chunkSize)&&s.chunkSize>0?s.chunkSize:Number.POSITIVE_INFINITY,v=s.chunkDelayMs,p=S===Number.POSITIVE_INFINITY&&v===0;return {names:n.slice(),sliceSize:S,chunkDelayMs:v,runInline:p,prioritySet:c}},vn=e=>{let t=e.notify,{names:r,sliceSize:n,chunkDelayMs:s,runInline:o,prioritySet:i}=bn(t),c=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),d=()=>{t.notifyScheduled=false,t.pendingNotifications.size>0&&ur(e);};if(o){for(let u of r){let a=ee[u];if(!a||a.size===0)continue;let f=h[u]?.updateCount??0,l=ar(u),m=Fe[u],k=m&&m.version===f?m.snapshot:(()=>{let M=cr(N[u],l);return Fe[u]={version:f,snapshot:M},M})(),C=c();for(let M of a)try{M(k);}catch(te){b(`Subscriber for "${u}" threw: ${te?.message??te}`);}let F=c()-C,y=h[u]?.metrics||{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0};y.notifyCount+=1,y.totalNotifyMs+=F,y.lastNotifyMs=F,h[u]&&(h[u].metrics=y),(h[u]?.updateCount??f)!==f&&t.pendingNotifications.add(u);}d();return}let g=u=>{let a=[];for(let f of r){if(u&&!u(f))continue;let l=ee[f];if(!l||l.size===0)continue;let m=h[f]?.updateCount??0,k=ar(f),C=Fe[f],F=C&&C.version===m?C.snapshot:(()=>{let y=cr(N[f],k);return Fe[f]={version:m,snapshot:y},y})();a.push({name:f,subsArray:Array.from(l),index:0,snapshot:F,version:m,notified:new Set,metrics:h[f]?.metrics?{...h[f].metrics}:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},totalMs:0});}return a},S=i?g(u=>i.has(u)):[],v=g(u=>!i||!i.has(u)),p=u=>{let a=ee[u.name];if(!a||a.size===0){u.subsArray=[],u.index=0;return}u.subsArray=Array.from(a),u.index=0;},w=(u,a)=>{let f=()=>{if(u.length===0){a();return}let l=u.shift();if((h[l.name]?.updateCount??l.version)!==l.version){if(t.pendingNotifications.add(l.name),u.length===0){a();return}o?f():He(f,s);return}if(p(l),l.subsArray.length===0){if(u.length===0){a();return}o?f():He(f,s);return}let k=c(),C=0,F=false;for(;l.index<l.subsArray.length&&C<n;){let M=l.subsArray[l.index++];if(l.notified.has(M))continue;l.notified.add(M);try{M(l.snapshot);}catch(fe){b(`Subscriber for "${l.name}" threw: ${fe?.message??fe}`);}if(C+=1,(h[l.name]?.updateCount??l.version)!==l.version){F=true,t.pendingNotifications.add(l.name);break}}if(l.totalMs+=c()-k,F){if(u.length===0){a();return}o?f():He(f,s);return}let y=ee[l.name],T=y?Array.from(y).some(M=>!l.notified.has(M)):false;if(l.index<l.subsArray.length||T?u.push(l):(l.metrics.notifyCount+=1,l.metrics.totalNotifyMs+=l.totalMs,l.metrics.lastNotifyMs=l.totalMs,h[l.name]&&(h[l.name].metrics=l.metrics)),u.length===0){a();return}o?f():He(f,s);};f();};S.length>0?w(S,()=>w(v,d)):w(v,d);},ur=e=>{let t=e.notify;if(t.notifyScheduled)return;t.notifyScheduled=true;let r=()=>Oe(e,()=>vn(e));typeof queueMicrotask=="function"?queueMicrotask(r):Promise.resolve().then(r);},Ve=e=>{let t=j(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&ur(t);};var wn=()=>{let e=j().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};O("notify.reset",wn,40);var kn=()=>j().computedCleanups;var lr=e=>{let t=kn(),r=t.get(e);if(!r){x()&&b(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var dr=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,s=e.initialFactories,o=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,d=e.deletingStores,g=(a,f)=>{Z(f,{onError:o[a]?.options?.onError,severity:"warn",visibility:"dev"});},S=({name:a,prev:f,options:l,initialState:m,getMeta:k,getStoreValue:C,hasStore:F})=>({name:a,options:l,prev:f,getMeta:k,getStoreValue:C,getAllStores:()=>t,getInitialState:()=>m,hasStore:F,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:y=>{Z(y,{onError:l.onError,severity:"warn",visibility:"dev"});},warn:b,log:W,hashState:he,deepClone:D,sanitize:X,validate:()=>({ok:true,value:f}),isDev:x}),v=({name:a,prev:f,options:l,initialState:m,phase:k})=>{let C=S({name:a,prev:f,options:l,initialState:m,getMeta:()=>o[a],getStoreValue:()=>t[a],hasStore:()=>re(e,a)}),F=S({name:a,prev:f,options:l,initialState:m,getMeta:()=>{},getStoreValue:()=>f,hasStore:()=>false});we().forEach(y=>{let T=c.get(y);k==="before"?T?.beforeStoreDelete?.(C):T?.afterStoreDelete?.(F);});},p=a=>{if(!re(e,a))return;let f=t[a],l=o[a].options,m=n[a],k=r[a];d.add(a);try{k?.forEach(y=>{try{y(null);}catch(T){b(`Subscriber for "${a}" threw during delete: ${T?.message??T}`);}}),Ne({name:a,label:"onDelete",fn:l.onDelete,args:[f],reportIssue:(y,T)=>{Z(y,{onError:l.onError,severity:"warn",visibility:T});}}),v({name:a,prev:f,options:l,initialState:m,phase:"before"}),delete t[a],delete r[a],delete n[a],delete s[a],delete o[a],delete i[a],Yt(a)&&lr(a);let F=e.computedDependents[a];if(F)for(let y of F)b(`[stroid] source store "${a}" was deleted. Computed store "${y}" depends on it and will return stale data. Call deleteComputed("${y}") to clean up.`);v({name:a,prev:f,options:l,initialState:m,phase:"after"}),W(`Store "${a}" deleted`);}finally{d.delete(a);}};return {deleteExistingStore:p,clearAllStores:()=>{let a=[],l=0,m=Number.POSITIVE_INFINITY;for(;l<20;){let C=Object.keys(t);if(C.length===0)break;C.forEach(y=>{re(e,y)&&(p(y),a.push(y));}),l+=1;let F=Object.keys(t).length;if(F===0||F>=m)break;m=F;}let k=Object.keys(t).length;return k>0?b(`clearAllStores stopped after ${l} pass${l===1?"":"es"}; ${k} store(s) still registered (likely recreated during deletion).`):b(`All stores cleared (${a.length} stores removed)`),a},clearStores:a=>{let f=Object.keys(t).filter(l=>a?a.endsWith("*")?l.startsWith(a.slice(0,-1)):l===a:true);return f.forEach(l=>p(l)),f},reportStoreError:g}};var Rn=pe,xn=ge(Rn),gr=null,fr=new WeakSet,Cn=e=>{fr.has(e)||(fr.add(e),we().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ct(t);r&&e.featureRuntimes.set(t,r());}}));},_=()=>{let e=B(xn);return Cn(e),e};var j=()=>_();function ir(e){gr=e;}var de=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,n)=>(e()[r]=n,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let n=Object.getOwnPropertyDescriptor(e(),r);if(n)return {...n,configurable:true}}}),Mn=e=>new Proxy(new Map,{get:(t,r)=>{let n=e();if(r==="size")return n.size;if(r===Symbol.iterator)return n[Symbol.iterator].bind(n);let s=n[r];return typeof s=="function"?s.bind(n):s},set:(t,r,n)=>(e()[r]=n,true)}),En=e=>new Proxy({},{get:(t,r)=>{let n=e(),s=n[r];return typeof s=="function"?s.bind(n):s},set:(t,r,n)=>(e()[r]=n,true)}),N=de(()=>_().stores),ee=de(()=>_().subscribers),J=de(()=>_().initialStates),ue=de(()=>_().initialFactories),h=de(()=>_().metaEntries),Fe=de(()=>_().snapshotCache),H=Mn(()=>_().featureRuntimes),pr=new WeakMap,Fn=e=>{let t=pr.get(e);return t||(t=dr(e),pr.set(e,t)),t},Sr=En(()=>Fn(_()));var Vn=e=>{let t=H.get(e);if(t)return t;let r=ct(e);if(!r)return;let n=r();return H.set(e,n),n},On=()=>{we().forEach(e=>{Vn(e);});};On();var L=e=>re(_(),e),Ee=e=>{if(E()){let r=ce(e);if(r.has)return r.value}let t=qe();return t&&Object.prototype.hasOwnProperty.call(t,e)?t[e]:N[e]},q=(e,t)=>{let n=x()?Ht(t):t;N[e]=n;},yr=(e,t,r=Date.now())=>{q(e,t),h[e]&&(h[e].updatedAt=new Date(r).toISOString(),h[e].updatedAtMs=r,h[e].updateCount++,gr?.(e));},Tn=()=>{yt(_());},Dn=()=>{H.forEach(e=>{try{e.resetAll?.();}catch{}}),H.clear();};O("features.reset",Dn,10);O("registries.clear",Tn,20);var tr=e=>St(_(),e);var mr=new WeakMap,hr=e=>{let t=mr.get(e);return t||(t=new Map,mr.set(e,t)),t},Pn=()=>{hr(j()).clear();};O("features.contexts",Pn,100);var br=e=>{let t=j(),r=hr(t),n=r.get(e);if(n)return n;let s=h[e];if(!s)return b(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let o={name:e,options:s.options,getMeta:()=>h[e],getStoreValue:()=>N[e],getAllStores:()=>N,getInitialState:()=>J[e],hasStore:()=>L(e),setStoreValue:i=>{q(e,i);},applyFeatureState:(i,c)=>{yr(e,i,c),U(e);},notify:()=>{},reportStoreError:i=>{Y(e,i);},warn:b,log:W,hashState:he,deepClone:D,sanitize:X,validate:i=>lt(e,i,h[e]?.options?.validate),isDev:x};return r.set(e,o),o},vr=(e,t)=>{let r=br(e);r&&(r.notify=()=>t(e),H.forEach(n=>{n.onStoreCreate?.(r);}));},wr=(e,t,r,n,s)=>{let o=br(e);if(!o)return;o.notify=()=>s(e);let i=Object.assign(Object.create(o),{action:t,prev:r,next:n});H.forEach(c=>{c.onStoreWrite?.(i);});};var kr=(e,t)=>Lt({name:e,payload:t,middlewares:(()=>{let r=h[e]?.options?.middleware||[],n=R().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{ae(e,r,n);},warn:b}),dt=(e,t,r,n)=>Ne({name:e,label:t,fn:r,args:n,reportIssue:(s,o)=>{ae(e,s,o);}}),Rr=(e,t)=>{let r={...t};return r.persist&&!De("persist")&&(r.explicitPersist&&_e(e,"persist",r.onError),r.persist=null),r.sync&&!De("sync")&&(r.explicitSync&&_e(e,"sync",r.onError),r.sync=false),De("devtools")||(r.explicitDevtools&&_e(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var Nn=32,xr=new Set,Cr=new Set,An=(e,t)=>{x()&&(t<Nn||xr.has(e)||(xr.add(e),b(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},Mr=({name:e,prev:t,next:r,action:n,hookLabel:s,logMessage:o})=>{q(e,r),U(e);let i=Date.now();h[e].updatedAt=new Date(i).toISOString(),h[e].updatedAtMs=i,h[e].updateCount++,wr(e,n,t,r,Ve),dt(e,s,h[e].options[s],[t,r]),Ve(e),W(o);},jn=e=>{if(E()){ze(e.name,e.next),Ie(()=>Mr(e));return}Mr(e);},$n=(e,t,r={})=>{if(E()){let a=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;Re(a,r.onError),A(a);return}if(!et(e)){Re(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!me(t)){Re(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&x()&&b(`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.`),zt(r).forEach(a=>{b(a);});let s=Rr(e,Wt(r,e,R().defaultSnapshotMode));if(s.scope==="temp"&&r.persist){let a=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;s.onError?.(a),x()||z(a),$(a);}let o=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=o&&i==="production",d=s.allowSSRGlobalStore??false;if(c&&!d){let a=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
14
- Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;Re(a,r.onError);return}if(c&&d&&!Cr.has(e)&&(Cr.add(e),z(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
15
- This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),L(e)){let a=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return ae(e,a),{name:e}}o&&!d&&!Xt(e)&&x()&&(Qt(e),b(`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 g=le(e,t,s.onError);if(!g.ok)return;let S=g.value,v=s.lazy===true&&typeof t=="function",p=(ee[e]?.size??0)>0;if(v)N[e]=void 0,ue[e]=t;else {let a=We(e,S,s.validate,s.onError);if(!a.ok)return;q(e,a.value),J[e]=D(a.value);}let w=Date.now(),u=new Date(w).toISOString();return h[e]={createdAt:u,updatedAt:u,updatedAtMs:w,updateCount:0,version:s.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},options:s},U(e),vr(e,Ve),dt(e,"onCreate",h[e].options.onCreate,[S]),p&&Ve(e),W(`Store "${e}" created -> ${JSON.stringify(S)}`),{name:e}};function _n(e,t,r){let n=ke(e);if(!Me(n))return {ok:false,reason:"validate"};if(!L(n)){let p=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return Y(n,p),E()&&A(p),{ok:false,reason:"not-found"}}let s,o=E()?ce(n):{has:false,value:void 0},i=o.has?o.value:Ee(n),c=typeof t=="function"&&r===void 0;if(c){let p=x()?Date.now():0;try{let w=R().mutatorProduce,u=!1,a,f=m=>{let k=t(m);return k!==void 0&&(u=!0,a=k),k},l=w?w(i,f):(()=>{let m=D(i);return f(m),m})();if(u&&R().strictMutatorReturns){let m=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return Y(n,m),E()&&A(m),{ok:!1,reason:"validate"}}u&&x()&&!R().strictMutatorReturns&&b(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),s=u&&!R().strictMutatorReturns?a:l;}catch(w){return Y(n,`Mutator for "${n}" failed: ${w?.message??w}`),E()&&A(w),{ok:false,reason:"validate"}}finally{p&&An(n,Date.now()-p);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!me(t))return E()&&A(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof i!="object"||i===null||Array.isArray(i))return $(`setStore("${n}", data) only merges into object stores.
16
- Use setStore("${n}", "path", value) or recreate the store with an object shape.`),E()&&A(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let p=le(n,t);if(!p.ok)return E()&&A(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};s={...i,...p.value};}else if(typeof t=="string"||Array.isArray(t)){if(!be(t))return E()&&A(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let p=le(n,r);if(!p.ok)return E()&&A(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let w=p.value,u=sr(n,i,t,w);if(!u.ok)return h[n]?.options?.onError?.(u.reason??`Invalid path for "${n}".`),E()&&A(u.reason),{ok:false,reason:"path"};s=ot(i,t,w);}else {let p=`setStore("${n}") - invalid arguments.
12
+ Call createStore("${e}", data) first.`);};var K=new Set(["__proto__","constructor","prototype"]),Ot=(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 ce=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,jr=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},Me=e=>{let t=ce(e);return t==="function"?(H(kr()),false):t==="map"||t==="set"?(S(Rr()),true):(t==="date"&&S(Cr()),true)},Dt=(e,t)=>{let r=jr(e);if(r)throw new Error(`${r} values are not supported`);let o=ce(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&&!Dt(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||K.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Dt(i.value,t))return false}return true}return true},At=e=>Dt(e,new WeakSet),ze=(e,t)=>{let r=jr(e);if(r)throw new Error(`${r} values are not supported`);let o=ce(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 C()&&S(Mr()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),C()&&S(Tr());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)]=ze(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),C()&&S(Er()),Array.from(e,n=>ze(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&&!K.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=ze(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=>ze(n,t))}return e},pe=e=>ze(e,new WeakSet),Pt=e=>typeof e!="string"||e.trim()===""?(H(Ar(e)),false):K.has(e)?(H(Nr(e)),false):e.includes(" ")?(H(Pr(e)),false):true;var Nt=null,un=()=>{if(Nt)return Nt;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 Nt=t,t},$r=e=>{let t=un(),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},dn=2166136261,fn=2654435761,pn=1e5,le=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},ge=(e,t)=>{le(e,t.length);for(let r=0;r<t.length;r++)le(e,t.charCodeAt(r));},P=(e,t)=>{ge(e,t);},Ir=(e,t)=>{if(Number.isNaN(t)){P(e,"NaN");return}if(!Number.isFinite(t)){P(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){P(e,"-0");return}let r=t|0;if(t===r){P(e,"int"),le(e,r);return}P(e,"num"),ge(e,String(t));},Te=(e,t)=>{if(e.nodes++>pn){P(e,"[max]");return}if(t===null){P(e,"null");return}let r=typeof t;if(r==="string"){P(e,"string"),ge(e,t);return}if(r==="number"){P(e,"number"),Ir(e,t);return}if(r==="boolean"){P(e,t?"true":"false");return}if(r==="undefined"){P(e,"undefined");return}if(r==="bigint"){P(e,"bigint"),ge(e,t.toString());return}if(r==="symbol"){P(e,"symbol");let c=t;ge(e,Symbol.keyFor(c)??c.description??String(c));return}if(r==="function"){P(e,"function"),ge(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){P(e,"ref"),le(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){P(e,"array"),le(e,o.length);for(let c=0;c<o.length;c++)Object.prototype.hasOwnProperty.call(o,c)?Te(e,o[c]):P(e,"hole");return}if(o instanceof Date){P(e,"date"),Ir(e,o.getTime());return}if(o instanceof Map){P(e,"map"),le(e,o.size),o.forEach((c,l)=>{Te(e,l),Te(e,c);});return}if(o instanceof Set){P(e,"set"),le(e,o.size),o.forEach(c=>{Te(e,c);});return}P(e,"object");let i=Object.getOwnPropertyDescriptors(o),a=[];Object.entries(i).forEach(([c,l])=>{l?.enumerable&&(K.has(c)||"get"in l||"set"in l||a.push([c,l]));}),le(e,a.length);for(let[c,l]of a)ge(e,c),Te(e,l.value);},_e=e=>{if(typeof e=="string")return $r(JSON.stringify(e));let t={h1:dn,h2:fn,seen:new WeakMap,nextId:1,nodes:0};Te(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 gn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",We=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&&(K.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},jt=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=[["WeakMap",globalThis.WeakMap],["WeakSet",globalThis.WeakSet],["WeakRef",globalThis.WeakRef],["Promise",globalThis.Promise],["ReadableStream",globalThis.ReadableStream],["WritableStream",globalThis.WritableStream],["TransformStream",globalThis.TransformStream],["EventTarget",globalThis.EventTarget]];for(let[o,n]of t)if(typeof n=="function"&&e instanceof n)return o;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},Sn=e=>jt(e)===null,yn=e=>{let t=jt(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},Se=(e,t=new WeakMap)=>{if(yn(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(Se(i,t),Se(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(Se(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=Se(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||K.has(n)||"get"in s||"set"in s||(r[n]=Se(s.value,t));}),r},O=e=>{if(gn)try{return structuredClone(e)}catch(t){if(!Sn(e)){let r=jt(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return S(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),Se(e)}return Se(e)},It=(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 zr=10,mn=5,hn=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},Ee=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?hn(e):[String(e)],He=e=>{let t=Ee(e),r=t.length;return r>zr?(H(Fr(r,zr,t)),false):(r>mn&&S(Vr(r,t)),true)},$t=(e,t)=>{let r=Ee(t),o=e;for(let n of r){if(o==null){S(Dr(r,n));return}if(typeof o!="object"){S(Or(n));return}o=o[n];}return o},zt=(e,t,r)=>{let o=Ee(t);if(o.length===0)return e;for(let s of o)if(K.has(s))return $(`Blocked forbidden path segment "${String(s)}" in setStore path "${o.join(".")}".`),e;let n=(s,i)=>{let a=o[i],c=i===o.length-1;if(Array.isArray(s)){let l=Number(a);if(!Number.isInteger(l))return s;let d=[...s];return c?(d[l]=r,d):(d[l]=n(d[l],i+1),d)}if(s&&typeof s=="object"){if(K.has(a))return $(`Blocked unsafe path segment "${String(a)}" while setting "${o.join(".")}".`),s;let l={...s};return c?(l[a]=r,l):(l[a]=n(l[a],i+1),l)}if(s==null&&!c){let l=Number.isInteger(Number(a)),d=l?[]:{};if(l){let b=d,w=Number(a);return b[w]=n(void 0,i+1),b}return d[a]=n(void 0,i+1),d}return c?r:s};return n(e,0)};var Wt=new Set,bn=()=>{Wt.clear();};F("options.legacy-warnings",bn,30);var ot=(()=>{let e=new Map;return {getItem:t=>e.has(t)?e.get(t):null,setItem:(t,r)=>{e.set(t,r);},removeItem:t=>{e.delete(t);},type:"memory"}})(),_t=e=>{try{return typeof window>"u"?ot:e==="session"||e==="sessionStorage"?window.sessionStorage??ot:window.localStorage??ot}catch{return ot}},Le=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Fe=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Wr=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}},wn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",_r=e=>{try{e[wn]=!0;}catch{}return e},vn={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"},xn=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:_r(b=>b),decrypt:_r(b=>b),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:_t("localStorage"),...r};if(typeof e=="string")return {driver:_t(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,a=e.sensitiveData===true,c=e.allowPlaintext===true,l=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,d=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(a&&Wr(o)&&!s)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`);return {driver:e.driver||e.storage||_t("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:o,decrypt:n,encryptAsync:s,decryptAsync:i,allowPlaintext:c,sensitiveData:a,maxSize:l,checksum:d,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Hr=e=>{if(!Le(e))return [];let t=[];return Object.entries(vn).forEach(([r,o])=>{Fe(e,r)&&(Wt.has(r)||(Wt.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},Lr=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=Le(e.lifecycle)?e.lifecycle:void 0,a=Le(e.persist)?e.persist:void 0,c=Le(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,d=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",b=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,w=Le(e.features)?{...e.features}:void 0,k=Fe(e,"persist"),m=Fe(e,"sync"),u=Fe(e,"devtools")||Fe(e,"historyLimit")||Fe(e,"redactor"),p=o==="global"?true:e.allowSSRGlobalStore??false,{persist:g=false,devtools:M=false,onError:v,sync:T}=e;if(a?.sensitiveData===true){let V=a.encrypt,h=a.encryptAsync;if((!V||Wr(V))&&!h)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:o,lazy:n,pathCreate:s,persist:o==="temp"&&!k?null:xn(g,t),devtools:o==="temp"&&!u?false:typeof M=="boolean"?M:c?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:v,validate:l,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:o==="temp"&&!u?void 0:c?.redactor??e.redactor,historyLimit:o==="temp"&&!u?0:c?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!m?false:T??false,features:w,allowSSRGlobalStore:p,snapshot:d,snapshotSafety:b,explicitPersist:k,explicitSync:m,explicitDevtools:u}};var nt=Symbol("stroid.middleware.abort"),Br=({name:e,payload:t,middlewares:r,reportIssue:o,warn:n})=>{if(!Array.isArray(r)||r.length===0)return t.next;let s=new WeakSet,i=O(t.next);for(let a of r){if(typeof a!="function")continue;let c,l=i;try{c=a({action:t.action,name:e,prev:t.prev,next:l,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(d){let b=`Middleware for "${e}" failed: ${d?.message??d}`;return o(b,"dev"),nt}if(c&&typeof c.then=="function"){let d=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(d,"dev"),nt}c===void 0?(C()&&!s.has(a)&&(s.add(a),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=l):i=c;}return i},st=({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 Q=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;U(`${t} callback threw: ${String(n)}`);}},ye=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(Q(n,"onError",e),r==="critical"){o==="dev"&&S(e),$(e);return}if(o==="always"){U(e);return}S(e);};var it=null,Ur=e=>{it=e;},qr=e=>it?it(e):[];F("computed.order-resolver",()=>{it=null;},105);var Kr=()=>ne(Re(ke)),Gr=()=>Kr().computedEntries,kn=()=>Kr().computedDependents;var Yr=e=>Object.prototype.hasOwnProperty.call(Gr(),e);var Rn=e=>{let t=Gr(),r=kn(),o=new Set,n=[...e];for(;n.length>0;){let d=n.shift(),b=r[d];if(b)for(let w of b)o.has(w)||(o.add(w),n.push(w));}if(o.size===0)return [];let s=d=>{let b=t[d];if(b)for(let w of b.deps)t[w]&&(o.has(w)||(o.add(w),s(w)));};Array.from(o).forEach(d=>s(d));let i=new Map,a=new Map;for(let d of o){let b=t[d];if(!b)continue;let w=0;for(let k of b.deps)o.has(k)&&(w++,a.has(k)||a.set(k,[]),a.get(k).push(d));i.set(d,w);}let c=[];for(let[d,b]of i)b===0&&c.push(d);c.sort();let l=[];for(;c.length>0;){let d=c.shift();l.push(d);let b=a.get(d)??[];for(let w of b){let k=(i.get(w)??1)-1;if(i.set(w,k),k===0){let m=c.findIndex(u=>u>w);m===-1?c.push(w):c.splice(m,0,w);}}}return l};Ur(Rn);var Jr=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")},Ht=e=>(Jr(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Xr=e=>{if(!Jr(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=null;var Cn=()=>{at=null;};F("transaction.runner",Cn,120);var Be=e=>{let t=at?.get();return t||(e??ne()).transaction},Mn=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var E=()=>at?(at.get()?.depth??0)>0:Be().depth>0,I=(e,t)=>{let r=Be(t);r.failed=true,r.error||(r.error=Mn(e));},ct=e=>{let t=ne();Be(t).pending.push(()=>rt(t,e));},lt=(e,t)=>{let r=Be();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},ue=e=>{let t=Be();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Qr=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Lt=(e,t)=>{if(t==="ref"){if(!C())return e;try{return Ht(e)}catch{return e}}if(t==="shallow"){let o=We(e);if(!C())return o;try{return Ht(o)}catch{return o}}let r=O(e);if(!C())return r;try{return Xr(r)}catch{return r}};var Zr=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:o}=e,n=R().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 m of t)r.push(m),a.add(m);for(let m of s)a.has(m)&&o.push(m);for(let m of r)i.has(m)||o.push(m);}else for(let m of t)r.push(m),a.add(m),o.push(m);t.clear();let c=qr(o),l=new Set(o);for(let m of c)l.has(m)||(o.push(m),l.add(m));let d=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,b=n.chunkDelayMs,w=d===Number.POSITIVE_INFINITY&&b===0;return {names:o,sliceSize:d,chunkDelayMs:b,runInline:w,prioritySet:i}};var Bt=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}),Ut=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),qt=(e,t)=>{e&&(e.metrics=t);};var Ue=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},eo=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>rt(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var to=new Map;var Kt=e=>{let t=to.get(e);return !!t&&t.size>0},qe=(e,t,r)=>{let o=to.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 ut=null,dt=()=>ut,Gt=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();let r=ut;ut=e;try{return t()}finally{ut=r;}};var ro=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)},oo=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:c,prioritySet:l}=t,b=n.subscriberBuffer,w=e.stores,k=e.subscribers,m=e.metaEntries,u=e.snapshotCache,p=R().defaultSnapshotMode,g=y=>Qr(m[y],p),M=y=>w[y],v=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),T=Kt("beforeFlush"),V=Kt("afterFlush"),h=y=>{T&&qe("beforeFlush",y,{type:"beforeFlush"});},x=(y,j)=>{V&&qe("afterFlush",y,{type:"afterFlush",elapsedMs:j});},J=y=>{let j=m[y];if(!j)return null;let A=j.lastCorrelationId??void 0,f=j.lastTraceContext??void 0;return !A&&!f?null:{correlationId:A,traceContext:f}},W=y=>{b.length=0;for(let j of y)b.push(j);return b},we=()=>{o();};if(c){for(let y of s){let j=k[y];if(!j||j.size===0)continue;let A=m[y]?.updateCount??0,f=g(y),ve=M(y),L=u[y],B=L&&L.source===ve&&L.mode===f?L.snapshot:(()=>{let _=Lt(ve,f);return u[y]={version:r,snapshot:_,source:ve,mode:f},_})(),te=Bt(m[y]?.metrics);h(y);let de=v(),ae=W(j),Ae=J(y),Pe=()=>{for(let _ of ae)try{_(B);}catch(fe){let re=m[y]?.options?.snapshotSafety??"warn";if(C()&&(f==="ref"||f==="shallow")&&ro(fe)){if(re==="throw")throw fe;if(re==="auto-clone")try{let je=O(B);S(`Snapshot mutation detected for "${y}". Delivered a cloned snapshot to the subscriber.`);try{_(je);}catch(xt){S(`Subscriber for "${y}" threw on cloned snapshot: ${xt?.message??xt}`);}continue}catch{}S(`Snapshot mutation detected for "${y}": ${fe?.message??fe}`);continue}S(`Subscriber for "${y}" threw: ${fe?.message??fe}`);}};Ae?Gt(Ae,Pe):Pe();let Ne=v()-de;x(y,Ne),Ut(te,Ne),qt(m[y],te),(m[y]?.updateCount??A)!==A&&n.pendingNotifications.add(y);}we();return}let Oe=y=>{let j=[];for(let A of s){if(y&&!y(A))continue;let f=k[A];if(!f||f.size===0)continue;let ve=m[A]?.updateCount??0,L=g(A),B=M(A),te=u[A],de=te&&te.source===B&&te.mode===L?te.snapshot:(()=>{let ae=Lt(B,L);return u[A]={version:r,snapshot:ae,source:B,mode:L},ae})();j.push({name:A,snapshot:de,version:ve,subscribers:Array.from(f),subscriberSet:new Set(f),notified:new Set,metrics:Bt(m[A]?.metrics),totalMs:0,beforeHooked:false});}return j},nr=l?Oe(y=>l.has(y)):[],sr=Oe(y=>!l||!l.has(y)),wt=(y,j)=>{let A=()=>{if(y.length===0){j();return}let f=y.shift();if((m[f.name]?.updateCount??f.version)!==f.version){if(n.pendingNotifications.add(f.name),y.length===0){j();return}Ue(A,a);return}let L=()=>{let X=k[f.name];if(!(!X||X.size===0))for(let _ of X)f.subscriberSet.has(_)||(f.subscriberSet.add(_),f.subscribers.push(_));};L();let B=f.subscribers;if(B.length===0){if(y.length===0){j();return}Ue(A,a);return}f.beforeHooked||(f.beforeHooked=true,h(f.name));let te=v(),de=0,ae=false,Ae=J(f.name),Pe=()=>{for(let X=0;X<B.length&&de<i;X+=1){let _=B[X];if(f.notified.has(_))continue;f.notified.add(_);try{_(f.snapshot);}catch(re){let vt=m[f.name]?.options?.snapshotSafety??"warn",je=g(f.name);if(C()&&(je==="ref"||je==="shallow")&&ro(re)){if(vt==="throw")throw re;if(vt==="auto-clone")try{let ir=O(f.snapshot);S(`Snapshot mutation detected for "${f.name}". Delivered a cloned snapshot to the subscriber.`);try{_(ir);}catch(ar){S(`Subscriber for "${f.name}" threw on cloned snapshot: ${ar?.message??ar}`);}if(f.notified.add(_),de+=1,(m[f.name]?.updateCount??f.version)!==f.version){ae=!0,n.pendingNotifications.add(f.name);break}continue}catch{}S(`Snapshot mutation detected for "${f.name}": ${re?.message??re}`);continue}S(`Subscriber for "${f.name}" threw: ${re?.message??re}`);}if(de+=1,(m[f.name]?.updateCount??f.version)!==f.version){ae=true,n.pendingNotifications.add(f.name);break}}};if(Ae?Gt(Ae,Pe):Pe(),f.totalMs+=v()-te,ae){if(y.length===0){j();return}Ue(A,a);return}L();let Ne=false;for(let X of B)if(!f.notified.has(X)){Ne=true;break}if(Ne?y.push(f):(Ut(f.metrics,f.totalMs),qt(m[f.name],f.metrics),x(f.name,f.totalMs)),y.length===0){j();return}Ue(A,a);};A();};nr.length>0?wt(nr,()=>wt(sr,we)):wt(sr,we);};var Tn=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=Zr(t);oo(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&Yt(e);});},Yt=e=>{eo(e,Tn);};var ft=null,no=e=>(ft=e,()=>{ft===e&&(ft=null);}),Ve=e=>{ft?.(e);};var En=e=>{let t=D(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&Yt(t);};no(En);var Fn=()=>{let e=D().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0;};F("notify.reset",Fn,40);var pt=new Set,io=e=>e?pt.has(e):pt.size>0,ao=e=>{e&&pt.add(e);},Vn=()=>{pt.clear();};F("ssr.warnings",Vn,60);var so=new Set,Dn=e=>{let t=vr();return !t||e.includes("::")?e:(C()&&!so.has(e)&&(so.add(e),S(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},me=e=>Dn(typeof e=="string"?e:e.name),Ge=e=>G(e)&&!uo(e)?true:(Vt(e,Object.keys(Je)),false),co=(e,t,r={})=>{ye(t,{...r,onError:N[e]?.options?.onError});},lo=(e,t,r={})=>{ye(e,{...r,onError:t});},se=(e,t,r="dev")=>{co(e,t,{severity:"warn",visibility:r});},On=(e,t,r="dev")=>{lo(e,t,{severity:"warn",visibility:r});},ie=(e,t)=>co(e,t,{severity:"critical",visibility:"always"}),Ye=(e,t)=>lo(e,t,{severity:"critical",visibility:"always"}),gt=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
13
+ Import "stroid/${t}" before calling createStore("${e}", ...).`;if(On(o,r,"always"),R().strictMissingFeatures)throw new Error(o)};var fo=new WeakMap,po=new WeakMap,An=500,Pn="",Xe=e=>{let t=fo.get(e);return t||(t=new Map,fo.set(e,t)),t},Xt=e=>{let t=po.get(e);return t||(t=new Map,po.set(e,t)),t},Nn=(e,t)=>{let r=Xt(e),o=r.get(t);return o||(o=new Map,r.set(t,o)),o},jn=()=>{let e=R().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?An:Math.max(0,Math.floor(e))},go=(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=Xe(D());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)=>(Xe(D())[t]=r,true)});var So=(e,t,r,o)=>{let n=N[e];if(!n)return {ok:true};let s=Ee(r);if(s.length===0)return {ok:true};let i=ce(o),a=jn(),c=D(),l=Xe(c),d=Nn(c,e),b=s.join(Pn),w=l.get(e);w||(w={children:new Map},l.set(e,w));let k=w;for(let v of s){let T=k.children.get(v);T||(T={children:new Map},k.children.set(v,T)),k=T;}let m=k.verdicts?.get(i);if(m){let v=`${b}|${i}`;return go(d,v,{node:k,type:i},a),m}let u=n.options?.pathCreate===true,p=t,g={ok:true};for(let v=0;v<s.length;v++){let T=s[v],V=v===s.length-1;if(p==null){let x=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,v).join(".")||"root"}" is ${p===null?"null":"undefined"}.`;$(x),g={ok:false,reason:x};break}if(typeof p!="object"){let x=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,v).join(".")||"root"}" is not an object.`;$(x),g={ok:false,reason:x};break}if(Array.isArray(p)){let x=Number(T);if(!Number.isInteger(x)||x<0){let W=`Path "${s.join(".")}" targets non-numeric index "${T}" on an array in "${e}".`;$(W),g={ok:false,reason:W};break}let J=p;if(x>=J.length){let W=`Path "${s.join(".")}" is invalid for "${e}" - index ${x} is out of bounds (length ${J.length}).`;$(W),g={ok:false,reason:W};break}if(V){let W=J[x];if(W!=null){let we=ce(W);if(we!==i){let Oe=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${we}, received ${i}.`;$(Oe),g={ok:false,reason:Oe};break}}g={ok:true};break}p=J[x];continue}if(!Object.prototype.hasOwnProperty.call(p,T)){if(u&&V){g={ok:true};break}let x=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${T}" at "${s.slice(0,v).join(".")||"root"}".`;$(x),g={ok:false,reason:x};break}if(V){let x=p[T];if(x!=null){let J=ce(x);if(J!==i){let W=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${J}, received ${i}.`;$(W),g={ok:false,reason:W};break}}g={ok:true};break}p=p[T];}k.verdicts||(k.verdicts=new Map);let M=k.verdicts.has(i);if(k.verdicts.set(i,g),!M){let v=`${b}|${i}`;go(d,v,{node:k,type:i},a);}return g},he=(e,t,r,o)=>{try{return o?.reuseInput&&At(t)?{ok:!0,value:t}:{ok:!0,value:pe(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return Q(N[e]?.options?.onError,`onError(${e})`,s),Q(r,`onError(${e})`,s),S(s),{ok:false}}},In=(e,t)=>{let r=new Set,o=N[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Qt=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=In(e,o),s=(a,c)=>{n.forEach(l=>Q(l,`onError(${e})`,a)),c==="critical"?$(a):S(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=Ot(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Qe=(e,t,r,o,n)=>{let s=he(e,t,o,n);if(!s.ok)return {ok:false};let i=Qt(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},Y=e=>{let t=D();Xe(t).delete(e),Xt(t).delete(e);},$n=()=>{let e=D();Xe(e).clear(),Xt(e).clear();};F("validation.path-cache",$n,50);yo(Y);var be=(e,t=D())=>{if((E()?ue(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=he(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=Qe(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(E()){let c=a.value;lt(e,c),ct(()=>{ee(e,c,t),t.initialStates[e]=O(c),delete t.initialFactories[e],Y(e);});}else ee(e,a.value,t),t.initialStates[e]=O(a.value),delete t.initialFactories[e],Y(e);return !0}catch(n){return ie(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var mo=new WeakMap,ho=e=>{let t=mo.get(e);return t||(t=new Map,mo.set(e,t)),t},zn=()=>{ho(D()).clear();};F("features.contexts",zn,100);var bo=e=>{let t=D(),r=ho(t),o=r.get(e);if(o)return o;let n=N[e];if(!n)return S(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>N[e],getStoreValue:()=>Je[e],getAllStores:()=>Je,getInitialState:()=>Co[e],hasStore:()=>G(e),setStoreValue:i=>{ee(e,i);},applyFeatureState:(i,a)=>{Mo(e,i,a),Y(e);},notify:()=>{},reportStoreError:i=>{ie(e,i);},warn:S,warnAlways:U,log:q,hashState:_e,deepClone:O,sanitize:pe,validate:i=>Qt(e,i,N[e]?.options?.validate),isDev:C};return r.set(e,s),s},wo=(e,t)=>{let r=R();if(!r.strictMissingFeatures&&!r.assertRuntime)return;let o=[];if(typeof t.getMeta!="function"&&o.push("getMeta"),typeof t.getStoreValue!="function"&&o.push("getStoreValue"),typeof t.getAllStores!="function"&&o.push("getAllStores"),typeof t.getInitialState!="function"&&o.push("getInitialState"),typeof t.hasStore!="function"&&o.push("hasStore"),typeof t.setStoreValue!="function"&&o.push("setStoreValue"),typeof t.applyFeatureState!="function"&&o.push("applyFeatureState"),typeof t.notify!="function"&&o.push("notify"),typeof t.reportStoreError!="function"&&o.push("reportStoreError"),typeof t.warn!="function"&&o.push("warn"),typeof t.warnAlways!="function"&&o.push("warnAlways"),typeof t.log!="function"&&o.push("log"),typeof t.hashState!="function"&&o.push("hashState"),typeof t.deepClone!="function"&&o.push("deepClone"),typeof t.sanitize!="function"&&o.push("sanitize"),typeof t.validate!="function"&&o.push("validate"),typeof t.isDev!="function"&&o.push("isDev"),o.length===0)return;let n=`Feature hook context missing fields for "${e}": ${o.join(", ")}.`;if(ie(e,n),r.assertRuntime)throw new Error(n)},vo=(e,t)=>{yt();let r=bo(e);r&&(r.notify=()=>t(e),wo(e,r),Z.forEach(o=>{o.onStoreCreate?.(r);}));},xo=(e,t,r,o,n)=>{yt();let s=bo(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});wo(e,i),Z.forEach(a=>{a.onStoreWrite?.(i);});};var ko=(e,t)=>Br({name:e,payload:t,middlewares:(()=>{let r=N[e]?.options?.middleware||[],o=R().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{se(e,r,o);},warn:S}),St=(e,t,r,o)=>st({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{se(e,n,s);}}),Ro=(e,t)=>{let r={...t};return r.persist&&!Ze("persist")&&(r.explicitPersist&&gt(e,"persist",r.onError),r.persist=null),r.sync&&!Ze("sync")&&(r.explicitSync&&gt(e,"sync",r.onError),r.sync=false),Ze("devtools")||(r.explicitDevtools&&gt(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var _n=32,mt=new Set;F("store-write.slow-mutator-warned",()=>mt.clear(),65);var Wn=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var Eo=e=>{mt.delete(e);},Fo=(e,t)=>{C()&&(t<_n||mt.has(e)||(mt.add(e),S(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},Vo=e=>dt(),To=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:a})=>{let c=e.metaEntries;ee(t,o,e),Y(t);let l=Date.now();c[t].updatedAt=new Date(l).toISOString(),c[t].updatedAtMs=l;let d=a??dt();d&&(d.correlationId||d.traceContext)?(c[t].lastCorrelationId=d.correlationId??null,c[t].lastCorrelationAt=new Date(l).toISOString(),c[t].lastCorrelationAtMs=l,c[t].lastTraceContext=d.traceContext??null):(c[t].lastCorrelationId=null,c[t].lastCorrelationAt=null,c[t].lastCorrelationAtMs=null,c[t].lastTraceContext=null),Wn(c[t]),xo(t,n,r,o,Ve),St(t,s,c[t].options[s],[r,o]),Ve(t),q(i);},ht=(e,t)=>{let r=t.context??dt();if(E()){lt(t.name,t.next),ct(()=>To(e,{...t,context:r}));return}To(e,{...t,context:r});};function Zt(e,t,r){return Hn(e,t,r)}var Hn=(e,t,r,o)=>{let n=me(e),s=D(),i=s.metaEntries;if(!be(n,s))return {ok:false,reason:"validate"};if(!G(n,s)){let p=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return ie(n,p),E()&&I(p),{ok:false,reason:"not-found"}}let a,c=E()?ue(n):{has:false,value:void 0},l=c.has?c.value:Ke(n,s),d=typeof t=="function"&&r===void 0;if(d){let p=C()?Date.now():0;try{let g=R().mutatorProduce,M=!1,v,T=h=>{let x=t(h);return x!==void 0&&(M=!0,v=x),x},V=g?g(l,T):(()=>{let h=O(l);return T(h),h})();if(M&&R().strictMutatorReturns){let h=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return ie(n,h),E()&&I(h),{ok:!1,reason:"validate"}}M&&C()&&!R().strictMutatorReturns&&S(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=M&&!R().strictMutatorReturns?v:V;}catch(g){return ie(n,`Mutator for "${n}" failed: ${g?.message??g}`),E()&&I(g),{ok:false,reason:"validate"}}finally{p&&Fo(n,Date.now()-p);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!Me(t))return E()&&I(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof l!="object"||l===null||Array.isArray(l))return H(`setStore("${n}", data) only merges into object stores.
14
+ Use setStore("${n}", "path", value) or recreate the store with an object shape.`),E()&&I(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let p=he(n,t);if(!p.ok)return E()&&I(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};a={...l,...p.value};}else if(typeof t=="string"||Array.isArray(t)){if(!He(t))return E()&&I(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let p=he(n,r);if(!p.ok)return E()&&I(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let g=p.value,M=So(n,l,t,g);if(!M.ok)return Q(i[n]?.options?.onError,`onError(${n})`,M.reason??`Invalid path for "${n}".`),E()&&I(M.reason),{ok:false,reason:"path"};a=zt(l,t,g);}else {let p=`setStore("${n}") - invalid arguments.
17
15
  Usage:
18
16
  setStore("${n}", "field", value)
19
17
  setStore("${n}", "nested.field", value)
20
18
  setStore("${n}", { field: value })
21
19
  setStore(storeDef, draft => { draft.field = value })
22
- replaceStore("${n}", value) // full-store replace`;return $(p),h[n]?.options?.onError?.(p),E()&&A(p),{ok:false,reason:"invalid-args"}}if(!me(s))return E()&&A(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let d=h[n]?.options?.validate,g=kr(n,{action:"set",prev:i,next:s,path:t});if(g===Pe)return E()&&A(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let v=We(n,g,d,void 0,c&&g===s?{reuseInput:true}:void 0);return v.ok?(jn({name:n,prev:i,next:v.value,action:"set",hookLabel:"onSet",logMessage:`Store "${n}" updated`}),{ok:true}):(E()&&A(`setStore("${n}") failed validation`),{ok:false,reason:"validate"})}function In(e){let t=ke(e);if($e(t)&&Me(t)){if(E()){let r=`deleteStore("${t}") cannot be called inside setStoreBatch. Move deleteStore outside the batch to preserve transaction semantics.`;ae(t,r),A(r);return}Sr.deleteExistingStore(t),U(t);}}
23
- export{$n as createStore,In as deleteStore,hn as getStore,_n as setStore};//# sourceMappingURL=core.js.map
20
+ replaceStore("${n}", value) // full-store replace`;return H(p),Q(i[n]?.options?.onError,`onError(${n})`,p),E()&&I(p),{ok:false,reason:"invalid-args"}}if(!Me(a))return E()&&I(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let b=i[n]?.options?.validate,w=Vo(),k=ko(n,{action:"set",prev:l,next:a,path:t,correlationId:w?.correlationId,traceContext:w?.traceContext});if(k===nt)return E()&&I(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let u=Qe(n,k,b,void 0,d&&k===a?{reuseInput:true}:void 0);if(!u.ok)return E()&&I(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};try{if(It(l,u.value))return {ok:!0}}catch{}return ht(s,{name:n,prev:l,next:u.value,action:"set",hookLabel:"onSet",logMessage:`Store "${n}" updated`,context:w}),{ok:true}};var Bn=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Do=(e,t)=>t==="ref"?e:t==="shallow"?We(e):O(e);function Un(e,t){let r=me(e);if(!Ge(r))return null;let o=D();if(!be(r,o))return null;Jt(r,o);let n=Ke(r,o),s=Bn(o.metaEntries[r],R().defaultSnapshotMode);if(t===void 0)return n===null||typeof n!="object"?n:Do(n,s);if(!He(t))return null;let i=$t(n,t);return i===null||typeof i!="object"?i:Do(i,s)}var qn=e=>G(e);function er(e){let t=me(e);if(!Ge(t))return;let r=D();if(!be(t,r))return;if(E()){let n=`deleteStore("${t}") cannot be called inside setStoreBatch. Move deleteStore outside the batch to preserve transaction semantics.`;se(t,n),I(n);return}Oo().deleteExistingStore(t),Y(t),Eo(t),rr(t);}function tr(e){let t=me(e);if(!Ge(t))return {ok:false,reason:"not-found"};let r=D();if(r.metaEntries[t]?.options?.lazy===true&&!!r.initialFactories[t]){let d=`resetStore("${t}") cannot run on a lazy store before it is initialized. Read the store once (getStore) to materialize it before resetting.`;return se(t,d),E()&&I(d),{ok:false,reason:"lazy-uninitialized"}}if(!be(t,r))return {ok:false,reason:"validate"};if(!r.initialStates[t]){let d=`resetStore("${t}") has no initial state to reset to. If this is a lazy store, ensure it has been initialized before calling resetStore.`;return se(t,d),E()&&I(d),{ok:false,reason:"not-found"}}let n=E()?ue(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=O(r.initialStates[t]),c=(typeof performance<"u"&&performance.now?performance.now():Date.now())-i,l=r.metaEntries[t]?.metrics;return l&&(l.resetCount=(l.resetCount??0)+1,l.totalResetMs=(l.totalResetMs??0)+c,l.lastResetMs=c),ht(r,{name:t,prev:s,next:a,action:"reset",hookLabel:"onReset",logMessage:`Store "${t}" reset to initial state/value`}),{ok:true}}var Yn=()=>D().computedCleanups;var Ao=e=>{let t=Yn(),r=t.get(e);if(!r){C()&&S(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Po=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,a=e.featureRuntimes,c=e.deletingStores,l=(u,p)=>{ye(p,{onError:s[u]?.options?.onError,severity:"warn",visibility:"dev"});},d=({name:u,prev:p,options:g,initialState:M,getMeta:v,getStoreValue:T,hasStore:V})=>({name:u,options:g,prev:p,getMeta:v,getStoreValue:T,getAllStores:()=>t,getInitialState:()=>M,hasStore:V,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:h=>{ye(h,{onError:g.onError,severity:"warn",visibility:"dev"});},warn:S,warnAlways:U,log:q,hashState:_e,deepClone:O,sanitize:pe,validate:()=>({ok:true,value:p}),isDev:C}),b=({name:u,prev:p,options:g,initialState:M,phase:v})=>{let T=d({name:u,prev:p,options:g,initialState:M,getMeta:()=>s[u],getStoreValue:()=>t[u],hasStore:()=>Ce(e,u)}),V=d({name:u,prev:p,options:g,initialState:M,getMeta:()=>{},getStoreValue:()=>p,hasStore:()=>false});xe().forEach(h=>{let x=a.get(h);v==="before"?x?.beforeStoreDelete?.(T):x?.afterStoreDelete?.(V);});},w=u=>{if(!Ce(e,u))return;let p=t[u],g=s[u].options,M=o[u],v=r[u];c.add(u);try{v?.forEach(h=>{try{h(null);}catch(x){S(`Subscriber for "${u}" threw during delete: ${x?.message??x}`);}}),st({name:u,label:"onDelete",fn:g.onDelete,args:[p],reportIssue:(h,x)=>{ye(h,{onError:g.onError,severity:"warn",visibility:x});}}),b({name:u,prev:p,options:g,initialState:M,phase:"before"}),delete t[u],delete r[u],delete o[u],delete n[u],delete s[u],delete i[u],Yr(u)&&Ao(u);let V=e.computedDependents[u];if(V)for(let h of V)S(`[stroid] source store "${u}" was deleted. Computed store "${h}" depends on it and will return stale data. Call deleteComputed("${h}") to clean up.`);b({name:u,prev:p,options:g,initialState:M,phase:"after"}),qe("afterStoreDelete",u,{type:"afterStoreDelete",prev:p}),tt(e,{type:"deleted",name:u}),q(`Store "${u}" deleted`);}finally{c.delete(u);}};return {deleteExistingStore:w,clearAllStores:()=>{let u=[],g=0,M=Number.POSITIVE_INFINITY;for(;g<20;){let T=Object.keys(t);if(T.length===0)break;T.forEach(h=>{Ce(e,h)&&(w(h),u.push(h));}),g+=1;let V=Object.keys(t).length;if(V===0||V>=M)break;M=V;}let v=Object.keys(t).length;return v>0?S(`clearAllStores stopped after ${g} pass${g===1?"":"es"}; ${v} store(s) still registered (likely recreated during deletion).`):S(`All stores cleared (${u.length} stores removed)`),u},clearStores:u=>{let p=Object.keys(t).filter(g=>u?u.endsWith("*")?g.startsWith(u.slice(0,-1)):g===u:true);return p.forEach(g=>w(g)),p},reportStoreError:l}};var or=ke,jo=Re(or),Io=null,z=()=>{let e=ne(jo);return Ct(e),e};var D=()=>z();var $o=(e,t)=>{tt(e,t);};function yo(e){Io=e;}var De=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}}}),Jn=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)}),Xn=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)}),Je=De(()=>z().stores);De(()=>z().subscribers);var Co=De(()=>z().initialStates);De(()=>z().initialFactories);var N=De(()=>z().metaEntries);De(()=>z().snapshotCache);var Z=Jn(()=>z().featureRuntimes),No=new WeakMap,zo=e=>{let t=No.get(e);return t||(t=Po(e),No.set(e,t)),t};Xn(()=>zo(z()));var Oo=()=>zo(z()),Qn=e=>{let t=Z.get(e);if(t)return t;let r=et(e);if(!r)return;let o=r();return Z.set(e,o),o},yt=()=>{xe().forEach(e=>{Qn(e);});};yt();var G=(e,t)=>Ce(t??z(),e),Ke=(e,t=z())=>{if(E()){let o=ue(e);if(o.has)return o.value}let r=Ie();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},ee=(e,t,r=z())=>{r.stores[e]=t;},Mo=(e,t,r=Date.now())=>{ee(e,t),N[e]&&(N[e].updatedAt=new Date(r).toISOString(),N[e].updatedAtMs=r,N[e].lastCorrelationId=null,N[e].lastCorrelationAt=null,N[e].lastCorrelationAtMs=null,N[e].lastTraceContext=null,N[e].updateCount>=Number.MAX_SAFE_INTEGER?N[e].updateCount=0:N[e].updateCount+=1,Io?.(e));},Jt=(e,t=z())=>{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();},Zn=()=>{yr(z());},es=()=>{Z.forEach(e=>{try{e.resetAll?.();}catch{}}),Z.clear();};F("features.reset",es,10);F("registries.clear",Zn,20);F("registry.default",()=>{or=ke,jo=Re(or);},115);var uo=e=>Sr(z(),e);var bt=new Set,rr=e=>{if(e){bt.delete(e);return}bt.clear();};F("store-create.ssr-global-warned",()=>rr(),65);function ts(e,t,r={}){if(E()){let h=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;Ye(h,r.onError),I(h);return}if(!Pt(e)){Ye(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Me(t)){Ye(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&C()&&S(`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.`),Hr(r).forEach(h=>{S(h);});let n=Ro(e,Lr(r,e,R().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let h=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;Q(n.onError,`onError(${e})`,h),C()||U(h),H(h);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",c=n.allowSSRGlobalStore??false,l=D(),d=l.stores,b=l.subscribers,w=l.initialStates,k=l.initialFactories,m=l.metaEntries,u=l.scope==="request";if(a&&!c&&!u){let h=`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.`;Ye(h,r.onError);return}if(a&&c&&!u&&!bt.has(e)&&(bt.add(e),U(`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.`)),G(e,l)){let h=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return se(e,h),{name:e}}s&&!c&&!u&&!io(e)&&C()&&(ao(e),S(`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 p=he(e,t,n.onError);if(!p.ok)return;let g=p.value,M=n.lazy===true&&typeof t=="function",v=(b[e]?.size??0)>0;if(M)d[e]=void 0,k[e]=t;else {let h=Qe(e,g,n.validate,n.onError);if(!h.ok)return;ee(e,h.value,l),w[e]=O(h.value);}let T=Date.now(),V=new Date(T).toISOString();return m[e]={createdAt:V,updatedAt:V,updatedAtMs:T,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},Y(e),vo(e,Ve),St(e,"onCreate",m[e].options.onCreate,[g]),$o(l,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),v&&Ve(e),q(`Store "${e}" created -> ${JSON.stringify(g)}`),{name:e}}export{ts as createStore,er as deleteStore,Un as getStore,qn as hasStore,tr as resetStore,Zt as setStore};//# sourceMappingURL=core.js.map
24
23
  //# sourceMappingURL=core.js.map