stroid 0.1.3 → 0.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (133) hide show
  1. package/CHANGELOG.md +312 -265
  2. package/README.md +1017 -115
  3. package/dist/async.d.ts +1 -1
  4. package/dist/async.js +1 -33
  5. package/dist/chunk-645IESIU.js +2 -0
  6. package/dist/chunk-6ELWGQ4Q.js +2 -0
  7. package/dist/chunk-BW32TJGE.js +13 -0
  8. package/dist/chunk-FOQKGHPS.js +26 -0
  9. package/dist/chunk-KQCSFGHJ.js +2 -0
  10. package/dist/chunk-M2NJVI36.js +2 -0
  11. package/dist/chunk-PVATWAY4.js +2 -0
  12. package/dist/chunk-X3JR32JD.js +2 -0
  13. package/dist/chunk-YU5GMPCC.js +2 -0
  14. package/dist/computed-types.d.ts +42 -0
  15. package/dist/computed-types.js +2 -0
  16. package/dist/computed.d.ts +9 -2
  17. package/dist/computed.js +1 -12
  18. package/dist/core.js +1 -22
  19. package/dist/devtools.d.ts +1 -1
  20. package/dist/devtools.js +1 -1
  21. package/dist/feature.js +1 -1
  22. package/dist/helpers.js +1 -22
  23. package/dist/index-internal.d.ts +1 -1
  24. package/dist/index.d.cts +3 -1
  25. package/dist/index.d.ts +3 -1
  26. package/dist/index.js +1 -35
  27. package/dist/install.js +1 -1
  28. package/dist/options.d.ts +1 -1
  29. package/dist/persist.js +1 -1
  30. package/dist/psr.d.ts +48 -0
  31. package/dist/psr.js +2 -0
  32. package/dist/react/index.d.ts +3 -1
  33. package/dist/react/index.js +5 -36
  34. package/dist/registry.d.ts +1 -0
  35. package/dist/runtime-admin.js +1 -1
  36. package/dist/runtime-patch.d.ts +29 -0
  37. package/dist/runtime-tools.d.ts +6 -1
  38. package/dist/runtime-tools.js +1 -3
  39. package/dist/selectors.js +1 -1
  40. package/dist/server.d.ts +4 -1
  41. package/dist/server.js +1 -12
  42. package/dist/store-registry.d.ts +8 -0
  43. package/dist/sync.js +1 -1
  44. package/dist/testing.js +1 -22
  45. package/dist/types/adapters/options.d.ts +335 -0
  46. package/dist/types/async/cache.d.ts +40 -0
  47. package/dist/types/async/clone.d.ts +10 -0
  48. package/dist/types/async/errors.d.ts +3 -0
  49. package/dist/types/async/fetch.d.ts +37 -0
  50. package/dist/types/async/inflight.d.ts +30 -0
  51. package/dist/types/async/rate.d.ts +5 -0
  52. package/dist/types/async/registry.d.ts +117 -0
  53. package/dist/types/async/request.d.ts +11 -0
  54. package/dist/types/async/retry.d.ts +10 -0
  55. package/dist/types/async.d.ts +10 -0
  56. package/dist/types/computed/computed-graph.d.ts +33 -0
  57. package/dist/types/computed/index.d.ts +21 -0
  58. package/dist/types/computed/types.d.ts +40 -0
  59. package/dist/types/config.d.ts +10 -0
  60. package/dist/types/core/index.d.ts +11 -0
  61. package/dist/types/core/lifecycle-hooks.d.ts +16 -0
  62. package/dist/types/core/runtime-patch.d.ts +67 -0
  63. package/dist/types/core/store-admin-impl.d.ts +9 -0
  64. package/dist/types/core/store-admin.d.ts +9 -0
  65. package/dist/types/core/store-core.d.ts +13 -0
  66. package/dist/types/core/store-create.d.ts +16 -0
  67. package/dist/types/core/store-hydrate-impl.d.ts +35 -0
  68. package/dist/types/core/store-hydrate.d.ts +9 -0
  69. package/dist/types/core/store-lifecycle/hooks.d.ts +20 -0
  70. package/dist/types/core/store-lifecycle/identity.d.ts +23 -0
  71. package/dist/types/core/store-lifecycle/registry.d.ts +54 -0
  72. package/dist/types/core/store-lifecycle/types.d.ts +67 -0
  73. package/dist/types/core/store-lifecycle/validation.d.ts +53 -0
  74. package/dist/types/core/store-name.d.ts +28 -0
  75. package/dist/types/core/store-notify.d.ts +13 -0
  76. package/dist/types/core/store-read.d.ts +18 -0
  77. package/dist/types/core/store-registry.d.ts +115 -0
  78. package/dist/types/core/store-replace-impl.d.ts +11 -0
  79. package/dist/types/core/store-replace.d.ts +9 -0
  80. package/dist/types/core/store-set-impl.d.ts +13 -0
  81. package/dist/types/core/store-set.d.ts +9 -0
  82. package/dist/types/core/store-shared/core.d.ts +13 -0
  83. package/dist/types/core/store-shared/notify.d.ts +12 -0
  84. package/dist/types/core/store-transaction.d.ts +28 -0
  85. package/dist/types/core/store-write-shared.d.ts +25 -0
  86. package/dist/types/core/store-write.d.ts +13 -0
  87. package/dist/types/features/feature-registry.d.ts +91 -0
  88. package/dist/types/features/lifecycle.d.ts +40 -0
  89. package/dist/types/index.d.ts +17 -0
  90. package/dist/types/integrations/query.d.ts +8 -0
  91. package/dist/types/internals/computed-order.d.ts +3 -0
  92. package/dist/types/internals/config.d.ts +116 -0
  93. package/dist/types/internals/diagnostics.d.ts +21 -0
  94. package/dist/types/internals/reporting.d.ts +9 -0
  95. package/dist/types/internals/store-admin.d.ts +7 -0
  96. package/dist/types/internals/store-ops.d.ts +13 -0
  97. package/dist/types/internals/test-reset.d.ts +2 -0
  98. package/dist/types/internals/write-context.d.ts +20 -0
  99. package/dist/types/notification/delivery.d.ts +3 -0
  100. package/dist/types/notification/index.d.ts +10 -0
  101. package/dist/types/notification/metrics.d.ts +12 -0
  102. package/dist/types/notification/priority.d.ts +9 -0
  103. package/dist/types/notification/scheduler.d.ts +11 -0
  104. package/dist/types/notification/snapshot.d.ts +8 -0
  105. package/dist/types/runtime-admin/index.d.ts +2 -0
  106. package/dist/types/runtime-tools/index.d.ts +63 -0
  107. package/dist/types/store.d.ts +16 -0
  108. package/dist/types/types/utility.d.ts +17 -0
  109. package/dist/types/utils/clone.d.ts +4 -0
  110. package/dist/types/utils/devfreeze.d.ts +2 -0
  111. package/dist/types/utils/hash.d.ts +8 -0
  112. package/dist/types/utils/path.d.ts +5 -0
  113. package/dist/types/utils/validation.d.ts +14 -0
  114. package/dist/types/utils.d.ts +13 -0
  115. package/dist/types.d.ts +2 -2
  116. package/package.json +31 -20
  117. package/dist/async.js.map +0 -1
  118. package/dist/computed.js.map +0 -1
  119. package/dist/core.js.map +0 -1
  120. package/dist/devtools.js.map +0 -1
  121. package/dist/feature.js.map +0 -1
  122. package/dist/helpers.js.map +0 -1
  123. package/dist/index.js.map +0 -1
  124. package/dist/install.js.map +0 -1
  125. package/dist/persist.js.map +0 -1
  126. package/dist/react/index.js.map +0 -1
  127. package/dist/runtime-admin.js.map +0 -1
  128. package/dist/runtime-tools.js.map +0 -1
  129. package/dist/selectors.js.map +0 -1
  130. package/dist/server.js.map +0 -1
  131. package/dist/sync.js.map +0 -1
  132. package/dist/testing.js.map +0 -1
  133. package/dist/tsdoc-metadata.json +0 -11
