stroid 0.1.0 → 0.1.1

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 (155) hide show
  1. package/CHANGELOG.md +33 -0
  2. package/README.md +375 -468
  3. package/dist/_tsup-dts-rollup.d.cts +2411 -0
  4. package/dist/_tsup-dts-rollup.d.ts +2411 -0
  5. package/dist/async.cjs +29 -24
  6. package/dist/async.cjs.map +1 -0
  7. package/dist/async.d.cts +9 -40
  8. package/dist/async.d.ts +9 -40
  9. package/dist/async.js +29 -24
  10. package/dist/async.js.map +1 -0
  11. package/dist/computed.cjs +12 -10
  12. package/dist/computed.cjs.map +1 -0
  13. package/dist/computed.d.cts +7 -29
  14. package/dist/computed.d.ts +7 -29
  15. package/dist/computed.js +12 -10
  16. package/dist/computed.js.map +1 -0
  17. package/dist/core.cjs +17 -23
  18. package/dist/core.cjs.map +1 -0
  19. package/dist/core.d.cts +15 -5
  20. package/dist/core.d.ts +15 -5
  21. package/dist/core.js +17 -23
  22. package/dist/core.js.map +1 -0
  23. package/dist/devtools.cjs +2 -1
  24. package/dist/devtools.cjs.map +1 -0
  25. package/dist/devtools.d.cts +5 -19
  26. package/dist/devtools.d.ts +5 -19
  27. package/dist/devtools.js +2 -1
  28. package/dist/devtools.js.map +1 -0
  29. package/dist/feature.cjs +2 -0
  30. package/dist/feature.cjs.map +1 -0
  31. package/dist/feature.d.cts +14 -0
  32. package/dist/feature.d.ts +14 -0
  33. package/dist/feature.js +2 -0
  34. package/dist/feature.js.map +1 -0
  35. package/dist/helpers.cjs +17 -13
  36. package/dist/helpers.cjs.map +1 -0
  37. package/dist/helpers.d.cts +3 -29
  38. package/dist/helpers.d.ts +3 -29
  39. package/dist/helpers.js +17 -13
  40. package/dist/helpers.js.map +1 -0
  41. package/dist/index.cjs +26 -21
  42. package/dist/index.cjs.map +1 -0
  43. package/dist/index.d.cts +33 -130
  44. package/dist/index.d.ts +33 -130
  45. package/dist/index.js +26 -21
  46. package/dist/index.js.map +1 -0
  47. package/dist/install.cjs +2 -0
  48. package/dist/install.cjs.map +1 -0
  49. package/dist/install.d.cts +4 -0
  50. package/dist/install.d.ts +4 -0
  51. package/dist/install.js +2 -0
  52. package/dist/install.js.map +1 -0
  53. package/dist/persist.cjs +2 -1
  54. package/dist/persist.cjs.map +1 -0
  55. package/dist/persist.d.cts +1 -2
  56. package/dist/persist.d.ts +1 -2
  57. package/dist/persist.js +2 -1
  58. package/dist/persist.js.map +1 -0
  59. package/dist/react.cjs +27 -22
  60. package/dist/react.cjs.map +1 -0
  61. package/dist/react.d.cts +7 -52
  62. package/dist/react.d.ts +7 -52
  63. package/dist/react.js +27 -22
  64. package/dist/react.js.map +1 -0
  65. package/dist/runtime-admin.cjs +2 -1
  66. package/dist/runtime-admin.cjs.map +1 -0
  67. package/dist/runtime-admin.d.cts +2 -4
  68. package/dist/runtime-admin.d.ts +2 -4
  69. package/dist/runtime-admin.js +2 -1
  70. package/dist/runtime-admin.js.map +1 -0
  71. package/dist/runtime-tools.cjs +3 -2
  72. package/dist/runtime-tools.cjs.map +1 -0
  73. package/dist/runtime-tools.d.cts +9 -39
  74. package/dist/runtime-tools.d.ts +9 -39
  75. package/dist/runtime-tools.js +3 -2
  76. package/dist/runtime-tools.js.map +1 -0
  77. package/dist/selectors.cjs +2 -1
  78. package/dist/selectors.cjs.map +1 -0
  79. package/dist/selectors.d.cts +2 -4
  80. package/dist/selectors.d.ts +2 -4
  81. package/dist/selectors.js +2 -1
  82. package/dist/selectors.js.map +1 -0
  83. package/dist/server.cjs +11 -9
  84. package/dist/server.cjs.map +1 -0
  85. package/dist/server.d.cts +2 -14
  86. package/dist/server.d.ts +2 -14
  87. package/dist/server.js +11 -9
  88. package/dist/server.js.map +1 -0
  89. package/dist/sync.cjs +2 -1
  90. package/dist/sync.cjs.map +1 -0
  91. package/dist/sync.d.cts +1 -2
  92. package/dist/sync.d.ts +1 -2
  93. package/dist/sync.js +2 -1
  94. package/dist/sync.js.map +1 -0
  95. package/dist/testing.cjs +17 -13
  96. package/dist/testing.cjs.map +1 -0
  97. package/dist/testing.d.cts +4 -16
  98. package/dist/testing.d.ts +4 -16
  99. package/dist/testing.js +17 -13
  100. package/dist/testing.js.map +1 -0
  101. package/package.json +12 -3
  102. package/dist/async-cache-DFHwcBQL.d.cts +0 -52
  103. package/dist/async-cache-DFHwcBQL.d.ts +0 -52
  104. package/dist/computed-BbAZm1Dq.d.cts +0 -17
  105. package/dist/computed-CccdgY5j.d.ts +0 -17
  106. package/dist/options-CB35e3Xo.d.cts +0 -245
  107. package/dist/options-CB35e3Xo.d.ts +0 -245
  108. package/dist/types/adapters/options.d.ts +0 -247
  109. package/dist/types/async/clone.d.ts +0 -2
  110. package/dist/types/async/errors.d.ts +0 -3
  111. package/dist/types/async/inflight.d.ts +0 -13
  112. package/dist/types/async/rate.d.ts +0 -5
  113. package/dist/types/async/request.d.ts +0 -3
  114. package/dist/types/async-cache.d.ts +0 -57
  115. package/dist/types/async-fetch.d.ts +0 -37
  116. package/dist/types/async-registry.d.ts +0 -96
  117. package/dist/types/async-retry.d.ts +0 -10
  118. package/dist/types/async.d.ts +0 -2
  119. package/dist/types/computed-graph.d.ts +0 -31
  120. package/dist/types/computed.d.ts +0 -15
  121. package/dist/types/config.d.ts +0 -2
  122. package/dist/types/core.d.ts +0 -1
  123. package/dist/types/devfreeze.d.ts +0 -1
  124. package/dist/types/feature-registry.d.ts +0 -69
  125. package/dist/types/features/lifecycle.d.ts +0 -28
  126. package/dist/types/index.d.ts +0 -6
  127. package/dist/types/integrations/query.d.ts +0 -8
  128. package/dist/types/internals/config.d.ts +0 -62
  129. package/dist/types/internals/diagnostics.d.ts +0 -21
  130. package/dist/types/internals/hooks-warnings.d.ts +0 -6
  131. package/dist/types/internals/reporting.d.ts +0 -8
  132. package/dist/types/internals/store-admin.d.ts +0 -7
  133. package/dist/types/internals/store-ops.d.ts +0 -3
  134. package/dist/types/runtime-admin.d.ts +0 -2
  135. package/dist/types/store-lifecycle/bind.d.ts +0 -3
  136. package/dist/types/store-lifecycle/hooks.d.ts +0 -44
  137. package/dist/types/store-lifecycle/identity.d.ts +0 -23
  138. package/dist/types/store-lifecycle/registry.d.ts +0 -39
  139. package/dist/types/store-lifecycle/types.d.ts +0 -39
  140. package/dist/types/store-lifecycle/validation.d.ts +0 -45
  141. package/dist/types/store-lifecycle.d.ts +0 -20
  142. package/dist/types/store-name.d.ts +0 -19
  143. package/dist/types/store-notify.d.ts +0 -12
  144. package/dist/types/store-read.d.ts +0 -12
  145. package/dist/types/store-registry.d.ts +0 -74
  146. package/dist/types/store-transaction.d.ts +0 -12
  147. package/dist/types/store-write.d.ts +0 -45
  148. package/dist/types/store.d.ts +0 -7
  149. package/dist/types/utils/clone.d.ts +0 -4
  150. package/dist/types/utils/hash.d.ts +0 -8
  151. package/dist/types/utils/path.d.ts +0 -5
  152. package/dist/types/utils/validation.d.ts +0 -14
  153. package/dist/types/utils.d.ts +0 -5
  154. package/dist/types-grvlY4BX.d.cts +0 -37
  155. package/dist/types-grvlY4BX.d.ts +0 -37