package/dist/install.js CHANGED
@@ -1,2 +1,2 @@
1
- var Ue=new Map,Et=null,fe=(e,t)=>{Ue.set(e,t),Et?.(e,t);};var Pe=e=>Ue.get(e),pe=()=>Array.from(Ue.keys()),Ft=e=>{Et=e;};var Br=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",qe=e=>!!e?.[Br],Ae=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}},xt=(e,t,r)=>{let o="__stroid_persist_roundtrip_probe__",s;try{s=t(o);}catch(c){return {ok:false,reason:`persist: encrypt failed for store "${e}" (${c?.message??c})`}}if(typeof s!="string")return {ok:false,reason:`persist: encrypt must return a string for store "${e}".`};let a;try{a=r(s);}catch(c){return {ok:false,reason:`persist: decrypt failed for store "${e}" (${c?.message??c})`}}return typeof a!="string"?{ok:false,reason:`persist: decrypt must return a string for store "${e}".`}:a!==o?{ok:false,reason:`persist: encrypt/decrypt must round-trip for store "${e}".`}:{ok:true}};var Tt=(e,t,r)=>{e[t]&&(e[t].lastPresent=r);},Vt=({name:e,persistConfig:t,persistWatchState:r})=>{let o=t?.onStorageCleared;if(!t||typeof o!="function"||typeof window>"u"||typeof window.addEventListener!="function")return;r[e]?.dispose();let s=window,a=()=>{try{return t.driver.getItem?.(t.key)!=null}catch{return false}},c=n=>{let p=r[e],i=a();if(p){if(!p.lastPresent||i){p.lastPresent=i;return}p.lastPresent=false,o({name:e,key:t.key,reason:n});}},l=n=>{if(n.key===null){c("clear");return}n.key===t.key&&n.newValue===null&&c("remove");},g=()=>{c("missing");};s.addEventListener("storage",l),s.addEventListener("focus",g),r[e]={lastPresent:a(),dispose:()=>{s.removeEventListener("storage",l),s.removeEventListener("focus",g);}};};var Me=({value:e,sanitize:t,validate:r,onSanitizeError:o})=>{let s;if(t)try{s=t(e);}catch(c){return o?.(c),{ok:false}}else s=e;let a=r(s);return a.ok?{ok:true,value:a.value??s}:{ok:false}},ie=({value:e,fallbackMs:t=Date.now(),onInvalid:r})=>{if(typeof e=="number")return Number.isFinite(e)?e:(r?.(),t);if(typeof e=="string"){let o=Date.parse(e);return Number.isFinite(o)?o:(r?.(),t)}return r?.(),t};var Ur=new Map,A=(e,t,r=0)=>{!e||typeof t!="function"||Ur.set(e,{name:e,order:r,fn:t});};var jt=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),Pt=()=>({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:jt(),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}}),At=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(),jt().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 Ke=new Map,Dt=new WeakSet,Ge=e=>{Dt.has(e)||(Dt.add(e),pe().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Pe(t);r&&e.featureRuntimes.set(t,r());}}));},qr=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,$t,Ye=e=>($t||qr||e).replace(/\.ts(\?|$)/,".js$1"),ge=Ye("stroid:default-registry");var Kr=()=>{$t=void 0,Ke.clear();};A("registry.scope-override",Kr,110);var Gr=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Yr=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},Jr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),Xr=(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:Jr(),async:Pt(),notify:Gr(),lifecycleListener:null};return Ge(t),t},ye=e=>{let t=Ye(e),r=Ke.get(t);if(r)return r;let o=Xr();return Ke.set(t,o),o},ae=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var Ot=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,Yr(e.notify),At(e.async),e.lifecycleListener=null;};var Je=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var ee=[],It={run:(e,t)=>{ee.push(e);try{return t()}finally{ee.pop();}},get:()=>ee.length>0?ee[ee.length-1]:null,enterWith:e=>{if(ee.length>0){ee[ee.length-1]=e;return}ee.push(e);}};var he=e=>(It).get()||e||ye(ge);var Zr={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}`));}},zt={logSink:Zr,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},Qe=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}),Xe=new WeakMap,Wt=Qe(zt),eo=e=>{let t=Xe.get(e);return t||(t=Qe(Wt),Xe.set(e,t)),t};var N=()=>eo(he());var no=()=>{Xe=new WeakMap,Wt=Qe(zt);};A("config.reset",no,90);var so=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,io=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,Ht=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,ao="production",co=so??io??ao,$e=typeof Ht=="boolean"?Ht:co!=="production",D=()=>$e,Lt=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},uo=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},lo=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},Ee=(e,t)=>{if((N().logSink.critical??uo)(e,t),N().assertRuntime)throw new Error(e)},E=(e,t)=>{if(!$e)return;if((N().logSink.warn??Lt)(e,t),N().assertRuntime)throw new Error(e)},U=(e,t)=>{if((N().logSink.warn??Lt)(e,t),N().assertRuntime)throw new Error(e)};var oe=(e,t)=>{if(!$e)return;(N().logSink.log??lo)(e,t);};var Bt=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Ut=()=>"Map detected; converting to plain object.",qt=()=>"Set detected; converting to array.";var me=new Set(["__proto__","constructor","prototype"]),Ze=(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,a=s?.details?.[0]?.message||s?.message||r.message||e.errors;if(a)return {ok:!1,error:a};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 et=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,po=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};var Fe=(e,t)=>{let r=po(e);if(r)throw new Error(`${r} values are not supported`);let o=et(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 D()&&E(Bt()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),D()&&E(Ut());let s={};for(let[a,c]of e){if(typeof a!="string")throw new Error("Map keys must be strings to remain JSON-safe");s[String(a)]=Fe(c,t);}return s}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),D()&&E(qt()),Array.from(e,s=>Fe(s,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s={},a=Object.getOwnPropertyDescriptors(e);for(let[c,l]of Object.entries(a))if(l.enumerable&&!me.has(c)){if("get"in l||"set"in l)throw new Error(`Accessor properties are not supported during sanitize ("${c}")`);s[c]=Fe(l.value,t);}return s}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(s=>Fe(s,t))}return e},Se=e=>Fe(e,new WeakSet);var tt=null,go=()=>{if(tt)return tt;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 tt=t,t},Gt=e=>{let t=go(),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},yo=2166136261,ho=2654435761,mo=1e5,ne=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},ce=(e,t)=>{ne(e,t.length);for(let r=0;r<t.length;r++)ne(e,t.charCodeAt(r));},V=(e,t)=>{ce(e,t);},Kt=(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"),ne(e,r);return}V(e,"num"),ce(e,String(t));},be=(e,t)=>{if(e.nodes++>mo){V(e,"[max]");return}if(t===null){V(e,"null");return}let r=typeof t;if(r==="string"){V(e,"string"),ce(e,t);return}if(r==="number"){V(e,"number"),Kt(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"),ce(e,t.toString());return}if(r==="symbol"){V(e,"symbol");let g=t;ce(e,Symbol.keyFor(g)??g.description??String(g));return}if(r==="function"){V(e,"function"),ce(e,t.name||"anonymous");return}let o=t,s=e.seen.get(o);if(s!==void 0){V(e,"ref"),ne(e,s);return}let a=e.nextId++;if(e.seen.set(o,a),Array.isArray(o)){V(e,"array"),ne(e,o.length);for(let g=0;g<o.length;g++)Object.prototype.hasOwnProperty.call(o,g)?be(e,o[g]):V(e,"hole");return}if(o instanceof Date){V(e,"date"),Kt(e,o.getTime());return}if(o instanceof Map){V(e,"map"),ne(e,o.size),o.forEach((g,n)=>{be(e,n),be(e,g);});return}if(o instanceof Set){V(e,"set"),ne(e,o.size),o.forEach(g=>{be(e,g);});return}V(e,"object");let c=Object.getOwnPropertyDescriptors(o),l=[];Object.entries(c).forEach(([g,n])=>{n?.enumerable&&(me.has(g)||"get"in n||"set"in n||l.push([g,n]));}),ne(e,l.length);for(let[g,n]of l)ce(e,g),be(e,n.value);},ue=e=>{if(typeof e=="string")return Gt(JSON.stringify(e));let t={h1:yo,h2:ho,seen:new WeakMap,nextId:1,nodes:0};be(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 So=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",ot=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,s]of t)if(typeof s=="function"&&e instanceof s)return o;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},bo=e=>ot(e)===null,ko=e=>{let t=ot(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},le=(e,t=new WeakMap)=>{if(ko(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 s=new Map;return t.set(e,s),e.forEach((a,c)=>{s.set(le(c,t),le(a,t));}),s}if(e instanceof Set){let s=new Set;return t.set(e,s),e.forEach(a=>{s.add(le(a,t));}),s}if(Array.isArray(e)){let s=[];return t.set(e,s),e.forEach((a,c)=>{s[c]=le(a,t);}),s}let r={};t.set(e,r);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch(s){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${s?.message??s}`)}return Object.entries(o).forEach(([s,a])=>{!a.enumerable||me.has(s)||"get"in a||"set"in a||(r[s]=le(a.value,t));}),r},G=e=>{if(So)try{return structuredClone(e)}catch(t){if(!bo(e)){let r=ot(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return E(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),le(e)}return le(e)};var wo=e=>{let t=new Uint8Array(e),r="";for(let o=0;o<t.length;o++)r+=t[o].toString(16).padStart(2,"0");return r},Co=async e=>{if(typeof globalThis<"u"&&globalThis.crypto?.subtle){let t=typeof TextEncoder<"u"?new TextEncoder:null,r=t?t.encode(e):new Uint8Array(Buffer.from(e)),o=await globalThis.crypto.subtle.digest("SHA-256",r);return wo(o)}try{let{createHash:t}=await import('crypto');return t("sha256").update(e).digest("hex")}catch{throw new Error("sha256 checksum is not supported in this environment")}},Oe=async(e,t,r=ue)=>e==="none"?null:e==="sha256"?Co(t):r(t);var Yt=1e6,Jt=(e,t)=>{let r=e?.options?.migrations??{};if(Object.keys(r).length>0)return r;let o=t?.migrate;if(typeof o!="function")return r;let s=e?.version??1;return !Number.isFinite(s)||s<=1?r:{[s]:o}},nt=({name:e,persisted:t,reason:r,persistConfig:o,initialState:s,reportStoreError:a,sanitize:c,deepClone:l})=>{a(e,r);let g=o?.onMigrationFail??"reset";if(g==="keep")return {state:t,requiresValidation:true};if(typeof g=="function")try{let n=g(l(t));if(n!==void 0)return {state:c(n),requiresValidation:!0};a(e,`onMigrationFail for "${e}" returned undefined. Falling back to initial state.`);}catch(n){a(e,`onMigrationFail for "${e}" failed: ${n?.message??n}`);}return {state:l(s),requiresValidation:true}},Xt=e=>{let r=e.getMeta()?.options?.persist;return r?!!r.decryptAsync||r.checksum==="sha256"?Mo(e):Ro(e):false},Ro=({name:e,silent:t=false,getMeta:r,getInitialState:o,applyFeatureState:s,reportStoreError:a,warnMissingMaxSize:c,validate:l,log:g,hashState:n,deepClone:p,sanitize:i,shouldApply:u})=>{let m=r(),d=m?.options?.persist;if(!d)return false;let h=Jt(m,d),y=f=>Me({value:f,validate:l});try{let f=d.driver.getItem?.(d.key)??null;if(!f)return !1;if(typeof f!="string")return a(e,`Persist driver for "${e}" returned an async value during sync hydration. Provide async decrypt hooks or use an async-capable persist driver.`),!0;if(typeof d.maxSize!="number"&&f.length>Yt&&c?.(f.length),typeof d.maxSize=="number"&&f.length>d.maxSize)return a(e,`Persist payload for "${e}" exceeds maxSize (${f.length} > ${d.maxSize}). Skipping hydration.`),!0;let b=d.decrypt(f),v=JSON.parse(b),{v:C=1,checksum:M,data:R,updatedAt:j,updatedAtMs:O}=v||{};if(!R)return !0;let L=ie({value:typeof O=="number"?O:j,fallbackMs:Date.now(),onInvalid:()=>{g(`persist: corrupt updatedAt in stored data for "${e}". Using current time to prevent sync overwrite.`);}});if(d.checksum!=="none"&&M!==n(R))return a(e,`Checksum mismatch loading store "${e}". Falling back to initial state.`),(!u||u())&&s(p(o()),Date.now()),!0;let J=d.deserialize(R),X=m?.version??1,_=Qt({name:e,parsed:J,v:C,targetVersion:X,cfg:d,migrations:h,getInitialState:o,reportStoreError:a,sanitize:i,deepClone:p,validateState:y,safeUpdatedAt:L,applyFeatureState:s,shouldApply:u});return _.ok&&(J=_.state,(!u||u())&&(s(_.state,L),t||g(`Store "${e}" loaded from persistence`))),!0}catch(f){return a(e,`Could not load store "${e}" (${f?.message||f})`),true}},Mo=async({name:e,silent:t=false,getMeta:r,getInitialState:o,applyFeatureState:s,reportStoreError:a,warnMissingMaxSize:c,validate:l,log:g,hashState:n,deepClone:p,sanitize:i,shouldApply:u})=>{let m=r(),d=m?.options?.persist;if(!d)return false;let h=Jt(m,d),y=f=>Me({value:f,validate:l});try{let f=await Promise.resolve(d.driver.getItem?.(d.key)??null);if(!f)return !1;if(typeof d.maxSize!="number"&&typeof f=="string"&&f.length>Yt&&c?.(f.length),typeof d.maxSize=="number"&&typeof f=="string"&&f.length>d.maxSize)return a(e,`Persist payload for "${e}" exceeds maxSize (${f.length} > ${d.maxSize}). Skipping hydration.`),!0;let b=d.decryptAsync?await d.decryptAsync(f):d.decrypt(f),v=JSON.parse(b),{v:C=1,checksum:M,data:R,updatedAt:j,updatedAtMs:O}=v||{};if(!R)return !0;let L=ie({value:typeof O=="number"?O:j,fallbackMs:Date.now(),onInvalid:()=>{g(`persist: corrupt updatedAt in stored data for "${e}". Using current time to prevent sync overwrite.`);}}),J=await Oe(d.checksum,R,n);if(d.checksum!=="none"&&M!==J)return a(e,`Checksum mismatch loading store "${e}". Falling back to initial state.`),(!u||u())&&s(p(o()),Date.now()),!0;let X=d.deserialize(R),_=m?.version??1,k=Qt({name:e,parsed:X,v:C,targetVersion:_,cfg:d,migrations:h,getInitialState:o,reportStoreError:a,sanitize:i,deepClone:p,validateState:y,safeUpdatedAt:L,applyFeatureState:s,shouldApply:u});return k.ok&&(!u||u())&&(s(k.state,L),t||g(`Store "${e}" loaded from persistence`)),!0}catch(f){return a(e,`Could not load store "${e}" (${f?.message||f})`),true}},Qt=({name:e,parsed:t,v:r,targetVersion:o,cfg:s,migrations:a,getInitialState:c,reportStoreError:l,sanitize:g,deepClone:n,validateState:p,safeUpdatedAt:i,applyFeatureState:u,shouldApply:m})=>{if(r!==o){let h=Object.keys(a).map(b=>Number(b)).filter(b=>b>r&&b<=o).sort((b,v)=>b-v);if(h.length===0){let b=nt({name:e,persisted:t,reason:`No migration path from v${r} to v${o} for "${e}". Applying onMigrationFail strategy.`,persistConfig:s,initialState:c(),reportStoreError:l,sanitize:g,deepClone:n});if(t=b.state,!b.requiresValidation)return (!m||m())&&u(t,i),{ok:false,state:t}}let y=false,f=true;if(h.forEach(b=>{if(!y)try{let v=a[b](t);v!==void 0&&(t=v);}catch(v){let C=nt({name:e,persisted:t,reason:`Migration to v${b} failed for "${e}": ${v?.message||v}`,persistConfig:s,initialState:c(),reportStoreError:l,sanitize:g,deepClone:n});t=C.state,f=C.requiresValidation,y=true;}}),y){if(!f)return (!m||m())&&u(t,i),{ok:false,state:t};let b=p(t);return b.ok?{ok:true,state:b.value??t}:((!m||m())&&u(n(c()),Date.now()),{ok:false,state:t})}}let d=p(t);if(!d.ok){if(r!==o){let h=s?.onMigrationFail??"reset",y=nt({name:e,persisted:t,reason:`Persisted state for "${e}" failed schema after version change. Applying onMigrationFail strategy.`,persistConfig:s,initialState:c(),reportStoreError:l,sanitize:g,deepClone:n});if(!y.requiresValidation)return (!m||m())&&u(y.state,i),{ok:false,state:y.state};let f=p(y.state);if(f.ok)return h==="reset"&&l(e,`Persisted state for "${e}" failed schema; resetting to initial.`),{ok:true,state:f.value??y.state}}return l(e,`Persisted state for "${e}" failed schema; resetting to initial.`),(!m||m())&&u(n(c()),Date.now()),{ok:false,state:t}}return {ok:true,state:d.value??t}};var xe=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let s=o?.message??o;U(`${t} callback threw: ${String(s)}`);}},ke=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:s}=t;if(xe(s,"onError",e),r==="critical"){o==="dev"&&E(e),Ee(e);return}if(o==="always"){U(e);return}E(e);};var Zt=({name:e,persistTimers:t,persistInFlight:r,persistSequence:o,persistWatchState:s,plaintextWarningsIssued:a,exists:c,getMeta:l,getStoreValue:g,reportStoreError:n,hashState:p},i=false)=>{let u=l()?.options?.persist;if(!u)return;let m=async y=>{let f=l();if(!(!f?.options?.persist||f.options.persist!==u||!c())&&!(y!==void 0&&o[e]!==y)){if(!u.allowPlaintext&&!a.has(e)&&qe(u.encrypt)&&qe(u.decrypt)){a.add(e);let b=`[stroid/persist] Store '${e}' is persisted in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`;xe(f.options.onError,`onError(${e})`,b),U(b);}try{let b=u.serialize(g()),v=await Oe(u.checksum,b,p),C=JSON.stringify({v:f.version??1,updatedAt:f.updatedAt,updatedAtMs:f.updatedAtMs??Date.now(),checksum:v,data:b}),M=u.encryptAsync?await u.encryptAsync(C):u.encrypt(C);if(y!==void 0&&o[e]!==y)return;await Promise.resolve(u.driver.setItem?.(u.key,M)),Tt(s,e,!0);}catch(b){n(e,`Could not persist store "${e}" (${b?.message||b})`);}}},d=y=>{let f=r[e],b=(o[e]??0)+1;o[e]=b;let C=(async()=>{f&&await f,!(y&&t[e]!==y)&&o[e]===b&&await m(b);})().finally(()=>{r[e]===C&&(r[e]=null),y&&t[e]===y&&delete t[e];});r[e]=C;};if(i){t[e]&&(clearTimeout(t[e]),delete t[e]),d();return}t[e]&&clearTimeout(t[e]);let h=setTimeout(()=>{t[e]===h&&d(h);},0);t[e]=h;},Te=e=>Zt(e),er=(e,t)=>Zt({...t,name:e},true);var tr=false,Eo=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Fo=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,xo=Eo??Fo,To=()=>xo==="production",Vo=()=>{let e={},t={},r=Object.create(null),o=Object.create(null),s=Object.create(null),a=new Set,c=new Set,l=Object.create(null),g=Object.create(null);return {api:{getPersistQueueDepth(n){return e[n]?1:0}},onStoreCreate(n){let p=n.options.persist;if(!p)return;if(!p.encryptAsync&&Ae(p.encrypt)&&Ae(p.decrypt)&&!p.allowPlaintext){let y=`[stroid/persist] Store "${n.name}" is configured for plaintext persistence. Provide encrypt/decrypt hooks or set persist.allowPlaintext: true to acknowledge.`;if(To()){n.reportStoreError(y),n.options.persist=null;return}n.warn(y);}if(p.sensitiveData&&!p.encryptAsync&&Ae(p.encrypt)){n.reportStoreError(`persist: store "${n.name}" is marked sensitiveData but has no encrypt function. Plaintext data will be written to storage.`);return}let u=xt(n.name,p.encrypt,p.decrypt);if(!u.ok){n.reportStoreError(u.reason??`persist: encrypt/decrypt validation failed for store "${n.name}".`),n.options.persist=null;return}if(p.key){let y=o[p.key];y&&y!==n.name&&n.isDev()?n.warn(`Persist key collision: "${p.key}" already used by store "${y}". Store "${n.name}" will overwrite the same storage key.`):o[p.key]=n.name;}let m=n.getMeta()?.updateCount??0,d=()=>{let y=n.getMeta();return y?(y.updateCount??0)===m:false},h=Xt({name:n.name,silent:true,getMeta:n.getMeta,getInitialState:n.getInitialState,applyFeatureState:n.applyFeatureState,reportStoreError:(y,f)=>n.reportStoreError(f),warnMissingMaxSize:y=>{c.has(n.name)||(c.add(n.name),n.warnAlways(`[stroid/persist] Store "${n.name}" loaded ${y} bytes without a maxSize guard. Set persist.maxSize to prevent oversized payloads.`));},validate:n.validate,log:n.log,hashState:n.hashState,deepClone:n.deepClone,sanitize:n.sanitize,shouldApply:d});if(typeof h?.then=="function"?(l[n.name]={loading:true,pendingSave:false},h.then(y=>{let f=l[n.name];f&&(f.loading=false,(!y||f.pendingSave)&&Te({name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:s,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(b,v)=>n.reportStoreError(v),hashState:n.hashState}),delete l[n.name]);}).catch(()=>{let y=l[n.name];y&&(y.loading=false,y.pendingSave&&Te({name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:s,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(f,b)=>n.reportStoreError(b),hashState:n.hashState}),delete l[n.name]);})):h||Te({name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:s,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(y,f)=>n.reportStoreError(f),hashState:n.hashState}),typeof window<"u"&&typeof window.addEventListener=="function"){g[n.name]?.();let y=window,f=false,b=()=>{f||(f=true,y.removeEventListener("pagehide",v),y.removeEventListener("beforeunload",v),delete g[n.name]);},v=()=>{b(),er(n.name,{name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:s,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(C,M)=>n.reportStoreError(M),hashState:n.hashState});};y.addEventListener("pagehide",v,{once:true}),y.addEventListener("beforeunload",v,{once:true}),g[n.name]=b;}Vt({name:n.name,persistConfig:p,persistWatchState:s});},onStoreWrite(n){if(!n.options.persist)return;let p=l[n.name];if(p?.loading){p.pendingSave=true;return}Te({name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:s,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(i,u)=>n.reportStoreError(u),hashState:n.hashState});},beforeStoreDelete(n){let p=n.options.persist;if(p){delete l[n.name],c.delete(n.name),e[n.name]&&(clearTimeout(e[n.name]),delete e[n.name]),t[n.name]=null,delete r[n.name];try{p.driver.removeItem?.(p.key);}catch{}p.key&&o[p.key]===n.name&&delete o[p.key],g[n.name]?.(),s[n.name]?.dispose(),delete g[n.name],delete s[n.name];}},resetAll(){Object.values(e).forEach(n=>clearTimeout(n)),Object.values(g).forEach(n=>{try{n();}catch{}}),Object.values(s).forEach(n=>{try{n.dispose();}catch{}}),Object.keys(e).forEach(n=>delete e[n]),Object.keys(t).forEach(n=>{t[n]=null,delete t[n];}),Object.keys(r).forEach(n=>delete r[n]),Object.keys(o).forEach(n=>delete o[n]),Object.keys(s).forEach(n=>delete s[n]),Object.keys(l).forEach(n=>delete l[n]),a.clear(),c.clear();}}},rr=()=>{tr||(tr=true,fe("persist",Vo));};var or=({name:e,label:t,fn:r,args:o,reportIssue:s})=>{if(typeof r=="function")try{r(...o);}catch(a){let c=`${t} for "${e}" failed: ${a?.message??a}`;s(c,"always");}};A("computed.order-resolver",()=>{},105);var ir=()=>he(ye(ge)),st=()=>ir().computedEntries,ar=()=>ir().computedDependents;var cr=e=>Object.prototype.hasOwnProperty.call(st(),e);var it=e=>{let t=st()[e];if(!t)return null;let r=ar()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Po=new Set;var Ao=()=>{Po.clear();};A("ssr.warnings",Ao,60);var Do=(e,t,r={})=>{ke(t,{...r,onError:$[e]?.options?.onError});};var at=(e,t)=>Do(e,t,{severity:"critical",visibility:"always"});var ur=new WeakMap,lr=new WeakMap;var ze=e=>{let t=ur.get(e);return t||(t=new Map,ur.set(e,t)),t},dr=e=>{let t=lr.get(e);return t||(t=new Map,lr.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=ze(z());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let o=r[t];return typeof o=="function"?o.bind(r):o},set:(e,t,r)=>(ze(z())[t]=r,true)});var $o=(e,t)=>{let r=new Set,o=$[e]?.options?.onError;return typeof o=="function"&&r.add(o),r},fr=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let s=$o(e),a=(l,g)=>{s.forEach(n=>xe(n,`onError(${e})`,l)),g==="critical"?Ee(l):E(l);};if(typeof r=="function")try{let l=r(t);return l===!1?(a(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:l===!0?t:l}}catch(l){return a(`Validation for "${e}" failed: ${l?.message??l}`,"critical"),{ok:false}}let c=Ze(r,t);return c.ok?{ok:true,value:c.data??t}:(a(`Validation failed for "${e}": ${c.error}`,"critical"),{ok:false})};var ct=e=>{let t=z();ze(t).delete(e),dr(t).delete(e);},Oo=()=>{let e=z();ze(e).clear(),dr(e).clear();};A("validation.path-cache",Oo,50);pr(ct);var kr=new Map;var je=(e,t,r)=>{let o=kr.get(e);!o||o.size===0||o.forEach(s=>{try{s(t,r);}catch(a){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,a);}});};var _o=()=>{};A("write-context.runner",_o,121);var zo=()=>{let e=z().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};A("notify.reset",zo,40);var Wo=()=>z().computedCleanups,Cr=new WeakMap;var Ho=e=>{let t=Cr.get(e);return t||(t=new Map,Cr.set(e,t)),t};var Rr=e=>{let t=Wo(),r=t.get(e);if(!r){D()&&E(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Mr=(e,t=z())=>Ho(t).get(e)?.autoDispose===true;var Er=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,s=e.initialFactories,a=e.metaEntries,c=e.snapshotCache,l=e.featureRuntimes,g=e.deletingStores,n=(h,y)=>{ke(y,{onError:a[h]?.options?.onError,severity:"warn",visibility:"dev"});},p=({name:h,prev:y,options:f,initialState:b,getMeta:v,getStoreValue:C,hasStore:M})=>({name:h,options:f,prev:y,getMeta:v,getStoreValue:C,getAllStores:()=>t,getInitialState:()=>b,hasStore:M,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:R=>{ke(R,{onError:f.onError,severity:"warn",visibility:"dev"});},warn:E,warnAlways:U,log:oe,hashState:ue,deepClone:G,sanitize:Se,validate:()=>({ok:true,value:y}),isDev:D}),i=({name:h,prev:y,options:f,initialState:b,phase:v})=>{let C=p({name:h,prev:y,options:f,initialState:b,getMeta:()=>a[h],getStoreValue:()=>t[h],hasStore:()=>ae(e,h)}),M=p({name:h,prev:y,options:f,initialState:b,getMeta:()=>{},getStoreValue:()=>y,hasStore:()=>false});pe().forEach(R=>{let j=l.get(R);v==="before"?j?.beforeStoreDelete?.(C):j?.afterStoreDelete?.(M);});},u=h=>{if(!ae(e,h))return;let y=t[h],f=a[h].options,b=o[h],v=r[h];g.add(h);try{v?.forEach(R=>{try{R(null);}catch(j){E(`Subscriber for "${h}" threw during delete: ${j?.message??j}`);}}),or({name:h,label:"onDelete",fn:f.onDelete,args:[y],reportIssue:(R,j)=>{ke(R,{onError:f.onError,severity:"warn",visibility:j});}}),i({name:h,prev:y,options:f,initialState:b,phase:"before"}),delete t[h],delete r[h],delete o[h],delete s[h],delete a[h],delete c[h],cr(h)&&Rr(h);let M=e.computedDependents[h];if(M)for(let R of [...M]){let j=it(R);if(j&&Mr(R,e)&&j.deps.every(O=>!ae(e,O))){u(R);continue}E(`[stroid] source store "${h}" was deleted. Computed store "${R}" depends on it and will return stale data. Call deleteComputed("${R}") to clean up.`);}i({name:h,prev:y,options:f,initialState:b,phase:"after"}),je("afterStoreDelete",h,{type:"afterStoreDelete",prev:y}),Je(e,{type:"deleted",name:h}),oe(`Store "${h}" deleted`);}finally{g.delete(h);}};return {deleteExistingStore:u,clearAllStores:()=>{let h=[],f=0,b=Number.POSITIVE_INFINITY;for(;f<20;){let C=Object.keys(t);if(C.length===0)break;C.forEach(R=>{ae(e,R)&&(u(R),h.push(R));}),f+=1;let M=Object.keys(t).length;if(M===0||M>=b)break;b=M;}let v=Object.keys(t).length;return v>0?E(`clearAllStores stopped after ${f} pass${f===1?"":"es"}; ${v} store(s) still registered (likely recreated during deletion).`):oe(`All stores cleared (${h.length} stores removed)`),h},clearStores:h=>{let y=Object.keys(t).filter(f=>h?h.endsWith("*")?f.startsWith(h.slice(0,-1)):f===h:true);return y.forEach(f=>u(f)),y},reportStoreError:n}};var bt=ge,xr=ye(bt),Tr=null,q=()=>{let e=he(xr);return Ge(e),e};var z=()=>q();function pr(e){Tr=e;}var ve=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,o)=>(e()[r]=o,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let o=Object.getOwnPropertyDescriptor(e(),r);if(o)return {...o,configurable:true}}}),Lo=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 s=o[r];return typeof s=="function"?s.bind(o):s},set:(t,r,o)=>(e()[r]=o,true)}),Bo=e=>new Proxy({},{get:(t,r)=>{let o=e(),s=o[r];return typeof s=="function"?s.bind(o):s},set:(t,r,o)=>(e()[r]=o,true)}),Ie=ve(()=>q().stores);ve(()=>q().subscribers);var Vr=ve(()=>q().initialStates);ve(()=>q().initialFactories);var $=ve(()=>q().metaEntries);ve(()=>q().snapshotCache);var te=Lo(()=>q().featureRuntimes),Fr=new WeakMap,Uo=e=>{let t=Fr.get(e);return t||(t=Er(e),Fr.set(e,t)),t};Bo(()=>Uo(q()));var qo=e=>{let t=te.get(e);if(t)return t;let r=Pe(e);if(!r)return;let o=r();return te.set(e,o),o},kt=()=>{pe().forEach(e=>{qo(e);});};Ft((e,t)=>{te.get(e)||te.set(e,t());});kt();var Ne=(e,t)=>ae(q(),e);var We=(e,t,r=q())=>{r.stores[e]=t;},jr=(e,t,r=Date.now())=>{We(e,t),$[e]&&($[e].updatedAt=new Date(r).toISOString(),$[e].updatedAtMs=r,$[e].lastCorrelationId=null,$[e].lastCorrelationAt=null,$[e].lastCorrelationAtMs=null,$[e].lastTraceContext=null,$[e].updateCount>=Number.MAX_SAFE_INTEGER?$[e].updateCount=0:$[e].updateCount+=1,Tr?.(e));};var Ko=()=>{Ot(q());},Go=()=>{te.forEach(e=>{try{e.resetAll?.();}catch{}}),te.clear();};A("features.reset",Go,10);A("registries.clear",Ko,20);A("registry.default",()=>{bt=ge,xr=ye(bt);},115);var Pr=new WeakMap,Ar=e=>{let t=Pr.get(e);return t||(t=new Map,Pr.set(e,t)),t},Yo=()=>{Ar(z()).clear();};A("features.contexts",Yo,100);var Jo=e=>{let t=z(),r=Ar(t),o=r.get(e);if(o)return o;let s=$[e];if(!s)return E(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let a={name:e,options:s.options,getMeta:()=>$[e],getStoreValue:()=>Ie[e],getAllStores:()=>Ie,getInitialState:()=>Vr[e],hasStore:()=>Ne(e),setStoreValue:c=>{We(e,c);},applyFeatureState:(c,l)=>{jr(e,c,l),ct(e);},notify:()=>{},reportStoreError:c=>{at(e,c);},warn:E,warnAlways:U,log:oe,hashState:ue,deepClone:G,sanitize:Se,validate:c=>fr(e,c,$[e]?.options?.validate),isDev:D};return r.set(e,a),a},Xo=(e,t)=>{let r=N();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 s=`Feature hook context missing fields for "${e}": ${o.join(", ")}.`;if(at(e,s),r.assertRuntime)throw new Error(s)};var vt=(e,t,r,o,s,a)=>{kt();let c=Jo(e);if(!c)return;c.notify=()=>s(e);let l=Object.assign(Object.create(c),{action:t,prev:r,next:o});Xo(e,l);let g=new Set(a);te.forEach((n,p)=>{g.has(p)||n.onStoreWrite?.(l);});};var Dr=false,we=1,Qo=e=>typeof e?.v=="number"?e.v:typeof e?.protocol=="number"?e.protocol:void 0,wt=new Set,Ct=new Set,Le=100,_r=e=>{if(!e)return null;if(e===true)return Le;if(typeof e!="object")return null;let t=e.loopGuard;if(t===false)return null;if(t===true||t===void 0)return Le;if(typeof t=="object"){let r=t.windowMs;return typeof r=="number"&&Number.isFinite(r)&&r>0?r:Le}return Le},Zo=e=>typeof TextEncoder<"u"?new TextEncoder().encode(e).length:typeof Buffer<"u"?Buffer.byteLength(e):e.length,en=({incoming:e,accepted:t})=>{let r=t?.clock??0,o=typeof e.clock=="number"?e.clock:0;if(o!==r)return o-r;let s=e.source??"",a=t?.source??"";return s===a?0:s.localeCompare(a,"en",{sensitivity:"variant"})},tn=e=>e?.updatedAtMs??ie({value:e?.updatedAt,fallbackMs:0}),rn=e=>{if(typeof e!="object"||e===null)return false;let t=e;return (typeof t.v=="number"||typeof t.protocol=="number")&&typeof t.type=="string"&&typeof t.name=="string"&&typeof t.clock=="number"&&typeof t.source=="string"},$r=({name:e,syncChannels:t,instanceId:r,authToken:o,reportStoreError:s})=>{let a=t[e];if(a)try{let c={v:we,protocol:we,type:"sync-request",source:r,name:e,clock:0,requestedAt:Date.now()};o&&(c.token=o),a.postMessage(c);}catch(c){s(e,`Failed to request sync snapshot for "${e}": ${c?.message??c}`);}},on=(e,t)=>(t[e]=(t[e]??0)+1,t[e]),nn=(e,t,r)=>(r[e]=Math.max(r[e]??0,t)+1,r[e]),sn=({name:e,syncChannels:t,syncWindowCleanup:r,syncClocks:o,syncVersions:s})=>{t[e]?.close(),delete t[e],r[e]?.(),delete r[e],delete o[e],delete s[e];},an=({syncChannels:e,syncWindowCleanup:t})=>{Object.values(t).forEach(r=>{try{r();}catch{}}),Object.values(e).forEach(r=>{try{r.close();}catch{}});},cn=({name:e,syncOption:t,syncChannels:r,syncClocks:o,syncVersions:s,syncWindowCleanup:a,instanceId:c,getMeta:l,getAcceptedSyncVersion:g,getStoreValue:n,hasStoreEntry:p,notify:i,validate:u,reportStoreError:m,warn:d,setStoreValue:h,normalizeIncomingState:y,acceptIncomingSyncVersion:f,resolveSyncVersion:b,broadcastSync:v,markLoopGuard:C,hashState:M})=>{if(!t)return;if(typeof window>"u"||typeof BroadcastChannel>"u"){m(e,`Sync enabled for "${e}" but BroadcastChannel not available in this environment.`);return}let R=typeof t=="object"?t.policy:void 0,j=R==="insecure"||R!=="strict"&&typeof t=="object"&&t.insecure===true,O=typeof t=="object"&&typeof t.authToken=="string"&&t.authToken.length>0,L=typeof t=="object"&&typeof t.verify=="function",J=typeof t=="object"&&typeof t.sign=="function",X=R==="strict"||!D()&&R!=="insecure";if(X&&!j&&!O&&!L){m(e,`Sync for "${e}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`);return}!X&&!j&&!O&&!L&&!wt.has(e)&&(wt.add(e),U(`Sync for "${e}" is unauthenticated. Any same-origin tab can forge sync messages. Provide sync.authToken or sync.verify to enforce authentication.`)),J&&!L&&!Ct.has(e)&&(Ct.add(e),d(`Sync for "${e}" is configured with "sign" but no "verify". "sign" has no effect unless incoming messages are verified.`));let _=typeof t=="object"?t.authToken:void 0,k=_r(t),T=false,F=typeof t=="object"&&t.channel?t.channel:`stroid_sync_${e}`;try{let S=new BroadcastChannel(F);if(r[e]=S,S.onmessage=W=>{let w=W.data;if(!w||w.source===c||w.name!==e||r[e]!==S||!p(e)||!l(e))return;if(!rn(w)){m(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(_&&w.token!==_){T||(m(e,`Sync message for "${e}" failed auth token verification; ignoring.`),T=!0);return}let I=Qo(w);if(I!==we){m(e,`Sync protocol mismatch for "${e}". Expected v${we} but received ${String(I??"unknown")}. Ignoring message.`);return}let B=w.type==="sync-state";if(B&&(typeof w.data>"u"||typeof w.clock!="number")){m(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(typeof t=="object"&&typeof t.verify=="function"){let P=!1;try{P=!!t.verify(w);}catch(x){m(e,`Sync message verification failed for "${e}": ${x?.message??x}`);return}if(!P){m(e,`Sync message for "${e}" failed verification; ignoring.`);return}}let Q=typeof t=="object"&&t.checksum==="none"?"none":"hash";if(B&&Q!=="none"){let P=M(w.data);if(w.checksum!==P){m(e,`Sync checksum mismatch for "${e}". Expected ${String(P)}, got ${String(w.checksum)}. Ignoring message.`);return}}if(w.type==="sync-request"){v(e);return}let K=typeof t=="object"?t.conflictResolver:null;if(en({incoming:{clock:w.clock,source:w.source},accepted:g(e)})<=0){let P=tn(l(e)),x=typeof w.updatedAt=="number"?w.updatedAt:Date.now();if(K){let Y=K({local:n(e),incoming:w.data,localUpdated:P,incomingUpdated:x});if(Y!==void 0){let H=y(e,Y);if(H===null)return;let Ce=n(e);h(e,H);let re=typeof t=="object"?t.resolveUpdatedAt:null,Re=re?re({localUpdated:P,incomingUpdated:x,now:Date.now()}):Math.max(Date.now(),P,x);b(e,Re,typeof w.clock=="number"?w.clock:0),vt(e,"sync",Ce,H,()=>i(e),["sync"]),k&&C(e,k),i(e),v(e);}}return}let Z=y(e,w.data);if(Z===null)return;let se=n(e);h(e,Z),f(e,typeof w.updatedAt=="number"?w.updatedAt:Date.now(),typeof w.clock=="number"?w.clock:0,typeof w.source=="string"?w.source:""),vt(e,"sync",se,Z,()=>i(e),["sync"]),k&&C(e,k),i(e);},typeof window<"u"&&typeof window.addEventListener=="function"){a[e]?.();let W=window,w=()=>{$r({name:e,syncChannels:r,instanceId:c,authToken:_,reportStoreError:m});};W.addEventListener("focus",w),W.addEventListener("online",w),a[e]=()=>{W.removeEventListener("focus",w),W.removeEventListener("online",w);};}queueMicrotask(()=>{$r({name:e,syncChannels:r,instanceId:c,authToken:_,reportStoreError:m});});}catch(S){d(`Failed to setup sync for "${e}": ${S?.message||S}`);}},Or=({name:e,syncOption:t,syncChannels:r,syncClocks:o,instanceId:s,updatedAt:a,data:c,hashState:l,reportStoreError:g})=>{let n=r[e];if(n)try{let p=typeof t=="object"&&t.checksum==="none"?"none":"hash",i={v:we,protocol:we,type:"sync-state",source:s,name:e,clock:o[e]??0,updatedAt:ie({value:a,fallbackMs:Date.now()}),data:c,checksum:p==="hash"?l(c):null};if(typeof t=="object"&&t.authToken&&(i.token=t.authToken),typeof t=="object"&&typeof t.sign=="function")try{let d=t.sign(i);if(d&&typeof d.then=="function"){g(e,`Sync signer for "${e}" returned a Promise. "sign" must be synchronous.`);return}d!==void 0&&(i.auth=d);}catch(d){g(e,`Failed to sign sync payload for "${e}": ${d?.message??d}`);return}let u=typeof t=="object"&&typeof t.maxPayloadBytes=="number"?t.maxPayloadBytes:64*1024,m=Zo(JSON.stringify(i));if(m>u){g(e,`Sync payload for "${e}" exceeds ${u} bytes (${m} bytes). Skipping BroadcastChannel sync.`);return}try{n.postMessage(i);}catch(d){if(d&&typeof d=="object"&&d.name==="DataCloneError"){g(e,`Sync payload for "${e}" could not be cloned (DataCloneError). Remove non-serializable values or provide a custom serializer. Payload size ~${m} bytes.`);return}throw d}}catch(p){g(e,`Failed to broadcast sync for "${e}": ${p?.message??p}`);}},un=()=>{let e=Object.create(null),t=Object.create(null),r=Object.create(null),o=Object.create(null),s=Object.create(null),a=new Set,c=`stroid_${Math.random().toString(16).slice(2)}`,l=(i,u)=>{r[i]={clock:t[i]??0,updatedAt:ie({value:u,fallbackMs:Date.now()}),source:c};},g=(i,u)=>{on(i,t),l(i,u);},n=(i,u)=>{!u||!Number.isFinite(u)||(s[i]=Date.now()+u);},p=(i,u)=>{if(!u)return false;let m=s[i];return m?Date.now()>=m?(delete s[i],false):true:false};return {onStoreCreate(i){if(!i.options.sync)return;let u=i.options.sync,m=i.notify,d=typeof u=="object"?u.policy:void 0,h=d==="insecure"||d!=="strict"&&typeof u=="object"&&u.insecure===true,y=typeof u=="object"&&typeof u.authToken=="string"&&u.authToken.length>0,f=typeof u=="object"&&typeof u.verify=="function";if((d==="strict"||!i.isDev()&&d!=="insecure")&&u&&!h&&!y&&!f){i.reportStoreError(`Sync for "${i.name}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`),i.options.sync=false;return}if(cn({name:i.name,syncOption:u,syncChannels:e,syncClocks:t,syncVersions:r,syncWindowCleanup:o,instanceId:c,getMeta:i.getMeta,getAcceptedSyncVersion:v=>r[v],getStoreValue:v=>i.getStoreValue(),hasStoreEntry:()=>i.hasStore(),notify:()=>m(),validate:(v,C)=>i.validate(C),reportStoreError:(v,C)=>i.reportStoreError(C),warn:i.warn,setStoreValue:(v,C)=>i.setStoreValue(C),normalizeIncomingState:(v,C)=>{let M=Me({value:C,sanitize:i.sanitize,validate:i.validate,onSanitizeError:R=>{i.reportStoreError(`Sanitize failed for incoming sync "${v}": ${R?.message??R}`);}});return M.ok?M.value:null},acceptIncomingSyncVersion:(v,C,M,R)=>{i.applyFeatureState(i.getStoreValue(),C),t[i.name]=Math.max(t[i.name]??0,M),r[i.name]={clock:M,updatedAt:C,source:R};},resolveSyncVersion:(v,C,M)=>{i.applyFeatureState(i.getStoreValue(),C);let R=nn(i.name,M,t);return r[i.name]={clock:R,updatedAt:C,source:c},R},broadcastSync:()=>{let v=i.getMeta();v&&Or({name:i.name,syncOption:i.options.sync,syncChannels:e,syncClocks:t,instanceId:c,updatedAt:v.updatedAtMs??v.updatedAt,data:i.getStoreValue(),hashState:i.hashState,reportStoreError:(C,M)=>i.reportStoreError(M)});},markLoopGuard:n,hashState:i.hashState}),e[i.name]){let v=i.getMeta();l(i.name,v?.updatedAtMs??v?.updatedAt??new Date().toISOString());}},onStoreWrite(i){if(!i.options.sync)return;let u=i.getMeta();if(!u)return;let m=_r(i.options.sync);if(p(i.name,m)){g(i.name,u.updatedAtMs??u.updatedAt),a.has(i.name)||(a.add(i.name),i.warn(`Sync broadcast for "${i.name}" suppressed by loopGuard to prevent feedback loops.`));return}g(i.name,u.updatedAtMs??u.updatedAt),Or({name:i.name,syncOption:i.options.sync,syncChannels:e,syncClocks:t,instanceId:c,updatedAt:u.updatedAtMs??u.updatedAt,data:i.next,hashState:i.hashState,reportStoreError:(d,h)=>i.reportStoreError(h)});},beforeStoreDelete(i){sn({name:i.name,syncChannels:e,syncWindowCleanup:o,syncClocks:t,syncVersions:r}),delete s[i.name],a.delete(i.name);},resetAll(){an({syncChannels:e,syncWindowCleanup:o}),Object.keys(e).forEach(i=>delete e[i]),Object.keys(t).forEach(i=>delete t[i]),Object.keys(r).forEach(i=>delete r[i]),Object.keys(o).forEach(i=>delete o[i]),Object.keys(s).forEach(i=>delete s[i]),wt.clear(),Ct.clear(),a.clear();}}},Ir=()=>{Dr||(Dr=true,fe("sync",un));};var Nr=false,zr=e=>{try{return typeof structuredClone=="function"?structuredClone(e):JSON.parse(JSON.stringify(e))}catch{return e}},ln=({name:e,useDevtools:t,existingDevtools:r,stores:o,warn:s})=>{if(!t||typeof window>"u")return r;let a=window.__REDUX_DEVTOOLS_EXTENSION__||window.__REDUX_DEVTOOLS_EXTENSION__;if(!a||typeof a.connect!="function")return s(`DevTools requested for "${e}" but Redux DevTools extension not found.`),r;if(r)return r;let c=a.connect({name:"stroid"});return c.init(o),c},Be=({data:e,redactor:t,deepClone:r})=>{if(typeof t=="function")try{return t(r(e))}catch{return e}return e},dn=(e,t)=>{if(typeof e!="object"||typeof t!="object"||e===null||t===null)return null;let r=e,o=t,s=[],a=[],c=[],l=new Set(Object.keys(r)),g=new Set(Object.keys(o));return g.forEach(n=>{l.has(n)?Object.is(r[n],o[n])||c.push(n):s.push(n);}),l.forEach(n=>{g.has(n)||a.push(n);}),{added:s,removed:a,changed:c}},Wr=({name:e,action:t,prev:r,next:o,history:s,historyLimit:a,applyRedactor:c,deepClone:l})=>{if(a===0)return;s[e]||(s[e]=[]);let g={ts:Date.now(),action:t,prev:l(c(r)),next:l(c(o)),diff:dn(r,o)};s[e].push(g),s[e].length>a&&s[e].splice(0,s[e].length-a);},Hr=({name:e,action:t,force:r=false,devtools:o,enabled:s,stores:a,applyRedactor:c})=>{if(!(!o||!r&&!s))try{let l={...a,[e]:c(a[e])};o.send({type:`${e}/${t}`},l);}catch{}},fn=()=>{let e=Object.create(null),t;return {onStoreCreate(r){t=ln({name:r.name,useDevtools:!!r.options.devtools,existingDevtools:t,stores:r.getAllStores(),warn:r.warn}),Wr({name:r.name,action:"create",prev:null,next:r.getStoreValue(),history:e,historyLimit:r.options.historyLimit??50,applyRedactor:o=>Be({data:o,redactor:r.options.redactor,deepClone:r.deepClone}),deepClone:r.deepClone});},onStoreWrite(r){Wr({name:r.name,action:r.action,prev:r.prev,next:r.next,history:e,historyLimit:r.options.historyLimit??50,applyRedactor:o=>Be({data:o,redactor:r.options.redactor,deepClone:r.deepClone}),deepClone:r.deepClone}),Hr({name:r.name,action:r.action,devtools:t,enabled:!!r.options.devtools,stores:r.getAllStores(),applyRedactor:o=>Be({data:o,redactor:r.options.redactor,deepClone:r.deepClone})});},afterStoreDelete(r){r.options.devtools&&Hr({name:r.name,action:"delete",force:true,devtools:t,enabled:true,stores:r.getAllStores(),applyRedactor:o=>Be({data:o,redactor:r.options.redactor,deepClone:r.deepClone})}),delete e[r.name];},resetAll(){Object.keys(e).forEach(r=>{delete e[r];}),t=void 0;},api:{getHistory(r,o){if(!e[r])return [];let s=e[r];return o&&o>0?zr(s.slice(-o)):zr(s)},clearHistory(r){if(r){delete e[r];return}Object.keys(e).forEach(o=>{delete e[o];});}}}},Lr=()=>{Nr||(Nr=true,fe("devtools",fn));};var pn=()=>{rr();},gn=()=>{Ir();},yn=()=>{Lr();},ma=()=>{pn(),gn(),yn();};export{ma as installAllFeatures,yn as installDevtools,pn as installPersist,gn as installSync};//# sourceMappingURL=install.js.map
1
+ export{d as installAllFeatures,c as installDevtools,a as installPersist,b as installSync}from'./chunk-PVATWAY4.js';import'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';//# sourceMappingURL=install.js.map
2
2
  //# sourceMappingURL=install.js.map
package/dist/options.d.ts CHANGED
@@ -153,7 +153,7 @@ interface SyncOptions {
153
153
  * Optional guard to prevent rapid feedback loops when sync updates trigger local reactions.
154
154
  *
155
155
  * - true: enable with a default window (100ms)
156
- * - { windowMs }: customize the guard window in milliseconds
156
+ * - `windowMs`: customize the guard window in milliseconds
157
157
  * - false: disable (default is enabled when sync is truthy)
158
158
  */
159
159
  loopGuard?: boolean | {
package/dist/persist.js CHANGED
@@ -1,2 +1,2 @@
1
- var $=new Map,X=(e,t)=>{$.set(e,t);};var Q=e=>$.get(e),Z=()=>Array.from($.keys());var Me=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",z=e=>!!e?.[Me],j=e=>{try{let t=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`,n=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`;return e(t)!==t?!1:e(n)===n}catch{return false}},ee=(e,t,n)=>{let o="__stroid_persist_roundtrip_probe__",i;try{i=t(o);}catch(g){return {ok:false,reason:`persist: encrypt failed for store "${e}" (${g?.message??g})`}}if(typeof i!="string")return {ok:false,reason:`persist: encrypt must return a string for store "${e}".`};let l;try{l=n(i);}catch(g){return {ok:false,reason:`persist: decrypt failed for store "${e}" (${g?.message??g})`}}return typeof l!="string"?{ok:false,reason:`persist: decrypt must return a string for store "${e}".`}:l!==o?{ok:false,reason:`persist: encrypt/decrypt must round-trip for store "${e}".`}:{ok:true}};var te=(e,t,n)=>{e[t]&&(e[t].lastPresent=n);},re=({name:e,persistConfig:t,persistWatchState:n})=>{let o=t?.onStorageCleared;if(!t||typeof o!="function"||typeof window>"u"||typeof window.addEventListener!="function")return;n[e]?.dispose();let i=window,l=()=>{try{return t.driver.getItem?.(t.key)!=null}catch{return false}},g=r=>{let u=n[e],k=l();if(u){if(!u.lastPresent||k){u.lastPresent=k;return}u.lastPresent=false,o({name:e,key:t.key,reason:r});}},y=r=>{if(r.key===null){g("clear");return}r.key===t.key&&r.newValue===null&&g("remove");},c=()=>{g("missing");};i.addEventListener("storage",y),i.addEventListener("focus",c),n[e]={lastPresent:l(),dispose:()=>{i.removeEventListener("storage",y),i.removeEventListener("focus",c);}};};var W=({value:e,sanitize:t,validate:n,onSanitizeError:o})=>{let i;if(t)try{i=t(e);}catch(g){return o?.(g),{ok:false}}else i=e;let l=n(i);return l.ok?{ok:true,value:l.value??i}:{ok:false}},H=({value:e,fallbackMs:t=Date.now(),onInvalid:n})=>{if(typeof e=="number")return Number.isFinite(e)?e:(n?.(),t);if(typeof e=="string"){let o=Date.parse(e);return Number.isFinite(o)?o:(n?.(),t)}return n?.(),t};var Ce=new Map,D=(e,t,n=0)=>{!e||typeof t!="function"||Ce.set(e,{name:e,order:n,fn:t});};var Ee=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),ne=()=>({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:Ee(),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}});var L=new Map,oe=new WeakSet,Fe=e=>{oe.has(e)||(oe.add(e),Z().forEach(t=>{if(!e.featureRuntimes.get(t)){let n=Q(t);n&&e.featureRuntimes.set(t,n());}}));},Pe=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,se,ie=e=>(se||Pe||e).replace(/\.ts(\?|$)/,".js$1"),Te=ie("stroid:default-registry");var Oe=()=>{se=void 0,L.clear();};D("registry.scope-override",Oe,110);var _e=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false});var xe=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),Ae=(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:xe(),async:ne(),notify:_e(),lifecycleListener:null};return Fe(t),t},je=e=>{let t=ie(e),n=L.get(t);if(n)return n;let o=Ae();return L.set(t,o),o};var v=[],Ve={run:(e,t)=>{v.push(e);try{return t()}finally{v.pop();}},get:()=>v.length>0?v[v.length-1]:null,enterWith:e=>{if(v.length>0){v[v.length-1]=e;return}v.push(e);}};var ae=e=>(Ve).get()||e||je(Te);var Ne={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}`));}},ue={logSink:Ne,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},B=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}),U=new WeakMap,ce=B(ue),Ie=e=>{let t=U.get(e);return t||(t=B(ce),U.set(e,t)),t};var q=()=>Ie(ae());var He=()=>{U=new WeakMap,ce=B(ue);};D("config.reset",He,90);typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0;typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0;var Le=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));};var _=(e,t)=>{if((q().logSink.warn??Le)(e,t),q().assertRuntime)throw new Error(e)};var le=new Set(["__proto__","constructor","prototype"]);var Y=null,Ue=()=>{if(Y)return Y;let e,t=[];for(let n=0;n<256;n++){e=n;for(let o=0;o<8;o++)e=e&1?3988292384^e>>>1:e>>>1;t[n]=e>>>0;}return Y=t,t},fe=e=>{let t=Ue(),n=-1;for(let o=0;o<e.length;o++)n=n>>>0,n=n>>>8^t[(n^e.charCodeAt(o))&255];return (n^-1)>>>0},Be=2166136261,qe=2654435761,Ye=1e5,R=(e,t)=>{let n=t>>>0;e.h1=Math.imul(e.h1^n,2246822507),e.h2=Math.imul(e.h2^n,3266489909);},E=(e,t)=>{R(e,t.length);for(let n=0;n<t.length;n++)R(e,t.charCodeAt(n));},h=(e,t)=>{E(e,t);},de=(e,t)=>{if(Number.isNaN(t)){h(e,"NaN");return}if(!Number.isFinite(t)){h(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){h(e,"-0");return}let n=t|0;if(t===n){h(e,"int"),R(e,n);return}h(e,"num"),E(e,String(t));},F=(e,t)=>{if(e.nodes++>Ye){h(e,"[max]");return}if(t===null){h(e,"null");return}let n=typeof t;if(n==="string"){h(e,"string"),E(e,t);return}if(n==="number"){h(e,"number"),de(e,t);return}if(n==="boolean"){h(e,t?"true":"false");return}if(n==="undefined"){h(e,"undefined");return}if(n==="bigint"){h(e,"bigint"),E(e,t.toString());return}if(n==="symbol"){h(e,"symbol");let c=t;E(e,Symbol.keyFor(c)??c.description??String(c));return}if(n==="function"){h(e,"function"),E(e,t.name||"anonymous");return}let o=t,i=e.seen.get(o);if(i!==void 0){h(e,"ref"),R(e,i);return}let l=e.nextId++;if(e.seen.set(o,l),Array.isArray(o)){h(e,"array"),R(e,o.length);for(let c=0;c<o.length;c++)Object.prototype.hasOwnProperty.call(o,c)?F(e,o[c]):h(e,"hole");return}if(o instanceof Date){h(e,"date"),de(e,o.getTime());return}if(o instanceof Map){h(e,"map"),R(e,o.size),o.forEach((c,r)=>{F(e,r),F(e,c);});return}if(o instanceof Set){h(e,"set"),R(e,o.size),o.forEach(c=>{F(e,c);});return}h(e,"object");let g=Object.getOwnPropertyDescriptors(o),y=[];Object.entries(g).forEach(([c,r])=>{r?.enumerable&&(le.has(c)||"get"in r||"set"in r||y.push([c,r]));}),R(e,y.length);for(let[c,r]of y)E(e,c),F(e,r.value);},K=e=>{if(typeof e=="string")return fe(JSON.stringify(e));let t={h1:Be,h2:qe,seen:new WeakMap,nextId:1,nodes:0};F(t,e);let n=t.h1>>>0,o=t.h2>>>0;return n^=n>>>16,n=Math.imul(n,2246822507),n^=n>>>13,n=Math.imul(n,3266489909),n^=n>>>16,o^=o>>>16,o=Math.imul(o,668265261),o^=o>>>15,o=Math.imul(o,374761393),o^=o>>>16,(n&2097151)*4294967296+(o>>>0)};var Ge=e=>{let t=new Uint8Array(e),n="";for(let o=0;o<t.length;o++)n+=t[o].toString(16).padStart(2,"0");return n},Xe=async e=>{if(typeof globalThis<"u"&&globalThis.crypto?.subtle){let t=typeof TextEncoder<"u"?new TextEncoder:null,n=t?t.encode(e):new Uint8Array(Buffer.from(e)),o=await globalThis.crypto.subtle.digest("SHA-256",n);return Ge(o)}try{let{createHash:t}=await import('crypto');return t("sha256").update(e).digest("hex")}catch{throw new Error("sha256 checksum is not supported in this environment")}},V=async(e,t,n=K)=>e==="none"?null:e==="sha256"?Xe(t):n(t);var pe=1e6,ge=(e,t)=>{let n=e?.options?.migrations??{};if(Object.keys(n).length>0)return n;let o=t?.migrate;if(typeof o!="function")return n;let i=e?.version??1;return !Number.isFinite(i)||i<=1?n:{[i]:o}},J=({name:e,persisted:t,reason:n,persistConfig:o,initialState:i,reportStoreError:l,sanitize:g,deepClone:y})=>{l(e,n);let c=o?.onMigrationFail??"reset";if(c==="keep")return {state:t,requiresValidation:true};if(typeof c=="function")try{let r=c(y(t));if(r!==void 0)return {state:g(r),requiresValidation:!0};l(e,`onMigrationFail for "${e}" returned undefined. Falling back to initial state.`);}catch(r){l(e,`onMigrationFail for "${e}" failed: ${r?.message??r}`);}return {state:y(i),requiresValidation:true}},ye=e=>{let n=e.getMeta()?.options?.persist;return n?!!n.decryptAsync||n.checksum==="sha256"?Ze(e):Qe(e):false},Qe=({name:e,silent:t=false,getMeta:n,getInitialState:o,applyFeatureState:i,reportStoreError:l,warnMissingMaxSize:g,validate:y,log:c,hashState:r,deepClone:u,sanitize:k,shouldApply:p})=>{let m=n(),f=m?.options?.persist;if(!f)return false;let b=ge(m,f),a=s=>W({value:s,validate:y});try{let s=f.driver.getItem?.(f.key)??null;if(!s)return !1;if(typeof s!="string")return l(e,`Persist driver for "${e}" returned an async value during sync hydration. Provide async decrypt hooks or use an async-capable persist driver.`),!0;if(typeof f.maxSize!="number"&&s.length>pe&&g?.(s.length),typeof f.maxSize=="number"&&s.length>f.maxSize)return l(e,`Persist payload for "${e}" exceeds maxSize (${s.length} > ${f.maxSize}). Skipping hydration.`),!0;let d=f.decrypt(s),S=JSON.parse(d),{v:w=1,checksum:M,data:C,updatedAt:N,updatedAtMs:P}=S||{};if(!C)return !0;let T=H({value:typeof P=="number"?P:N,fallbackMs:Date.now(),onInvalid:()=>{c(`persist: corrupt updatedAt in stored data for "${e}". Using current time to prevent sync overwrite.`);}});if(f.checksum!=="none"&&M!==r(C))return l(e,`Checksum mismatch loading store "${e}". Falling back to initial state.`),(!p||p())&&i(u(o()),Date.now()),!0;let A=f.deserialize(C),I=m?.version??1,O=me({name:e,parsed:A,v:w,targetVersion:I,cfg:f,migrations:b,getInitialState:o,reportStoreError:l,sanitize:k,deepClone:u,validateState:a,safeUpdatedAt:T,applyFeatureState:i,shouldApply:p});return O.ok&&(A=O.state,(!p||p())&&(i(O.state,T),t||c(`Store "${e}" loaded from persistence`))),!0}catch(s){return l(e,`Could not load store "${e}" (${s?.message||s})`),true}},Ze=async({name:e,silent:t=false,getMeta:n,getInitialState:o,applyFeatureState:i,reportStoreError:l,warnMissingMaxSize:g,validate:y,log:c,hashState:r,deepClone:u,sanitize:k,shouldApply:p})=>{let m=n(),f=m?.options?.persist;if(!f)return false;let b=ge(m,f),a=s=>W({value:s,validate:y});try{let s=await Promise.resolve(f.driver.getItem?.(f.key)??null);if(!s)return !1;if(typeof f.maxSize!="number"&&typeof s=="string"&&s.length>pe&&g?.(s.length),typeof f.maxSize=="number"&&typeof s=="string"&&s.length>f.maxSize)return l(e,`Persist payload for "${e}" exceeds maxSize (${s.length} > ${f.maxSize}). Skipping hydration.`),!0;let d=f.decryptAsync?await f.decryptAsync(s):f.decrypt(s),S=JSON.parse(d),{v:w=1,checksum:M,data:C,updatedAt:N,updatedAtMs:P}=S||{};if(!C)return !0;let T=H({value:typeof P=="number"?P:N,fallbackMs:Date.now(),onInvalid:()=>{c(`persist: corrupt updatedAt in stored data for "${e}". Using current time to prevent sync overwrite.`);}}),A=await V(f.checksum,C,r);if(f.checksum!=="none"&&M!==A)return l(e,`Checksum mismatch loading store "${e}". Falling back to initial state.`),(!p||p())&&i(u(o()),Date.now()),!0;let I=f.deserialize(C),O=m?.version??1,G=me({name:e,parsed:I,v:w,targetVersion:O,cfg:f,migrations:b,getInitialState:o,reportStoreError:l,sanitize:k,deepClone:u,validateState:a,safeUpdatedAt:T,applyFeatureState:i,shouldApply:p});return G.ok&&(!p||p())&&(i(G.state,T),t||c(`Store "${e}" loaded from persistence`)),!0}catch(s){return l(e,`Could not load store "${e}" (${s?.message||s})`),true}},me=({name:e,parsed:t,v:n,targetVersion:o,cfg:i,migrations:l,getInitialState:g,reportStoreError:y,sanitize:c,deepClone:r,validateState:u,safeUpdatedAt:k,applyFeatureState:p,shouldApply:m})=>{if(n!==o){let b=Object.keys(l).map(d=>Number(d)).filter(d=>d>n&&d<=o).sort((d,S)=>d-S);if(b.length===0){let d=J({name:e,persisted:t,reason:`No migration path from v${n} to v${o} for "${e}". Applying onMigrationFail strategy.`,persistConfig:i,initialState:g(),reportStoreError:y,sanitize:c,deepClone:r});if(t=d.state,!d.requiresValidation)return (!m||m())&&p(t,k),{ok:false,state:t}}let a=false,s=true;if(b.forEach(d=>{if(!a)try{let S=l[d](t);S!==void 0&&(t=S);}catch(S){let w=J({name:e,persisted:t,reason:`Migration to v${d} failed for "${e}": ${S?.message||S}`,persistConfig:i,initialState:g(),reportStoreError:y,sanitize:c,deepClone:r});t=w.state,s=w.requiresValidation,a=true;}}),a){if(!s)return (!m||m())&&p(t,k),{ok:false,state:t};let d=u(t);return d.ok?{ok:true,state:d.value??t}:((!m||m())&&p(r(g()),Date.now()),{ok:false,state:t})}}let f=u(t);if(!f.ok){if(n!==o){let b=i?.onMigrationFail??"reset",a=J({name:e,persisted:t,reason:`Persisted state for "${e}" failed schema after version change. Applying onMigrationFail strategy.`,persistConfig:i,initialState:g(),reportStoreError:y,sanitize:c,deepClone:r});if(!a.requiresValidation)return (!m||m())&&p(a.state,k),{ok:false,state:a.state};let s=u(a.state);if(s.ok)return b==="reset"&&y(e,`Persisted state for "${e}" failed schema; resetting to initial.`),{ok:true,state:s.value??a.state}}return y(e,`Persisted state for "${e}" failed schema; resetting to initial.`),(!m||m())&&p(r(g()),Date.now()),{ok:false,state:t}}return {ok:true,state:f.value??t}};var Se=(e,t,...n)=>{if(typeof e=="function")try{e(...n);}catch(o){let i=o?.message??o;_(`${t} callback threw: ${String(i)}`);}};var he=({name:e,persistTimers:t,persistInFlight:n,persistSequence:o,persistWatchState:i,plaintextWarningsIssued:l,exists:g,getMeta:y,getStoreValue:c,reportStoreError:r,hashState:u},k=false)=>{let p=y()?.options?.persist;if(!p)return;let m=async a=>{let s=y();if(!(!s?.options?.persist||s.options.persist!==p||!g())&&!(a!==void 0&&o[e]!==a)){if(!p.allowPlaintext&&!l.has(e)&&z(p.encrypt)&&z(p.decrypt)){l.add(e);let d=`[stroid/persist] Store '${e}' is persisted in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`;Se(s.options.onError,`onError(${e})`,d),_(d);}try{let d=p.serialize(c()),S=await V(p.checksum,d,u),w=JSON.stringify({v:s.version??1,updatedAt:s.updatedAt,updatedAtMs:s.updatedAtMs??Date.now(),checksum:S,data:d}),M=p.encryptAsync?await p.encryptAsync(w):p.encrypt(w);if(a!==void 0&&o[e]!==a)return;await Promise.resolve(p.driver.setItem?.(p.key,M)),te(i,e,!0);}catch(d){r(e,`Could not persist store "${e}" (${d?.message||d})`);}}},f=a=>{let s=n[e],d=(o[e]??0)+1;o[e]=d;let w=(async()=>{s&&await s,!(a&&t[e]!==a)&&o[e]===d&&await m(d);})().finally(()=>{n[e]===w&&(n[e]=null),a&&t[e]===a&&delete t[e];});n[e]=w;};if(k){t[e]&&(clearTimeout(t[e]),delete t[e]),f();return}t[e]&&clearTimeout(t[e]);let b=setTimeout(()=>{t[e]===b&&f(b);},0);t[e]=b;},x=e=>he(e),be=(e,t)=>he({...t,name:e},true);var ke=false,et=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,tt=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,rt=et??tt,nt=()=>rt==="production",ot=()=>{let e={},t={},n=Object.create(null),o=Object.create(null),i=Object.create(null),l=new Set,g=new Set,y=Object.create(null),c=Object.create(null);return {api:{getPersistQueueDepth(r){return e[r]?1:0}},onStoreCreate(r){let u=r.options.persist;if(!u)return;if(!u.encryptAsync&&j(u.encrypt)&&j(u.decrypt)&&!u.allowPlaintext){let a=`[stroid/persist] Store "${r.name}" is configured for plaintext persistence. Provide encrypt/decrypt hooks or set persist.allowPlaintext: true to acknowledge.`;if(nt()){r.reportStoreError(a),r.options.persist=null;return}r.warn(a);}if(u.sensitiveData&&!u.encryptAsync&&j(u.encrypt)){r.reportStoreError(`persist: store "${r.name}" is marked sensitiveData but has no encrypt function. Plaintext data will be written to storage.`);return}let p=ee(r.name,u.encrypt,u.decrypt);if(!p.ok){r.reportStoreError(p.reason??`persist: encrypt/decrypt validation failed for store "${r.name}".`),r.options.persist=null;return}if(u.key){let a=o[u.key];a&&a!==r.name&&r.isDev()?r.warn(`Persist key collision: "${u.key}" already used by store "${a}". Store "${r.name}" will overwrite the same storage key.`):o[u.key]=r.name;}let m=r.getMeta()?.updateCount??0,f=()=>{let a=r.getMeta();return a?(a.updateCount??0)===m:false},b=ye({name:r.name,silent:true,getMeta:r.getMeta,getInitialState:r.getInitialState,applyFeatureState:r.applyFeatureState,reportStoreError:(a,s)=>r.reportStoreError(s),warnMissingMaxSize:a=>{g.has(r.name)||(g.add(r.name),r.warnAlways(`[stroid/persist] Store "${r.name}" loaded ${a} bytes without a maxSize guard. Set persist.maxSize to prevent oversized payloads.`));},validate:r.validate,log:r.log,hashState:r.hashState,deepClone:r.deepClone,sanitize:r.sanitize,shouldApply:f});if(typeof b?.then=="function"?(y[r.name]={loading:true,pendingSave:false},b.then(a=>{let s=y[r.name];s&&(s.loading=false,(!a||s.pendingSave)&&x({name:r.name,persistTimers:e,persistInFlight:t,persistSequence:n,persistWatchState:i,plaintextWarningsIssued:l,exists:()=>r.hasStore(),getMeta:r.getMeta,getStoreValue:r.getStoreValue,reportStoreError:(d,S)=>r.reportStoreError(S),hashState:r.hashState}),delete y[r.name]);}).catch(()=>{let a=y[r.name];a&&(a.loading=false,a.pendingSave&&x({name:r.name,persistTimers:e,persistInFlight:t,persistSequence:n,persistWatchState:i,plaintextWarningsIssued:l,exists:()=>r.hasStore(),getMeta:r.getMeta,getStoreValue:r.getStoreValue,reportStoreError:(s,d)=>r.reportStoreError(d),hashState:r.hashState}),delete y[r.name]);})):b||x({name:r.name,persistTimers:e,persistInFlight:t,persistSequence:n,persistWatchState:i,plaintextWarningsIssued:l,exists:()=>r.hasStore(),getMeta:r.getMeta,getStoreValue:r.getStoreValue,reportStoreError:(a,s)=>r.reportStoreError(s),hashState:r.hashState}),typeof window<"u"&&typeof window.addEventListener=="function"){c[r.name]?.();let a=window,s=false,d=()=>{s||(s=true,a.removeEventListener("pagehide",S),a.removeEventListener("beforeunload",S),delete c[r.name]);},S=()=>{d(),be(r.name,{name:r.name,persistTimers:e,persistInFlight:t,persistSequence:n,persistWatchState:i,plaintextWarningsIssued:l,exists:()=>r.hasStore(),getMeta:r.getMeta,getStoreValue:r.getStoreValue,reportStoreError:(w,M)=>r.reportStoreError(M),hashState:r.hashState});};a.addEventListener("pagehide",S,{once:true}),a.addEventListener("beforeunload",S,{once:true}),c[r.name]=d;}re({name:r.name,persistConfig:u,persistWatchState:i});},onStoreWrite(r){if(!r.options.persist)return;let u=y[r.name];if(u?.loading){u.pendingSave=true;return}x({name:r.name,persistTimers:e,persistInFlight:t,persistSequence:n,persistWatchState:i,plaintextWarningsIssued:l,exists:()=>r.hasStore(),getMeta:r.getMeta,getStoreValue:r.getStoreValue,reportStoreError:(k,p)=>r.reportStoreError(p),hashState:r.hashState});},beforeStoreDelete(r){let u=r.options.persist;if(u){delete y[r.name],g.delete(r.name),e[r.name]&&(clearTimeout(e[r.name]),delete e[r.name]),t[r.name]=null,delete n[r.name];try{u.driver.removeItem?.(u.key);}catch{}u.key&&o[u.key]===r.name&&delete o[u.key],c[r.name]?.(),i[r.name]?.dispose(),delete c[r.name],delete i[r.name];}},resetAll(){Object.values(e).forEach(r=>clearTimeout(r)),Object.values(c).forEach(r=>{try{r();}catch{}}),Object.values(i).forEach(r=>{try{r.dispose();}catch{}}),Object.keys(e).forEach(r=>delete e[r]),Object.keys(t).forEach(r=>{t[r]=null,delete t[r];}),Object.keys(n).forEach(r=>delete n[r]),Object.keys(o).forEach(r=>delete o[r]),Object.keys(i).forEach(r=>delete i[r]),Object.keys(y).forEach(r=>delete y[r]),l.clear(),g.clear();}}},we=()=>{ke||(ke=true,X("persist",ot));};var ve=()=>{we();};ve();export{ve as installPersist};//# sourceMappingURL=persist.js.map
1
+ export{a as installPersist}from'./chunk-PVATWAY4.js';import'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';//# sourceMappingURL=persist.js.map
2
2
  //# sourceMappingURL=persist.js.map
package/dist/psr.d.ts ADDED
@@ -0,0 +1,48 @@
1
+ export { evaluateComputed, getComputedDescriptor, getStoreMeta, listStores } from './runtime-tools.js';
2
+ import { R as RuntimePatch } from './runtime-patch.js';
3
+ export { a as RuntimePatchMeta, b as RuntimePatchOp } from './runtime-patch.js';
4
+ import { W as WriteResult, S as StoreValue, a as StoreDefinition, b as StoreKey } from './types.js';
5
+ import { RuntimeGraph } from './computed-types.js';
6
+ export { ComputedClassification, ComputedDescriptor, RuntimeEdgeType, RuntimeGraphEdge, RuntimeGraphGranularity, RuntimeGraphNode, RuntimeNodeId, RuntimeNodeType } from './computed-types.js';
7
+ import './feature.js';
8
+ import './options.js';
9
+ import './utility.js';
10
+ import './async.js';
11
+ import './cache.js';
12
+ import './registry.js';
13
+
14
+ type StoreTarget = StoreDefinition<string, StoreValue> | StoreKey<string, StoreValue> | string;
15
+ type StoreListener = (value: StoreValue | null) => void;
16
+ type PatchFailureReason = Extract<WriteResult, {
17
+ ok: false;
18
+ }>["reason"];
19
+ type PatchApplyResult = {
20
+ ok: true;
21
+ } | {
22
+ ok: false;
23
+ reason: PatchFailureReason;
24
+ failedPatchId?: string;
25
+ };
26
+ type GovernanceMode = "full-governor" | "bounded-governor" | "observer";
27
+ type MutationAuthority = "exclusive" | "shared";
28
+ type CausalityBoundary = "none" | "async-boundary";
29
+ interface TimingContract {
30
+ simulationWindow: "pre-commit" | "pre-render" | "post-render";
31
+ executionModel: "sync" | "async-boundary";
32
+ effectScope: "in-pipeline" | "out-of-pipeline";
33
+ governanceMode: GovernanceMode;
34
+ mutationAuthority: MutationAuthority;
35
+ causalityBoundary: CausalityBoundary;
36
+ reasons: readonly string[];
37
+ }
38
+ declare const getStoreSnapshot: (target: StoreTarget) => StoreValue | null;
39
+ declare const getStoreSnapshotNoTrack: (target: StoreTarget) => StoreValue | null;
40
+ declare const subscribeStore: (target: StoreTarget, listener: StoreListener) => (() => void);
41
+ declare const hasStore: (target: StoreTarget) => boolean;
42
+ declare const applyStorePatch: (patch: RuntimePatch) => PatchApplyResult;
43
+ declare const applyStorePatchesAtomic: (patches: readonly RuntimePatch[]) => PatchApplyResult;
44
+ declare const getTimingContract: (target?: StoreTarget) => TimingContract;
45
+ declare const getComputedGraph: () => RuntimeGraph;
46
+ declare const getRuntimeGraph: () => RuntimeGraph;
47
+
48
+ export { type CausalityBoundary, type GovernanceMode, type MutationAuthority, type PatchApplyResult, RuntimeGraph, RuntimePatch, type StoreListener, type StoreTarget, type TimingContract, applyStorePatch, applyStorePatchesAtomic, getComputedGraph, getRuntimeGraph, getStoreSnapshot, getStoreSnapshotNoTrack, getTimingContract, hasStore, subscribeStore };
package/dist/psr.js ADDED
@@ -0,0 +1,2 @@
1
+ import {k as k$1,b,m as m$1,a}from'./chunk-M2NJVI36.js';export{n as evaluateComputed,m as getComputedDescriptor,b as getStoreMeta,a as listStores}from'./chunk-M2NJVI36.js';import'./chunk-BW32TJGE.js';import'./chunk-6ELWGQ4Q.js';import {pa,na,N,ba,ja,ka,la,G,y as y$1,T as T$1,U as U$1,ga}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';var T={ok:false,reason:"invalid-args"},J={reason:"unsupported-op"};var Q=["set","merge","delete","insert"],X=["setStore","replaceStore","resetStore","hydrateStores"],m=e=>G(e),j=e=>!!e?.options.persist?.encryptAsync||!!e?.options.persist?.decryptAsync||e?.options.persist?.checksum==="sha256",Y=e=>!!e?.options.sync||j(e),Z=e=>!!e?.options.persist||!!e?.options.sync||e?.options.devtools===true,ee=(e,t)=>JSON.stringify([e,t,[]]),te=e=>ee("leaf",e),U=(e,t)=>{let r=new Map;return e.edges.forEach(n=>{let o=t==="forward"?n.from:n.to,s=t==="forward"?n.to:n.from,a=r.get(o);if(a){a.push(s);return}r.set(o,[s]);}),r},_=(e,t)=>{let r=new Set,n=[...e];for(;n.length>0;){let o=n.shift();if(r.has(o))continue;r.add(o);let s=t.get(o);s&&s.forEach(a=>{r.has(a)||n.push(a);});}return r},y=e=>Array.from(new Set(e)).sort((t,r)=>t.localeCompare(r)),re=e=>{if(!e)return [];let t=m$1(e);return t?[t.id]:[te(e)]},ne=(e,t)=>{if(!e)return y(a());let r=m$1(e);if(!r)return [e];let n=new Map(t.nodes.map(u=>[u.id,u])),o=U(t,"reverse"),s=_([r.id],o),a$1=Array.from(s).map(u=>n.get(u)).filter(u=>!!u).filter(u=>u.type==="leaf").map(u=>u.storeId);return a$1.length>0?y(a$1):[e]},oe=(e,t)=>{let r=new Set(t.nodes.filter(a=>a.type==="async-boundary").map(a=>a.id));if(r.size===0)return [];if(!e)return y(r);let n=re(e),o=U(t,"forward"),s=_(n,o);return y(Array.from(s).filter(a=>r.has(a)))},p=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),se=e=>typeof e=="string"&&Q.includes(e),ae=e=>typeof e=="string"&&X.includes(e),z=e=>typeof e?.id=="string"&&e.id.length>0?e.id:void 0,c=(e,t)=>t?{ok:false,reason:e,failedPatchId:t}:{ok:false,reason:e},R=(e,t)=>e.ok?{ok:true}:c(e.reason,"failedPatchId"in e?e.failedPatchId??t:t),x=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),S=e=>typeof e=="number"?Number.isInteger(e)&&e>=0?e:null:/^(0|[1-9]\d*)$/.test(e)?Number(e):null,L=(e,t)=>{if(Array.isArray(e)){let n=S(t);return n===null?{ok:false,reason:"unsupported-path-shape"}:n>=e.length?{ok:false,reason:"path"}:{ok:true,value:e[n]}}let r=String(t);return Object.prototype.hasOwnProperty.call(e,r)?{ok:true,value:e[r]}:{ok:false,reason:"path"}},H=(e,t,r)=>{if(Array.isArray(e)){let n=S(t);if(n===null)return e;let o=[...e];return o[n]=r,o}return {...e,[String(t)]:r}},k=(e,t,r)=>{if(t.length===0)return {ok:false,reason:"unsupported-path-shape"};if(!Array.isArray(e)&&!x(e))return {ok:false,reason:"unsupported-path-shape"};let[n,...o]=t;if(o.length===0)return r(e,n);let s=L(e,n);if(!s.ok)return s;let a=k(s.value,o,r);return a.ok?{ok:true,value:H(e,n,a.value)}:a},ue=(e,t,r)=>x(r)?k(e,t,(n,o)=>{let s=L(n,o);return s.ok?x(s.value)?{ok:true,value:H(n,o,{...s.value,...r})}:{ok:false,reason:"unsupported-path-shape"}:s}):{ok:false,reason:"unsupported-path-shape"},ie=(e,t)=>k(e,t,(r,n)=>{if(Array.isArray(r)){let a=S(n);if(a===null)return {ok:false,reason:"unsupported-path-shape"};if(a>=r.length)return {ok:false,reason:"path"};let u=[...r];return u.splice(a,1),{ok:true,value:u}}let o=String(n);if(!Object.prototype.hasOwnProperty.call(r,o))return {ok:false,reason:"path"};let s={...r};return delete s[o],{ok:true,value:s}}),le=(e,t,r)=>k(e,t,(n,o)=>{if(!Array.isArray(n))return {ok:false,reason:"unsupported-path-shape"};let s=S(o);if(s===null)return {ok:false,reason:"unsupported-path-shape"};if(s>n.length)return {ok:false,reason:"path"};let a=[...n];return a.splice(s,0,r),{ok:true,value:a}}),I=(e,t)=>{let r=e.id;if(!N(e.store))return c("not-found",r);let n=ba(),o=ga(e.store,n);if(o===void 0)return c("not-found",r);let s=t(o);return s.ok?R(T$1(e.store,s.value),r):c(s.reason,r)},W=e=>{if(!e||typeof e!="object"||!p(e,"id")||typeof e.id!="string"||e.id.length===0||!p(e,"store")||typeof e.store!="string"||e.store.length===0||!p(e,"path")||!Array.isArray(e.path)||e.path.some(r=>typeof r!="string"&&typeof r!="number")||!se(e.op)||(e.op==="set"||e.op==="merge"||e.op==="insert")&&!p(e,"value")||!p(e,"meta")||!e.meta||typeof e.meta!="object"||typeof e.meta.timestamp!="number"||!Number.isFinite(e.meta.timestamp)||!ae(e.meta.source)||e.meta.causedBy!==void 0&&(!Array.isArray(e.meta.causedBy)||e.meta.causedBy.some(r=>typeof r!="string"))||e.meta.isUnsafe!==void 0&&typeof e.meta.isUnsafe!="boolean"||e.meta.asyncBoundary!==void 0&&typeof e.meta.asyncBoundary!="boolean")return null;let t=e.path.map(r=>typeof r=="number"?r:String(r));return y$1(t.map(r=>String(r)))?{id:e.id,store:e.store,path:t,op:e.op,...p(e,"value")?{value:e.value}:{},meta:{timestamp:e.meta.timestamp,source:e.meta.source,...e.meta.causedBy&&e.meta.causedBy.length>0?{causedBy:[...e.meta.causedBy]}:{},...e.meta.isUnsafe===true?{isUnsafe:true}:{},...e.meta.asyncBoundary===true?{asyncBoundary:true}:{}}}:null},$=e=>e.op==="set"?e.path.length===0?R(T$1(e.store,e.value),e.id):R(U$1(e.store,e.path.map(t=>String(t)),e.value),e.id):e.op==="merge"?e.path.length===0?R(U$1(e.store,e.value),e.id):I(e,t=>ue(t,e.path,e.value)):e.op==="delete"?I(e,t=>ie(t,e.path)):e.op==="insert"?I(e,t=>le(t,e.path,e.value)):c(J.reason,e.id),de=e=>{let t=k$1(),n=ne(e,t).map(i=>({storeId:i,meta:b(i)})),o=oe(e,t),s=new Map(t.nodes.map(i=>[i.id,i])),a=e?m$1(e):null,u=new Set;n.forEach(({storeId:i,meta:f})=>{f?.options.sync&&u.add(`sync for "${i}" can apply remote writes outside the local commit path`),j(f)&&u.add(`persist for "${i}" introduces async boundary work`);}),o.forEach(i=>{let f=s.get(i)?.storeId;if(!f)return;let q=a?.id===i||!e?"computed node":"downstream computed node";u.add(`${q} "${f}" is marked asyncBoundary`);});let l=n.some(({meta:i})=>!!i?.options.sync),d=o.length>0||n.some(({meta:i})=>Y(i)),B=n.some(({meta:i})=>Z(i))?"in-pipeline":"out-of-pipeline";return {simulationWindow:"pre-commit",executionModel:d?"async-boundary":"sync",effectScope:B,governanceMode:l?"observer":d?"bounded-governor":"full-governor",mutationAuthority:l?"shared":"exclusive",causalityBoundary:d?"async-boundary":"none",reasons:y(u)}},Pe=e=>pa(m(e)),ve=e=>pa(m(e)),Ae=(e,t)=>na(m(e),t),be=e=>N(m(e)),we=e=>{let t=W(e);return t?$(t):c(T.reason,z(e))},Ie=e=>{if(!Array.isArray(e))return T;if(e.length===0)return {ok:true};let t=[];for(let l of e){let d=W(l);if(!d)return c(T.reason,z(l));t.push(d);}let r=ba(),n=r.notify;n.batchDepth=Math.max(0,n.batchDepth+1),ja(r);let o=null,s=null,a=null,u;try{for(let l of t){u=l.id;let d=$(l);if(!d.ok){o=d.failedPatchId?d:{ok:!1,reason:d.reason,failedPatchId:l.id};break}}}catch(l){s=l instanceof Error?l:new Error(String(l));}finally{let l=o?.reason;a=ka(s??(l?new Error(`applyStorePatchesAtomic failed: ${l}`):void 0),r),n.batchDepth=Math.max(0,n.batchDepth-1),n.batchDepth===0&&n.pendingNotifications.size>0&&la(r);}return o||(s||a?c("validate",u):{ok:true})},Te=e=>de(e?m(e):void 0),xe=()=>k$1(),Be=()=>k$1();export{we as applyStorePatch,Ie as applyStorePatchesAtomic,xe as getComputedGraph,Be as getRuntimeGraph,Pe as getStoreSnapshot,ve as getStoreSnapshotNoTrack,Te as getTimingContract,be as hasStore,Ae as subscribeStore};//# sourceMappingURL=psr.js.map
2
+ //# sourceMappingURL=psr.js.map
@@ -1,4 +1,4 @@
1
- import { a as StoreDefinition, b as StoreKey, c as StoreName, e as StateFor, i as Path, j as PathValue } from '../types.js';
1
+ import { a as StoreDefinition, b as StoreKey, d as StoreName, e as StateFor, i as Path, j as PathValue } from '../types.js';
2
2
  import { F as FetchInput } from '../cache.js';
3
3
  import { F as FetchOptions } from '../registry.js';
4
4
  import React, { ReactNode } from 'react';
@@ -6,6 +6,8 @@ import { S as StoreRegistry } from '../store-registry.js';
6
6
  import '../utility.js';
7
7
  import '../feature.js';
8
8
  import '../options.js';
9
+ import '../runtime-patch.js';
10
+ import '../computed-types.js';
9
11
 
10
12
  type StoreSnapshot$1<T> = T extends object ? Readonly<T> : T;
11
13
  declare function useStore<Name extends string, State, P extends Path<State>>(name: StoreDefinition<Name, State>, path: P): StoreSnapshot$1<PathValue<State, P>> | null;
@@ -1,38 +1,7 @@
1
- import Ii,{createContext,useRef,useCallback,useSyncExternalStore,useEffect,useMemo,useContext}from'react';var Ts=new Map,F=(e,t,r=0)=>{!e||typeof t!="function"||Ts.set(e,{name:e,order:r,fn:t});};var fr=new Map;var Vt=e=>fr.has(e),jt=e=>fr.get(e),qe=()=>Array.from(fr.keys());var nn=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),on=()=>({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:nn(),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}}),sn=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(n=>{try{n();}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(),nn().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 pr=new Map,an=new WeakSet,gr=e=>{an.has(e)||(an.add(e),qe().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=jt(t);r&&e.featureRuntimes.set(t,r());}}));},Fs=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,cn,Sr=e=>(cn||Fs||e).replace(/\.ts(\?|$)/,".js$1"),De=Sr("stroid:default-registry"),be=()=>Oe(De);var Es=()=>{cn=void 0,pr.clear();};F("registry.scope-override",Es,110);var As=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Ns=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},un=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),Ps=(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:un(),async:on(),notify:As(),lifecycleListener:null};return gr(t),t},Oe=e=>{let t=Sr(e),r=pr.get(t);if(r)return r;let n=Ps();return pr.set(t,n),n},Ve=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),ln=(e,t)=>e.deletingStores.has(t),dn=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,Ns(e.notify),sn(e.async),e.lifecycleListener=null;};var It=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var gt=()=>null,he=[],pn={run:(e,t)=>{he.push(e);try{return t()}finally{he.pop();}},get:()=>he.length>0?he[he.length-1]:null,enterWith:e=>{if(he.length>0){he[he.length-1]=e;return}he.push(e);}};var K=(e,t)=>(pn).run(e,t),H=e=>(pn).get()||e||Oe(De);var Os={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}`));}},gn={logSink:Os,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},mr=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}),yr=new WeakMap,Sn=mr(gn),Vs=e=>{let t=yr.get(e);return t||(t=mr(Sn),yr.set(e,t)),t};var k=()=>Vs(H());var Ws=()=>{yr=new WeakMap,Sn=mr(gn);};F("config.reset",Ws,90);var yn=()=>k().namespace;var _s=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,zs=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,mn=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,Hs="production",Ls=_s??zs??Hs,St=typeof mn=="boolean"?mn:Ls!=="production",v=()=>St,hr=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Bs=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},qs=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},L=(e,t)=>{if((k().logSink.critical??Bs)(e,t),k().assertRuntime)throw new Error(e)},d=(e,t)=>{if(!St)return;if((k().logSink.warn??hr)(e,t),k().assertRuntime)throw new Error(e)},ne=(e,t)=>{if((k().logSink.warn??hr)(e,t),k().assertRuntime)throw new Error(e)},I=(e,t)=>{if(St&&(k().logSink.warn??hr)(e,t),L(e,t),k().assertRuntime)throw new Error(e)},oe=(e,t)=>{if(!St)return;(k().logSink.log??qs)(e,t);},hn=()=>`Functions cannot be stored in stroid.
2
- Store data only - handle functions outside the store.`,bn=()=>`Map/Set detected. stroid converts these to plain objects.
3
- Use arrays or plain objects for best results.`,wn=()=>`Date object detected. stroid stores it as ISO string.
4
- Use new Date(value) to convert back when reading.`,xn=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Rn=()=>"Map detected; converting to plain object.",vn=()=>"Set detected; converting to array.",kn=(e,t,r)=>`Path depth of ${e} exceeded maximum of ${t}.
5
- "${r.join(".")}"
6
- This is a data design issue. Split into separate stores:
7
- createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,Cn=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
8
- Consider splitting into separate stores for better readability.`,Tn=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,Mn=e=>`Cannot go deeper at "${e}" - value is not an object`,Fn=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,En=e=>`Store name "${e}" contains spaces.
9
- Use camelCase or kebab-case: "userName" or "user-name"`,An=e=>`Store name "${e}" is not allowed.
10
- Reserved names: "__proto__", "constructor", "prototype".`,Ks=128,Us=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=Ks,Gs=(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},(o,s)=>s),n=new Array(e.length+1);for(let o=1;o<=t.length;o++){n[0]=o;for(let s=1;s<=e.length;s++)n[s]=t[o-1]===e[s-1]?r[s-1]:Math.min(r[s-1],n[s-1],r[s])+1;[r,n]=[n,r];}return r[e.length]},br=(e,t)=>{let r=t.find(n=>{let o=n.toLowerCase(),s=e.toLowerCase();return o.includes(s)||s.includes(o)||Us(o,s)&&Gs(o,s)<=2});if(r){d(`Store "${e}" not found. Did you mean "${r}"?`);return}I(`Store "${e}" not found.
11
- Available stores: [${t.join(", ")}]
12
- Call createStore("${e}", data) first.`);};var ce=new Set(["__proto__","constructor","prototype"]),xr=(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 o=r.error,s=o?.details?.[0]?.message||o?.message||r.message||e.errors;if(s)return {ok:!1,error:s};if(o)return {ok:!1,error:o}}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 Fe=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,Nn=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null},Ke=e=>{let t=Fe(e);return t==="function"?(I(hn()),false):t==="map"||t==="set"?(d(bn()),true):(t==="date"&&d(wn()),true)},wr=(e,t)=>{let r=Nn(e);if(r)throw new Error(`${r} values are not supported`);let n=Fe(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 o=Object.keys(e);for(let s of o){let i=Number(s);if(!Number.isInteger(i))return false}for(let s=0;s<e.length;s+=1)if(s in e&&!wr(e[s],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 o=Object.getOwnPropertyDescriptors(e);for(let[s,i]of Object.entries(o)){if(!i.enumerable||ce.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!wr(i.value,t))return false}return true}return true},Rr=e=>wr(e,new WeakSet),yt=(e,t)=>{let r=Nn(e);if(r)throw new Error(`${r} values are not supported`);let n=Fe(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 v()&&d(xn()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),v()&&d(Rn());let o={};for(let[s,i]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");o[String(s)]=yt(i,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),v()&&d(vn()),Array.from(e,o=>yt(o,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let o={},s=Object.getOwnPropertyDescriptors(e);for(let[i,a]of Object.entries(s))if(a.enumerable&&!ce.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);o[i]=yt(a.value,t);}return o}if(n==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(o=>yt(o,t))}return e},je=e=>yt(e,new WeakSet),vr=e=>typeof e!="string"||e.trim()===""?(I(Fn(e)),false):ce.has(e)?(I(An(e)),false):e.includes(" ")?(I(En(e)),false):true;var kr=null,Ys=()=>{if(kr)return kr;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 kr=t,t},Dn=e=>{let t=Ys(),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},Xs=2166136261,Js=2654435761,Qs=1e5,Ee=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},Ie=(e,t)=>{Ee(e,t.length);for(let r=0;r<t.length;r++)Ee(e,t.charCodeAt(r));},$=(e,t)=>{Ie(e,t);},Pn=(e,t)=>{if(Number.isNaN(t)){$(e,"NaN");return}if(!Number.isFinite(t)){$(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){$(e,"-0");return}let r=t|0;if(t===r){$(e,"int"),Ee(e,r);return}$(e,"num"),Ie(e,String(t));},Ue=(e,t)=>{if(e.nodes++>Qs){$(e,"[max]");return}if(t===null){$(e,"null");return}let r=typeof t;if(r==="string"){$(e,"string"),Ie(e,t);return}if(r==="number"){$(e,"number"),Pn(e,t);return}if(r==="boolean"){$(e,t?"true":"false");return}if(r==="undefined"){$(e,"undefined");return}if(r==="bigint"){$(e,"bigint"),Ie(e,t.toString());return}if(r==="symbol"){$(e,"symbol");let u=t;Ie(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){$(e,"function"),Ie(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){$(e,"ref"),Ee(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){$(e,"array"),Ee(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?Ue(e,n[u]):$(e,"hole");return}if(n instanceof Date){$(e,"date"),Pn(e,n.getTime());return}if(n instanceof Map){$(e,"map"),Ee(e,n.size),n.forEach((u,c)=>{Ue(e,c),Ue(e,u);});return}if(n instanceof Set){$(e,"set"),Ee(e,n.size),n.forEach(u=>{Ue(e,u);});return}$(e,"object");let i=Object.getOwnPropertyDescriptors(n),a=[];Object.entries(i).forEach(([u,c])=>{c?.enumerable&&(ce.has(u)||"get"in c||"set"in c||a.push([u,c]));}),Ee(e,a.length);for(let[u,c]of a)Ie(e,u),Ue(e,c.value);},mt=e=>{if(typeof e=="string")return Dn(JSON.stringify(e));let t={h1:Xs,h2:Js,seen:new WeakMap,nextId:1,nodes:0};Ue(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 Zs=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,o])=>{o.enumerable&&(ce.has(n)||"get"in o||"set"in o||(t[n]=o.value));}),t},Cr=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[n,o]of t)if(typeof o=="function"&&e instanceof o)return n;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},ei=e=>Cr(e)===null,ti=e=>{let t=Cr(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},$e=(e,t=new WeakMap)=>{if(ti(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 o=new Map;return t.set(e,o),e.forEach((s,i)=>{o.set($e(i,t),$e(s,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(s=>{o.add($e(s,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((s,i)=>{o[i]=$e(s,t);}),o}let r={};t.set(e,r);let n;try{n=Object.getOwnPropertyDescriptors(e);}catch(o){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${o?.message??o}`)}return Object.entries(n).forEach(([o,s])=>{!s.enumerable||ce.has(o)||"get"in s||"set"in s||(r[o]=$e(s.value,t));}),r},O=e=>{if(Zs)try{return structuredClone(e)}catch(t){if(!ei(e)){let r=Cr(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return d(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),$e(e)}return $e(e)},ht=(e,t)=>{if(Object.is(e,t))return true;if(!e||!t||typeof e!="object"||typeof t!="object")return false;let r=e,n=t,o=Object.keys(r),s=Object.keys(n);if(o.length!==s.length)return false;for(let i of o)if(!Object.prototype.hasOwnProperty.call(n,i)||!Object.is(r[i],n[i]))return false;return true};var On=10,ri=5,ni=e=>{let t=[],r="",n=false;for(let o of e){if(n){r+=o,n=false;continue}if(o==="\\"){n=true;continue}if(o==="."){t.push(r),r="";continue}r+=o;}return n&&(r+="\\"),t.push(r),t},Ge=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?ni(e):[String(e)],bt=e=>{let t=Ge(e),r=t.length;return r>On?(I(kn(r,On,t)),false):(r>ri&&d(Cn(r,t)),true)},Ye=(e,t)=>{let r=Ge(t),n=e;for(let o of r){if(n==null){d(Tn(r,o));return}if(typeof n!="object"){d(Mn(o));return}n=n[o];}return n},Tr=(e,t,r)=>{let n=Ge(t);if(n.length===0)return e;for(let s of n)if(ce.has(s))return L(`Blocked forbidden path segment "${String(s)}" in setStore path "${n.join(".")}".`),e;let o=(s,i)=>{let a=n[i],u=i===n.length-1;if(Array.isArray(s)){let c=Number(a);if(!Number.isInteger(c))return s;let l=[...s];return u?(l[c]=r,l):(l[c]=o(l[c],i+1),l)}if(s&&typeof s=="object"){if(ce.has(a))return L(`Blocked unsafe path segment "${String(a)}" while setting "${n.join(".")}".`),s;let c={...s};return u?(c[a]=r,c):(c[a]=o(c[a],i+1),c)}if(s==null&&!u){let c=Number.isInteger(Number(a)),l=c?[]:{};if(c){let S=l,y=Number(a);return S[y]=o(void 0,i+1),S}return l[a]=o(void 0,i+1),l}return u?r:s};return o(e,0)};var Vn=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")},wt=e=>(Vn(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),$t=e=>{if(!Vn(e))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 o of Object.keys(n)){let s=n[o];typeof s=="object"&&s!==null&&!r.has(s)&&t.push(s);}}}return e};var Wt=null;var oi=()=>{Wt=null;};F("transaction.runner",oi,120);var xt=e=>{let t=Wt?.get();return t||(e??H()).transaction},si=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 D=()=>Wt?(Wt.get()?.depth??0)>0:xt().depth>0,G=(e,t)=>{let r=xt(t);r.failed=true,r.error||(r.error=si(e));},_t=e=>{let t=H();xt(t).pending.push(()=>K(t,e));},zt=(e,t)=>{let r=xt();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},Xe=e=>{let t=xt();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Ht=Symbol("stroid.middleware.abort"),jn=({name:e,payload:t,middlewares:r,reportIssue:n,warn:o})=>{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 u,c=i;try{u=a({action:t.action,name:e,prev:t.prev,next:c,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(l){let S=`Middleware for "${e}" failed: ${l?.message??l}`;return n(S,"dev"),Ht}if(u&&typeof u.then=="function"){let l=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(l,"dev"),Ht}u===void 0?(v()&&!s.has(a)&&(s.add(a),o(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=c):i=u;}return i},Lt=({name:e,label:t,fn:r,args:n,reportIssue:o})=>{if(typeof r=="function")try{r(...n);}catch(s){let i=`${t} for "${e}" failed: ${s?.message??s}`;o(i,"always");}};var se=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(n){let o=n?.message??n;ne(`${t} callback threw: ${String(o)}`);}},We=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(se(o,"onError",e),r==="critical"){n==="dev"&&d(e),L(e);return}if(n==="always"){ne(e);return}d(e);};var Bt=null,In=e=>{Bt=e;},$n=e=>Bt?Bt(e):[];F("computed.order-resolver",()=>{Bt=null;},105);var Wn=()=>H(Oe(De)),Mr=()=>Wn().computedEntries,_n=()=>Wn().computedDependents;var zn=e=>Object.prototype.hasOwnProperty.call(Mr(),e);var ii=e=>{let t=Mr(),r=_n(),n=new Set,o=[...e];for(;o.length>0;){let l=o.shift(),S=r[l];if(S)for(let y of S)n.has(y)||(n.add(y),o.push(y));}if(n.size===0)return [];let s=l=>{let S=t[l];if(S)for(let y of S.deps)t[y]&&(n.has(y)||(n.add(y),s(y)));};Array.from(n).forEach(l=>s(l));let i=new Map,a=new Map;for(let l of n){let S=t[l];if(!S)continue;let y=0;for(let h of S.deps)n.has(h)&&(y++,a.has(h)||a.set(h,[]),a.get(h).push(l));i.set(l,y);}let u=[];for(let[l,S]of i)S===0&&u.push(l);u.sort();let c=[];for(;u.length>0;){let l=u.shift();c.push(l);let S=a.get(l)??[];for(let y of S){let h=(i.get(y)??1)-1;if(i.set(y,h),h===0){let x=u.findIndex(f=>f>y);x===-1?u.push(y):u.splice(x,0,y);}}}return c};In(ii);var Fr=e=>{let t=Mr()[e];if(!t)return null;let r=_n()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Ar=new Set,ai=()=>{Ar.clear();};F("options.legacy-warnings",ai,30);var qt=(()=>{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"}})(),Er=e=>{try{return typeof window>"u"?qt:e==="session"||e==="sessionStorage"?window.sessionStorage??qt:window.localStorage??qt}catch{return qt}},Rt=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Je=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Ln=e=>{try{let t=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`,r=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`;return e(t)!==t?!1:e(r)===r}catch{return false}},ci=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Hn=e=>{try{e[ci]=!0;}catch{}return e},ui={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"},li=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Hn(S=>S),decrypt:Hn(S=>S),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Er("localStorage"),...r};if(typeof e=="string")return {driver:Er(e),...r};let n=e.encrypt||r.encrypt,o=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,a=e.sensitiveData===true,u=e.allowPlaintext===true,c=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,l=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(a&&Ln(n)&&!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||Er("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:n,decrypt:o,encryptAsync:s,decryptAsync:i,allowPlaintext:u,sensitiveData:a,maxSize:c,checksum:l,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Bn=e=>{if(!Rt(e))return [];let t=[];return Object.entries(ui).forEach(([r,n])=>{Je(e,r)&&(Ar.has(r)||(Ar.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},qn=(e={},t,r="deep")=>{let n=e.scope??"request",o=e.lazy===true,s=e.pathCreate===true,i=Rt(e.lifecycle)?e.lifecycle:void 0,a=Rt(e.persist)?e.persist:void 0,u=Rt(e.devtools)?e.devtools:void 0,c=e.validate??e.validator??e.schema,l=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",S=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,y=Rt(e.features)?{...e.features}:void 0,h=Je(e,"persist"),x=Je(e,"sync"),f=Je(e,"devtools")||Je(e,"historyLimit")||Je(e,"redactor"),g=n==="global"?true:e.allowSSRGlobalStore??false,{persist:p=false,devtools:C=false,onError:T,sync:E}=e;if(a?.sensitiveData===true){let A=a.encrypt,b=a.encryptAsync;if((!A||Ln(A))&&!b)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:n,lazy:o,pathCreate:s,persist:n==="temp"&&!h?null:li(p,t),devtools:n==="temp"&&!f?false:typeof C=="boolean"?C:u?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:T,validate:c,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:n==="temp"&&!f?void 0:u?.redactor??e.redactor,historyLimit:n==="temp"&&!f?0:u?.historyLimit??e.historyLimit??50,sync:n==="temp"&&!x?false:E??false,features:y,allowSSRGlobalStore:g,snapshot:l,snapshotSafety:S,explicitPersist:h,explicitSync:x,explicitDevtools:f}};var Kt=new Set,Un=e=>e?Kt.has(e):Kt.size>0,Gn=e=>{e&&Kt.add(e);},di=()=>{Kt.clear();};F("ssr.warnings",di,60);var Kn=new Set,fi=e=>{let t=yn();return !t||e.includes("::")?e:(v()&&!Kn.has(e)&&(Kn.add(e),d(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},_e=e=>fi(typeof e=="string"?e:e.name),Yn=e=>ie(e)&&!Qn(e)?true:(br(e,Object.keys(Ct)),false),Xn=(e,t,r={})=>{We(t,{...r,onError:j[e]?.options?.onError});},Jn=(e,t,r={})=>{We(e,{...r,onError:t});},vt=(e,t,r="dev")=>{Xn(e,t,{severity:"warn",visibility:r});},pi=(e,t,r="dev")=>{Jn(e,t,{severity:"warn",visibility:r});},xe=(e,t)=>Xn(e,t,{severity:"critical",visibility:"always"}),kt=(e,t)=>Jn(e,t,{severity:"critical",visibility:"always"}),Ut=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
13
- Import "stroid/${t}" before calling createStore("${e}", ...).`;if(pi(n,r,"always"),k().strictMissingFeatures)throw new Error(n)};var Zn=new WeakMap,eo=new WeakMap,gi=500,Si="",Tt=e=>{let t=Zn.get(e);return t||(t=new Map,Zn.set(e,t)),t},Nr=e=>{let t=eo.get(e);return t||(t=new Map,eo.set(e,t)),t},yi=(e,t)=>{let r=Nr(e),n=r.get(t);return n||(n=new Map,r.set(t,n)),n},mi=()=>{let e=k().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?gi:Math.max(0,Math.floor(e))},to=(e,t,r,n)=>{if(n<=0){e.has(t)&&e.delete(t);return}for(e.has(t)&&e.delete(t),e.set(t,r);e.size>n;){let o=e.keys().next().value;if(!o)break;let s=e.get(o);e.delete(o),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=Tt(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)=>(Tt(P())[t]=r,true)});var ro=(e,t,r,n)=>{let o=j[e];if(!o)return {ok:true};let s=Ge(r);if(s.length===0)return {ok:true};let i=Fe(n),a=mi(),u=P(),c=Tt(u),l=yi(u,e),S=s.join(Si),y=c.get(e);y||(y={children:new Map},c.set(e,y));let h=y;for(let T of s){let E=h.children.get(T);E||(E={children:new Map},h.children.set(T,E)),h=E;}let x=h.verdicts?.get(i);if(x){let T=`${S}|${i}`;return to(l,T,{node:h,type:i},a),x}let f=o.options?.pathCreate===true,g=t,p={ok:true};for(let T=0;T<s.length;T++){let E=s[T],A=T===s.length-1;if(g==null){let w=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,T).join(".")||"root"}" is ${g===null?"null":"undefined"}.`;L(w),p={ok:false,reason:w};break}if(typeof g!="object"){let w=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,T).join(".")||"root"}" is not an object.`;L(w),p={ok:false,reason:w};break}if(Array.isArray(g)){let w=Number(E);if(!Number.isInteger(w)||w<0){let M=`Path "${s.join(".")}" targets non-numeric index "${E}" on an array in "${e}".`;L(M),p={ok:false,reason:M};break}let B=g;if(w>=B.length){let M=`Path "${s.join(".")}" is invalid for "${e}" - index ${w} is out of bounds (length ${B.length}).`;L(M),p={ok:false,reason:M};break}if(A){let M=B[w];if(M!=null){let q=Fe(M);if(q!==i){let ke=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${q}, received ${i}.`;L(ke),p={ok:false,reason:ke};break}}p={ok:true};break}g=B[w];continue}if(!Object.prototype.hasOwnProperty.call(g,E)){if(f&&A){p={ok:true};break}let w=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${E}" at "${s.slice(0,T).join(".")||"root"}".`;L(w),p={ok:false,reason:w};break}if(A){let w=g[E];if(w!=null){let B=Fe(w);if(B!==i){let M=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${B}, received ${i}.`;L(M),p={ok:false,reason:M};break}}p={ok:true};break}g=g[E];}h.verdicts||(h.verdicts=new Map);let C=h.verdicts.has(i);if(h.verdicts.set(i,p),!C){let T=`${S}|${i}`;to(l,T,{node:h,type:i},a);}return p},ze=(e,t,r,n)=>{try{return n?.reuseInput&&Rr(t)?{ok:!0,value:t}:{ok:!0,value:je(t)}}catch(o){let s=`Sanitize failed for "${e}": ${o?.message??o}`;return se(j[e]?.options?.onError,`onError(${e})`,s),se(r,`onError(${e})`,s),d(s),{ok:false}}},hi=(e,t)=>{let r=new Set,n=j[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},Pr=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let o=hi(e,n),s=(a,u)=>{o.forEach(c=>se(c,`onError(${e})`,a)),u==="critical"?L(a):d(a);};if(typeof r=="function")try{let a=r(t);return a===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:a===!0?t:a}}catch(a){return s(`Validation for "${e}" failed: ${a?.message??a}`,"critical"),{ok:false}}let i=xr(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Mt=(e,t,r,n,o)=>{let s=ze(e,t,n,o);if(!s.ok)return {ok:false};let i=Pr(e,s.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},Re=e=>{let t=P();Tt(t).delete(e),Nr(t).delete(e);},bi=()=>{let e=P();Tt(e).clear(),Nr(e).clear();};F("validation.path-cache",bi,50);no(Re);var Gt=(e,t=P())=>{if((D()?Xe(e):{has:false}).has||t.stores[e]!==void 0)return true;let n=t.initialFactories[e];if(!n)return true;try{let o=n(),s=ze(e,o,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=Mt(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(D()){let u=a.value;zt(e,u),_t(()=>{ge(e,u,t),t.initialStates[e]=O(u),delete t.initialFactories[e],Re(e);});}else ge(e,a.value,t),t.initialStates[e]=O(a.value),delete t.initialFactories[e],Re(e);return !0}catch(o){return xe(e,`Lazy initializer for "${e}" failed: ${o?.message??o}`),false}};var oo=new WeakMap,so=e=>{let t=oo.get(e);return t||(t=new Map,oo.set(e,t)),t},wi=()=>{so(P()).clear();};F("features.contexts",wi,100);var io=e=>{let t=P(),r=so(t),n=r.get(e);if(n)return n;let o=j[e];if(!o)return d(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:o.options,getMeta:()=>j[e],getStoreValue:()=>Ct[e],getAllStores:()=>Ct,getInitialState:()=>po[e],hasStore:()=>ie(e),setStoreValue:i=>{ge(e,i);},applyFeatureState:(i,a)=>{go(e,i,a),Re(e);},notify:()=>{},reportStoreError:i=>{xe(e,i);},warn:d,warnAlways:ne,log:oe,hashState:mt,deepClone:O,sanitize:je,validate:i=>Pr(e,i,j[e]?.options?.validate),isDev:v};return r.set(e,s),s},ao=(e,t)=>{let r=k();if(!r.strictMissingFeatures&&!r.assertRuntime)return;let n=[];if(typeof t.getMeta!="function"&&n.push("getMeta"),typeof t.getStoreValue!="function"&&n.push("getStoreValue"),typeof t.getAllStores!="function"&&n.push("getAllStores"),typeof t.getInitialState!="function"&&n.push("getInitialState"),typeof t.hasStore!="function"&&n.push("hasStore"),typeof t.setStoreValue!="function"&&n.push("setStoreValue"),typeof t.applyFeatureState!="function"&&n.push("applyFeatureState"),typeof t.notify!="function"&&n.push("notify"),typeof t.reportStoreError!="function"&&n.push("reportStoreError"),typeof t.warn!="function"&&n.push("warn"),typeof t.warnAlways!="function"&&n.push("warnAlways"),typeof t.log!="function"&&n.push("log"),typeof t.hashState!="function"&&n.push("hashState"),typeof t.deepClone!="function"&&n.push("deepClone"),typeof t.sanitize!="function"&&n.push("sanitize"),typeof t.validate!="function"&&n.push("validate"),typeof t.isDev!="function"&&n.push("isDev"),n.length===0)return;let o=`Feature hook context missing fields for "${e}": ${n.join(", ")}.`;if(xe(e,o),r.assertRuntime)throw new Error(o)},co=(e,t)=>{Xt();let r=io(e);r&&(r.notify=()=>t(e),ao(e,r),pe.forEach(n=>{n.onStoreCreate?.(r);}));},uo=(e,t,r,n,o)=>{Xt();let s=io(e);if(!s)return;s.notify=()=>o(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:n});ao(e,i),pe.forEach(a=>{a.onStoreWrite?.(i);});};var lo=(e,t)=>jn({name:e,payload:t,middlewares:(()=>{let r=j[e]?.options?.middleware||[],n=k().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{vt(e,r,n);},warn:d}),Yt=(e,t,r,n)=>Lt({name:e,label:t,fn:r,args:n,reportIssue:(o,s)=>{vt(e,o,s);}}),fo=(e,t)=>{let r={...t};return r.persist&&!Vt("persist")&&(r.explicitPersist&&Ut(e,"persist",r.onError),r.persist=null),r.sync&&!Vt("sync")&&(r.explicitSync&&Ut(e,"sync",r.onError),r.sync=false),Vt("devtools")||(r.explicitDevtools&&Ut(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var Jt=null,So=e=>(Jt=e,()=>{Jt===e&&(Jt=null);}),Qe=e=>{Jt?.(e);};var Qt=new Set,xi=e=>{Qt.clear();};F("store-create.ssr-global-warned",()=>xi(),65);function Dr(e,t,r={}){if(D()){let b=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;kt(b,r.onError),G(b);return}if(!vr(e)){kt(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Ke(t)){kt(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&v()&&d(`createStore("${e}") received an undefined initial value. This can be indistinguishable from a missing store in some consumers; consider null or an explicit shape if that is intentional.`),Bn(r).forEach(b=>{d(b);});let o=fo(e,qn(r,e,k().defaultSnapshotMode));if(o.scope==="temp"&&r.persist){let b=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;se(o.onError,`onError(${e})`,b),v()||ne(b),I(b);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",u=o.allowSSRGlobalStore??false,c=P(),l=c.stores,S=c.subscribers,y=c.initialStates,h=c.initialFactories,x=c.metaEntries,f=c.scope==="request";if(a&&!u&&!f){let b=`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.`;kt(b,r.onError);return}if(a&&u&&!f&&!Qt.has(e)&&(Qt.add(e),ne(`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.`)),ie(e,c)){let b=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return vt(e,b),{name:e}}s&&!u&&!f&&!Un(e)&&v()&&(Gn(e),d(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let g=ze(e,t,o.onError);if(!g.ok)return;let p=g.value,C=o.lazy===true&&typeof t=="function",T=(S[e]?.size??0)>0;if(C)l[e]=void 0,h[e]=t;else {let b=Mt(e,p,o.validate,o.onError);if(!b.ok)return;ge(e,b.value,c),y[e]=O(b.value);}let E=Date.now(),A=new Date(E).toISOString();return x[e]={createdAt:A,updatedAt:A,updatedAtMs:E,updateCount:0,version:o.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0,resetCount:0,totalResetMs:0,lastResetMs:0},options:o,readCount:0,lastReadAt:null,lastReadAtMs:null,lastCorrelationId:null,lastCorrelationAt:null,lastCorrelationAtMs:null,lastTraceContext:null},Re(e),co(e,Qe),Yt(e,"onCreate",x[e].options.onCreate,[p]),yo(c,{type:"created",name:e,isGlobal:o.scope==="global",isTemp:o.scope==="temp"}),T&&Qe(e),oe(`Store "${e}" created -> ${JSON.stringify(p)}`),{name:e}}var Ft=null,Zt=null;var Ri=()=>{Ft=null,Zt=null;};F("write-context.runner",Ri,121);var er=()=>Zt?.get()??Ft,Ze=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(Zt)return Zt.run(e,t);let r=Ft;Ft=e;try{return t()}finally{Ft=r;}};var vi=32,Or=new Set;F("store-write.slow-mutator-warned",()=>Or.clear(),65);var ki=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var ho=(e,t)=>{v()&&(t<vi||Or.has(e)||(Or.add(e),d(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},bo=e=>e??er(),mo=(e,{name:t,prev:r,next:n,action:o,hookLabel:s,logMessage:i,context:a})=>{let u=e.metaEntries;ge(t,n,e),Re(t);let c=Date.now();u[t].updatedAt=new Date(c).toISOString(),u[t].updatedAtMs=c;let l=a??er();l&&(l.correlationId||l.traceContext)?(u[t].lastCorrelationId=l.correlationId??null,u[t].lastCorrelationAt=new Date(c).toISOString(),u[t].lastCorrelationAtMs=c,u[t].lastTraceContext=l.traceContext??null):(u[t].lastCorrelationId=null,u[t].lastCorrelationAt=null,u[t].lastCorrelationAtMs=null,u[t].lastTraceContext=null),ki(u[t]),uo(t,o,r,n,Qe),Yt(t,s,u[t].options[s],[r,n]),Qe(t),oe(i);},wo=(e,t)=>{let r=t.context??er();if(D()){zt(t.name,t.next),_t(()=>mo(e,{...t,context:r}));return}mo(e,{...t,context:r});};function et(e,t,r){return xo(e,t,r)}var xo=(e,t,r,n)=>{let o=_e(e),s=P(),i=s.metaEntries;if(!Gt(o,s))return {ok:false,reason:"validate"};if(!ie(o,s)){let g=`setStore("${o}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return xe(o,g),D()&&G(g),{ok:false,reason:"not-found"}}let a,u=D()?Xe(o):{has:false,value:void 0},c=u.has?u.value:He(o,s),l=typeof t=="function"&&r===void 0;if(l){let g=v()?Date.now():0;try{let p=k().mutatorProduce,C=!1,T,E=b=>{let w=t(b);return w!==void 0&&(C=!0,T=w),w},A=p?p(c,E):(()=>{let b=O(c);return E(b),b})();if(C&&k().strictMutatorReturns){let b=`setStore("${o}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return xe(o,b),D()&&G(b),{ok:!1,reason:"validate"}}C&&v()&&!k().strictMutatorReturns&&d(`setStore("${o}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=C&&!k().strictMutatorReturns?T:A;}catch(p){return xe(o,`Mutator for "${o}" failed: ${p?.message??p}`),D()&&G(p),{ok:false,reason:"validate"}}finally{g&&ho(o,Date.now()-g);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!Ke(t))return D()&&G(`setStore("${o}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof c!="object"||c===null||Array.isArray(c))return I(`setStore("${o}", data) only merges into object stores.
16
- Use setStore("${o}", "path", value) or recreate the store with an object shape.`),D()&&G(`setStore("${o}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let g=ze(o,t);if(!g.ok)return D()&&G(`setStore("${o}") failed sanitize`),{ok:false,reason:"validate"};a={...c,...g.value};}else if(typeof t=="string"||Array.isArray(t)){if(!bt(t))return D()&&G(`setStore("${o}") received invalid path`),{ok:false,reason:"invalid-args"};let g=ze(o,r);if(!g.ok)return D()&&G(`setStore("${o}") failed sanitize`),{ok:false,reason:"validate"};let p=g.value,C=ro(o,c,t,p);if(!C.ok)return se(i[o]?.options?.onError,`onError(${o})`,C.reason??`Invalid path for "${o}".`),D()&&G(C.reason),{ok:false,reason:"path"};a=Tr(c,t,p);}else {let g=`setStore("${o}") - invalid arguments.
17
- Usage:
18
- setStore("${o}", "field", value)
19
- setStore("${o}", "nested.field", value)
20
- setStore("${o}", { field: value })
21
- setStore(storeDef, draft => { draft.field = value })
22
- replaceStore("${o}", value) // full-store replace`;return I(g),se(i[o]?.options?.onError,`onError(${o})`,g),D()&&G(g),{ok:false,reason:"invalid-args"}}if(!Ke(a))return D()&&G(`setStore("${o}") produced invalid data`),{ok:false,reason:"validate"};let S=i[o]?.options?.validate,y=bo(n),h=lo(o,{action:"set",prev:c,next:a,path:t,correlationId:y?.correlationId,traceContext:y?.traceContext});if(h===Ht)return D()&&G(`setStore("${o}") aborted by middleware`),{ok:false,reason:"middleware"};let f=Mt(o,h,S,void 0,l&&h===a?{reuseInput:true}:void 0);if(!f.ok)return D()&&G(`setStore("${o}") failed validation`),{ok:false,reason:"validate"};try{if(ht(c,f.value))return {ok:!0}}catch{}return wo(s,{name:o,prev:c,next:f.value,action:"set",hookLabel:"onSet",logMessage:`Store "${o}" updated`,context:y}),{ok:true}},tt=(e,t,r,n)=>xo(e,t,r,n);var Ci=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Ro=(e,t)=>t==="ref"?e:t==="shallow"?we(e):O(e);function tr(e,t){let r=_e(e);if(!Yn(r))return null;let n=P();if(!Gt(r,n))return null;rr(r,n);let o=He(r,n),s=Ci(n.metaEntries[r],k().defaultSnapshotMode);return o===null||typeof o!="object"?o:Ro(o,s);}var ue=e=>ie(e);var nr=e=>({name:e});var Ti=()=>P().computedCleanups,vo=new WeakMap;var Mi=e=>{let t=vo.get(e);return t||(t=new Map,vo.set(e,t)),t};var ko=e=>{let t=Ti(),r=t.get(e);if(!r){v()&&d(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Co=(e,t=P())=>Mi(t).get(e)?.autoDispose===true;var rt=new Map,To=(e,t)=>{let r=rt.get(e);return r||(r=new Set,rt.set(e,r)),r.add(t),()=>{let n=rt.get(e);n&&(n.delete(t),n.size===0&&rt.delete(e));}},Vr=e=>{let t=rt.get(e);return !!t&&t.size>0},Et=(e,t,r)=>{let n=rt.get(e);!n||n.size===0||n.forEach(o=>{try{o(t,r);}catch(s){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,s);}});};var Mo=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,a=e.featureRuntimes,u=e.deletingStores,c=(f,g)=>{We(g,{onError:s[f]?.options?.onError,severity:"warn",visibility:"dev"});},l=({name:f,prev:g,options:p,initialState:C,getMeta:T,getStoreValue:E,hasStore:A})=>({name:f,options:p,prev:g,getMeta:T,getStoreValue:E,getAllStores:()=>t,getInitialState:()=>C,hasStore:A,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:b=>{We(b,{onError:p.onError,severity:"warn",visibility:"dev"});},warn:d,warnAlways:ne,log:oe,hashState:mt,deepClone:O,sanitize:je,validate:()=>({ok:true,value:g}),isDev:v}),S=({name:f,prev:g,options:p,initialState:C,phase:T})=>{let E=l({name:f,prev:g,options:p,initialState:C,getMeta:()=>s[f],getStoreValue:()=>t[f],hasStore:()=>Ve(e,f)}),A=l({name:f,prev:g,options:p,initialState:C,getMeta:()=>{},getStoreValue:()=>g,hasStore:()=>false});qe().forEach(b=>{let w=a.get(b);T==="before"?w?.beforeStoreDelete?.(E):w?.afterStoreDelete?.(A);});},y=f=>{if(!Ve(e,f))return;let g=t[f],p=s[f].options,C=n[f],T=r[f];u.add(f);try{T?.forEach(b=>{try{b(null);}catch(w){d(`Subscriber for "${f}" threw during delete: ${w?.message??w}`);}}),Lt({name:f,label:"onDelete",fn:p.onDelete,args:[g],reportIssue:(b,w)=>{We(b,{onError:p.onError,severity:"warn",visibility:w});}}),S({name:f,prev:g,options:p,initialState:C,phase:"before"}),delete t[f],delete r[f],delete n[f],delete o[f],delete s[f],delete i[f],zn(f)&&ko(f);let A=e.computedDependents[f];if(A)for(let b of [...A]){let w=Fr(b);if(w&&Co(b,e)&&w.deps.every(B=>!Ve(e,B))){y(b);continue}d(`[stroid] source store "${f}" was deleted. Computed store "${b}" depends on it and will return stale data. Call deleteComputed("${b}") to clean up.`);}S({name:f,prev:g,options:p,initialState:C,phase:"after"}),Et("afterStoreDelete",f,{type:"afterStoreDelete",prev:g}),It(e,{type:"deleted",name:f}),oe(`Store "${f}" deleted`);}finally{u.delete(f);}};return {deleteExistingStore:y,clearAllStores:()=>{let f=[],p=0,C=Number.POSITIVE_INFINITY;for(;p<20;){let E=Object.keys(t);if(E.length===0)break;E.forEach(b=>{Ve(e,b)&&(y(b),f.push(b));}),p+=1;let A=Object.keys(t).length;if(A===0||A>=C)break;C=A;}let T=Object.keys(t).length;return T>0?d(`clearAllStores stopped after ${p} pass${p===1?"":"es"}; ${T} store(s) still registered (likely recreated during deletion).`):oe(`All stores cleared (${f.length} stores removed)`),f},clearStores:f=>{let g=Object.keys(t).filter(p=>f?f.endsWith("*")?p.startsWith(f.slice(0,-1)):p===f:true);return g.forEach(p=>y(p)),g},reportStoreError:c}};var jr=De,Eo=Oe(jr),Ao=null,J=()=>{let e=H(Eo);return gr(e),e};var P=()=>J();var yo=(e,t)=>{It(e,t);};function no(e){Ao=e;}var nt=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}}}),Fi=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 o=n[r];return typeof o=="function"?o.bind(n):o},set:(t,r,n)=>(e()[r]=n,true)}),Ei=e=>new Proxy({},{get:(t,r)=>{let n=e(),o=n[r];return typeof o=="function"?o.bind(n):o},set:(t,r,n)=>(e()[r]=n,true)}),Ct=nt(()=>J().stores);nt(()=>J().subscribers);var po=nt(()=>J().initialStates);nt(()=>J().initialFactories);var j=nt(()=>J().metaEntries);nt(()=>J().snapshotCache);var pe=Fi(()=>J().featureRuntimes),Fo=new WeakMap,Ai=e=>{let t=Fo.get(e);return t||(t=Mo(e),Fo.set(e,t)),t};Ei(()=>Ai(J()));var Ni=e=>{let t=pe.get(e);if(t)return t;let r=jt(e);if(!r)return;let n=r();return pe.set(e,n),n},Xt=()=>{qe().forEach(e=>{Ni(e);});};Xt();var ie=(e,t)=>Ve(t??J(),e),He=(e,t=J())=>{if(D()){let n=Xe(e);if(n.has)return n.value}let r=gt();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},ge=(e,t,r=J())=>{r.stores[e]=t;},go=(e,t,r=Date.now())=>{ge(e,t),j[e]&&(j[e].updatedAt=new Date(r).toISOString(),j[e].updatedAtMs=r,j[e].lastCorrelationId=null,j[e].lastCorrelationAt=null,j[e].lastCorrelationAtMs=null,j[e].lastTraceContext=null,j[e].updateCount>=Number.MAX_SAFE_INTEGER?j[e].updateCount=0:j[e].updateCount+=1,Ao?.(e));},rr=(e,t=J())=>{let r=t.metaEntries[e];if(!r)return;r.readCount=(r.readCount??0)+1;let n=Date.now();r.lastReadAtMs=n,r.lastReadAt=new Date(n).toISOString();},Pi=()=>{dn(J());},Di=()=>{pe.forEach(e=>{try{e.resetAll?.();}catch{}}),pe.clear();};F("features.reset",Di,10);F("registries.clear",Pi,20);F("registry.default",()=>{jr=De,Eo=Oe(jr);},115);var Qn=e=>ln(J(),e);var sr=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},ot=(e,t)=>{if(t==="ref"){if(!v())return e;try{return wt(e)}catch{return e}}if(t==="shallow"){let n=we(e);if(!v())return n;try{return wt(n)}catch{return n}}let r=O(e);if(!v())return r;try{return $t(r)}catch{return r}};var No=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:n}=e,o=k().flush,s=o.priorityStores||[],i=s.length?new Set(s):null;n.length=0,r.length=0;let a=new Set;if(i){for(let x of t)r.push(x),a.add(x);for(let x of s)a.has(x)&&n.push(x);for(let x of r)i.has(x)||n.push(x);}else for(let x of t)r.push(x),a.add(x),n.push(x);t.clear();let u=$n(n),c=new Set(n);for(let x of u)c.has(x)||(n.push(x),c.add(x));let l=Number.isFinite(o.chunkSize)&&o.chunkSize>0?o.chunkSize:Number.POSITIVE_INFINITY,S=o.chunkDelayMs,y=l===Number.POSITIVE_INFINITY&&S===0;return {names:n,sliceSize:l,chunkDelayMs:S,runInline:y,prioritySet:i}};var Ir=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}),$r=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),Wr=(e,t)=>{e&&(e.metrics=t);};var At=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Po=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let n=()=>K(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(n):Promise.resolve().then(n);};var Do=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,n)=>{let o=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:u,prioritySet:c}=t,S=e.stores,y=e.subscribers,h=e.metaEntries,x=e.snapshotCache,f=k().defaultSnapshotMode,g=R=>sr(h[R],f),p=R=>S[R],C=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),T=Vr("beforeFlush"),E=Vr("afterFlush"),A=R=>{T&&Et("beforeFlush",R,{type:"beforeFlush"});},b=(R,W)=>{E&&Et("afterFlush",R,{type:"afterFlush",elapsedMs:W});},w=R=>{let W=h[R];if(!W)return null;let V=W.lastCorrelationId??void 0,m=W.lastTraceContext??void 0;return !V&&!m?null:{correlationId:V,traceContext:m}},B=()=>{n();};if(u){for(let R of s){let W=y[R];if(!W||W.size===0)continue;let V=h[R]?.updateCount??0,m=g(R),ye=p(R),Y=x[R],_=Y&&Y.source===ye&&Y.mode===m?Y.snapshot:(()=>{let U=ot(ye,m);return x[R]={version:r,snapshot:U,source:ye,mode:m},U})(),Q=Ir(h[R]?.metrics);A(R);let de=C(),z=Array.from(W),Pe=w(R),fe=()=>{for(let U of z)try{U(_);}catch(re){let ae=h[R]?.options?.snapshotSafety??"warn";if(v()&&(m==="ref"||m==="shallow")&&Do(re)){if(ae==="throw")throw re;if(ae==="auto-clone")try{let Ce=O(_);d(`Snapshot mutation detected for "${R}". Delivered a cloned snapshot to the subscriber.`);try{U(Ce);}catch(pt){d(`Subscriber for "${R}" threw on cloned snapshot: ${pt?.message??pt}`);}continue}catch{}d(`Snapshot mutation detected for "${R}": ${re?.message??re}`);continue}d(`Subscriber for "${R}" threw: ${re?.message??re}`);}};Pe?Ze(Pe,fe):fe();let te=C()-de;b(R,te),$r(Q,te),Wr(h[R],Q),(h[R]?.updateCount??V)!==V&&o.pendingNotifications.add(R);}B();return}let M=R=>{let W=[];for(let V of s){if(R&&!R(V))continue;let m=y[V];if(!m||m.size===0)continue;let ye=h[V]?.updateCount??0,Y=g(V),_=p(V),Q=x[V],de=Q&&Q.source===_&&Q.mode===Y?Q.snapshot:(()=>{let z=ot(_,Y);return x[V]={version:r,snapshot:z,source:_,mode:Y},z})();W.push({name:V,snapshot:de,version:ye,subscribers:Array.from(m),subscriberSet:new Set(m),notified:new Set,metrics:Ir(h[V]?.metrics),totalMs:0,beforeHooked:false});}return W},q=c?M(R=>c.has(R)):[],ke=M(R=>!c||!c.has(R)),Ne=(R,W)=>{let V=()=>{if(R.length===0){W();return}let m=R.shift();if((h[m.name]?.updateCount??m.version)!==m.version){if(o.pendingNotifications.add(m.name),R.length===0){W();return}At(V,a);return}let Y=()=>{let X=y[m.name];if(!(!X||X.size===0))for(let U of X)m.subscriberSet.has(U)||(m.subscriberSet.add(U),m.subscribers.push(U));};Y();let _=m.subscribers;if(_.length===0){if(R.length===0){W();return}At(V,a);return}m.beforeHooked||(m.beforeHooked=true,A(m.name));let Q=C(),de=0,z=false,Pe=w(m.name),fe=()=>{for(let X=0;X<_.length&&de<i;X+=1){let U=_[X];if(m.notified.has(U))continue;m.notified.add(U);try{U(m.snapshot);}catch(ae){let Le=h[m.name]?.options?.snapshotSafety??"warn",Ce=g(m.name);if(v()&&(Ce==="ref"||Ce==="shallow")&&Do(ae)){if(Le==="throw")throw ae;if(Le==="auto-clone")try{let N=O(m.snapshot);d(`Snapshot mutation detected for "${m.name}". Delivered a cloned snapshot to the subscriber.`);try{U(N);}catch(me){d(`Subscriber for "${m.name}" threw on cloned snapshot: ${me?.message??me}`);}if(m.notified.add(U),de+=1,(h[m.name]?.updateCount??m.version)!==m.version){z=!0,o.pendingNotifications.add(m.name);break}continue}catch{}d(`Snapshot mutation detected for "${m.name}": ${ae?.message??ae}`);continue}d(`Subscriber for "${m.name}" threw: ${ae?.message??ae}`);}if(de+=1,(h[m.name]?.updateCount??m.version)!==m.version){z=true,o.pendingNotifications.add(m.name);break}}};if(Pe?Ze(Pe,fe):fe(),m.totalMs+=C()-Q,z){if(R.length===0){W();return}At(V,a);return}Y();let te=false;for(let X of _)if(!m.notified.has(X)){te=true;break}if(te?R.push(m):($r(m.metrics,m.totalMs),Wr(h[m.name],m.metrics),b(m.name,m.totalMs)),R.length===0){W();return}At(V,a);};V();};q.length>0?Ne(q,()=>Ne(ke,B)):Ne(ke,B);};var Oi=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,n=No(t);Oo(e,n,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&_r(e);});},_r=e=>{Po(e,Oi);};var ir=(e,t)=>{if(!(!e||typeof e!="object")){if(t==="ref"||t==="shallow"){wt(e);return}t==="deep"&&$t(e);}},Vi=e=>{let t=P(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&_r(t);};So(Vi);var or=(e,t)=>{let n=P().subscribers;return n[e]||(n[e]=new Set),n[e].add(t),()=>{n[e]?.delete(t),n[e]?.size===0&&delete n[e];}};var st=e=>{if(!ie(e))return null;let t=P();rr(e,t);let r=sr(t.metaEntries[e],k().defaultSnapshotMode);if(D()){let a=t.transaction.snapshotCache,u=He(e);if(u===void 0)return null;let c=a.get(e);if(c&&c.source===u&&c.mode===r){let S=c.snapshot;return ir(S,r),S}let l=ot(u,r);return a.set(e,{source:u,snapshot:l,mode:r}),ir(l,r),l}let n=t.notify.flushId,o=He(e,t),s=t.snapshotCache[e];if(s&&s.source===o&&s.mode===r){let a=s.snapshot;return ir(a,r),a}let i=ot(o,r);return ir(i,r),t.snapshotCache[e]={version:n,snapshot:i,source:o,mode:r},i};var ji=()=>{let e=P().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};F("notify.reset",ji,40);var zr=e=>{let t=P();return Object.prototype.hasOwnProperty.call(t.stores,e)};var Vo=(e,t)=>{let n=P().subscribers;return n[e]||(n[e]=new Set),n[e].add(t),()=>{n[e]?.delete(t),n[e]?.size===0&&delete n[e];}};var Hr=(e,t,r=Object.is,n)=>{if(typeof t!="function"||typeof n!="function")return d(`subscribeWithSelector("${e}") requires selector and listener functions.`),()=>{};let o=false,s,i=()=>{let c=j[e]?.options?.snapshot;return c==="shallow"||c==="ref"?c:"deep"},a=c=>{let l=c!==void 0?c:st(e);if(l===null||typeof l!="object")return l;let S=i();return S==="ref"?l:S==="shallow"?we(l):O(l)};return zr(e)&&(s=t(a()),o=true),Vo(e,c=>{if(c===null||!zr(e)){o=false,s=void 0;return}let l=t(a(c));if(!o){let y=s;o=true,s=l,n(l,y);return}if(!r(l,s)){let y=s;s=l,n(l,y);}})};var jo=createContext(null),_i=({value:e,children:t})=>Ii.createElement(jo.Provider,{value:e},t),Ae=()=>useContext(jo);var Lr=new Set,Br=new Set,qr=false,Io=e=>Lr.has(e),$o=e=>{e&&Lr.add(e);},Wo=e=>Br.has(e),_o=e=>{e&&Br.add(e);},zi=()=>{Lr.clear();},Hi=()=>{Br.clear();},zo=()=>qr,Ho=()=>{qr=true;},Li=()=>{qr=false;};F("hooks.broad-warning",zi,70);F("hooks.missing-warning",Hi,80);F("hooks.loose-warning",Li,90);var qo=(e,t)=>t?Ye(e,t)??null:e,Ko=()=>({hasValue:false,storeName:"",snapshot:void 0,selector:void 0,value:null}),Uo=(e,t,r,n,o)=>{if(t==null||!r.current)return o.current={hasValue:true,storeName:e,snapshot:t,selector:r.current,value:null},null;let s=r.current,i=o.current;if(i.hasValue&&i.storeName===e&&i.snapshot===t&&i.selector===s)return i.value;let a=s(t);return i.hasValue&&i.storeName===e&&n.current(a,i.value)?(i.snapshot=t,i.selector=s,i.value):(i.hasValue=true,i.storeName=e,i.snapshot=t,i.selector=s,i.value=a,a)},Kr=e=>{ue(e)||Wo(e)||(_o(e),d(`useStore("${e}") - store not found yet.
23
- Component will update automatically when createStore("${e}") is called.`));},Bi=(e,t,r)=>{t||r||Io(e)||($o(e),ne(`useStore("${e}") without a selector/path subscribes to the entire store and may re-render on every change.
24
- Prefer useSelector/useStoreField for better performance.`));},qi=(e,t)=>{v()&&(k().acknowledgeLooseTypes||zo()||typeof e=="string"&&(Ho(),d(`useStore("${t}") - store name is untyped.
1
+ import {a as a$1,b as b$1}from'../chunk-BW32TJGE.js';import {d as d$1,c}from'../chunk-6ELWGQ4Q.js';import {b}from'../chunk-X3JR32JD.js';import {a,w,k,d,j as j$1,na,oa,n,p,P,U as U$1,l,N,q,z}from'../chunk-FOQKGHPS.js';import'../chunk-KQCSFGHJ.js';import le,{createContext,useRef,useCallback,useSyncExternalStore,useEffect,useMemo,useContext}from'react';var G=createContext(null),fe=({value:e,children:t})=>le.createElement(G.Provider,{value:e},t),h=()=>useContext(G);var K=new Set,U=new Set,j=false,J=e=>K.has(e),Q=e=>{e&&K.add(e);},X=e=>U.has(e),Z=e=>{e&&U.add(e);},de=()=>{K.clear();},ge=()=>{U.clear();},ee=()=>j,te=()=>{j=true;},ye=()=>{j=false;};a("hooks.broad-warning",de,70);a("hooks.missing-warning",ge,80);a("hooks.loose-warning",ye,90);var ne=(e,t)=>t?z(e,t)??null:e,se=()=>({hasValue:false,storeName:"",snapshot:void 0,selector:void 0,value:null}),ae=(e,t,n,r,s)=>{if(t==null||!n.current)return s.current={hasValue:true,storeName:e,snapshot:t,selector:n.current,value:null},null;let a=n.current,o=s.current;if(o.hasValue&&o.storeName===e&&o.snapshot===t&&o.selector===a)return o.value;let i=a(t);return o.hasValue&&o.storeName===e&&r.current(i,o.value)?(o.snapshot=t,o.selector=a,o.value):(o.hasValue=true,o.storeName=e,o.snapshot=t,o.selector=a,o.value=i,i)},M=e=>{N(e)||X(e)||(Z(e),p(`useStore("${e}") - store not found yet.
2
+ Component will update automatically when createStore("${e}") is called.`));},he=(e,t,n)=>{t||n||J(e)||(Q(e),q(`useStore("${e}") without a selector/path subscribes to the entire store and may re-render on every change.
3
+ Prefer useSelector/useStoreField for better performance.`));},Re=(e,t)=>{n()&&(l().acknowledgeLooseTypes||ee()||typeof e=="string"&&(te(),p(`useStore("${t}") - store name is untyped.
25
4
  Extend StoreStateMap for full type safety and path inference.
26
- See: https://stroid.dev/docs/strict-mode`)));};function ar(e,t,r=Object.is){let n=typeof e=="string"?e:e.name,o=typeof t=="function",s=typeof t=="string"?t:void 0,i=o?t:void 0,a=Ae()??H(be()),u=useRef(i),c=useRef(r),l=useRef(Ko()),S=useRef(false),y=useRef(i);u.current=i,c.current=r;let h=useCallback(p=>Uo(n,p,u,c,l),[n]),x=useCallback(p=>K(a,()=>o?Hr(n,C=>u.current(C),(C,T)=>c.current(C,T),p):or(n,()=>p())),[a,n,o]),f=useCallback(()=>K(a,()=>{let p=st(n);return qi(e,n),Kr(n),Bi(n,o,s),o?h(p):qo(p,s)}),[a,n,o,s,h,e]),g=useSyncExternalStore(x,f,f);return useEffect(()=>{if(v()&&o){let p=y.current;p&&p!==i&&!S.current&&(S.current=true,d(`useStore("${n}") selector was recreated between renders. This can cause extra selector work and reduce selector cache reuse. Wrap the selector in useCallback or define it outside the component.`)),y.current=i;}},[n,o,s,i]),g}function cr(e,t){return ar(e,t)}function Ki(e,t,r=ht){let n=typeof e=="string"?e:e.name,o=Ae()??H(be()),s=useRef(t),i=useRef(r),a=useRef(Ko()),u=useRef(false),c=useRef(t);s.current=t,i.current=r;let l=useCallback(x=>Uo(n,x,s,i,a),[n]),S=useCallback(()=>K(o,()=>{let x=st(n);return Kr(n),l(x)}),[o,n,l]),y=useCallback(x=>K(o,()=>Hr(n,f=>s.current(f),(f,g)=>i.current(f,g),()=>x())),[o,n]),h=useSyncExternalStore(y,S,S);return useEffect(()=>{if(!v())return;let x=c.current;x&&x!==t&&!u.current&&(u.current=true,d(`useSelector("${n}") selector was recreated between renders. Wrap it in useCallback or define it outside the component to reduce selector churn and preserve selector cache reuse.`)),c.current=t;},[n,t]),h}function Ui(e,t){let r=typeof e=="string"?e:e.name,n=Ae()??H(be()),o=K(n,()=>{let s=st(r);return Kr(r),s});return o==null?null:qo(o,t)}function Ur(e){let t=typeof e=="string"?nr(e):e,r=ar(t);return {data:r?.data??null,loading:r?.loading??false,revalidating:r?.revalidating??false,error:r?.error??null,status:r?.status??"idle",isEmpty:r?.data==null&&!r?.loading&&!r?.error}}var Yo=e=>{let t=e?.target;return t?t.type==="checkbox"?!!t.checked:t.value:e};function Gi(e,t){let r=Ae()??H(be());if(typeof e=="string"){let a=t,u=cr(e,a),c=useCallback(l=>{let S=Yo(l);K(r,()=>{et(e,a,S);});},[r,e,a]);return {value:u,onChange:c}}let n=t,o=e,s=cr(o,n),i=useCallback(a=>{let u=Yo(a);K(r,()=>{et(o,n,u);});},[r,o,n]);return {value:s,onChange:i}}var ee=()=>H().async;var Xo=100,Gr=100,Yi=1e3,at=()=>ee().fetchRegistry,ve=()=>ee().inflight,ct=()=>ee().requestVersion,ut=()=>ee().cacheMeta,Yr=()=>ee().rateWindowStart,Xr=()=>ee().rateCount;var ur=()=>ee().storeCleanups,Zo=()=>ee().warnedOnce;var lr=()=>ee().asyncMetrics,Xi=e=>{let t=Zo(),r=t.get(e);return r||(r=new Set,t.set(e,r)),r},Ji=(e,t)=>{if(e.has(t)||(e.add(t),e.size<=Yi))return;let r=e.values().next().value;r!==void 0&&e.delete(r);},Nt=(e,t,r)=>{let n=Xi(e);n.has(t)||(Ji(n,t),r());},Jo=null,Qo=e=>{e&&Array.from(e).forEach(t=>{try{t();}catch{}});},Qi=e=>{let t=ur(),r=t[e];return r||(r=Object.create(null),t[e]=r),r},Zi=(e,t)=>{Object.keys(t).length===0&&delete ur()[e];},ea=(e,t)=>{Object.keys(e).forEach(r=>{Qo(e[r]),delete e[r];});},ta=e=>{let t=ur(),r=t[e];r&&(ea(r),delete t[e]);};var es=()=>{Jo||(Jo=To("afterStoreDelete",e=>{ta(e),ra(e);}));};var ts=(e,t)=>{if(!t)return false;let r=ut(),n=r[e];return n?n.expiresAt!==null&&n.expiresAt<=Date.now()?(delete r[e],false):Date.now()-n.timestamp<t:false},ra=e=>{let t=at(),r=ut(),n=ve(),o=ct(),s=Yr(),i=Xr(),a=Zo();delete t[e],a.get("noSignal")?.delete(e),a.get("shape")?.delete(e),a.get("autoCreate")?.delete(e),a.get("mutableResult")?.delete(e);let u=c=>c===e||c.startsWith(`${e}:`);Object.keys(n).forEach(c=>{u(c)&&delete n[c];}),Object.keys(o).forEach(c=>{u(c)&&delete o[c];}),Object.keys(r).forEach(c=>{u(c)&&delete r[c];}),Object.keys(s).forEach(c=>{u(c)&&delete s[c];}),Object.keys(i).forEach(c=>{u(c)&&delete i[c];});},rs=e=>{let t=`${e}:`,r=ut(),n=ct(),o=Object.entries(r).filter(([i,a])=>i!==e&&!i.startsWith(t)?false:a.expiresAt!==null&&a.expiresAt<=Date.now()?(delete r[i],false):true).sort((i,a)=>i[1].timestamp-a[1].timestamp);if(o.length<=Xo)return;let s=o.length-Xo;o.slice(0,s).forEach(([i])=>{delete r[i],delete n[i];});},ns=e=>{let t=`${e}:`,r=ve(),n=0;return Object.keys(r).forEach(o=>{(o===e||o.startsWith(t))&&(n+=1);}),n},os=(e,t,r="store")=>{es();let n=Qi(e),o=n[r];o||(o=new Set,n[r]=o),o.add(t);},ss=(e,t,r)=>{let o=ur()[e];if(!o)return;let s=i=>{let a=o[i];a&&(a.delete(t),a.size===0&&delete o[i]);};Object.keys(o).forEach(s),Zi(e,o);},is=e=>{es();};var as=10,na=10,Jr=3e4,oa=8,us=(e,t)=>new Promise(r=>{if(t?.aborted){r();return}let n=setTimeout(()=>{t?.removeEventListener("abort",o),r();},e),o=()=>{clearTimeout(n),t?.removeEventListener("abort",o),r();};t?.addEventListener("abort",o,{once:true});}),cs=(e,t,r,n)=>Number.isFinite(r)?r:(d(`fetchStore("${e}") received non-finite ${t}; using ${n}.`),n),ls=(e,t,r,n)=>{let o=Number.isFinite(t)?t:t>0?as:0,s=Math.min(as,Math.max(0,Math.trunc(o)));Number.isFinite(t)||d(`fetchStore("${e}") received non-finite retry; using ${s}.`);let i=Math.min(Jr,Math.max(na,cs(e,"retryDelay",r,400))),a=Math.min(oa,Math.max(1,cs(e,"retryBackoff",n,1.7)));return s!==t&&d(`fetchStore("${e}") clamped retry attempts to ${s}.`),i!==r&&d(`fetchStore("${e}") clamped retryDelay to ${i}ms.`),a!==n&&d(`fetchStore("${e}") clamped retryBackoff to ${a}.`),{retry:s,retryDelay:i,retryBackoff:a}};var ds=(e,t)=>!t||t==="none"||e===null||typeof e!="object"?e:t==="shallow"?we(e):O(e);var lt=(e,t,r,n)=>{if(typeof r=="function")try{r(n);}catch(o){d(`fetchStore("${e}") ${t} callback failed: ${o?.message??o}`);}},le=(e,t,r)=>k().strictAsyncUsageErrors?sa(e,t,r):(lt(e,"onError",r,t),v()?(I(t),null):(L(t),null)),sa=(e,t,r)=>{throw lt(e,"onError",r,t),v()?I(t):L(t),new Error(t)};var Pt=(e,t)=>(ct()[e]??0)===t,fs=e=>{let t=ct(),r=(t[e]??0)+1;return t[e]=r,r},ps=(e,t)=>{let r=ct();r[e]===t&&delete r[e];},gs=(e,t)=>{let r=ve();r[e]=t;},Ss=e=>{let t=ve();delete t[e];},ys=e=>!!ve()[e],ms=(e,t,r,n)=>{let o=ve()[t];if(o)return lr().dedupes+=1,r&&o.transform&&o.transform!==r?(le(e,`fetchStore("${e}") cannot dedupe callers that use different transform functions for cacheSlot "${t}".`,n),null):!r||o.transform===r?o.promise:o.raw.then(s=>r(s))};var dt=1e3,Qr=100,hs=(e,t)=>{t-e.ratePruneState.lastAt<dt||(e.ratePruneState.lastAt=t,Object.keys(e.rateWindowStart).forEach(r=>{t-(e.rateWindowStart[r]??0)>dt&&(delete e.rateWindowStart[r],delete e.rateCount[r]);}));},bs=e=>{hs(ee(),e);},ws=(e=dt)=>{let t=ee();t.ratePruneTimer||typeof setTimeout=="function"&&(t.ratePruneTimer=setTimeout(()=>{t.ratePruneTimer=null,hs(t,Date.now());},e));},xs=(e,t)=>{let r=Yr(),n=Xr(),o=r[e],s=n[e]??0;return o!==void 0&&t-o<dt?s>=Qr?true:(n[e]=s+1,false):(r[e]=t,n[e]=1,false)};var Rs=e=>{let t={},r=(e.method??"GET").toUpperCase(),n=e.body!==void 0&&e.body!==null;return e.method&&(t.method=r),e.headers?t.headers=e.headers:(n||!["GET","HEAD","DELETE"].includes(r))&&(t.headers={"Content-Type":"application/json"}),n&&(t.body=typeof e.body=="string"?e.body:JSON.stringify(e.body)),e.signal&&(t.signal=e.signal),t},vs=async(e,t)=>{let r=t??"auto";if(r==="json")return e.json();if(r==="text")return e.text();if(r==="arrayBuffer")return e.arrayBuffer();if(r==="blob")return e.blob();if(r==="formData")return e.formData();let n=e.headers.get("content-type")||"";return n.includes("application/json")||n.includes("+json")?e.json():n.startsWith("text/")||n.includes("xml")||n.includes("html")?e.text():n.includes("form-data")?e.formData():e.arrayBuffer()};var ia=e=>{if(!e||typeof e!="object")return false;let t=e;return "data"in t&&"loading"in t&&"error"in t&&"status"in t},aa=(e,t,r,n,o)=>{if(!ue(e))return;let s=n.stateAdapter;if(s){try{let i=tr({name:e}),a=u=>{tt(t,u,void 0,o);};Ze(o,()=>{s({name:e,prev:i,next:r,set:a});});}catch(i){d(`fetchStore("${e}") stateAdapter failed: ${i?.message??i}`);}return}Ze(o,()=>{tt(t,r,void 0,o);});},ft=(e,t,r,n)=>(d(`fetchStore("${e}") aborted`),Pt(t,r)&&ue(e)&&n({loading:false,error:"aborted",status:"aborted",revalidating:false}),null);async function dr(e,t,r={}){let n=_e(e);if(!n||typeof n!="string"){I("fetchStore requires a store name as first argument");return}let o={name:n};if(!t){I(`fetchStore("${n}") requires a URL, Promise, or Promise factory as second argument`);return}let{transform:s,onSuccess:i,onError:a,stateAdapter:u,method:c,headers:l,body:S,ttl:y,staleWhileRevalidate:h=false,dedupe:x=true,retry:f=0,retryDelay:g=400,retryBackoff:p=1.7,signal:C,cacheKey:T,responseType:E="auto"}=r,A=ut(),b=at(),w=lr(),B=(()=>{let N=r.correlationId,Z=r.traceContext;return N||Z?{correlationId:N,traceContext:Z}:k().autoCorrelationIds?{correlationId:`stroid-${n}-${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,traceContext:Z}:null})();!C&&v()&&Nt("noSignal",n,()=>{d(`fetchStore("${n}") called without an AbortSignal. Provide "signal" to enable cancellation (recommended).`);});let M=T?`${n}:${T}`:n,q=N=>aa(n,o,B?{...N,correlationId:B.correlationId,traceContext:B.traceContext}:N,r,B),ke=typeof t!="string"&&typeof t!="function"&&typeof t?.then=="function",Ne=ls(n,f,g,p),R=false,W=ke&&f>0,V=typeof window>"u"&&(typeof process<"u"?process.env?.NODE_ENV:void 0)==="production",m=r.autoCreate??k().asyncAutoCreate,ye=r.cloneResult??k().asyncCloneResult;if(u&&!ue(n))return le(n,`fetchStore("${n}") with stateAdapter requires an existing backing store.
27
- Call createStore("${n}", ...) first or omit stateAdapter to use the default AsyncState shape.`,a);if(!ue(n)&&V)return le(n,`fetchStore("${n}") cannot create a backing store on the server in production.
28
- Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,a);if(!ue(n)){if(!m)return le(n,`fetchStore("${n}") requires an existing backing store when autoCreate is disabled.
29
- Call createStore("${n}", ...) first or enable autoCreate.`,a);if(v()&&Nt("autoCreate",n,()=>{let N=`fetchStore("${n}") auto-created its backing store.
30
- Call createStore("${n}", ...) first to avoid typos creating phantom stores.`;se(a,`fetchStore.onError(${n})`,N),d(N);}),Dr(n,{data:null,loading:false,error:null,status:"idle"}),!ue(n))return le(n,`fetchStore("${n}") could not initialize its backing store.
31
- On the server in production, use createStoreForRequest(...) inside the request scope or create the store with { allowSSRGlobalStore: true } before calling fetchStore.`,a)}if(!u){let N=tr({name:n});if(N&&!ia(N))return Nt("shape",n,()=>{}),le(n,`fetchStore("${n}") cannot write AsyncState into an existing non-async store. Provide a stateAdapter or create the store with the async shape to avoid overwriting fields.`,a)}is();let Y=null,_=false,Q=()=>A[M]?.data??null;if(ts(M,y)){if(w.cacheHits+=1,Y=Q(),q({data:Y,loading:h,error:null,status:"success",cached:true,revalidating:h}),!h)return Y;_=true;}else w.cacheMisses+=1;if(x){let N=ms(n,M,s,a);if(N!==void 0)return N}let de=Date.now();if(bs(de),ws(),xs(M,de))return le(n,`fetchStore("${n}") rate limited: ${Qr} requests per ${dt}ms window for store "${n}".`,a);if(!ys(M)&&ns(n)>=Gr)return le(n,`fetchStore("${n}") exceeded ${Gr} concurrent request slots. Reuse cacheKey values, wait for pending requests, or delete the store to clear async state.`,a);let z=fs(M);_||q({loading:true,error:null,status:"loading",cached:false,revalidating:false}),w.requests+=1;let Pe=Date.now(),fe=!C&&typeof AbortController<"u"?new AbortController:null,te=C||fe?.signal,X=fe?()=>{fe.signal.aborted||fe.abort();}:null;X&&os(n,X);let U=async()=>{let N=0,Z=Ne.retryDelay;for(;;){if(te?.aborted)return ft(n,M,z,q);let me=typeof t=="function"?t():t,Zr=ke||typeof me!="string"&&typeof me?.then=="function",en=Zr?{...Ne,retry:0}:Ne;Zr&&(f>0||W)&&!R&&(d(`fetchStore("${n}") ignores retry settings for direct Promise inputs; pass a URL string or factory to use retries.`),R=true);try{let Te;if(typeof me=="string"){let Dt=Rs({method:c,headers:l,body:S,signal:te,...r}),Ot=await fetch(me,Dt);if(!Ot.ok)throw new Error(`HTTP ${Ot.status}: ${Ot.statusText}`);Te=await vs(Ot,E);}else if(typeof me.then=="function")Te=await me;else return I(`fetchStore("${n}") - second argument must be a URL string, Promise, or Promise factory.
32
- Examples:
33
- fetchStore("users", "https://api.example.com/users")
34
- fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(te?.aborted)return ft(n,M,z,q);let Be=s?s(Te):Te;if(Be&&typeof Be.then=="function"){let Dt=`fetchStore("${n}") transform must be synchronous. Return the transformed value directly instead of a Promise.`;return Pt(M,z)&&q({data:_?Q():null,loading:!1,error:Dt,status:"error",cached:_,revalidating:!1}),le(n,Dt,a)}ye==="none"&&v()&&Be&&typeof Be=="object"&&Nt("mutableResult",n,()=>{d(`fetchStore("${n}") received a mutable object while asyncCloneResult is "none".
35
- Async data is stored by reference; mutations will affect cache and subscribers.
36
- Set cloneResult: "deep" (per call) or configureStroid({ asyncCloneResult: "deep" }).`);});let Me=ds(Be,ye);if(te?.aborted)return ft(n,M,z,q);if(!Pt(M,z))return null;A[M]={timestamp:Date.now(),expiresAt:y?Date.now()+y:null,data:Me},rs(n),q({data:Me,loading:!1,error:null,status:"success",cached:!1,revalidating:!1}),lt(n,"onSuccess",i,Me);let tn=Date.now()-Pe;return w.lastMs=tn,w.avgMs=(w.avgMs*(w.requests-1)+tn)/w.requests,{raw:Te,transformed:Me}}catch(Te){if(N+=1,Te?.name==="AbortError")return ft(n,M,z,q);if(N<=en.retry){if(te?.aborted||(await us(Z,te),te?.aborted))return ft(n,M,z,q);Z=Math.min(Jr,Z*en.retryBackoff);continue}if(!Pt(M,z))return null;let Me=Te?.message||"Something went wrong";return q({data:_?Q():null,loading:false,error:Me,status:"error",cached:_,revalidating:false}),lt(n,"onError",a,Me),w.failures+=1,d(`fetchStore("${n}") failed: ${Me}`),null}}},re=null,ae=new Promise((N,Z)=>{C||(re=setTimeout(()=>{re=null,Z(new Error("Timeout: async request hung for 60 seconds without an AbortSignal"));},6e4));}),Le=Promise.race([U().finally(()=>{re&&(clearTimeout(re),re=null);}),ae]).catch(N=>{let Z=N?.message||"Request timed out";return q({data:_?Q():null,loading:false,error:Z,status:"error",cached:_,revalidating:false}),lt(n,"onError",a,Z),w.failures+=1,d(`fetchStore("${n}") failed: ${Z}`),null}),Ce=Le.then(N=>N?.transformed??null).finally(()=>{Ss(M),ps(M,z),X&&ss(n,X);}),pt=Le.then(N=>N?.raw);return gs(M,{promise:Ce,raw:pt,transform:s}),typeof t=="function"?b[n]={kind:"factory",factory:t,options:{...r,cacheKey:T}}:typeof t=="string"?b[n]={kind:"url",url:t,options:{...r,cacheKey:T}}:delete b[n],Ce}async function ks(e){let t=_e(e);if(!ue(t))return;let n=at()[t];if(!n){let s=`${t}:`,i=ut(),a=Object.entries(i).filter(([u])=>u===t||u.startsWith(s));if(a.length>0){let[,u]=a.reduce((c,l)=>l[1].timestamp>=c[1].timestamp?l:c);return u.data}v()&&d(`refetchStore("${t}") - no previous fetch found.
37
- Call fetchStore("${t}", url) first.`);return}let o={name:t};return n.kind==="factory"?dr(o,n.factory,n.options):dr(o,n.url,n.options)}var ca={};function ua(e,t,r){let n=Ae()??H(be()),o=r??ca,s=typeof e=="string"?e:e.name,i=useMemo(()=>typeof e=="string"?nr(e):e,[e]),a=Ur(i),u=a.loading||a.status==="idle",c=o.cacheKey?`${s}:${o.cacheKey}`:s,l=useMemo(()=>{if(!u)return null;let S=K(n,()=>ve()[c]?.promise);return S||(t!==void 0?K(n,()=>dr(i,t,o)):K(n,()=>at())[s]?K(n,()=>ks(i)):null)},[n,c,t,i,s,o,u]);if(l)throw l;if(a.error)throw new Error(a.error);return a.data}export{_i as RegistryScope,Ur as useAsyncStore,ua as useAsyncStoreSuspense,Gi as useFormStore,Ki as useSelector,ar as useStore,cr as useStoreField,Ui as useStoreStatic};//# sourceMappingURL=index.js.map
5
+ See: https://stroid.dev/docs/strict-mode`)));};function T(e,t,n$1=Object.is){let r=typeof e=="string"?e:e.name,s=typeof t=="function",a=typeof t=="string"?t:void 0,o=s?t:void 0,i=h()??k(d()),S=useRef(o),c=useRef(n$1),d$1=useRef(se()),l=useRef(false),N=useRef(o);S.current=o,c.current=n$1;let b$1=useCallback(m=>ae(r,m,S,c,d$1),[r]),p$1=useCallback(m=>j$1(i,()=>s?b(r,V=>S.current(V),(V,ce)=>c.current(V,ce),m):na(r,()=>m())),[i,r,s]),R=useCallback(()=>j$1(i,()=>{let m=oa(r);return Re(e,r),M(r),he(r,s,a),s?b$1(m):ne(m,a)}),[i,r,s,a,b$1,e]),D=useSyncExternalStore(p$1,R,R);return useEffect(()=>{if(n()&&s){let m=N.current;m&&m!==o&&!l.current&&(l.current=true,p(`useStore("${r}") selector was recreated between renders. This can cause extra selector work and reduce selector cache reuse. Wrap the selector in useCallback or define it outside the component.`)),N.current=o;}},[r,s,a,o]),D}function A(e,t){return T(e,t)}function xe(e,t,n$1=w){let r=typeof e=="string"?e:e.name,s=h()??k(d()),a=useRef(t),o=useRef(n$1),i=useRef(se()),S=useRef(false),c=useRef(t);a.current=t,o.current=n$1;let d$1=useCallback(p=>ae(r,p,a,o,i),[r]),l=useCallback(()=>j$1(s,()=>{let p=oa(r);return M(r),d$1(p)}),[s,r,d$1]),N=useCallback(p=>j$1(s,()=>b(r,R=>a.current(R),(R,D)=>o.current(R,D),()=>p())),[s,r]),b$1=useSyncExternalStore(N,l,l);return useEffect(()=>{if(!n())return;let p$1=c.current;p$1&&p$1!==t&&!S.current&&(S.current=true,p(`useSelector("${r}") selector was recreated between renders. Wrap it in useCallback or define it outside the component to reduce selector churn and preserve selector cache reuse.`)),c.current=t;},[r,t]),b$1}function Ne(e,t){let n=typeof e=="string"?e:e.name,r=h()??k(d()),s=j$1(r,()=>{let a=oa(n);return M(n),a});return s==null?null:ne(s,t)}function O(e){let t=typeof e=="string"?P(e):e,n=T(t);return {data:n?.data??null,loading:n?.loading??false,revalidating:n?.revalidating??false,error:n?.error??null,status:n?.status??"idle",isEmpty:n?.data==null&&!n?.loading&&!n?.error}}var ue=e=>{let t=e?.target;return t?t.type==="checkbox"?!!t.checked:t.value:e};function Pe(e,t){let n=h()??k(d());if(typeof e=="string"){let i=t,S=A(e,i),c=useCallback(d=>{let l=ue(d);j$1(n,()=>{U$1(e,i,l);});},[n,e,i]);return {value:S,onChange:c}}let r=t,s=e,a=A(s,r),o=useCallback(i=>{let S=ue(i);j$1(n,()=>{U$1(s,r,S);});},[n,s,r]);return {value:a,onChange:o}}var be={};function we(e,t,n){let r=h()??k(d()),s=n??be,a=typeof e=="string"?e:e.name,o=useMemo(()=>typeof e=="string"?P(e):e,[e]),i=O(o),S=i.loading||i.status==="idle",c$1=s.cacheKey?`${a}:${s.cacheKey}`:a,d$2=useMemo(()=>{if(!S)return null;let l=j$1(r,()=>d$1()[c$1]?.promise);return l||(t!==void 0?j$1(r,()=>a$1(o,t,s)):j$1(r,()=>c())[a]?j$1(r,()=>b$1(o)):null)},[r,c$1,t,o,a,s,S]);if(d$2)throw d$2;if(i.error)throw new Error(i.error);return i.data}
6
+ export{fe as RegistryScope,O as useAsyncStore,we as useAsyncStoreSuspense,Pe as useFormStore,xe as useSelector,T as useStore,A as useStoreField,Ne as useStoreStatic};//# sourceMappingURL=index.js.map
38
7
  //# sourceMappingURL=index.js.map
@@ -88,6 +88,7 @@ type AsyncRegistry = {
88
88
  }>;
89
89
  inflight: Partial<Record<string, InflightEntry>>;
90
90
  requestVersion: Record<string, number>;
91
+ requestSequence: Record<string, number>;
91
92
  cacheMeta: Record<string, {
92
93
  timestamp: number;
93
94
  expiresAt: number | null;