package/dist/server.d.cts CHANGED
@@ -1,14 +1,2 @@
1
- import { S as StoreOptions } from './options-CB35e3Xo.cjs';
2
-
3
- declare const createStoreForRequest: (initializer?: (api: {
4
- create: (name: string, data: any, options?: StoreOptions) => any;
5
- set: (name: string, updater: any) => any;
6
- get: (name: string) => any;
7
- }) => void) => {
8
- snapshot: () => Record<string, any>;
9
- hydrate: <T>(renderFn: () => T, options?: Partial<Record<string, StoreOptions>> & {
10
- default?: StoreOptions;
11
- }) => T;
12
- };
13
-
14
- export { createStoreForRequest };
1
+ export { RequestStoreApi } from './_tsup-dts-rollup.cjs';
2
+ export { createStoreForRequest } from './_tsup-dts-rollup.cjs';
package/dist/server.d.ts CHANGED
@@ -1,14 +1,2 @@
1
- import { S as StoreOptions } from './options-CB35e3Xo.js';
2
-
3
- declare const createStoreForRequest: (initializer?: (api: {
4
- create: (name: string, data: any, options?: StoreOptions) => any;
5
- set: (name: string, updater: any) => any;
6
- get: (name: string) => any;
7
- }) => void) => {
8
- snapshot: () => Record<string, any>;
9
- hydrate: <T>(renderFn: () => T, options?: Partial<Record<string, StoreOptions>> & {
10
- default?: StoreOptions;
11
- }) => T;
12
- };
13
-
14
- export { createStoreForRequest };
1
+ export { RequestStoreApi } from './_tsup-dts-rollup.js';
2
+ export { createStoreForRequest } from './_tsup-dts-rollup.js';
package/dist/server.js CHANGED
@@ -1,10 +1,12 @@
1
- import {AsyncLocalStorage}from'async_hooks';var ir={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}`));}},ar={logSink:ir,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",middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0},cr={...ar},R=()=>cr;var ur=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,lr=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,ot=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,dr="production",fr=ur??lr??dr,se=typeof ot=="boolean"?ot:fr!=="production",x=()=>se,Fe=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},pr=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},gr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},G=(e,t)=>{if((R().logSink.critical??pr)(e,t),R().assertRuntime)throw new Error(e)},S=(e,t)=>{if(!se)return;if((R().logSink.warn??Fe)(e,t),R().assertRuntime)throw new Error(e)},O=(e,t)=>{if((R().logSink.warn??Fe)(e,t),R().assertRuntime)throw new Error(e)},j=(e,t)=>{if(se&&(R().logSink.warn??Fe)(e,t),G(e,t),R().assertRuntime)throw new Error(e)},T=(e,t)=>{if(!se)return;(R().logSink.log??gr)(e,t);},st=()=>`Functions cannot be stored in stroid.
2
- Store data only - handle functions outside the store.`,it=()=>`Map/Set detected. stroid converts these to plain objects.
3
- Use arrays or plain objects for best results.`,at=()=>`Date object detected. stroid stores it as ISO string.
4
- Use new Date(value) to convert back when reading.`,ct=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",ut=()=>"Map detected; converting to plain object.",lt=()=>"Set detected; converting to array.";var dt=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,ft=e=>`Store name "${e}" contains spaces.
5
- Use camelCase or kebab-case: "userName" or "user-name"`,pt=e=>`Store name "${e}" is not allowed.
6
- Reserved names: "__proto__", "constructor", "prototype".`,Sr=128,yr=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=Sr,hr=(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]},Ee=(e,t)=>{let r=t.find(n=>{let s=n.toLowerCase(),o=e.toLowerCase();return s.includes(o)||o.includes(s)||yr(s,o)&&hr(s,o)<=2});if(r){S(`Store "${e}" not found. Did you mean "${r}"?`);return}j(`Store "${e}" not found.
1
+ import {AsyncLocalStorage}from'async_hooks';var Sr=new Map,E=(e,t,r=0)=>{!e||typeof t!="function"||Sr.set(e,{name:e,order:r,fn:t});};var nt=()=>({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}}),ot=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 Oe=new Map,yr=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,st,Fe=e=>(st||yr||e).replace(/\.ts(\?|$)/,".js$1"),re=Fe(new URL("./store.js",import.meta.url).href);var mr=()=>{st=void 0,Oe.clear();};E("registry.scope-override",mr,110);var hr=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0}),br=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;},Ve=()=>({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:nt(),notify:hr()}),ne=e=>{let t=Fe(e),r=Oe.get(t);if(r)return r;let n=Ve();return Oe.set(t,n),n},G=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),at=(e,t)=>e.deletingStores.has(t),it=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,br(e.notify),ot(e.async);};var ct=null,ut=e=>{ct=e;},lt=()=>ct?.get()||null,ge=null,dt=e=>{ge=e;},Te=(e,t)=>ge?.run?ge.run(e,t):t(),I=e=>ge?.get()||e||ne(re);var vr={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}`));}},pt={logSink:vr,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},De=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}),Ne=new WeakMap,ft=De(pt),wr=e=>{let t=Ne.get(e);return t||(t=De(ft),Ne.set(e,t)),t};var k=()=>wr(I());var xr=()=>{Ne=new WeakMap,ft=De(pt);};E("config.reset",xr,90);var Mr=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Cr=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,gt=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,Er="production",Or=Mr??Cr??Er,oe=typeof gt=="boolean"?gt:Or!=="production",x=()=>oe,Ae=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Fr=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},Vr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},Y=(e,t)=>{if((k().logSink.critical??Fr)(e,t),k().assertRuntime)throw new Error(e)},y=(e,t)=>{if(!oe)return;if((k().logSink.warn??Ae)(e,t),k().assertRuntime)throw new Error(e)},T=(e,t)=>{if((k().logSink.warn??Ae)(e,t),k().assertRuntime)throw new Error(e)},_=(e,t)=>{if(oe&&(k().logSink.warn??Ae)(e,t),Y(e,t),k().assertRuntime)throw new Error(e)},j=(e,t)=>{if(!oe)return;(k().logSink.log??Vr)(e,t);},St=()=>`Functions cannot be stored in stroid.
2
+ Store data only - handle functions outside the store.`,yt=()=>`Map/Set detected. stroid converts these to plain objects.
3
+ Use arrays or plain objects for best results.`,mt=()=>`Date object detected. stroid stores it as ISO string.
4
+ Use new Date(value) to convert back when reading.`,ht=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",bt=()=>"Map detected; converting to plain object.",vt=()=>"Set detected; converting to array.";var wt=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Rt=e=>`Store name "${e}" contains spaces.
5
+ Use camelCase or kebab-case: "userName" or "user-name"`,kt=e=>`Store name "${e}" is not allowed.
6
+ Reserved names: "__proto__", "constructor", "prototype".`,Tr=128,Nr=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=Tr,Dr=(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]},Pe=(e,t)=>{let r=t.find(n=>{let s=n.toLowerCase(),o=e.toLowerCase();return s.includes(o)||o.includes(s)||Nr(s,o)&&Dr(s,o)<=2});if(r){y(`Store "${e}" not found. Did you mean "${r}"?`);return}_(`Store "${e}" not found.
7
7
  Available stores: [${t.join(", ")}]
8
- Call createStore("${e}", data) first.`);};var _=new Set(["__proto__","constructor","prototype"]),Oe=(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 ae=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,gt=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},De=e=>{let t=ae(e);return t==="function"?(j(st()),false):t==="map"||t==="set"?(S(it()),true):(t==="date"&&S(at()),true)},Ve=(e,t)=>{let r=gt(e);if(r)throw new Error(`${r} values are not supported`);let n=ae(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&&!Ve(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||_.has(o))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${o}")`);if(!Ve(i.value,t))return false}return true}return true},Ae=e=>Ve(e,new WeakSet),ie=(e,t)=>{let r=gt(e);if(r)throw new Error(`${r} values are not supported`);let n=ae(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()&&S(ct()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),x()&&S(ut());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)]=ie(i,t);}return s}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),x()&&S(lt()),Array.from(e,s=>ie(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&&!_.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);s[i]=ie(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=>ie(s,t))}return e},H=e=>ie(e,new WeakSet),Se=e=>typeof e!="string"||e.trim()===""?(j(dt(e)),false):_.has(e)?(j(pt(e)),false):e.includes(" ")?(j(ft(e)),false):true;var Te=null,mr=()=>{if(Te)return Te;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 Te=t,t},yt=e=>{let t=mr(),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},br=2166136261,vr=2654435761,wr=1e5,I=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},B=(e,t)=>{I(e,t.length);for(let r=0;r<t.length;r++)I(e,t.charCodeAt(r));},k=(e,t)=>{B(e,t);},St=(e,t)=>{if(Number.isNaN(t)){k(e,"NaN");return}if(!Number.isFinite(t)){k(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){k(e,"-0");return}let r=t|0;if(t===r){k(e,"int"),I(e,r);return}k(e,"num"),B(e,String(t));},Y=(e,t)=>{if(e.nodes++>wr){k(e,"[max]");return}if(t===null){k(e,"null");return}let r=typeof t;if(r==="string"){k(e,"string"),B(e,t);return}if(r==="number"){k(e,"number"),St(e,t);return}if(r==="boolean"){k(e,t?"true":"false");return}if(r==="undefined"){k(e,"undefined");return}if(r==="bigint"){k(e,"bigint"),B(e,t.toString());return}if(r==="symbol"){k(e,"symbol");let l=t;B(e,Symbol.keyFor(l)??l.description??String(l));return}if(r==="function"){k(e,"function"),B(e,t.name||"anonymous");return}let n=t,s=e.seen.get(n);if(s!==void 0){k(e,"ref"),I(e,s);return}let o=e.nextId++;if(e.seen.set(n,o),Array.isArray(n)){k(e,"array"),I(e,n.length);for(let l=0;l<n.length;l++)Object.prototype.hasOwnProperty.call(n,l)?Y(e,n[l]):k(e,"hole");return}if(n instanceof Date){k(e,"date"),St(e,n.getTime());return}if(n instanceof Map){k(e,"map"),I(e,n.size),n.forEach((l,p)=>{Y(e,p),Y(e,l);});return}if(n instanceof Set){k(e,"set"),I(e,n.size),n.forEach(l=>{Y(e,l);});return}k(e,"object");let i=Object.getOwnPropertyDescriptors(n),c=[];Object.entries(i).forEach(([l,p])=>{p?.enumerable&&(_.has(l)||"get"in p||"set"in p||c.push([l,p]));}),I(e,c.length);for(let[l,p]of c)B(e,l),Y(e,p.value);},ce=e=>{if(typeof e=="string")return yt(JSON.stringify(e));let t={h1:br,h2:vr,seen:new WeakMap,nextId:1,nodes:0};Y(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 kr=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Pe=e=>{if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map)return new Map(e);if(e instanceof Set)return new Set(e);if(Array.isArray(e))return e.slice();let t={},r=Object.getOwnPropertyDescriptors(e);return Object.entries(r).forEach(([n,s])=>{s.enumerable&&(_.has(n)||"get"in s||"set"in s||(t[n]=s.value));}),t},J=(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(J(c,t),J(i,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(i=>{o.add(J(i,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((i,c)=>{o[c]=J(i,t);}),o}let r=globalThis?.WeakRef;if(r&&e instanceof r)return O("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 O("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||_.has(o)||"get"in i||"set"in i||(n[o]=J(i.value,t));}),n},F=e=>{try{if(kr)return structuredClone(e)}catch{}return J(e)};var je=(e,t)=>{try{let r=F(e);return t(r),r}catch(r){throw new Error(`produceClone failed (possible circular reference or unserializable data): ${r?.message??r}`)}};var ht=new Set;var ye=(()=>{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"}})(),Ne=e=>{try{return typeof window>"u"?ye:e==="session"||e==="sessionStorage"?window.sessionStorage??ye:window.localStorage??ye}catch{return ye}},he=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),X=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),bt=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}},xr=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",mt=e=>{try{e[xr]=!0;}catch{}return e},Rr={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"},Cr=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:mt(f=>f),decrypt:mt(f=>f),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Ne("localStorage"),...r};if(typeof e=="string")return {driver:Ne(e),...r};let n=e.encrypt||r.encrypt,s=e.decrypt||r.decrypt,o=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,l=e.allowPlaintext===true,p=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&&bt(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||Ne("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:l,sensitiveData:c,checksum:p,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},vt=e=>{if(!he(e))return [];let t=[];return Object.entries(Rr).forEach(([r,n])=>{X(e,r)&&(ht.has(r)||(ht.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},wt=(e={},t)=>{let r=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,o=he(e.lifecycle)?e.lifecycle:void 0,i=he(e.persist)?e.persist:void 0,c=he(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,p=e.snapshot==="shallow"||e.snapshot==="ref"?e.snapshot:"deep",f=X(e,"persist"),d=X(e,"sync"),u=X(e,"devtools")||X(e,"historyLimit")||X(e,"redactor"),h=r==="global"?true:e.allowSSRGlobalStore??false,{persist:y=false,devtools:a=false,onError:b,sync:m}=e;if(i?.sensitiveData===true){let v=i.encrypt,C=i.encryptAsync;if((!v||bt(v))&&!C)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:r,lazy:n,pathCreate:s,persist:r==="temp"&&!f?null:Cr(y,t),devtools:r==="temp"&&!u?false:typeof a=="boolean"?a:c?.enabled??true,middleware:o?.middleware??e.middleware??[],onSet:o?.onSet??e.onSet,onReset:o?.onReset??e.onReset,onDelete:o?.onDelete??e.onDelete,onCreate:o?.onCreate??e.onCreate,onError:b,validate:l,migrations:i?.migrations??e.migrations??{},version:i?.version??e.version??1,redactor:r==="temp"&&!u?void 0:c?.redactor??e.redactor,historyLimit:r==="temp"&&!u?0:c?.historyLimit??e.historyLimit??50,sync:r==="temp"&&!d?false:m??false,allowSSRGlobalStore:h,snapshot:p,explicitPersist:f,explicitSync:d,explicitDevtools:u}};var kt=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 xt=()=>({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,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}});var Rt=new Map,Mr=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,$e=e=>(Mr||e).replace(/\.ts(\?|$)/,".js$1"),L=$e(new URL("./store.js",import.meta.url).href);var _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:{depth:0,pending:[],stagedValues:new Map,failed:false,error:void 0},async:xt()}),ue=e=>{let t=$e(e),r=Rt.get(t);if(r)return r;let n=_e();return Rt.set(t,n),n},Q=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),Ct=(e,t)=>e.deletingStores.has(t);var Mt=null,Ft=e=>{Mt=e;},Et=()=>Mt?.get()||null,Vt=null,Ot=e=>{Vt=e;};var Z=e=>Vt?.get()||e||ue(L);var Ie=new Map;var me=e=>Ie.has(e),ze=e=>Ie.get(e),le=()=>Array.from(Ie.keys());var be=Symbol("stroid.middleware.abort"),At=({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=F(t.next);for(let c of r){if(typeof c!="function")continue;let l,p=i;try{l=c({action:t.action,name:e,prev:t.prev,next:p,path:t.path});}catch(f){let d=`Middleware for "${e}" failed: ${f?.message??f}`;return n(d,"dev"),be}if(l&&typeof l.then=="function"){let f=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(f,"dev"),be}l===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=p):i=l;}return i},ve=({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 q=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:s}=t;if(s?.(e),r==="critical"){n==="dev"&&S(e),G(e);return}if(n==="always"){O(e);return}S(e);};var Tt=()=>Z(ue(L)),Pt=()=>Tt().computedEntries,Vr=()=>Tt().computedDependents;var jt=e=>Object.prototype.hasOwnProperty.call(Pt(),e);var Nt=e=>{let t=Pt(),r=Vr(),n=new Set,s=[...e];for(;s.length>0;){let f=s.shift(),d=r[f];if(d)for(let u of d)n.has(u)||(n.add(u),s.push(u));}if(n.size===0)return [];let o=f=>{let d=t[f];if(d)for(let u of d.deps)t[u]&&(n.has(u)||(n.add(u),o(u)));};Array.from(n).forEach(f=>o(f));let i=new Map,c=new Map;for(let f of n){let d=t[f];if(!d)continue;let u=0;for(let h of d.deps)n.has(h)&&(u++,c.has(h)||c.set(h,[]),c.get(h).push(f));i.set(f,u);}let l=[];for(let[f,d]of i)d===0&&l.push(f);l.sort();let p=[];for(;l.length>0;){let f=l.shift();p.push(f);let d=c.get(f)??[];for(let u of d){let h=(i.get(u)??1)-1;if(i.set(u,h),h===0){let y=l.findIndex(a=>a>u);y===-1?l.push(u):l.splice(y,0,u);}}}return p};var $t=e=>(e??Z()).transaction,Or=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 We=()=>$t().depth>0,He=(e,t)=>{let r=$t(t);r.failed=true,r.error||(r.error=Or(e));};var te=new Set,de=[],Le=false,_t=e=>{let t=g[e]?.options?.snapshot??R().defaultSnapshotMode;return t==="shallow"||t==="ref"?t:"deep"},It=(e,t)=>t==="ref"?e:t==="shallow"?Pe(e):F(e);var Be=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Ar=()=>{de.length=0;for(let d of te)de.push(d);te.clear();let e=R().flush,t=e.priorityStores||[],r=new Set(de),n=t.length?new Set(t):null,s=[];if(n){for(let d of t)r.has(d)&&s.push(d);for(let d of de)n.has(d)||s.push(d);}else s.push(...de);let o=Nt(s),i=new Set(s);for(let d of o)r.has(d)&&!i.has(d)&&(s.push(d),i.add(d));let c=Number.isFinite(e.chunkSize)&&e.chunkSize>0?e.chunkSize:Number.POSITIVE_INFINITY,l=e.chunkDelayMs,p=c===Number.POSITIVE_INFINITY&&l===0;return {names:s.slice(),sliceSize:c,chunkDelayMs:l,runInline:p,prioritySet:n}},zt=()=>{let{names:e,sliceSize:t,chunkDelayMs:r,runInline:n,prioritySet:s}=Ar(),o=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),i=()=>{Le=false,te.size>0&&Wt();};if(n){for(let u of e){let h=z[u];if(!h||h.size===0)continue;let y=g[u]?.updateCount??0,a=_t(u),b=ee[u],m=b&&b.version===y?b.snapshot:(()=>{let w=It(V[u],a);return ee[u]={version:y,snapshot:w},w})(),v=o();for(let w of h)try{w(m);}catch(A){S(`Subscriber for "${u}" threw: ${A?.message??A}`);}let C=o()-v,M=g[u]?.metrics||{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0};M.notifyCount+=1,M.totalNotifyMs+=C,M.lastNotifyMs=C,g[u]&&(g[u].metrics=M),(g[u]?.updateCount??y)!==y&&te.add(u);}i();return}let c=u=>{let h=[];for(let y of e){if(u&&!u(y))continue;let a=z[y];if(!a||a.size===0)continue;let b=g[y]?.updateCount??0,m=_t(y),v=ee[y],C=v&&v.version===b?v.snapshot:(()=>{let M=It(V[y],m);return ee[y]={version:b,snapshot:M},M})();h.push({name:y,subsArray:Array.from(a),index:0,snapshot:C,version:b,notified:new Set,metrics:g[y]?.metrics?{...g[y].metrics}:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},totalMs:0});}return h},l=s?c(u=>s.has(u)):[],p=c(u=>!s||!s.has(u)),f=u=>{let h=z[u.name];if(!h||h.size===0){u.subsArray=[],u.index=0;return}u.subsArray=Array.from(h),u.index=0;},d=(u,h)=>{let y=()=>{if(u.length===0){h();return}let a=u.shift();if((g[a.name]?.updateCount??a.version)!==a.version){if(te.add(a.name),u.length===0){h();return}n?y():Be(y,r);return}if(f(a),a.subsArray.length===0){if(u.length===0){h();return}n?y():Be(y,r);return}let m=o(),v=0;for(;a.index<a.subsArray.length&&v<t;){let E=a.subsArray[a.index++];if(!a.notified.has(E)){a.notified.add(E);try{E(a.snapshot);}catch(w){S(`Subscriber for "${a.name}" threw: ${w?.message??w}`);}v+=1;}}a.totalMs+=o()-m;let C=z[a.name],M=C?Array.from(C).some(E=>!a.notified.has(E)):false;if(a.index<a.subsArray.length||M?u.push(a):(a.metrics.notifyCount+=1,a.metrics.totalNotifyMs+=a.totalMs,a.metrics.lastNotifyMs=a.totalMs,g[a.name]&&(g[a.name].metrics=a.metrics)),u.length===0){h();return}n?y():Be(y,r);};y();};l.length>0?d(l,()=>d(p,i)):d(p,i);},Wt=()=>{Le||(Le=true,typeof queueMicrotask=="function"?queueMicrotask(zt):Promise.resolve().then(zt));},fe=e=>{te.add(e),Wt();};var Tr=()=>P().computedCleanups;var Bt=e=>{let t=Tr(),r=t.get(e);if(!r){x()&&S(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Lt=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,s=e.initialFactories,o=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,l=e.deletingStores,p=(a,b)=>{q(b,{onError:o[a]?.options?.onError,severity:"warn",visibility:"dev"});},f=({name:a,prev:b,options:m,initialState:v,getMeta:C,getStoreValue:M,hasStore:E})=>({name:a,options:m,prev:b,getMeta:C,getStoreValue:M,getAllStores:()=>t,getInitialState:()=>v,hasStore:E,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:w=>{q(w,{onError:m.onError,severity:"warn",visibility:"dev"});},warn:S,log:T,hashState:ce,deepClone:F,sanitize:H,validate:()=>({ok:true,value:b}),isDev:x}),d=({name:a,prev:b,options:m,initialState:v,phase:C})=>{let M=f({name:a,prev:b,options:m,initialState:v,getMeta:()=>o[a],getStoreValue:()=>t[a],hasStore:()=>Q(e,a)}),E=f({name:a,prev:b,options:m,initialState:v,getMeta:()=>{},getStoreValue:()=>b,hasStore:()=>false});le().forEach(w=>{let A=c.get(w);C==="before"?A?.beforeStoreDelete?.(M):A?.afterStoreDelete?.(E);});},u=a=>{if(!Q(e,a))return;let b=t[a],m=o[a].options,v=n[a],C=r[a];l.add(a);try{C?.forEach(w=>{try{w(null);}catch(A){S(`Subscriber for "${a}" threw during delete: ${A?.message??A}`);}}),ve({name:a,label:"onDelete",fn:m.onDelete,args:[b],reportIssue:(w,A)=>{q(w,{onError:m.onError,severity:"warn",visibility:A});}}),d({name:a,prev:b,options:m,initialState:v,phase:"before"}),delete t[a],delete r[a],delete n[a],delete s[a],delete o[a],delete i[a],jt(a)&&Bt(a);let E=e.computedDependents[a];if(E)for(let w of E)S(`[stroid] source store "${a}" was deleted. Computed store "${w}" depends on it and will return stale data. Call deleteComputed("${w}") to clean up.`);d({name:a,prev:b,options:m,initialState:v,phase:"after"}),T(`Store "${a}" deleted`);}finally{l.delete(a);}};return {deleteExistingStore:u,clearAllStores:()=>{let a=[],m=0,v=Number.POSITIVE_INFINITY;for(;m<20;){let M=Object.keys(t);if(M.length===0)break;M.forEach(w=>{Q(e,w)&&(u(w),a.push(w));}),m+=1;let E=Object.keys(t).length;if(E===0||E>=v)break;v=E;}let C=Object.keys(t).length;return C>0?S(`clearAllStores stopped after ${m} pass${m===1?"":"es"}; ${C} store(s) still registered (likely recreated during deletion).`):S(`All stores cleared (${a.length} stores removed)`),a},clearStores:a=>{let b=Object.keys(t).filter(m=>a?a.endsWith("*")?m.startsWith(a.slice(0,-1)):m===a:true);return b.forEach(m=>u(m)),b},reportStoreError:p}};var Pr=L,jr=ue(Pr),Kt=null,qt=new WeakSet,Nr=e=>{qt.has(e)||(qt.add(e),le().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ze(t);r&&e.featureRuntimes.set(t,r());}}));},D=()=>{let e=Z(jr);return Nr(e),e};var P=()=>D(),Gt=e=>{Kt=e;},re=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}}}),$r=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)}),_r=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)}),V=re(()=>D().stores),z=re(()=>D().subscribers),ne=re(()=>D().initialStates),we=re(()=>D().initialFactories),g=re(()=>D().metaEntries),ee=re(()=>D().snapshotCache),$=$r(()=>D().featureRuntimes),Ut=new WeakMap,Ir=e=>{let t=Ut.get(e);return t||(t=Lt(e),Ut.set(e,t)),t};_r(()=>Ir(D()));var Jt=e=>{let t=$.get(e);if(t)return t;let r=ze(e);if(!r)return;let n=r();return $.set(e,n),n},zr=()=>{le().forEach(e=>{Jt(e);});};zr();var N=e=>Q(D(),e);var W=(e,t)=>{let r=Et(),n=x()?kt(t):t;r?(r[e]=n,Object.prototype.hasOwnProperty.call(V,e)||(V[e]=void 0)):V[e]=n;},qe=(e,t,r=Date.now())=>{W(e,t),g[e]&&(g[e].updatedAt=new Date(r).toISOString(),g[e].updatedAtMs=r,g[e].updateCount++,Kt?.(e));};var Xt=e=>Ct(D(),e);var Ue=new Set,Ke=e=>e?Ue.has(e):Ue.size>0,Ge=e=>{e&&Ue.add(e);};var Ye=e=>N(e)&&!Xt(e)?true:(Ee(e,Object.keys(V)),false),Qt=(e,t,r={})=>{q(t,{...r,onError:g[e]?.options?.onError});},Zt=(e,t,r={})=>{q(e,{...r,onError:t});},U=(e,t,r="dev")=>{Qt(e,t,{severity:"warn",visibility:r});},er=(e,t,r="dev")=>{Zt(e,t,{severity:"warn",visibility:r});},ke=(e,t)=>Qt(e,t,{severity:"critical",visibility:"always"}),oe=(e,t)=>Zt(e,t,{severity:"critical",visibility:"always"}),pe=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
9
- Import "stroid/${t}" before calling createStore("${e}", ...).`;if(er(n,r,"always"),R().strictMissingFeatures)throw new Error(n)};var tr=new WeakMap,rr=new WeakMap;var Je=e=>{let t=tr.get(e);return t||(t=new Map,tr.set(e,t)),t},Wr=e=>{let t=rr.get(e);return t||(t=new Map,rr.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=Je(P());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)=>(Je(P())[t]=r,true)});var ge=(e,t,r,n)=>{try{return n?.reuseInput&&Ae(t)?{ok:!0,value:t}:{ok:!0,value:H(t)}}catch(s){let o=`Sanitize failed for "${e}": ${s?.message??s}`;return g[e]?.options?.onError?.(o),r?.(o),S(o),{ok:false}}},Br=(e,t)=>{let r=new Set,n=g[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},xe=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let s=Br(e,n),o=(c,l)=>{s.forEach(p=>p(c)),l==="critical"?G(c):S(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=Oe(r,t);return i.ok?{ok:true,value:i.data??t}:(o(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Re=(e,t,r,n,s)=>{let o=ge(e,t,n,s);if(!o.ok)return {ok:false};let i=xe(e,o.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},K=e=>{let t=P();Je(t).delete(e),Wr(t).delete(e);};Gt(K);var nr=new WeakMap,Lr=e=>{let t=nr.get(e);return t||(t=new Map,nr.set(e,t)),t};var Xe=e=>{let t=P(),r=Lr(t),n=r.get(e);if(n)return n;let s=g[e];if(!s)return S(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let o={name:e,options:s.options,getMeta:()=>g[e],getStoreValue:()=>V[e],getAllStores:()=>V,getInitialState:()=>ne[e],hasStore:()=>N(e),setStoreValue:i=>{W(e,i);},applyFeatureState:(i,c)=>{qe(e,i,c),K(e);},notify:()=>{},reportStoreError:i=>{ke(e,i);},warn:S,log:T,hashState:ce,deepClone:F,sanitize:H,validate:i=>xe(e,i,g[e]?.options?.validate),isDev:x};return r.set(e,o),o},Qe=(e,t)=>{let r=Xe(e);r&&(r.notify=()=>t(e),$.forEach(n=>{n.onStoreCreate?.(r);}));},Ze=(e,t,r,n,s)=>{let o=Xe(e);if(!o)return;o.notify=()=>s(e);let i=Object.assign(Object.create(o),{action:t,prev:r,next:n});$.forEach(c=>{c.onStoreWrite?.(i);});};var et=(e,t)=>At({name:e,payload:t,middlewares:(()=>{let r=g[e]?.options?.middleware||[],n=R().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{U(e,r,n);},warn:S}),Ce=(e,t,r,n)=>ve({name:e,label:t,fn:r,args:n,reportIssue:(s,o)=>{U(e,s,o);}}),tt=(e,t)=>{let r={...t};return r.persist&&!me("persist")&&(r.explicitPersist&&pe(e,"persist",r.onError),r.persist=null),r.sync&&!me("sync")&&(r.explicitSync&&pe(e,"sync",r.onError),r.sync=false),me("devtools")||(r.explicitDevtools&&pe(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var or=(e,t,r={})=>{if(We()){let a=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;oe(a,r.onError),He(a);return}if(!Se(e)){oe(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!De(t)){oe(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&x()&&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.`),vt(r).forEach(a=>{S(a);});let s=tt(e,wt(r,e));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()||O(a),j(a);}let o=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=o&&i==="production",l=s.allowSSRGlobalStore??false;if(c&&!l){let a=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
10
- Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;oe(a,r.onError);return}if(N(e)){let a=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return U(e,a),{name:e}}o&&!l&&!Ke(e)&&x()&&(Ge(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=ge(e,t,s.onError);if(!p.ok)return;let f=p.value,d=s.lazy===true&&typeof t=="function",u=(z[e]?.size??0)>0;if(d)V[e]=void 0,we[e]=t;else {let a=Re(e,f,s.validate,s.onError);if(!a.ok)return;W(e,a.value),ne[e]=F(a.value);}let h=Date.now(),y=new Date(h).toISOString();return g[e]={createdAt:y,updatedAt:y,updatedAtMs:h,updateCount:0,version:s.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},options:s},K(e),Qe(e,fe),Ce(e,"onCreate",g[e].options.onCreate,[f]),u&&fe(e),T(`Store "${e}" created -> ${JSON.stringify(f)}`),{name:e}};var Zr=(e,t,r="hydrate")=>{if(!Ye(e))return {ok:false,reason:"not-found"};let n=V[e],s=ge(e,t);if(!s.ok)return {ok:false,reason:"sanitize"};let o=s.value;if(o===void 0){let f=`Whole-store undefined replacement is blocked for "${e}". Use null for intentional empty state.`;return U(e,f),{ok:false,reason:"undefined"}}let i=g[e]?.options?.validate,c=et(e,{action:r,prev:n,next:o,path:null});if(c===be)return {ok:false,reason:"middleware"};let l=Re(e,c,i);if(!l.ok)return {ok:false,reason:"validate"};W(e,l.value),K(e);let p=Date.now();return g[e].updatedAt=new Date(p).toISOString(),g[e].updatedAtMs=p,g[e].updateCount++,Ze(e,r,n,l.value,fe),Ce(e,"onSet",g[e].options.onSet,[n,l.value]),fe(e),T(`Store "${e}" ${r==="hydrate"?"hydrated":"replaced"}`),{ok:true}};var rt=(e,t={},r={})=>{if(We()){let o="hydrateStores(...) cannot be called inside setStoreBatch.";return S(o),He(o),{hydrated:[],created:[],failed:{_batch:"transaction"}}}let n={hydrated:[],created:[],failed:Object.create(null)};if(!e||typeof e!="object")return n;if(!(r.allowUntrusted===true||R().allowUntrustedHydration===true))return O("hydrateStores(...) requires explicit trust. Pass { allowUntrusted: true } as the third argument or configureStroid({ allowUntrustedHydration: true })."),n.failed._hydration="untrusted",n;if(typeof r.validate=="function"){let o=false;try{o=!!r.validate(e);}catch(i){return O(`hydrateStores(...) trust validation threw: ${i?.message??i}`),n.failed._hydration="validation-error",n}if(!o)return O("hydrateStores(...) rejected by trust validation."),n.failed._hydration="validation-failed",n}return Object.entries(e).forEach(([o,i])=>{if(!Se(o)){n.failed[o]="invalid-name";return}if(N(o)){let c=Zr(o,i,"hydrate");c.ok?n.hydrated.push(o):n.failed[o]=c.reason??"hydrate-failed";}else {let c=t;or(o,i,c[o]||c.default||{})?n.created.push(o):n.failed[o]="create-failed";}}),n};var nt=new AsyncLocalStorage,Me=new AsyncLocalStorage;Ft({run:(e,t)=>nt.run(e,t),get:()=>nt.getStore()||null});Ot({run:(e,t)=>Me.run(e,t),get:()=>Me.getStore()||null,enterWith:e=>Me.enterWith(e)});var ps=e=>{let t=_e(),r={},n={},s=i=>Object.prototype.hasOwnProperty.call(r,i);return typeof e=="function"&&e({create:(i,c,l={})=>(r[i]=F(c),n[i]={...l},r[i]),set:(i,c)=>{if(!s(i))throw new Error(`createStoreForRequest.set("${i}") requires create("${i}", initialState) first.`);return r[i]=typeof c=="function"?je(r[i],c):c,r[i]},get:i=>s(i)?F(r[i]):void 0}),{snapshot:()=>F(r),hydrate:(i,c={})=>{let l={...c,default:c.default};return Object.keys(r).forEach(p=>{l[p]={...c.default||{},...c[p]||{},...n[p]||{}};}),Me.run(t,()=>nt.run(F(r),()=>(rt(r,l,{allowUntrusted:true}),i())))}}};export{ps as createStoreForRequest};
8
+ Call createStore("${e}", data) first.`);};var z=new Set(["__proto__","constructor","prototype"]),$e=(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 ae=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,xt=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},_e=e=>{let t=ae(e);return t==="function"?(_(St()),false):t==="map"||t==="set"?(y(yt()),true):(t==="date"&&y(mt()),true)},je=(e,t)=>{let r=xt(e);if(r)throw new Error(`${r} values are not supported`);let n=ae(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 a=Number(o);if(!Number.isInteger(a))return false}for(let o=0;o<e.length;o+=1)if(o in e&&!je(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,a]of Object.entries(s)){if(!a.enumerable||z.has(o))return false;if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${o}")`);if(!je(a.value,t))return false}return true}return true},Ie=e=>je(e,new WeakSet),se=(e,t)=>{let r=xt(e);if(r)throw new Error(`${r} values are not supported`);let n=ae(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()&&y(ht()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),x()&&y(bt());let s={};for(let[o,a]of e){if(typeof o!="string")throw new Error("Map keys must be strings to remain JSON-safe");s[String(o)]=se(a,t);}return s}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),x()&&y(vt()),Array.from(e,s=>se(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[a,i]of Object.entries(o))if(i.enumerable&&!z.has(a)){if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${a}")`);s[a]=se(i.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=>se(s,t))}return e},q=e=>se(e,new WeakSet),Se=e=>typeof e!="string"||e.trim()===""?(_(wt(e)),false):z.has(e)?(_(kt(e)),false):e.includes(" ")?(_(Rt(e)),false):true;var ze=null,Ar=()=>{if(ze)return ze;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 ze=t,t},Ct=e=>{let t=Ar(),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},Pr=2166136261,jr=2654435761,$r=1e5,W=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},B=(e,t)=>{W(e,t.length);for(let r=0;r<t.length;r++)W(e,t.charCodeAt(r));},w=(e,t)=>{B(e,t);},Mt=(e,t)=>{if(Number.isNaN(t)){w(e,"NaN");return}if(!Number.isFinite(t)){w(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){w(e,"-0");return}let r=t|0;if(t===r){w(e,"int"),W(e,r);return}w(e,"num"),B(e,String(t));},J=(e,t)=>{if(e.nodes++>$r){w(e,"[max]");return}if(t===null){w(e,"null");return}let r=typeof t;if(r==="string"){w(e,"string"),B(e,t);return}if(r==="number"){w(e,"number"),Mt(e,t);return}if(r==="boolean"){w(e,t?"true":"false");return}if(r==="undefined"){w(e,"undefined");return}if(r==="bigint"){w(e,"bigint"),B(e,t.toString());return}if(r==="symbol"){w(e,"symbol");let l=t;B(e,Symbol.keyFor(l)??l.description??String(l));return}if(r==="function"){w(e,"function"),B(e,t.name||"anonymous");return}let n=t,s=e.seen.get(n);if(s!==void 0){w(e,"ref"),W(e,s);return}let o=e.nextId++;if(e.seen.set(n,o),Array.isArray(n)){w(e,"array"),W(e,n.length);for(let l=0;l<n.length;l++)Object.prototype.hasOwnProperty.call(n,l)?J(e,n[l]):w(e,"hole");return}if(n instanceof Date){w(e,"date"),Mt(e,n.getTime());return}if(n instanceof Map){w(e,"map"),W(e,n.size),n.forEach((l,g)=>{J(e,g),J(e,l);});return}if(n instanceof Set){w(e,"set"),W(e,n.size),n.forEach(l=>{J(e,l);});return}w(e,"object");let a=Object.getOwnPropertyDescriptors(n),i=[];Object.entries(a).forEach(([l,g])=>{g?.enumerable&&(z.has(l)||"get"in g||"set"in g||i.push([l,g]));}),W(e,i.length);for(let[l,g]of i)B(e,l),J(e,g.value);},ie=e=>{if(typeof e=="string")return Ct(JSON.stringify(e));let t={h1:Pr,h2:jr,seen:new WeakMap,nextId:1,nodes:0};J(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 _r=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(([n,s])=>{s.enumerable&&(z.has(n)||"get"in s||"set"in s||(t[n]=s.value));}),t},X=(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((a,i)=>{o.set(X(i,t),X(a,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(a=>{o.add(X(a,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((a,i)=>{o[i]=X(a,t);}),o}let r=globalThis?.WeakRef;if(r&&e instanceof r)return T("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 T("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(s).forEach(([o,a])=>{!a.enumerable||z.has(o)||"get"in a||"set"in a||(n[o]=X(a.value,t));}),n},O=e=>{try{if(_r)return structuredClone(e)}catch{}return X(e)};var He=(e,t)=>{try{let r=O(e);return t(r),r}catch(r){throw new Error(`produceClone failed (possible circular reference or unserializable data): ${r?.message??r}`)}};var Be=new Set,Ir=()=>{Be.clear();};E("options.legacy-warnings",Ir,30);var ye=(()=>{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"}})(),qe=e=>{try{return typeof window>"u"?ye:e==="session"||e==="sessionStorage"?window.sessionStorage??ye:window.localStorage??ye}catch{return ye}},ce=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Q=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Ot=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}},zr=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Et=e=>{try{e[zr]=!0;}catch{}return e},Wr={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"},Hr=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Et(f=>f),decrypt:Et(f=>f),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:qe("localStorage"),...r};if(typeof e=="string")return {driver:qe(e),...r};let n=e.encrypt||r.encrypt,s=e.decrypt||r.decrypt,o=e.encryptAsync,a=e.decryptAsync,i=e.sensitiveData===true,l=e.allowPlaintext===true,g=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(o&&!a||!o&&a)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(i&&Ot(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||qe("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:n,decrypt:s,encryptAsync:o,decryptAsync:a,allowPlaintext:l,sensitiveData:i,checksum:g,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Ft=e=>{if(!ce(e))return [];let t=[];return Object.entries(Wr).forEach(([r,n])=>{Q(e,r)&&(Be.has(r)||(Be.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},Vt=(e={},t,r="deep")=>{let n=e.scope??"request",s=e.lazy===true,o=e.pathCreate===true,a=ce(e.lifecycle)?e.lifecycle:void 0,i=ce(e.persist)?e.persist:void 0,l=ce(e.devtools)?e.devtools:void 0,g=e.validate??e.validator??e.schema,f=e.snapshot==="shallow"||e.snapshot==="ref"?e.snapshot:r==="shallow"||r==="ref"?r:"deep",h=ce(e.features)?{...e.features}:void 0,m=Q(e,"persist"),M=Q(e,"sync"),d=Q(e,"devtools")||Q(e,"historyLimit")||Q(e,"redactor"),c=n==="global"?true:e.allowSSRGlobalStore??false,{persist:p=false,devtools:u=false,onError:v,sync:F}=e;if(i?.sensitiveData===true){let C=i.encrypt,R=i.encryptAsync;if((!C||Ot(C))&&!R)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"&&!m?null:Hr(p,t),devtools:n==="temp"&&!d?false:typeof u=="boolean"?u:l?.enabled??true,middleware:a?.middleware??e.middleware??[],onSet:a?.onSet??e.onSet,onReset:a?.onReset??e.onReset,onDelete:a?.onDelete??e.onDelete,onCreate:a?.onCreate??e.onCreate,onError:v,validate:g,migrations:i?.migrations??e.migrations??{},version:i?.version??e.version??1,redactor:n==="temp"&&!d?void 0:l?.redactor??e.redactor,historyLimit:n==="temp"&&!d?0:l?.historyLimit??e.historyLimit??50,sync:n==="temp"&&!M?false:F??false,features:h,allowSSRGlobalStore:c,snapshot:f,explicitPersist:m,explicitSync:M,explicitDevtools:d}};var Tt=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 Le=new Map;var me=e=>Le.has(e),Ue=e=>Le.get(e),ue=()=>Array.from(Le.keys());var he=Symbol("stroid.middleware.abort"),Dt=({name:e,payload:t,middlewares:r,reportIssue:n,warn:s})=>{if(!Array.isArray(r)||r.length===0)return t.next;let o=new WeakSet,a=O(t.next);for(let i of r){if(typeof i!="function")continue;let l,g=a;try{l=i({action:t.action,name:e,prev:t.prev,next:g,path:t.path});}catch(f){let h=`Middleware for "${e}" failed: ${f?.message??f}`;return n(h,"dev"),he}if(l&&typeof l.then=="function"){let f=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(f,"dev"),he}l===void 0?(x()&&!o.has(i)&&(o.add(i),s(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),a=g):a=l;}return a},be=({name:e,label:t,fn:r,args:n,reportIssue:s})=>{if(typeof r=="function")try{r(...n);}catch(o){let a=`${t} for "${e}" failed: ${o?.message??o}`;s(a,"always");}};var L=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:s}=t;if(s?.(e),r==="critical"){n==="dev"&&y(e),Y(e);return}if(n==="always"){T(e);return}y(e);};var ve=null,At=e=>{ve=e;},Pt=e=>ve?ve(e):[];E("computed.order-resolver",()=>{ve=null;},105);var jt=()=>I(ne(re)),$t=()=>jt().computedEntries,Br=()=>jt().computedDependents;var _t=e=>Object.prototype.hasOwnProperty.call($t(),e);var Lr=e=>{let t=$t(),r=Br(),n=new Set,s=[...e];for(;s.length>0;){let f=s.shift(),h=r[f];if(h)for(let m of h)n.has(m)||(n.add(m),s.push(m));}if(n.size===0)return [];let o=f=>{let h=t[f];if(h)for(let m of h.deps)t[m]&&(n.has(m)||(n.add(m),o(m)));};Array.from(n).forEach(f=>o(f));let a=new Map,i=new Map;for(let f of n){let h=t[f];if(!h)continue;let m=0;for(let M of h.deps)n.has(M)&&(m++,i.has(M)||i.set(M,[]),i.get(M).push(f));a.set(f,m);}let l=[];for(let[f,h]of a)h===0&&l.push(f);l.sort();let g=[];for(;l.length>0;){let f=l.shift();g.push(f);let h=i.get(f)??[];for(let m of h){let M=(a.get(m)??1)-1;if(a.set(m,M),M===0){let d=l.findIndex(c=>c>m);d===-1?l.push(m):l.splice(d,0,m);}}}return g};At(Lr);var we=new Set,It=e=>e?we.has(e):we.size>0,zt=e=>{e&&we.add(e);},Ur=()=>{we.clear();};E("ssr.warnings",Ur,60);var Wt=e=>H(e)&&!Bt(e)?true:(Pe(e,Object.keys(V)),false),Ht=(e,t,r={})=>{L(t,{...r,onError:S[e]?.options?.onError});},qt=(e,t,r={})=>{L(e,{...r,onError:t});},Z=(e,t,r="dev")=>{Ht(e,t,{severity:"warn",visibility:r});},Kr=(e,t,r="dev")=>{qt(e,t,{severity:"warn",visibility:r});},Ke=(e,t)=>Ht(e,t,{severity:"critical",visibility:"always"}),le=(e,t)=>qt(e,t,{severity:"critical",visibility:"always"}),Re=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
9
+ Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Kr(n,r,"always"),k().strictMissingFeatures)throw new Error(n)};var Lt=e=>(e??I()).transaction,Gr=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 Ge=()=>Lt().depth>0,Ye=(e,t)=>{let r=Lt(t);r.failed=true,r.error||(r.error=Gr(e));};var Ut=new WeakMap,Kt=new WeakMap;var ke=e=>{let t=Ut.get(e);return t||(t=new Map,Ut.set(e,t)),t},Gt=e=>{let t=Kt.get(e);return t||(t=new Map,Kt.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=ke(N());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)=>(ke(N())[t]=r,true)});var xe=(e,t,r,n)=>{try{return n?.reuseInput&&Ie(t)?{ok:!0,value:t}:{ok:!0,value:q(t)}}catch(s){let o=`Sanitize failed for "${e}": ${s?.message??s}`;return S[e]?.options?.onError?.(o),r?.(o),y(o),{ok:false}}},Yr=(e,t)=>{let r=new Set,n=S[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},Je=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let s=Yr(e,n),o=(i,l)=>{s.forEach(g=>g(i)),l==="critical"?Y(i):y(i);};if(typeof r=="function")try{let i=r(t);return i===!1?(o(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:i===!0?t:i}}catch(i){return o(`Validation for "${e}" failed: ${i?.message??i}`,"critical"),{ok:false}}let a=$e(r,t);return a.ok?{ok:true,value:a.data??t}:(o(`Validation failed for "${e}": ${a.error}`,"critical"),{ok:false})},Xe=(e,t,r,n,s)=>{let o=xe(e,t,n,s);if(!o.ok)return {ok:false};let a=Je(e,o.value,r,n);return a.ok?{ok:true,value:a.value}:{ok:false}},ee=e=>{let t=N();ke(t).delete(e),Gt(t).delete(e);},Jr=()=>{let e=N();ke(e).clear(),Gt(e).clear();};E("validation.path-cache",Jr,50);Yt(ee);var Jt=e=>{let t=S[e]?.options?.snapshot??k().defaultSnapshotMode;return t==="shallow"||t==="ref"?t:"deep"},Xt=(e,t)=>t==="ref"?e:t==="shallow"?We(e):O(e);var Me=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Xr=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:n}=e;r.length=0;for(let d of t)r.push(d);t.clear();let s=k().flush,o=s.priorityStores||[],a=new Set(r),i=o.length?new Set(o):null;if(n.length=0,i){for(let d of o)a.has(d)&&n.push(d);for(let d of r)i.has(d)||n.push(d);}else n.push(...r);let l=Pt(n),g=new Set(n);for(let d of l)a.has(d)&&!g.has(d)&&(n.push(d),g.add(d));let f=Number.isFinite(s.chunkSize)&&s.chunkSize>0?s.chunkSize:Number.POSITIVE_INFINITY,h=s.chunkDelayMs,m=f===Number.POSITIVE_INFINITY&&h===0;return {names:n.slice(),sliceSize:f,chunkDelayMs:h,runInline:m,prioritySet:i}},Qr=e=>{let t=e.notify,{names:r,sliceSize:n,chunkDelayMs:s,runInline:o,prioritySet:a}=Xr(t),i=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),l=()=>{t.notifyScheduled=false,t.pendingNotifications.size>0&&Qt(e);};if(o){for(let d of r){let c=K[d];if(!c||c.size===0)continue;let p=S[d]?.updateCount??0,u=Jt(d),v=pe[d],F=v&&v.version===p?v.snapshot:(()=>{let P=Xt(V[d],u);return pe[d]={version:p,snapshot:P},P})(),C=i();for(let P of c)try{P(F);}catch(Ee){y(`Subscriber for "${d}" threw: ${Ee?.message??Ee}`);}let R=i()-C,b=S[d]?.metrics||{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0};b.notifyCount+=1,b.totalNotifyMs+=R,b.lastNotifyMs=R,S[d]&&(S[d].metrics=b),(S[d]?.updateCount??p)!==p&&t.pendingNotifications.add(d);}l();return}let g=d=>{let c=[];for(let p of r){if(d&&!d(p))continue;let u=K[p];if(!u||u.size===0)continue;let v=S[p]?.updateCount??0,F=Jt(p),C=pe[p],R=C&&C.version===v?C.snapshot:(()=>{let b=Xt(V[p],F);return pe[p]={version:v,snapshot:b},b})();c.push({name:p,subsArray:Array.from(u),index:0,snapshot:R,version:v,notified:new Set,metrics:S[p]?.metrics?{...S[p].metrics}:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},totalMs:0});}return c},f=a?g(d=>a.has(d)):[],h=g(d=>!a||!a.has(d)),m=d=>{let c=K[d.name];if(!c||c.size===0){d.subsArray=[],d.index=0;return}d.subsArray=Array.from(c),d.index=0;},M=(d,c)=>{let p=()=>{if(d.length===0){c();return}let u=d.shift();if((S[u.name]?.updateCount??u.version)!==u.version){if(t.pendingNotifications.add(u.name),d.length===0){c();return}o?p():Me(p,s);return}if(m(u),u.subsArray.length===0){if(d.length===0){c();return}o?p():Me(p,s);return}let F=i(),C=0,R=false;for(;u.index<u.subsArray.length&&C<n;){let P=u.subsArray[u.index++];if(u.notified.has(P))continue;u.notified.add(P);try{P(u.snapshot);}catch(rt){y(`Subscriber for "${u.name}" threw: ${rt?.message??rt}`);}if(C+=1,(S[u.name]?.updateCount??u.version)!==u.version){R=true,t.pendingNotifications.add(u.name);break}}if(u.totalMs+=i()-F,R){if(d.length===0){c();return}o?p():Me(p,s);return}let b=K[u.name],A=b?Array.from(b).some(P=>!u.notified.has(P)):false;if(u.index<u.subsArray.length||A?d.push(u):(u.metrics.notifyCount+=1,u.metrics.totalNotifyMs+=u.totalMs,u.metrics.lastNotifyMs=u.totalMs,S[u.name]&&(S[u.name].metrics=u.metrics)),d.length===0){c();return}o?p():Me(p,s);};p();};f.length>0?M(f,()=>M(h,l)):M(h,l);},Qt=e=>{let t=e.notify;if(t.notifyScheduled)return;t.notifyScheduled=true;let r=()=>Te(e,()=>Qr(e));typeof queueMicrotask=="function"?queueMicrotask(r):Promise.resolve().then(r);},fe=e=>{let t=N(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&Qt(t);};var Zr=()=>{let e=N().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};E("notify.reset",Zr,40);var tn=()=>N().computedCleanups;var Zt=e=>{let t=tn(),r=t.get(e);if(!r){x()&&y(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var er=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,s=e.initialFactories,o=e.metaEntries,a=e.snapshotCache,i=e.featureRuntimes,l=e.deletingStores,g=(c,p)=>{L(p,{onError:o[c]?.options?.onError,severity:"warn",visibility:"dev"});},f=({name:c,prev:p,options:u,initialState:v,getMeta:F,getStoreValue:C,hasStore:R})=>({name:c,options:u,prev:p,getMeta:F,getStoreValue:C,getAllStores:()=>t,getInitialState:()=>v,hasStore:R,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:b=>{L(b,{onError:u.onError,severity:"warn",visibility:"dev"});},warn:y,log:j,hashState:ie,deepClone:O,sanitize:q,validate:()=>({ok:true,value:p}),isDev:x}),h=({name:c,prev:p,options:u,initialState:v,phase:F})=>{let C=f({name:c,prev:p,options:u,initialState:v,getMeta:()=>o[c],getStoreValue:()=>t[c],hasStore:()=>G(e,c)}),R=f({name:c,prev:p,options:u,initialState:v,getMeta:()=>{},getStoreValue:()=>p,hasStore:()=>false});ue().forEach(b=>{let A=i.get(b);F==="before"?A?.beforeStoreDelete?.(C):A?.afterStoreDelete?.(R);});},m=c=>{if(!G(e,c))return;let p=t[c],u=o[c].options,v=n[c],F=r[c];l.add(c);try{F?.forEach(b=>{try{b(null);}catch(A){y(`Subscriber for "${c}" threw during delete: ${A?.message??A}`);}}),be({name:c,label:"onDelete",fn:u.onDelete,args:[p],reportIssue:(b,A)=>{L(b,{onError:u.onError,severity:"warn",visibility:A});}}),h({name:c,prev:p,options:u,initialState:v,phase:"before"}),delete t[c],delete r[c],delete n[c],delete s[c],delete o[c],delete a[c],_t(c)&&Zt(c);let R=e.computedDependents[c];if(R)for(let b of R)y(`[stroid] source store "${c}" was deleted. Computed store "${b}" depends on it and will return stale data. Call deleteComputed("${b}") to clean up.`);h({name:c,prev:p,options:u,initialState:v,phase:"after"}),j(`Store "${c}" deleted`);}finally{l.delete(c);}};return {deleteExistingStore:m,clearAllStores:()=>{let c=[],u=0,v=Number.POSITIVE_INFINITY;for(;u<20;){let C=Object.keys(t);if(C.length===0)break;C.forEach(b=>{G(e,b)&&(m(b),c.push(b));}),u+=1;let R=Object.keys(t).length;if(R===0||R>=v)break;v=R;}let F=Object.keys(t).length;return F>0?y(`clearAllStores stopped after ${u} pass${u===1?"":"es"}; ${F} store(s) still registered (likely recreated during deletion).`):y(`All stores cleared (${c.length} stores removed)`),c},clearStores:c=>{let p=Object.keys(t).filter(u=>c?c.endsWith("*")?u.startsWith(c.slice(0,-1)):u===c:true);return p.forEach(u=>m(u)),p},reportStoreError:g}};var rn=re,nn=ne(rn),nr=null,tr=new WeakSet,on=e=>{tr.has(e)||(tr.add(e),ue().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Ue(t);r&&e.featureRuntimes.set(t,r());}}));},D=()=>{let e=I(nn);return on(e),e};var N=()=>D();function Yt(e){nr=e;}var te=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}}}),sn=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)}),an=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)}),V=te(()=>D().stores),K=te(()=>D().subscribers),de=te(()=>D().initialStates),Qe=te(()=>D().initialFactories),S=te(()=>D().metaEntries),pe=te(()=>D().snapshotCache),$=sn(()=>D().featureRuntimes),rr=new WeakMap,cn=e=>{let t=rr.get(e);return t||(t=er(e),rr.set(e,t)),t};an(()=>cn(D()));var ln=e=>{let t=$.get(e);if(t)return t;let r=Ue(e);if(!r)return;let n=r();return $.set(e,n),n},dn=()=>{ue().forEach(e=>{ln(e);});};dn();var H=e=>G(D(),e);var U=(e,t)=>{let r=lt(),n=x()?Tt(t):t;r?(r[e]=n,Object.prototype.hasOwnProperty.call(V,e)||(V[e]=void 0)):V[e]=n;},or=(e,t,r=Date.now())=>{U(e,t),S[e]&&(S[e].updatedAt=new Date(r).toISOString(),S[e].updatedAtMs=r,S[e].updateCount++,nr?.(e));},pn=()=>{it(D());},fn=()=>{$.forEach(e=>{try{e.resetAll?.();}catch{}}),$.clear();};E("features.reset",fn,10);E("registries.clear",pn,20);var Bt=e=>at(D(),e);var sr=new WeakMap,ar=e=>{let t=sr.get(e);return t||(t=new Map,sr.set(e,t)),t},gn=()=>{ar(N()).clear();};E("features.contexts",gn,100);var ir=e=>{let t=N(),r=ar(t),n=r.get(e);if(n)return n;let s=S[e];if(!s)return y(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let o={name:e,options:s.options,getMeta:()=>S[e],getStoreValue:()=>V[e],getAllStores:()=>V,getInitialState:()=>de[e],hasStore:()=>H(e),setStoreValue:a=>{U(e,a);},applyFeatureState:(a,i)=>{or(e,a,i),ee(e);},notify:()=>{},reportStoreError:a=>{Ke(e,a);},warn:y,log:j,hashState:ie,deepClone:O,sanitize:q,validate:a=>Je(e,a,S[e]?.options?.validate),isDev:x};return r.set(e,o),o},cr=(e,t)=>{let r=ir(e);r&&(r.notify=()=>t(e),$.forEach(n=>{n.onStoreCreate?.(r);}));},ur=(e,t,r,n,s)=>{let o=ir(e);if(!o)return;o.notify=()=>s(e);let a=Object.assign(Object.create(o),{action:t,prev:r,next:n});$.forEach(i=>{i.onStoreWrite?.(a);});};var lr=(e,t)=>Dt({name:e,payload:t,middlewares:(()=>{let r=S[e]?.options?.middleware||[],n=k().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{Z(e,r,n);},warn:y}),Ze=(e,t,r,n)=>be({name:e,label:t,fn:r,args:n,reportIssue:(s,o)=>{Z(e,s,o);}}),dr=(e,t)=>{let r={...t};return r.persist&&!me("persist")&&(r.explicitPersist&&Re(e,"persist",r.onError),r.persist=null),r.sync&&!me("sync")&&(r.explicitSync&&Re(e,"sync",r.onError),r.sync=false),me("devtools")||(r.explicitDevtools&&Re(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var pr=new Set;var Sn=({name:e,prev:t,next:r,action:n,hookLabel:s,logMessage:o})=>{U(e,r),ee(e);let a=Date.now();S[e].updatedAt=new Date(a).toISOString(),S[e].updatedAtMs=a,S[e].updateCount++,ur(e,n,t,r,fe),Ze(e,s,S[e].options[s],[t,r]),fe(e),j(o);};var fr=(e,t,r={})=>{if(Ge()){let c=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;le(c,r.onError),Ye(c);return}if(!Se(e)){le(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!_e(t)){le(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&x()&&y(`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.`),Ft(r).forEach(c=>{y(c);});let s=dr(e,Vt(r,e,k().defaultSnapshotMode));if(s.scope==="temp"&&r.persist){let c=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;s.onError?.(c),x()||T(c),_(c);}let o=typeof window>"u",a=typeof process<"u"?process.env?.NODE_ENV:void 0,i=o&&a==="production",l=s.allowSSRGlobalStore??false;if(i&&!l){let c=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
10
+ Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;le(c,r.onError);return}if(i&&l&&!pr.has(e)&&(pr.add(e),T(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
11
+ This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),H(e)){let c=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return Z(e,c),{name:e}}o&&!l&&!It(e)&&x()&&(zt(e),y(`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=xe(e,t,s.onError);if(!g.ok)return;let f=g.value,h=s.lazy===true&&typeof t=="function",m=(K[e]?.size??0)>0;if(h)V[e]=void 0,Qe[e]=t;else {let c=Xe(e,f,s.validate,s.onError);if(!c.ok)return;U(e,c.value),de[e]=O(c.value);}let M=Date.now(),d=new Date(M).toISOString();return S[e]={createdAt:d,updatedAt:d,updatedAtMs:M,updateCount:0,version:s.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},options:s},ee(e),cr(e,fe),Ze(e,"onCreate",S[e].options.onCreate,[f]),m&&fe(e),j(`Store "${e}" created -> ${JSON.stringify(f)}`),{name:e}};var yn=(e,t,r="hydrate")=>{if(!Wt(e))return {ok:false,reason:"not-found"};let n=V[e],s=xe(e,t);if(!s.ok)return {ok:false,reason:"sanitize"};let o=s.value;if(o===void 0){let g=`Whole-store undefined replacement is blocked for "${e}". Use null for intentional empty state.`;return Z(e,g),{ok:false,reason:"undefined"}}let a=S[e]?.options?.validate,i=lr(e,{action:r,prev:n,next:o,path:null});if(i===he)return {ok:false,reason:"middleware"};let l=Xe(e,i,a);return l.ok?(Sn({name:e,prev:n,next:l.value,action:r,hookLabel:"onSet",logMessage:`Store "${e}" ${r==="hydrate"?"hydrated":"replaced"}`}),{ok:true}):{ok:false,reason:"validate"}};var et=(e,t={},r={})=>{if(Ge()){let o="hydrateStores(...) cannot be called inside setStoreBatch.";return y(o),Ye(o),{hydrated:[],created:[],failed:{_batch:"transaction"}}}let n={hydrated:[],created:[],failed:Object.create(null)};if(!e||typeof e!="object")return n;if(!(r.allowUntrusted===true||k().allowUntrustedHydration===true))return T("hydrateStores(...) requires explicit trust. Pass { allowUntrusted: true } as the third argument or configureStroid({ allowUntrustedHydration: true })."),n.failed._hydration="untrusted",n;if(typeof r.validate=="function"){let o=false;try{o=!!r.validate(e);}catch(a){return T(`hydrateStores(...) trust validation threw: ${a?.message??a}`),n.failed._hydration="validation-error",n}if(!o)return T("hydrateStores(...) rejected by trust validation."),n.failed._hydration="validation-failed",n}return Object.entries(e).forEach(([o,a])=>{if(!Se(o)){n.failed[o]="invalid-name";return}if(H(o)){let i=yn(o,a,"hydrate");i.ok?n.hydrated.push(o):n.failed[o]=i.reason??"hydrate-failed";}else {let i=t;fr(o,a,i[o]||i.default||{})?n.created.push(o):n.failed[o]="create-failed";}}),n};var tt=new AsyncLocalStorage,Ce=new AsyncLocalStorage;ut({run:(e,t)=>tt.run(e,t),get:()=>tt.getStore()||null});dt({run:(e,t)=>Ce.run(e,t),get:()=>Ce.getStore()||null,enterWith:e=>Ce.enterWith(e)});var Ds=e=>{let t=Ve(),r={},n={},s=a=>Object.prototype.hasOwnProperty.call(r,a);return typeof e=="function"&&e({create:(a,i,l={})=>(r[a]=O(i),n[a]={...l},r[a]),set:(a,i)=>{if(!s(a))throw new Error(`createStoreForRequest.set("${a}") requires create("${a}", initialState) first.`);return r[a]=typeof i=="function"?He(r[a],i):i,r[a]},get:a=>s(a)?O(r[a]):void 0}),{snapshot:()=>O(r),hydrate:(a,i={})=>{let l={...i,default:i.default};return Object.keys(r).forEach(g=>{let f=g,h={...i.default||{},...i[f]||{},...n[g]||{}};l[f]=h;}),Ce.run(t,()=>tt.run(O(r),()=>(et(r,l,{allowUntrusted:true}),a())))}}};export{Ds as createStoreForRequest};//# sourceMappingURL=server.js.map
12
+ //# sourceMappingURL=server.js.map