stroid 0.1.2 → 0.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +27 -2
- package/dist/async.js +22 -22
- package/dist/async.js.map +1 -1
- package/dist/computed.d.ts +7 -1
- package/dist/computed.js +11 -11
- package/dist/computed.js.map +1 -1
- package/dist/core.js +14 -14
- package/dist/core.js.map +1 -1
- package/dist/devtools.js +1 -1
- package/dist/devtools.js.map +1 -1
- package/dist/feature.js.map +1 -1
- package/dist/helpers.js +14 -14
- package/dist/helpers.js.map +1 -1
- package/dist/index.d.cts +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +24 -24
- package/dist/index.js.map +1 -1
- package/dist/install.js +1 -1
- package/dist/install.js.map +1 -1
- package/dist/persist.js +1 -1
- package/dist/persist.js.map +1 -1
- package/dist/react/index.js +25 -25
- package/dist/react/index.js.map +1 -1
- package/dist/runtime-admin.js +1 -1
- package/dist/runtime-admin.js.map +1 -1
- package/dist/runtime-tools.js +2 -2
- package/dist/runtime-tools.js.map +1 -1
- package/dist/selectors.js +1 -1
- package/dist/selectors.js.map +1 -1
- package/dist/server.js +11 -11
- package/dist/server.js.map +1 -1
- package/dist/store-registry.d.ts +0 -1
- package/dist/sync.js +1 -1
- package/dist/sync.js.map +1 -1
- package/dist/testing.js +14 -14
- package/dist/testing.js.map +1 -1
- package/package.json +4 -1
- package/dist/types/adapters/options.d.ts +0 -335
- package/dist/types/async/cache.d.ts +0 -39
- package/dist/types/async/clone.d.ts +0 -10
- package/dist/types/async/errors.d.ts +0 -3
- package/dist/types/async/fetch.d.ts +0 -37
- package/dist/types/async/inflight.d.ts +0 -13
- package/dist/types/async/rate.d.ts +0 -5
- package/dist/types/async/registry.d.ts +0 -116
- package/dist/types/async/request.d.ts +0 -11
- package/dist/types/async/retry.d.ts +0 -10
- package/dist/types/async.d.ts +0 -10
- package/dist/types/computed/computed-graph.d.ts +0 -29
- package/dist/types/computed/index.d.ts +0 -16
- package/dist/types/config.d.ts +0 -10
- package/dist/types/core/index.d.ts +0 -11
- package/dist/types/core/lifecycle-hooks.d.ts +0 -16
- package/dist/types/core/store-admin-impl.d.ts +0 -9
- package/dist/types/core/store-admin.d.ts +0 -9
- package/dist/types/core/store-core.d.ts +0 -13
- package/dist/types/core/store-create.d.ts +0 -16
- package/dist/types/core/store-hydrate-impl.d.ts +0 -35
- package/dist/types/core/store-hydrate.d.ts +0 -9
- package/dist/types/core/store-lifecycle/hooks.d.ts +0 -19
- package/dist/types/core/store-lifecycle/identity.d.ts +0 -23
- package/dist/types/core/store-lifecycle/registry.d.ts +0 -53
- package/dist/types/core/store-lifecycle/types.d.ts +0 -67
- package/dist/types/core/store-lifecycle/validation.d.ts +0 -53
- package/dist/types/core/store-name.d.ts +0 -28
- package/dist/types/core/store-notify.d.ts +0 -12
- package/dist/types/core/store-read.d.ts +0 -18
- package/dist/types/core/store-registry.d.ts +0 -108
- package/dist/types/core/store-replace-impl.d.ts +0 -11
- package/dist/types/core/store-replace.d.ts +0 -9
- package/dist/types/core/store-set-impl.d.ts +0 -13
- package/dist/types/core/store-set.d.ts +0 -9
- package/dist/types/core/store-shared/core.d.ts +0 -13
- package/dist/types/core/store-shared/notify.d.ts +0 -12
- package/dist/types/core/store-transaction.d.ts +0 -26
- package/dist/types/core/store-write-shared.d.ts +0 -19
- package/dist/types/core/store-write.d.ts +0 -13
- package/dist/types/features/feature-registry.d.ts +0 -91
- package/dist/types/features/lifecycle.d.ts +0 -40
- package/dist/types/index.d.ts +0 -17
- package/dist/types/integrations/query.d.ts +0 -8
- package/dist/types/internals/computed-order.d.ts +0 -3
- package/dist/types/internals/config.d.ts +0 -116
- package/dist/types/internals/diagnostics.d.ts +0 -21
- package/dist/types/internals/reporting.d.ts +0 -9
- package/dist/types/internals/store-admin.d.ts +0 -7
- package/dist/types/internals/store-ops.d.ts +0 -13
- package/dist/types/internals/test-reset.d.ts +0 -2
- package/dist/types/internals/write-context.d.ts +0 -15
- package/dist/types/notification/delivery.d.ts +0 -3
- package/dist/types/notification/index.d.ts +0 -10
- package/dist/types/notification/metrics.d.ts +0 -12
- package/dist/types/notification/priority.d.ts +0 -9
- package/dist/types/notification/scheduler.d.ts +0 -11
- package/dist/types/notification/snapshot.d.ts +0 -8
- package/dist/types/runtime-admin/index.d.ts +0 -2
- package/dist/types/runtime-tools/index.d.ts +0 -58
- package/dist/types/store.d.ts +0 -16
- package/dist/types/types/utility.d.ts +0 -17
- package/dist/types/utils/clone.d.ts +0 -4
- package/dist/types/utils/devfreeze.d.ts +0 -2
- package/dist/types/utils/hash.d.ts +0 -8
- package/dist/types/utils/path.d.ts +0 -5
- package/dist/types/utils/validation.d.ts +0 -14
- package/dist/types/utils.d.ts +0 -13
package/CHANGELOG.md
CHANGED
|
@@ -6,8 +6,33 @@ Versioning: [Semantic Versioning](https://semver.org/).
|
|
|
6
6
|
|
|
7
7
|
---
|
|
8
8
|
<details open>
|
|
9
|
-
<summary><strong>Unreleased
|
|
10
|
-
|
|
9
|
+
<summary><strong>Unreleased</strong></summary>
|
|
10
|
+
|
|
11
|
+
- No unreleased changes yet.
|
|
12
|
+
|
|
13
|
+
</details>
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
<details open>
|
|
18
|
+
<summary><strong>v0.1.3 — 2026-03-22</strong></summary>
|
|
19
|
+
|
|
20
|
+
- Fixed async rate limiting so `fetchStore(..., { cacheKey })` is throttled per `cacheSlot` instead of incorrectly sharing one counter across the whole store name.
|
|
21
|
+
- Fixed `createSelector` dependency tracking for object-valued reads so cached selector results no longer go stale when object references change without primitive leaf access.
|
|
22
|
+
- Fixed `setStoreBatch` teardown so a later commit-phase feature error does not discard notifications that were already queued by earlier successful commits.
|
|
23
|
+
- Fixed persist unload listeners so deleting and recreating a persisted store no longer accumulates stale `pagehide` / `beforeunload` flush handlers.
|
|
24
|
+
- Fixed sync-applied remote state so feature write hooks still run, allowing `persist` and other write-driven features to observe synced updates.
|
|
25
|
+
- Fixed `clearAllStores()` under `assertRuntime: true` so a successful clear logs normally instead of throwing from the success path.
|
|
26
|
+
- Fixed sync checksum handling so incoming sync payloads are now verified before remote state is accepted.
|
|
27
|
+
- Fixed async request defaults so bodyless `GET` / `HEAD` / `DELETE` requests no longer send `Content-Type: application/json`.
|
|
28
|
+
- Fixed `createComputed(..., { autoDispose: true })` so computed stores are removed after their last dependency is deleted.
|
|
29
|
+
- Fixed `resetStore()` for falsy initial values (`false`, `0`, `""`, `null`) so registered stores no longer report `not-found` during reset.
|
|
30
|
+
- Replaced the default registry scope's `import.meta.url`-based identifier with a stable bundler-safe string to avoid webpack / Next.js resolution failures.
|
|
31
|
+
- Hardened SSR write-context isolation by routing `runWithWriteContext(...)` through the server AsyncLocalStorage runner instead of relying only on a module-level fallback context.
|
|
32
|
+
- Hardened inline notification delivery to snapshot the subscriber list per flush instead of reusing a shared registry buffer.
|
|
33
|
+
- Tightened React hook type coverage for ambient `StoreStateMap` usage, including `useStore`, `useStoreField`, `useStoreStatic`, `useSelector`, `useFormStore`, `useAsyncStore`, and `useAsyncStoreSuspense`.
|
|
34
|
+
- Clarified React selector recreation warnings and docs so they describe selector churn and cache reuse accurately instead of implying repeated re-subscriptions.
|
|
35
|
+
- Upgraded the transitive `flatted` resolution to `3.4.2` via `npm overrides` to address the Dependabot alert in the eslint / flat-cache toolchain path.
|
|
11
36
|
|
|
12
37
|
</details>
|
|
13
38
|
|
package/dist/async.js
CHANGED
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
var
|
|
2
|
-
Store data only - handle functions outside the store.`,
|
|
3
|
-
Use arrays or plain objects for best results.`,
|
|
4
|
-
Use new Date(value) to convert back when reading.`,
|
|
1
|
+
var Jo=new Map,A=(e,t,r=0)=>{!e||typeof t!="function"||Jo.set(e,{name:e,order:r,fn:t});};var Yt=new Map;var Tt=e=>Yt.has(e),Et=e=>Yt.get(e),$e=()=>Array.from(Yt.keys());var zr=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),Wr=()=>({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:zr(),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}}),Ft=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(),zr().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 Xt=new Map,Hr=new WeakSet,Jt=e=>{Hr.has(e)||(Hr.add(e),$e().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Et(t);r&&e.featureRuntimes.set(t,r());}}));},Zo=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,Lr,Qt=e=>(Lr||Zo||e).replace(/\.ts(\?|$)/,".js$1"),_e=Qt("stroid:default-registry");var es=()=>{Lr=void 0,Xt.clear();};A("registry.scope-override",es,110);var ts=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),rs=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},Br=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),ns=(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:Br(),async:Wr(),notify:ts(),lifecycleListener:null};return Jt(t),t},ze=e=>{let t=Qt(e),r=Xt.get(t);if(r)return r;let n=ns();return Xt.set(t,n),n},Ee=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),qr=(e,t)=>e.deletingStores.has(t),Ur=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,rs(e.notify),Ft(e.async),e.lifecycleListener=null;};var At=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var nt=()=>null,ye=[],Gr={run:(e,t)=>{ye.push(e);try{return t()}finally{ye.pop();}},get:()=>ye.length>0?ye[ye.length-1]:null,enterWith:e=>{if(ye.length>0){ye[ye.length-1]=e;return}ye.push(e);}};var Ot=(e,t)=>(Gr).run(e,t),oe=e=>(Gr).get()||e||ze(_e);var ss={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}`));}},Yr={logSink:ss,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},er=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}),Zt=new WeakMap,Xr=er(Yr),is=e=>{let t=Zt.get(e);return t||(t=er(Xr),Zt.set(e,t)),t};var M=()=>is(oe());var ls=()=>{Zt=new WeakMap,Xr=er(Yr);};A("config.reset",ls,90);var Jr=()=>M().namespace;var ds=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,fs=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,Qr=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,ps="production",gs=ds??fs??ps,ot=typeof Qr=="boolean"?Qr:gs!=="production",k=()=>ot,tr=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},ys=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},Ss=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},H=(e,t)=>{if((M().logSink.critical??ys)(e,t),M().assertRuntime)throw new Error(e)},f=(e,t)=>{if(!ot)return;if((M().logSink.warn??tr)(e,t),M().assertRuntime)throw new Error(e)},se=(e,t)=>{if((M().logSink.warn??tr)(e,t),M().assertRuntime)throw new Error(e)},N=(e,t)=>{if(ot&&(M().logSink.warn??tr)(e,t),H(e,t),M().assertRuntime)throw new Error(e)},te=(e,t)=>{if(!ot)return;(M().logSink.log??Ss)(e,t);},Zr=()=>`Functions cannot be stored in stroid.
|
|
2
|
+
Store data only - handle functions outside the store.`,en=()=>`Map/Set detected. stroid converts these to plain objects.
|
|
3
|
+
Use arrays or plain objects for best results.`,tn=()=>`Date object detected. stroid stores it as ISO string.
|
|
4
|
+
Use new Date(value) to convert back when reading.`,rn=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",nn=()=>"Map detected; converting to plain object.",on=()=>"Set detected; converting to array.",sn=(e,t,r)=>`Path depth of ${e} exceeded maximum of ${t}.
|
|
5
5
|
"${r.join(".")}"
|
|
6
6
|
This is a data design issue. Split into separate stores:
|
|
7
|
-
createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,
|
|
8
|
-
Consider splitting into separate stores for better readability.`,
|
|
9
|
-
Use camelCase or kebab-case: "userName" or "user-name"`,
|
|
10
|
-
Reserved names: "__proto__", "constructor", "prototype".`,
|
|
7
|
+
createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,an=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
|
|
8
|
+
Consider splitting into separate stores for better readability.`,ln=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,dn=e=>`Store name "${e}" contains spaces.
|
|
9
|
+
Use camelCase or kebab-case: "userName" or "user-name"`,fn=e=>`Store name "${e}" is not allowed.
|
|
10
|
+
Reserved names: "__proto__", "constructor", "prototype".`,ms=128,hs=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=ms,bs=(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]},rr=(e,t)=>{let r=t.find(n=>{let o=n.toLowerCase(),s=e.toLowerCase();return o.includes(s)||s.includes(o)||hs(o,s)&&bs(o,s)<=2});if(r){f(`Store "${e}" not found. Did you mean "${r}"?`);return}N(`Store "${e}" not found.
|
|
11
11
|
Available stores: [${t.join(", ")}]
|
|
12
|
-
Call createStore("${e}", data) first.`);};var ie=new Set(["__proto__","constructor","prototype"]),sr=(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 xe=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,ln=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null},_e=e=>{let t=xe(e);return t==="function"?(j(Xr()),false):t==="map"||t==="set"?(f(Jr()),true):(t==="date"&&f(Qr()),true)},or=(e,t)=>{let r=ln(e);if(r)throw new Error(`${r} values are not supported`);let n=xe(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&&!or(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||ie.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!or(i.value,t))return false}return true}return true},ir=e=>or(e,new WeakSet),it=(e,t)=>{let r=ln(e);if(r)throw new Error(`${r} values are not supported`);let n=xe(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 C()&&f(Zr()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),C()&&f(en());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)]=it(i,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),C()&&f(tn()),Array.from(e,o=>it(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&&!ie.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);o[i]=it(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=>it(o,t))}return e},Me=e=>it(e,new WeakSet),ar=e=>typeof e!="string"||e.trim()===""?(j(an(e)),false):ie.has(e)?(j(un(e)),false):e.includes(" ")?(j(cn(e)),false):true;var cr=null,ys=()=>{if(cr)return cr;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 cr=t,t},fn=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},Ss=2166136261,ms=2654435761,hs=1e5,Re=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},Te=(e,t)=>{Re(e,t.length);for(let r=0;r<t.length;r++)Re(e,t.charCodeAt(r));},I=(e,t)=>{Te(e,t);},dn=(e,t)=>{if(Number.isNaN(t)){I(e,"NaN");return}if(!Number.isFinite(t)){I(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){I(e,"-0");return}let r=t|0;if(t===r){I(e,"int"),Re(e,r);return}I(e,"num"),Te(e,String(t));},ze=(e,t)=>{if(e.nodes++>hs){I(e,"[max]");return}if(t===null){I(e,"null");return}let r=typeof t;if(r==="string"){I(e,"string"),Te(e,t);return}if(r==="number"){I(e,"number"),dn(e,t);return}if(r==="boolean"){I(e,t?"true":"false");return}if(r==="undefined"){I(e,"undefined");return}if(r==="bigint"){I(e,"bigint"),Te(e,t.toString());return}if(r==="symbol"){I(e,"symbol");let u=t;Te(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){I(e,"function"),Te(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){I(e,"ref"),Re(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){I(e,"array"),Re(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?ze(e,n[u]):I(e,"hole");return}if(n instanceof Date){I(e,"date"),dn(e,n.getTime());return}if(n instanceof Map){I(e,"map"),Re(e,n.size),n.forEach((u,c)=>{ze(e,c),ze(e,u);});return}if(n instanceof Set){I(e,"set"),Re(e,n.size),n.forEach(u=>{ze(e,u);});return}I(e,"object");let i=Object.getOwnPropertyDescriptors(n),a=[];Object.entries(i).forEach(([u,c])=>{c?.enumerable&&(ie.has(u)||"get"in c||"set"in c||a.push([u,c]));}),Re(e,a.length);for(let[u,c]of a)Te(e,u),ze(e,c.value);},at=e=>{if(typeof e=="string")return fn(JSON.stringify(e));let t={h1:Ss,h2:ms,seen:new WeakMap,nextId:1,nodes:0};ze(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 bs=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Fe=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&&(ie.has(n)||"get"in o||"set"in o||(t[n]=o.value));}),t},ur=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},ws=e=>ur(e)===null,vs=e=>{let t=ur(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},Ee=(e,t=new WeakMap)=>{if(vs(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(Ee(i,t),Ee(s,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(s=>{o.add(Ee(s,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((s,i)=>{o[i]=Ee(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||ie.has(o)||"get"in s||"set"in s||(r[o]=Ee(s.value,t));}),r},V=e=>{if(bs)try{return structuredClone(e)}catch(t){if(!ws(e)){let r=ur(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return f(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),Ee(e)}return Ee(e)},lr=(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 pn=10,xs=5,Rs=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},We=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?Rs(e):[String(e)],ct=e=>{let t=We(e),r=t.length;return r>pn?(j(rn(r,pn,t)),false):(r>xs&&f(nn(r,t)),true)},fr=(e,t,r)=>{let n=We(t);if(n.length===0)return e;for(let s of n)if(ie.has(s))return H(`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 d=[...s];return u?(d[c]=r,d):(d[c]=o(d[c],i+1),d)}if(s&&typeof s=="object"){if(ie.has(a))return H(`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)),d=c?[]:{};if(c){let x=d,h=Number(a);return x[h]=o(void 0,i+1),x}return d[a]=o(void 0,i+1),d}return u?r:s};return o(e,0)};var gr=new Set,ks=()=>{gr.clear();};O("options.legacy-warnings",ks,30);var Dt=(()=>{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"}})(),pr=e=>{try{return typeof window>"u"?Dt:e==="session"||e==="sessionStorage"?window.sessionStorage??Dt:window.localStorage??Dt}catch{return Dt}},ut=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),He=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),yn=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}},Cs=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",gn=e=>{try{e[Cs]=!0;}catch{}return e},Ms={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"},Ts=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:gn(x=>x),decrypt:gn(x=>x),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:pr("localStorage"),...r};if(typeof e=="string")return {driver:pr(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,d=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(a&&yn(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||pr("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:d,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Sn=e=>{if(!ut(e))return [];let t=[];return Object.entries(Ms).forEach(([r,n])=>{He(e,r)&&(gr.has(r)||(gr.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},mn=(e={},t,r="deep")=>{let n=e.scope??"request",o=e.lazy===true,s=e.pathCreate===true,i=ut(e.lifecycle)?e.lifecycle:void 0,a=ut(e.persist)?e.persist:void 0,u=ut(e.devtools)?e.devtools:void 0,c=e.validate??e.validator??e.schema,d=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",x=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,h=ut(e.features)?{...e.features}:void 0,R=He(e,"persist"),b=He(e,"sync"),l=He(e,"devtools")||He(e,"historyLimit")||He(e,"redactor"),p=n==="global"?true:e.allowSSRGlobalStore??false,{persist:y=false,devtools:k=false,onError:v,sync:T}=e;if(a?.sensitiveData===true){let F=a.encrypt,m=a.encryptAsync;if((!F||yn(F))&&!m)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:n,lazy:o,pathCreate:s,persist:n==="temp"&&!R?null:Ts(y,t),devtools:n==="temp"&&!l?false:typeof k=="boolean"?k: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:v,validate:c,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:n==="temp"&&!l?void 0:u?.redactor??e.redactor,historyLimit:n==="temp"&&!l?0:u?.historyLimit??e.historyLimit??50,sync:n==="temp"&&!b?false:T??false,features:h,allowSSRGlobalStore:p,snapshot:d,snapshotSafety:x,explicitPersist:R,explicitSync:b,explicitDevtools:l}};var Pt=Symbol("stroid.middleware.abort"),hn=({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=V(t.next);for(let a of r){if(typeof a!="function")continue;let u,c=i;try{u=a({action:t.action,name:e,prev:t.prev,next:c,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(d){let x=`Middleware for "${e}" failed: ${d?.message??d}`;return n(x,"dev"),Pt}if(u&&typeof u.then=="function"){let d=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(d,"dev"),Pt}u===void 0?(C()&&!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},Vt=({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 re=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(n){let o=n?.message??n;oe(`${t} callback threw: ${String(o)}`);}},Ae=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(re(o,"onError",e),r==="critical"){n==="dev"&&f(e),H(e);return}if(n==="always"){oe(e);return}f(e);};var Nt=null,bn=e=>{Nt=e;},wn=e=>Nt?Nt(e):[];O("computed.order-resolver",()=>{Nt=null;},105);var vn=()=>ne(Ie(je)),xn=()=>vn().computedEntries,Es=()=>vn().computedDependents;var Rn=e=>Object.prototype.hasOwnProperty.call(xn(),e);var Fs=e=>{let t=xn(),r=Es(),n=new Set,o=[...e];for(;o.length>0;){let d=o.shift(),x=r[d];if(x)for(let h of x)n.has(h)||(n.add(h),o.push(h));}if(n.size===0)return [];let s=d=>{let x=t[d];if(x)for(let h of x.deps)t[h]&&(n.has(h)||(n.add(h),s(h)));};Array.from(n).forEach(d=>s(d));let i=new Map,a=new Map;for(let d of n){let x=t[d];if(!x)continue;let h=0;for(let R of x.deps)n.has(R)&&(h++,a.has(R)||a.set(R,[]),a.get(R).push(d));i.set(d,h);}let u=[];for(let[d,x]of i)x===0&&u.push(d);u.sort();let c=[];for(;u.length>0;){let d=u.shift();c.push(d);let x=a.get(d)??[];for(let h of x){let R=(i.get(h)??1)-1;if(i.set(h,R),R===0){let b=u.findIndex(l=>l>h);b===-1?u.push(h):u.splice(b,0,h);}}}return c};bn(Fs);var kn=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")},yr=e=>(kn(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Cn=e=>{if(!kn(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 jt=null;var As=()=>{jt=null;};O("transaction.runner",As,120);var lt=e=>{let t=jt?.get();return t||(e??ne()).transaction},Os=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 P=()=>jt?(jt.get()?.depth??0)>0:lt().depth>0,G=(e,t)=>{let r=lt(t);r.failed=true,r.error||(r.error=Os(e));},It=e=>{let t=ne();lt(t).pending.push(()=>Ot(t,e));},$t=(e,t)=>{let r=lt();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},Le=e=>{let t=lt();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Mn=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Sr=(e,t)=>{if(t==="ref"){if(!C())return e;try{return yr(e)}catch{return e}}if(t==="shallow"){let n=Fe(e);if(!C())return n;try{return yr(n)}catch{return n}}let r=V(e);if(!C())return r;try{return Cn(r)}catch{return r}};var Tn=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:n}=e,o=M().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 b of t)r.push(b),a.add(b);for(let b of s)a.has(b)&&n.push(b);for(let b of r)i.has(b)||n.push(b);}else for(let b of t)r.push(b),a.add(b),n.push(b);t.clear();let u=wn(n),c=new Set(n);for(let b of u)c.has(b)||(n.push(b),c.add(b));let d=Number.isFinite(o.chunkSize)&&o.chunkSize>0?o.chunkSize:Number.POSITIVE_INFINITY,x=o.chunkDelayMs,h=d===Number.POSITIVE_INFINITY&&x===0;return {names:n,sliceSize:d,chunkDelayMs:x,runInline:h,prioritySet:i}};var mr=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}),hr=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),br=(e,t)=>{e&&(e.metrics=t);};var dt=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},En=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let n=()=>Ot(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(n):Promise.resolve().then(n);};var Be=new Map,Fn=(e,t)=>{let r=Be.get(e);return r||(r=new Set,Be.set(e,r)),r.add(t),()=>{let n=Be.get(e);n&&(n.delete(t),n.size===0&&Be.delete(e));}},wr=e=>{let t=Be.get(e);return !!t&&t.size>0},ft=(e,t,r)=>{let n=Be.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 _t=null,zt=()=>_t,qe=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();let r=_t;_t=e;try{return t()}finally{_t=r;}};var An=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)},On=(e,t,r,n)=>{let o=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:u,prioritySet:c}=t,x=o.subscriberBuffer,h=e.stores,R=e.subscribers,b=e.metaEntries,l=e.snapshotCache,p=M().defaultSnapshotMode,y=w=>Mn(b[w],p),k=w=>h[w],v=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),T=wr("beforeFlush"),F=wr("afterFlush"),m=w=>{T&&ft("beforeFlush",w,{type:"beforeFlush"});},S=(w,N)=>{F&&ft("afterFlush",w,{type:"afterFlush",elapsedMs:N});},Y=w=>{let N=b[w];if(!N)return null;let D=N.lastCorrelationId??void 0,g=N.lastTraceContext??void 0;return !D&&!g?null:{correlationId:D,traceContext:g}},E=w=>{x.length=0;for(let N of w)x.push(N);return x},W=()=>{n();};if(u){for(let w of s){let N=R[w];if(!N||N.size===0)continue;let D=b[w]?.updateCount??0,g=y(w),X=k(w),U=l[w],Q=U&&U.source===X&&U.mode===g?U.snapshot:(()=>{let L=Sr(X,g);return l[w]={version:r,snapshot:L,source:X,mode:g},L})(),z=mr(b[w]?.metrics);m(w);let pe=v(),Z=E(N),ee=Y(w),ue=()=>{for(let L of Z)try{L(Q);}catch(le){let te=b[w]?.options?.snapshotSafety??"warn";if(C()&&(g==="ref"||g==="shallow")&&An(le)){if(te==="throw")throw le;if(te==="auto-clone")try{let A=V(Q);f(`Snapshot mutation detected for "${w}". Delivered a cloned snapshot to the subscriber.`);try{L(A);}catch(B){f(`Subscriber for "${w}" threw on cloned snapshot: ${B?.message??B}`);}continue}catch{}f(`Snapshot mutation detected for "${w}": ${le?.message??le}`);continue}f(`Subscriber for "${w}" threw: ${le?.message??le}`);}};ee?qe(ee,ue):ue();let Ce=v()-pe;S(w,Ce),hr(z,Ce),br(b[w],z),(b[w]?.updateCount??D)!==D&&o.pendingNotifications.add(w);}W();return}let be=w=>{let N=[];for(let D of s){if(w&&!w(D))continue;let g=R[D];if(!g||g.size===0)continue;let X=b[D]?.updateCount??0,U=y(D),Q=k(D),z=l[D],pe=z&&z.source===Q&&z.mode===U?z.snapshot:(()=>{let Z=Sr(Q,U);return l[D]={version:r,snapshot:Z,source:Q,mode:U},Z})();N.push({name:D,snapshot:pe,version:X,subscribers:Array.from(g),subscriberSet:new Set(g),notified:new Set,metrics:mr(b[D]?.metrics),totalMs:0,beforeHooked:false});}return N},Pe=c?be(w=>c.has(w)):[],et=be(w=>!c||!c.has(w)),tt=(w,N)=>{let D=()=>{if(w.length===0){N();return}let g=w.shift();if((b[g.name]?.updateCount??g.version)!==g.version){if(o.pendingNotifications.add(g.name),w.length===0){N();return}dt(D,a);return}let U=()=>{let K=R[g.name];if(!(!K||K.size===0))for(let L of K)g.subscriberSet.has(L)||(g.subscriberSet.add(L),g.subscribers.push(L));};U();let Q=g.subscribers;if(Q.length===0){if(w.length===0){N();return}dt(D,a);return}g.beforeHooked||(g.beforeHooked=true,m(g.name));let z=v(),pe=0,Z=false,ee=Y(g.name),ue=()=>{for(let K=0;K<Q.length&&pe<i;K+=1){let L=Q[K];if(g.notified.has(L))continue;g.notified.add(L);try{L(g.snapshot);}catch(te){let rt=b[g.name]?.options?.snapshotSafety??"warn",A=y(g.name);if(C()&&(A==="ref"||A==="shallow")&&An(te)){if(rt==="throw")throw te;if(rt==="auto-clone")try{let ge=V(g.snapshot);f(`Snapshot mutation detected for "${g.name}". Delivered a cloned snapshot to the subscriber.`);try{L(ge);}catch(nt){f(`Subscriber for "${g.name}" threw on cloned snapshot: ${nt?.message??nt}`);}if(g.notified.add(L),pe+=1,(b[g.name]?.updateCount??g.version)!==g.version){Z=!0,o.pendingNotifications.add(g.name);break}continue}catch{}f(`Snapshot mutation detected for "${g.name}": ${te?.message??te}`);continue}f(`Subscriber for "${g.name}" threw: ${te?.message??te}`);}if(pe+=1,(b[g.name]?.updateCount??g.version)!==g.version){Z=true,o.pendingNotifications.add(g.name);break}}};if(ee?qe(ee,ue):ue(),g.totalMs+=v()-z,Z){if(w.length===0){N();return}dt(D,a);return}U();let Ce=false;for(let K of Q)if(!g.notified.has(K)){Ce=true;break}if(Ce?w.push(g):(hr(g.metrics,g.totalMs),br(b[g.name],g.metrics),S(g.name,g.totalMs)),w.length===0){N();return}dt(D,a);};D();};Pe.length>0?tt(Pe,()=>tt(et,W)):tt(et,W);};var Ds=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,n=Tn(t);On(e,n,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&vr(e);});},vr=e=>{En(e,Ds);};var Wt=null,Dn=e=>(Wt=e,()=>{Wt===e&&(Wt=null);}),Ue=e=>{Wt?.(e);};var Ps=e=>{let t=$(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&vr(t);};Dn(Ps);var Vs=()=>{let e=$().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0;};O("notify.reset",Vs,40);var Ht=new Set,Vn=e=>e?Ht.has(e):Ht.size>0,Nn=e=>{e&&Ht.add(e);},Ns=()=>{Ht.clear();};O("ssr.warnings",Ns,60);var Pn=new Set,js=e=>{let t=Gr();return !t||e.includes("::")?e:(C()&&!Pn.has(e)&&(Pn.add(e),f(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},ke=e=>js(typeof e=="string"?e:e.name),jn=e=>ae(e)&&!_n(e)?true:(nr(e,Object.keys(St)),false),In=(e,t,r={})=>{Ae(t,{...r,onError:_[e]?.options?.onError});},$n=(e,t,r={})=>{Ae(e,{...r,onError:t});},gt=(e,t,r="dev")=>{In(e,t,{severity:"warn",visibility:r});},Is=(e,t,r="dev")=>{$n(e,t,{severity:"warn",visibility:r});},Se=(e,t)=>In(e,t,{severity:"critical",visibility:"always"}),yt=(e,t)=>$n(e,t,{severity:"critical",visibility:"always"}),Lt=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
13
|
-
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(
|
|
14
|
-
Use setStore("${o}", "path", value) or recreate the store with an object shape.`),
|
|
12
|
+
Call createStore("${e}", data) first.`);};var ie=new Set(["__proto__","constructor","prototype"]),or=(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 Re=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,pn=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},We=e=>{let t=Re(e);return t==="function"?(N(Zr()),false):t==="map"||t==="set"?(f(en()),true):(t==="date"&&f(tn()),true)},nr=(e,t)=>{let r=pn(e);if(r)throw new Error(`${r} values are not supported`);let n=Re(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&&!nr(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||ie.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!nr(i.value,t))return false}return true}return true},sr=e=>nr(e,new WeakSet),st=(e,t)=>{let r=pn(e);if(r)throw new Error(`${r} values are not supported`);let n=Re(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 k()&&f(rn()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),k()&&f(nn());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)]=st(i,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),k()&&f(on()),Array.from(e,o=>st(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&&!ie.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);o[i]=st(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=>st(o,t))}return e},Fe=e=>st(e,new WeakSet),ir=e=>typeof e!="string"||e.trim()===""?(N(ln(e)),false):ie.has(e)?(N(fn(e)),false):e.includes(" ")?(N(dn(e)),false):true;var ar=null,ws=()=>{if(ar)return ar;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 ar=t,t},yn=e=>{let t=ws(),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},vs=2166136261,xs=2654435761,Rs=1e5,Ce=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},Ae=(e,t)=>{Ce(e,t.length);for(let r=0;r<t.length;r++)Ce(e,t.charCodeAt(r));},I=(e,t)=>{Ae(e,t);},gn=(e,t)=>{if(Number.isNaN(t)){I(e,"NaN");return}if(!Number.isFinite(t)){I(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){I(e,"-0");return}let r=t|0;if(t===r){I(e,"int"),Ce(e,r);return}I(e,"num"),Ae(e,String(t));},He=(e,t)=>{if(e.nodes++>Rs){I(e,"[max]");return}if(t===null){I(e,"null");return}let r=typeof t;if(r==="string"){I(e,"string"),Ae(e,t);return}if(r==="number"){I(e,"number"),gn(e,t);return}if(r==="boolean"){I(e,t?"true":"false");return}if(r==="undefined"){I(e,"undefined");return}if(r==="bigint"){I(e,"bigint"),Ae(e,t.toString());return}if(r==="symbol"){I(e,"symbol");let u=t;Ae(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){I(e,"function"),Ae(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){I(e,"ref"),Ce(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){I(e,"array"),Ce(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?He(e,n[u]):I(e,"hole");return}if(n instanceof Date){I(e,"date"),gn(e,n.getTime());return}if(n instanceof Map){I(e,"map"),Ce(e,n.size),n.forEach((u,c)=>{He(e,c),He(e,u);});return}if(n instanceof Set){I(e,"set"),Ce(e,n.size),n.forEach(u=>{He(e,u);});return}I(e,"object");let i=Object.getOwnPropertyDescriptors(n),a=[];Object.entries(i).forEach(([u,c])=>{c?.enumerable&&(ie.has(u)||"get"in c||"set"in c||a.push([u,c]));}),Ce(e,a.length);for(let[u,c]of a)Ae(e,u),He(e,c.value);},it=e=>{if(typeof e=="string")return yn(JSON.stringify(e));let t={h1:vs,h2:xs,seen:new WeakMap,nextId:1,nodes:0};He(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 Cs=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",De=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&&(ie.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},ks=e=>cr(e)===null,Ms=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.`)},Oe=(e,t=new WeakMap)=>{if(Ms(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(Oe(i,t),Oe(s,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(s=>{o.add(Oe(s,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((s,i)=>{o[i]=Oe(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||ie.has(o)||"get"in s||"set"in s||(r[o]=Oe(s.value,t));}),r},V=e=>{if(Cs)try{return structuredClone(e)}catch(t){if(!ks(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 f(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),Oe(e)}return Oe(e)},ur=(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 Sn=10,Ts=5,Es=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},Le=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?Es(e):[String(e)],at=e=>{let t=Le(e),r=t.length;return r>Sn?(N(sn(r,Sn,t)),false):(r>Ts&&f(an(r,t)),true)},dr=(e,t,r)=>{let n=Le(t);if(n.length===0)return e;for(let s of n)if(ie.has(s))return H(`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 d=[...s];return u?(d[c]=r,d):(d[c]=o(d[c],i+1),d)}if(s&&typeof s=="object"){if(ie.has(a))return H(`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)),d=c?[]:{};if(c){let x=d,b=Number(a);return x[b]=o(void 0,i+1),x}return d[a]=o(void 0,i+1),d}return u?r:s};return o(e,0)};var pr=new Set,Fs=()=>{pr.clear();};A("options.legacy-warnings",Fs,30);var Dt=(()=>{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"}})(),fr=e=>{try{return typeof window>"u"?Dt:e==="session"||e==="sessionStorage"?window.sessionStorage??Dt:window.localStorage??Dt}catch{return Dt}},ct=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Be=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),hn=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}},As=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",mn=e=>{try{e[As]=!0;}catch{}return e},Os={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"},Ds=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:mn(x=>x),decrypt:mn(x=>x),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:fr("localStorage"),...r};if(typeof e=="string")return {driver:fr(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,d=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(a&&hn(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||fr("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:d,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},bn=e=>{if(!ct(e))return [];let t=[];return Object.entries(Os).forEach(([r,n])=>{Be(e,r)&&(pr.has(r)||(pr.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},wn=(e={},t,r="deep")=>{let n=e.scope??"request",o=e.lazy===true,s=e.pathCreate===true,i=ct(e.lifecycle)?e.lifecycle:void 0,a=ct(e.persist)?e.persist:void 0,u=ct(e.devtools)?e.devtools:void 0,c=e.validate??e.validator??e.schema,d=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",x=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,b=ct(e.features)?{...e.features}:void 0,m=Be(e,"persist"),C=Be(e,"sync"),l=Be(e,"devtools")||Be(e,"historyLimit")||Be(e,"redactor"),p=n==="global"?true:e.allowSSRGlobalStore??false,{persist:g=false,devtools:R=false,onError:v,sync:E}=e;if(a?.sensitiveData===true){let F=a.encrypt,h=a.encryptAsync;if((!F||hn(F))&&!h)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:n,lazy:o,pathCreate:s,persist:n==="temp"&&!m?null:Ds(g,t),devtools:n==="temp"&&!l?false:typeof R=="boolean"?R: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:v,validate:c,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:n==="temp"&&!l?void 0:u?.redactor??e.redactor,historyLimit:n==="temp"&&!l?0:u?.historyLimit??e.historyLimit??50,sync:n==="temp"&&!C?false:E??false,features:b,allowSSRGlobalStore:p,snapshot:d,snapshotSafety:x,explicitPersist:m,explicitSync:C,explicitDevtools:l}};var Pt=Symbol("stroid.middleware.abort"),vn=({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=V(t.next);for(let a of r){if(typeof a!="function")continue;let u,c=i;try{u=a({action:t.action,name:e,prev:t.prev,next:c,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(d){let x=`Middleware for "${e}" failed: ${d?.message??d}`;return n(x,"dev"),Pt}if(u&&typeof u.then=="function"){let d=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(d,"dev"),Pt}u===void 0?(k()&&!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},Vt=({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 re=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(n){let o=n?.message??n;se(`${t} callback threw: ${String(o)}`);}},Pe=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(re(o,"onError",e),r==="critical"){n==="dev"&&f(e),H(e);return}if(n==="always"){se(e);return}f(e);};var jt=null,xn=e=>{jt=e;},Rn=e=>jt?jt(e):[];A("computed.order-resolver",()=>{jt=null;},105);var Cn=()=>oe(ze(_e)),gr=()=>Cn().computedEntries,kn=()=>Cn().computedDependents;var Mn=e=>Object.prototype.hasOwnProperty.call(gr(),e);var Ps=e=>{let t=gr(),r=kn(),n=new Set,o=[...e];for(;o.length>0;){let d=o.shift(),x=r[d];if(x)for(let b of x)n.has(b)||(n.add(b),o.push(b));}if(n.size===0)return [];let s=d=>{let x=t[d];if(x)for(let b of x.deps)t[b]&&(n.has(b)||(n.add(b),s(b)));};Array.from(n).forEach(d=>s(d));let i=new Map,a=new Map;for(let d of n){let x=t[d];if(!x)continue;let b=0;for(let m of x.deps)n.has(m)&&(b++,a.has(m)||a.set(m,[]),a.get(m).push(d));i.set(d,b);}let u=[];for(let[d,x]of i)x===0&&u.push(d);u.sort();let c=[];for(;u.length>0;){let d=u.shift();c.push(d);let x=a.get(d)??[];for(let b of x){let m=(i.get(b)??1)-1;if(i.set(b,m),m===0){let C=u.findIndex(l=>l>b);C===-1?u.push(b):u.splice(C,0,b);}}}return c};xn(Ps);var yr=e=>{let t=gr()[e];if(!t)return null;let r=kn()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Tn=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")},Sr=e=>(Tn(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),En=e=>{if(!Tn(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 Nt=null;var Vs=()=>{Nt=null;};A("transaction.runner",Vs,120);var ut=e=>{let t=Nt?.get();return t||(e??oe()).transaction},js=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=()=>Nt?(Nt.get()?.depth??0)>0:ut().depth>0,K=(e,t)=>{let r=ut(t);r.failed=true,r.error||(r.error=js(e));},It=e=>{let t=oe();ut(t).pending.push(()=>Ot(t,e));},$t=(e,t)=>{let r=ut();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},qe=e=>{let t=ut();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Fn=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},mr=(e,t)=>{if(t==="ref"){if(!k())return e;try{return Sr(e)}catch{return e}}if(t==="shallow"){let n=De(e);if(!k())return n;try{return Sr(n)}catch{return n}}let r=V(e);if(!k())return r;try{return En(r)}catch{return r}};var An=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:n}=e,o=M().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 C of t)r.push(C),a.add(C);for(let C of s)a.has(C)&&n.push(C);for(let C of r)i.has(C)||n.push(C);}else for(let C of t)r.push(C),a.add(C),n.push(C);t.clear();let u=Rn(n),c=new Set(n);for(let C of u)c.has(C)||(n.push(C),c.add(C));let d=Number.isFinite(o.chunkSize)&&o.chunkSize>0?o.chunkSize:Number.POSITIVE_INFINITY,x=o.chunkDelayMs,b=d===Number.POSITIVE_INFINITY&&x===0;return {names:n,sliceSize:d,chunkDelayMs:x,runInline:b,prioritySet:i}};var hr=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}),br=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),wr=(e,t)=>{e&&(e.metrics=t);};var lt=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},On=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let n=()=>Ot(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(n):Promise.resolve().then(n);};var Ue=new Map,Dn=(e,t)=>{let r=Ue.get(e);return r||(r=new Set,Ue.set(e,r)),r.add(t),()=>{let n=Ue.get(e);n&&(n.delete(t),n.size===0&&Ue.delete(e));}},vr=e=>{let t=Ue.get(e);return !!t&&t.size>0},dt=(e,t,r)=>{let n=Ue.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 ft=null,_t=null;var Ns=()=>{ft=null,_t=null;};A("write-context.runner",Ns,121);var zt=()=>_t?.get()??ft,Ke=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(_t)return _t.run(e,t);let r=ft;ft=e;try{return t()}finally{ft=r;}};var Pn=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)},Vn=(e,t,r,n)=>{let o=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:u,prioritySet:c}=t,x=e.stores,b=e.subscribers,m=e.metaEntries,C=e.snapshotCache,l=M().defaultSnapshotMode,p=w=>Fn(m[w],l),g=w=>x[w],R=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),v=vr("beforeFlush"),E=vr("afterFlush"),F=w=>{v&&dt("beforeFlush",w,{type:"beforeFlush"});},h=(w,_)=>{E&&dt("afterFlush",w,{type:"afterFlush",elapsedMs:_});},S=w=>{let _=m[w];if(!_)return null;let P=_.lastCorrelationId??void 0,y=_.lastTraceContext??void 0;return !P&&!y?null:{correlationId:P,traceContext:y}},L=()=>{n();};if(u){for(let w of s){let _=b[w];if(!_||_.size===0)continue;let P=m[w]?.updateCount??0,y=p(w),pe=g(w),G=C[w],z=G&&G.source===pe&&G.mode===y?G.snapshot:(()=>{let q=mr(pe,y);return C[w]={version:r,snapshot:q,source:pe,mode:y},q})(),J=hr(m[w]?.metrics);F(w);let ue=R(),W=Array.from(_),Te=S(w),le=()=>{for(let q of W)try{q(z);}catch(ee){let ne=m[w]?.options?.snapshotSafety??"warn";if(k()&&(y==="ref"||y==="shallow")&&Pn(ee)){if(ne==="throw")throw ee;if(ne==="auto-clone")try{let we=V(z);f(`Snapshot mutation detected for "${w}". Delivered a cloned snapshot to the subscriber.`);try{q(we);}catch(rt){f(`Subscriber for "${w}" threw on cloned snapshot: ${rt?.message??rt}`);}continue}catch{}f(`Snapshot mutation detected for "${w}": ${ee?.message??ee}`);continue}f(`Subscriber for "${w}" threw: ${ee?.message??ee}`);}};Te?Ke(Te,le):le();let Z=R()-ue;h(w,Z),br(J,Z),wr(m[w],J),(m[w]?.updateCount??P)!==P&&o.pendingNotifications.add(w);}L();return}let T=w=>{let _=[];for(let P of s){if(w&&!w(P))continue;let y=b[P];if(!y||y.size===0)continue;let pe=m[P]?.updateCount??0,G=p(P),z=g(P),J=C[P],ue=J&&J.source===z&&J.mode===G?J.snapshot:(()=>{let W=mr(z,G);return C[P]={version:r,snapshot:W,source:z,mode:G},W})();_.push({name:P,snapshot:ue,version:pe,subscribers:Array.from(y),subscriberSet:new Set(y),notified:new Set,metrics:hr(m[P]?.metrics),totalMs:0,beforeHooked:false});}return _},B=c?T(w=>c.has(w)):[],be=T(w=>!c||!c.has(w)),Me=(w,_)=>{let P=()=>{if(w.length===0){_();return}let y=w.shift();if((m[y.name]?.updateCount??y.version)!==y.version){if(o.pendingNotifications.add(y.name),w.length===0){_();return}lt(P,a);return}let G=()=>{let Y=b[y.name];if(!(!Y||Y.size===0))for(let q of Y)y.subscriberSet.has(q)||(y.subscriberSet.add(q),y.subscribers.push(q));};G();let z=y.subscribers;if(z.length===0){if(w.length===0){_();return}lt(P,a);return}y.beforeHooked||(y.beforeHooked=true,F(y.name));let J=R(),ue=0,W=false,Te=S(y.name),le=()=>{for(let Y=0;Y<z.length&&ue<i;Y+=1){let q=z[Y];if(y.notified.has(q))continue;y.notified.add(q);try{q(y.snapshot);}catch(ne){let Ne=m[y.name]?.options?.snapshotSafety??"warn",we=p(y.name);if(k()&&(we==="ref"||we==="shallow")&&Pn(ne)){if(Ne==="throw")throw ne;if(Ne==="auto-clone")try{let O=V(y.snapshot);f(`Snapshot mutation detected for "${y.name}". Delivered a cloned snapshot to the subscriber.`);try{q(O);}catch(ge){f(`Subscriber for "${y.name}" threw on cloned snapshot: ${ge?.message??ge}`);}if(y.notified.add(q),ue+=1,(m[y.name]?.updateCount??y.version)!==y.version){W=!0,o.pendingNotifications.add(y.name);break}continue}catch{}f(`Snapshot mutation detected for "${y.name}": ${ne?.message??ne}`);continue}f(`Subscriber for "${y.name}" threw: ${ne?.message??ne}`);}if(ue+=1,(m[y.name]?.updateCount??y.version)!==y.version){W=true,o.pendingNotifications.add(y.name);break}}};if(Te?Ke(Te,le):le(),y.totalMs+=R()-J,W){if(w.length===0){_();return}lt(P,a);return}G();let Z=false;for(let Y of z)if(!y.notified.has(Y)){Z=true;break}if(Z?w.push(y):(br(y.metrics,y.totalMs),wr(m[y.name],y.metrics),h(y.name,y.totalMs)),w.length===0){_();return}lt(P,a);};P();};B.length>0?Me(B,()=>Me(be,L)):Me(be,L);};var Is=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,n=An(t);Vn(e,n,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&xr(e);});},xr=e=>{On(e,Is);};var Wt=null,jn=e=>(Wt=e,()=>{Wt===e&&(Wt=null);}),Ge=e=>{Wt?.(e);};var $s=e=>{let t=j(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&xr(t);};jn($s);var _s=()=>{let e=j().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};A("notify.reset",_s,40);var Ht=new Set,In=e=>e?Ht.has(e):Ht.size>0,$n=e=>{e&&Ht.add(e);},zs=()=>{Ht.clear();};A("ssr.warnings",zs,60);var Nn=new Set,Ws=e=>{let t=Jr();return !t||e.includes("::")?e:(k()&&!Nn.has(e)&&(Nn.add(e),f(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},ke=e=>Ws(typeof e=="string"?e:e.name),_n=e=>ae(e)&&!Hn(e)?true:(rr(e,Object.keys(St)),false),zn=(e,t,r={})=>{Pe(t,{...r,onError:$[e]?.options?.onError});},Wn=(e,t,r={})=>{Pe(e,{...r,onError:t});},gt=(e,t,r="dev")=>{zn(e,t,{severity:"warn",visibility:r});},Hs=(e,t,r="dev")=>{Wn(e,t,{severity:"warn",visibility:r});},Se=(e,t)=>zn(e,t,{severity:"critical",visibility:"always"}),yt=(e,t)=>Wn(e,t,{severity:"critical",visibility:"always"}),Lt=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
13
|
+
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Hs(n,r,"always"),M().strictMissingFeatures)throw new Error(n)};var Ln=new WeakMap,Bn=new WeakMap,Ls=500,Bs="",mt=e=>{let t=Ln.get(e);return t||(t=new Map,Ln.set(e,t)),t},Cr=e=>{let t=Bn.get(e);return t||(t=new Map,Bn.set(e,t)),t},qs=(e,t)=>{let r=Cr(e),n=r.get(t);return n||(n=new Map,r.set(t,n)),n},Us=()=>{let e=M().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?Ls:Math.max(0,Math.floor(e))},qn=(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=mt(j());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let n=r[t];return typeof n=="function"?n.bind(r):n},set:(e,t,r)=>(mt(j())[t]=r,true)});var Un=(e,t,r,n)=>{let o=$[e];if(!o)return {ok:true};let s=Le(r);if(s.length===0)return {ok:true};let i=Re(n),a=Us(),u=j(),c=mt(u),d=qs(u,e),x=s.join(Bs),b=c.get(e);b||(b={children:new Map},c.set(e,b));let m=b;for(let v of s){let E=m.children.get(v);E||(E={children:new Map},m.children.set(v,E)),m=E;}let C=m.verdicts?.get(i);if(C){let v=`${x}|${i}`;return qn(d,v,{node:m,type:i},a),C}let l=o.options?.pathCreate===true,p=t,g={ok:true};for(let v=0;v<s.length;v++){let E=s[v],F=v===s.length-1;if(p==null){let S=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,v).join(".")||"root"}" is ${p===null?"null":"undefined"}.`;H(S),g={ok:false,reason:S};break}if(typeof p!="object"){let S=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,v).join(".")||"root"}" is not an object.`;H(S),g={ok:false,reason:S};break}if(Array.isArray(p)){let S=Number(E);if(!Number.isInteger(S)||S<0){let T=`Path "${s.join(".")}" targets non-numeric index "${E}" on an array in "${e}".`;H(T),g={ok:false,reason:T};break}let L=p;if(S>=L.length){let T=`Path "${s.join(".")}" is invalid for "${e}" - index ${S} is out of bounds (length ${L.length}).`;H(T),g={ok:false,reason:T};break}if(F){let T=L[S];if(T!=null){let B=Re(T);if(B!==i){let be=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${B}, received ${i}.`;H(be),g={ok:false,reason:be};break}}g={ok:true};break}p=L[S];continue}if(!Object.prototype.hasOwnProperty.call(p,E)){if(l&&F){g={ok:true};break}let S=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${E}" at "${s.slice(0,v).join(".")||"root"}".`;H(S),g={ok:false,reason:S};break}if(F){let S=p[E];if(S!=null){let L=Re(S);if(L!==i){let T=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${L}, received ${i}.`;H(T),g={ok:false,reason:T};break}}g={ok:true};break}p=p[E];}m.verdicts||(m.verdicts=new Map);let R=m.verdicts.has(i);if(m.verdicts.set(i,g),!R){let v=`${x}|${i}`;qn(d,v,{node:m,type:i},a);}return g},Ve=(e,t,r,n)=>{try{return n?.reuseInput&&sr(t)?{ok:!0,value:t}:{ok:!0,value:Fe(t)}}catch(o){let s=`Sanitize failed for "${e}": ${o?.message??o}`;return re($[e]?.options?.onError,`onError(${e})`,s),re(r,`onError(${e})`,s),f(s),{ok:false}}},Ks=(e,t)=>{let r=new Set,n=$[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},kr=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let o=Ks(e,n),s=(a,u)=>{o.forEach(c=>re(c,`onError(${e})`,a)),u==="critical"?H(a):f(a);};if(typeof r=="function")try{let a=r(t);return a===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:a===!0?t:a}}catch(a){return s(`Validation for "${e}" failed: ${a?.message??a}`,"critical"),{ok:false}}let i=or(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},ht=(e,t,r,n,o)=>{let s=Ve(e,t,n,o);if(!s.ok)return {ok:false};let i=kr(e,s.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},me=e=>{let t=j();mt(t).delete(e),Cr(t).delete(e);},Gs=()=>{let e=j();mt(e).clear(),Cr(e).clear();};A("validation.path-cache",Gs,50);Kn(me);var Bt=(e,t=j())=>{if((D()?qe(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=Ve(e,o,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=ht(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(D()){let u=a.value;$t(e,u),It(()=>{fe(e,u,t),t.initialStates[e]=V(u),delete t.initialFactories[e],me(e);});}else fe(e,a.value,t),t.initialStates[e]=V(a.value),delete t.initialFactories[e],me(e);return !0}catch(o){return Se(e,`Lazy initializer for "${e}" failed: ${o?.message??o}`),false}};var Gn=new WeakMap,Yn=e=>{let t=Gn.get(e);return t||(t=new Map,Gn.set(e,t)),t},Ys=()=>{Yn(j()).clear();};A("features.contexts",Ys,100);var Xn=e=>{let t=j(),r=Yn(t),n=r.get(e);if(n)return n;let o=$[e];if(!o)return f(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:o.options,getMeta:()=>$[e],getStoreValue:()=>St[e],getAllStores:()=>St,getInitialState:()=>ro[e],hasStore:()=>ae(e),setStoreValue:i=>{fe(e,i);},applyFeatureState:(i,a)=>{no(e,i,a),me(e);},notify:()=>{},reportStoreError:i=>{Se(e,i);},warn:f,warnAlways:se,log:te,hashState:it,deepClone:V,sanitize:Fe,validate:i=>kr(e,i,$[e]?.options?.validate),isDev:k};return r.set(e,s),s},Jn=(e,t)=>{let r=M();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(Se(e,o),r.assertRuntime)throw new Error(o)},Qn=(e,t)=>{Ut();let r=Xn(e);r&&(r.notify=()=>t(e),Jn(e,r),de.forEach(n=>{n.onStoreCreate?.(r);}));},Zn=(e,t,r,n,o)=>{Ut();let s=Xn(e);if(!s)return;s.notify=()=>o(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:n});Jn(e,i),de.forEach(a=>{a.onStoreWrite?.(i);});};var eo=(e,t)=>vn({name:e,payload:t,middlewares:(()=>{let r=$[e]?.options?.middleware||[],n=M().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{gt(e,r,n);},warn:f}),qt=(e,t,r,n)=>Vt({name:e,label:t,fn:r,args:n,reportIssue:(o,s)=>{gt(e,o,s);}}),to=(e,t)=>{let r={...t};return r.persist&&!Tt("persist")&&(r.explicitPersist&&Lt(e,"persist",r.onError),r.persist=null),r.sync&&!Tt("sync")&&(r.explicitSync&&Lt(e,"sync",r.onError),r.sync=false),Tt("devtools")||(r.explicitDevtools&&Lt(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var Xs=32,Mr=new Set;A("store-write.slow-mutator-warned",()=>Mr.clear(),65);var Js=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var so=(e,t)=>{k()&&(t<Xs||Mr.has(e)||(Mr.add(e),f(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},io=e=>e??zt(),oo=(e,{name:t,prev:r,next:n,action:o,hookLabel:s,logMessage:i,context:a})=>{let u=e.metaEntries;fe(t,n,e),me(t);let c=Date.now();u[t].updatedAt=new Date(c).toISOString(),u[t].updatedAtMs=c;let d=a??zt();d&&(d.correlationId||d.traceContext)?(u[t].lastCorrelationId=d.correlationId??null,u[t].lastCorrelationAt=new Date(c).toISOString(),u[t].lastCorrelationAtMs=c,u[t].lastTraceContext=d.traceContext??null):(u[t].lastCorrelationId=null,u[t].lastCorrelationAt=null,u[t].lastCorrelationAtMs=null,u[t].lastTraceContext=null),Js(u[t]),Zn(t,o,r,n,Ge),qt(t,s,u[t].options[s],[r,n]),Ge(t),te(i);},ao=(e,t)=>{let r=t.context??zt();if(D()){$t(t.name,t.next),It(()=>oo(e,{...t,context:r}));return}oo(e,{...t,context:r});};var Qs=(e,t,r,n)=>{let o=ke(e),s=j(),i=s.metaEntries;if(!Bt(o,s))return {ok:false,reason:"validate"};if(!ae(o,s)){let p=`setStore("${o}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return Se(o,p),D()&&K(p),{ok:false,reason:"not-found"}}let a,u=D()?qe(o):{has:false,value:void 0},c=u.has?u.value:pt(o,s),d=typeof t=="function"&&r===void 0;if(d){let p=k()?Date.now():0;try{let g=M().mutatorProduce,R=!1,v,E=h=>{let S=t(h);return S!==void 0&&(R=!0,v=S),S},F=g?g(c,E):(()=>{let h=V(c);return E(h),h})();if(R&&M().strictMutatorReturns){let h=`setStore("${o}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return Se(o,h),D()&&K(h),{ok:!1,reason:"validate"}}R&&k()&&!M().strictMutatorReturns&&f(`setStore("${o}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=R&&!M().strictMutatorReturns?v:F;}catch(g){return Se(o,`Mutator for "${o}" failed: ${g?.message??g}`),D()&&K(g),{ok:false,reason:"validate"}}finally{p&&so(o,Date.now()-p);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!We(t))return D()&&K(`setStore("${o}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof c!="object"||c===null||Array.isArray(c))return N(`setStore("${o}", data) only merges into object stores.
|
|
14
|
+
Use setStore("${o}", "path", value) or recreate the store with an object shape.`),D()&&K(`setStore("${o}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let p=Ve(o,t);if(!p.ok)return D()&&K(`setStore("${o}") failed sanitize`),{ok:false,reason:"validate"};a={...c,...p.value};}else if(typeof t=="string"||Array.isArray(t)){if(!at(t))return D()&&K(`setStore("${o}") received invalid path`),{ok:false,reason:"invalid-args"};let p=Ve(o,r);if(!p.ok)return D()&&K(`setStore("${o}") failed sanitize`),{ok:false,reason:"validate"};let g=p.value,R=Un(o,c,t,g);if(!R.ok)return re(i[o]?.options?.onError,`onError(${o})`,R.reason??`Invalid path for "${o}".`),D()&&K(R.reason),{ok:false,reason:"path"};a=dr(c,t,g);}else {let p=`setStore("${o}") - invalid arguments.
|
|
15
15
|
Usage:
|
|
16
16
|
setStore("${o}", "field", value)
|
|
17
17
|
setStore("${o}", "nested.field", value)
|
|
18
18
|
setStore("${o}", { field: value })
|
|
19
19
|
setStore(storeDef, draft => { draft.field = value })
|
|
20
|
-
replaceStore("${o}", value) // full-store replace`;return
|
|
21
|
-
Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;yt(
|
|
22
|
-
This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),ae(e,c)){let
|
|
23
|
-
Call createStore("${n}", ...) first or omit stateAdapter to use the default AsyncState shape.`,a);if(!he(n)&&
|
|
24
|
-
Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,a);if(!he(n)){if(!
|
|
25
|
-
Call createStore("${n}", ...) first or enable autoCreate.`,a);if(
|
|
26
|
-
Call createStore("${n}", ...) first to avoid typos creating phantom stores.`;re(a,`fetchStore.onError(${n})`,
|
|
27
|
-
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
|
|
20
|
+
replaceStore("${o}", value) // full-store replace`;return N(p),re(i[o]?.options?.onError,`onError(${o})`,p),D()&&K(p),{ok:false,reason:"invalid-args"}}if(!We(a))return D()&&K(`setStore("${o}") produced invalid data`),{ok:false,reason:"validate"};let x=i[o]?.options?.validate,b=io(n),m=eo(o,{action:"set",prev:c,next:a,path:t,correlationId:b?.correlationId,traceContext:b?.traceContext});if(m===Pt)return D()&&K(`setStore("${o}") aborted by middleware`),{ok:false,reason:"middleware"};let l=ht(o,m,x,void 0,d&&m===a?{reuseInput:true}:void 0);if(!l.ok)return D()&&K(`setStore("${o}") failed validation`),{ok:false,reason:"validate"};try{if(ur(c,l.value))return {ok:!0}}catch{}return ao(s,{name:o,prev:c,next:l.value,action:"set",hookLabel:"onSet",logMessage:`Store "${o}" updated`,context:b}),{ok:true}},bt=(e,t,r,n)=>Qs(e,t,r,n);var ei=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},co=(e,t)=>t==="ref"?e:t==="shallow"?De(e):V(e);function Kt(e,t){let r=ke(e);if(!_n(r))return null;let n=j();if(!Bt(r,n))return null;Rr(r,n);let o=pt(r,n),s=ei(n.metaEntries[r],M().defaultSnapshotMode);return o===null||typeof o!="object"?o:co(o,s);}var he=e=>ae(e);var ti=()=>j().computedCleanups,uo=new WeakMap;var ri=e=>{let t=uo.get(e);return t||(t=new Map,uo.set(e,t)),t};var lo=e=>{let t=ti(),r=t.get(e);if(!r){k()&&f(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var fo=(e,t=j())=>ri(t).get(e)?.autoDispose===true;var po=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=(l,p)=>{Pe(p,{onError:s[l]?.options?.onError,severity:"warn",visibility:"dev"});},d=({name:l,prev:p,options:g,initialState:R,getMeta:v,getStoreValue:E,hasStore:F})=>({name:l,options:g,prev:p,getMeta:v,getStoreValue:E,getAllStores:()=>t,getInitialState:()=>R,hasStore:F,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:h=>{Pe(h,{onError:g.onError,severity:"warn",visibility:"dev"});},warn:f,warnAlways:se,log:te,hashState:it,deepClone:V,sanitize:Fe,validate:()=>({ok:true,value:p}),isDev:k}),x=({name:l,prev:p,options:g,initialState:R,phase:v})=>{let E=d({name:l,prev:p,options:g,initialState:R,getMeta:()=>s[l],getStoreValue:()=>t[l],hasStore:()=>Ee(e,l)}),F=d({name:l,prev:p,options:g,initialState:R,getMeta:()=>{},getStoreValue:()=>p,hasStore:()=>false});$e().forEach(h=>{let S=a.get(h);v==="before"?S?.beforeStoreDelete?.(E):S?.afterStoreDelete?.(F);});},b=l=>{if(!Ee(e,l))return;let p=t[l],g=s[l].options,R=n[l],v=r[l];u.add(l);try{v?.forEach(h=>{try{h(null);}catch(S){f(`Subscriber for "${l}" threw during delete: ${S?.message??S}`);}}),Vt({name:l,label:"onDelete",fn:g.onDelete,args:[p],reportIssue:(h,S)=>{Pe(h,{onError:g.onError,severity:"warn",visibility:S});}}),x({name:l,prev:p,options:g,initialState:R,phase:"before"}),delete t[l],delete r[l],delete n[l],delete o[l],delete s[l],delete i[l],Mn(l)&&lo(l);let F=e.computedDependents[l];if(F)for(let h of [...F]){let S=yr(h);if(S&&fo(h,e)&&S.deps.every(L=>!Ee(e,L))){b(h);continue}f(`[stroid] source store "${l}" was deleted. Computed store "${h}" depends on it and will return stale data. Call deleteComputed("${h}") to clean up.`);}x({name:l,prev:p,options:g,initialState:R,phase:"after"}),dt("afterStoreDelete",l,{type:"afterStoreDelete",prev:p}),At(e,{type:"deleted",name:l}),te(`Store "${l}" deleted`);}finally{u.delete(l);}};return {deleteExistingStore:b,clearAllStores:()=>{let l=[],g=0,R=Number.POSITIVE_INFINITY;for(;g<20;){let E=Object.keys(t);if(E.length===0)break;E.forEach(h=>{Ee(e,h)&&(b(h),l.push(h));}),g+=1;let F=Object.keys(t).length;if(F===0||F>=R)break;R=F;}let v=Object.keys(t).length;return v>0?f(`clearAllStores stopped after ${g} pass${g===1?"":"es"}; ${v} store(s) still registered (likely recreated during deletion).`):te(`All stores cleared (${l.length} stores removed)`),l},clearStores:l=>{let p=Object.keys(t).filter(g=>l?l.endsWith("*")?g.startsWith(l.slice(0,-1)):g===l:true);return p.forEach(g=>b(g)),p},reportStoreError:c}};var Tr=_e,yo=ze(Tr),So=null,X=()=>{let e=oe(yo);return Jt(e),e};var j=()=>X();var mo=(e,t)=>{At(e,t);};function Kn(e){So=e;}var Ye=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}}}),ni=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)}),oi=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)}),St=Ye(()=>X().stores);Ye(()=>X().subscribers);var ro=Ye(()=>X().initialStates);Ye(()=>X().initialFactories);var $=Ye(()=>X().metaEntries);Ye(()=>X().snapshotCache);var de=ni(()=>X().featureRuntimes),go=new WeakMap,si=e=>{let t=go.get(e);return t||(t=po(e),go.set(e,t)),t};oi(()=>si(X()));var ii=e=>{let t=de.get(e);if(t)return t;let r=Et(e);if(!r)return;let n=r();return de.set(e,n),n},Ut=()=>{$e().forEach(e=>{ii(e);});};Ut();var ae=(e,t)=>Ee(t??X(),e),pt=(e,t=X())=>{if(D()){let n=qe(e);if(n.has)return n.value}let r=nt();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},fe=(e,t,r=X())=>{r.stores[e]=t;},no=(e,t,r=Date.now())=>{fe(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,So?.(e));},Rr=(e,t=X())=>{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();},ai=()=>{Ur(X());},ci=()=>{de.forEach(e=>{try{e.resetAll?.();}catch{}}),de.clear();};A("features.reset",ci,10);A("registries.clear",ai,20);A("registry.default",()=>{Tr=_e,yo=ze(Tr);},115);var Hn=e=>qr(X(),e);var Gt=new Set,ui=e=>{Gt.clear();};A("store-create.ssr-global-warned",()=>ui(),65);function Er(e,t,r={}){if(D()){let h=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;yt(h,r.onError),K(h);return}if(!ir(e)){yt(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!We(t)){yt(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&k()&&f(`createStore("${e}") received an undefined initial value. This can be indistinguishable from a missing store in some consumers; consider null or an explicit shape if that is intentional.`),bn(r).forEach(h=>{f(h);});let o=to(e,wn(r,e,M().defaultSnapshotMode));if(o.scope==="temp"&&r.persist){let h=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;re(o.onError,`onError(${e})`,h),k()||se(h),N(h);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",u=o.allowSSRGlobalStore??false,c=j(),d=c.stores,x=c.subscribers,b=c.initialStates,m=c.initialFactories,C=c.metaEntries,l=c.scope==="request";if(a&&!u&&!l){let h=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
|
|
21
|
+
Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;yt(h,r.onError);return}if(a&&u&&!l&&!Gt.has(e)&&(Gt.add(e),se(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
|
|
22
|
+
This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),ae(e,c)){let h=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return gt(e,h),{name:e}}s&&!u&&!l&&!In(e)&&k()&&($n(e),f(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let p=Ve(e,t,o.onError);if(!p.ok)return;let g=p.value,R=o.lazy===true&&typeof t=="function",v=(x[e]?.size??0)>0;if(R)d[e]=void 0,m[e]=t;else {let h=ht(e,g,o.validate,o.onError);if(!h.ok)return;fe(e,h.value,c),b[e]=V(h.value);}let E=Date.now(),F=new Date(E).toISOString();return C[e]={createdAt:F,updatedAt:F,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},me(e),Qn(e,Ge),qt(e,"onCreate",C[e].options.onCreate,[g]),mo(c,{type:"created",name:e,isGlobal:o.scope==="global",isTemp:o.scope==="temp"}),v&&Ge(e),te(`Store "${e}" created -> ${JSON.stringify(g)}`),{name:e}}var U=()=>oe().async;var ho=100,Fr=100,di=1e3,Xe=()=>U().fetchRegistry,je=()=>U().inflight,Je=()=>U().requestVersion,Qe=()=>U().cacheMeta,Ar=()=>U().rateWindowStart,Or=()=>U().rateCount;var vo=()=>U().revalidateHandlers,wt=()=>U().storeCleanups,xo=()=>U().warnedOnce,Ro=()=>U().revalidateKeys,vt=()=>U().asyncMetrics,fi=e=>{let t=xo(),r=t.get(e);return r||(r=new Set,t.set(e,r)),r},pi=(e,t)=>{if(e.has(t)||(e.add(t),e.size<=di))return;let r=e.values().next().value;r!==void 0&&e.delete(r);},xt=(e,t,r)=>{let n=fi(e);n.has(t)||(pi(n,t),r());},bo=null,wo=e=>{e&&Array.from(e).forEach(t=>{try{t();}catch{}});},gi=e=>{let t=wt(),r=t[e];return r||(r=Object.create(null),t[e]=r),r},Co=(e,t)=>{Object.keys(t).length===0&&delete wt()[e];},ko=(e,t)=>{if(t){wo(e[t]),delete e[t];return}Object.keys(e).forEach(r=>{wo(e[r]),delete e[r];});},yi=e=>{let t=wt(),r=t[e];r&&(ko(r),delete t[e]);},Mo=e=>{let t=wt();Object.entries(t).forEach(([r,n])=>{n[e]&&(ko(n,e),Co(r,n));});},To=()=>{bo||(bo=Dn("afterStoreDelete",e=>{yi(e),Si(e);}));},Eo=()=>{Ft(U());},Fo=(e,t)=>{if(!t)return false;let r=Qe(),n=r[e];return n?n.expiresAt!==null&&n.expiresAt<=Date.now()?(delete r[e],false):Date.now()-n.timestamp<t:false},Si=e=>{let t=Xe(),r=Qe(),n=je(),o=Je(),s=Ar(),i=Or(),a=xo();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];});},Ao=e=>{let t=`${e}:`,r=Qe(),n=Je(),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<=ho)return;let s=o.length-ho;o.slice(0,s).forEach(([i])=>{delete r[i],delete n[i];});},Oo=e=>{let t=`${e}:`,r=je(),n=0;return Object.keys(r).forEach(o=>{(o===e||o.startsWith(t))&&(n+=1);}),n},Dr=(e,t,r="store")=>{To();let n=gi(e),o=n[r];o||(o=new Set,n[r]=o),o.add(t);},Pr=(e,t,r)=>{let o=wt()[e];if(!o)return;let s=i=>{let a=o[i];a&&(a.delete(t),a.size===0&&delete o[i]);};r?s(r):Object.keys(o).forEach(s),Co(e,o);},Do=e=>{To();};var Po=10,mi=10,Vr=3e4,hi=8,jo=(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});}),Vo=(e,t,r,n)=>Number.isFinite(r)?r:(f(`fetchStore("${e}") received non-finite ${t}; using ${n}.`),n),No=(e,t,r,n)=>{let o=Number.isFinite(t)?t:t>0?Po:0,s=Math.min(Po,Math.max(0,Math.trunc(o)));Number.isFinite(t)||f(`fetchStore("${e}") received non-finite retry; using ${s}.`);let i=Math.min(Vr,Math.max(mi,Vo(e,"retryDelay",r,400))),a=Math.min(hi,Math.max(1,Vo(e,"retryBackoff",n,1.7)));return s!==t&&f(`fetchStore("${e}") clamped retry attempts to ${s}.`),i!==r&&f(`fetchStore("${e}") clamped retryDelay to ${i}ms.`),a!==n&&f(`fetchStore("${e}") clamped retryBackoff to ${a}.`),{retry:s,retryDelay:i,retryBackoff:a}};var Io=(e,t)=>!t||t==="none"||e===null||typeof e!="object"?e:t==="shallow"?De(e):V(e);var Ze=(e,t,r,n)=>{if(typeof r=="function")try{r(n);}catch(o){f(`fetchStore("${e}") ${t} callback failed: ${o?.message??o}`);}},ce=(e,t,r)=>M().strictAsyncUsageErrors?bi(e,t,r):(Ze(e,"onError",r,t),k()?(N(t),null):(H(t),null)),bi=(e,t,r)=>{throw Ze(e,"onError",r,t),k()?N(t):H(t),new Error(t)};var Rt=(e,t)=>(Je()[e]??0)===t,$o=e=>{let t=Je(),r=(t[e]??0)+1;return t[e]=r,r},_o=(e,t)=>{let r=Je();r[e]===t&&delete r[e];},zo=(e,t)=>{let r=je();r[e]=t;},Wo=e=>{let t=je();delete t[e];},Ho=e=>!!je()[e],Lo=(e,t,r,n)=>{let o=je()[t];if(o)return vt().dedupes+=1,r&&o.transform&&o.transform!==r?(ce(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 et=1e3,jr=100,Bo=(e,t)=>{t-e.ratePruneState.lastAt<et||(e.ratePruneState.lastAt=t,Object.keys(e.rateWindowStart).forEach(r=>{t-(e.rateWindowStart[r]??0)>et&&(delete e.rateWindowStart[r],delete e.rateCount[r]);}));},qo=e=>{Bo(U(),e);},Uo=(e=et)=>{let t=U();t.ratePruneTimer||typeof setTimeout=="function"&&(t.ratePruneTimer=setTimeout(()=>{t.ratePruneTimer=null,Bo(t,Date.now());},e));},Ko=(e,t)=>{let r=Ar(),n=Or(),o=r[e],s=n[e]??0;return o!==void 0&&t-o<et?s>=jr?true:(n[e]=s+1,false):(r[e]=t,n[e]=1,false)};var Go=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},Yo=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 wi=e=>{if(!e||typeof e!="object")return false;let t=e;return "data"in t&&"loading"in t&&"error"in t&&"status"in t},vi=(e,t,r,n,o)=>{if(!he(e))return;let s=n.stateAdapter;if(s){try{let i=Kt({name:e}),a=u=>{bt(t,u,void 0,o);};Ke(o,()=>{s({name:e,prev:i,next:r,set:a});});}catch(i){f(`fetchStore("${e}") stateAdapter failed: ${i?.message??i}`);}return}Ke(o,()=>{bt(t,r,void 0,o);});},tt=(e,t,r,n)=>(f(`fetchStore("${e}") aborted`),Rt(t,r)&&he(e)&&n({loading:false,error:"aborted",status:"aborted",revalidating:false}),null);async function Ct(e,t,r={}){let n=ke(e);if(!n||typeof n!="string"){N("fetchStore requires a store name as first argument");return}let o={name:n};if(!t){N(`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:d,body:x,ttl:b,staleWhileRevalidate:m=false,dedupe:C=true,retry:l=0,retryDelay:p=400,retryBackoff:g=1.7,signal:R,cacheKey:v,responseType:E="auto"}=r,F=Qe(),h=Xe(),S=vt(),L=(()=>{let O=r.correlationId,Q=r.traceContext;return O||Q?{correlationId:O,traceContext:Q}:M().autoCorrelationIds?{correlationId:`stroid-${n}-${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,traceContext:Q}:null})();!R&&k()&&xt("noSignal",n,()=>{f(`fetchStore("${n}") called without an AbortSignal. Provide "signal" to enable cancellation (recommended).`);});let T=v?`${n}:${v}`:n,B=O=>vi(n,o,L?{...O,correlationId:L.correlationId,traceContext:L.traceContext}:O,r,L),be=typeof t!="string"&&typeof t!="function"&&typeof t?.then=="function",Me=No(n,l,p,g),w=false,_=be&&l>0,P=typeof window>"u"&&(typeof process<"u"?process.env?.NODE_ENV:void 0)==="production",y=r.autoCreate??M().asyncAutoCreate,pe=r.cloneResult??M().asyncCloneResult;if(u&&!he(n))return ce(n,`fetchStore("${n}") with stateAdapter requires an existing backing store.
|
|
23
|
+
Call createStore("${n}", ...) first or omit stateAdapter to use the default AsyncState shape.`,a);if(!he(n)&&P)return ce(n,`fetchStore("${n}") cannot create a backing store on the server in production.
|
|
24
|
+
Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,a);if(!he(n)){if(!y)return ce(n,`fetchStore("${n}") requires an existing backing store when autoCreate is disabled.
|
|
25
|
+
Call createStore("${n}", ...) first or enable autoCreate.`,a);if(k()&&xt("autoCreate",n,()=>{let O=`fetchStore("${n}") auto-created its backing store.
|
|
26
|
+
Call createStore("${n}", ...) first to avoid typos creating phantom stores.`;re(a,`fetchStore.onError(${n})`,O),f(O);}),Er(n,{data:null,loading:false,error:null,status:"idle"}),!he(n))return ce(n,`fetchStore("${n}") could not initialize its backing store.
|
|
27
|
+
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 O=Kt({name:n});if(O&&!wi(O))return xt("shape",n,()=>{}),ce(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)}Do();let G=null,z=false,J=()=>F[T]?.data??null;if(Fo(T,b)){if(S.cacheHits+=1,G=J(),B({data:G,loading:m,error:null,status:"success",cached:true,revalidating:m}),!m)return G;z=true;}else S.cacheMisses+=1;if(C){let O=Lo(n,T,s,a);if(O!==void 0)return O}let ue=Date.now();if(qo(ue),Uo(),Ko(T,ue))return ce(n,`fetchStore("${n}") rate limited: ${jr} requests per ${et}ms window for store "${n}".`,a);if(!Ho(T)&&Oo(n)>=Fr)return ce(n,`fetchStore("${n}") exceeded ${Fr} concurrent request slots. Reuse cacheKey values, wait for pending requests, or delete the store to clear async state.`,a);let W=$o(T);z||B({loading:true,error:null,status:"loading",cached:false,revalidating:false}),S.requests+=1;let Te=Date.now(),le=!R&&typeof AbortController<"u"?new AbortController:null,Z=R||le?.signal,Y=le?()=>{le.signal.aborted||le.abort();}:null;Y&&Dr(n,Y);let q=async()=>{let O=0,Q=Me.retryDelay;for(;;){if(Z?.aborted)return tt(n,T,W,B);let ge=typeof t=="function"?t():t,Nr=be||typeof ge!="string"&&typeof ge?.then=="function",Ir=Nr?{...Me,retry:0}:Me;Nr&&(l>0||_)&&!w&&(f(`fetchStore("${n}") ignores retry settings for direct Promise inputs; pass a URL string or factory to use retries.`),w=true);try{let ve;if(typeof ge=="string"){let kt=Go({method:c,headers:d,body:x,signal:Z,...r}),Mt=await fetch(ge,kt);if(!Mt.ok)throw new Error(`HTTP ${Mt.status}: ${Mt.statusText}`);ve=await Yo(Mt,E);}else if(typeof ge.then=="function")ve=await ge;else return N(`fetchStore("${n}") - second argument must be a URL string, Promise, or Promise factory.
|
|
28
28
|
Examples:
|
|
29
29
|
fetchStore("users", "https://api.example.com/users")
|
|
30
|
-
fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(
|
|
30
|
+
fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(Z?.aborted)return tt(n,T,W,B);let Ie=s?s(ve):ve;if(Ie&&typeof Ie.then=="function"){let kt=`fetchStore("${n}") transform must be synchronous. Return the transformed value directly instead of a Promise.`;return Rt(T,W)&&B({data:z?J():null,loading:!1,error:kt,status:"error",cached:z,revalidating:!1}),ce(n,kt,a)}pe==="none"&&k()&&Ie&&typeof Ie=="object"&&xt("mutableResult",n,()=>{f(`fetchStore("${n}") received a mutable object while asyncCloneResult is "none".
|
|
31
31
|
Async data is stored by reference; mutations will affect cache and subscribers.
|
|
32
|
-
Set cloneResult: "deep" (per call) or configureStroid({ asyncCloneResult: "deep" }).`);});let
|
|
33
|
-
Call fetchStore("${t}", url) first.`);return}let o={name:t};return n.kind==="factory"?
|
|
32
|
+
Set cloneResult: "deep" (per call) or configureStroid({ asyncCloneResult: "deep" }).`);});let xe=Io(Ie,pe);if(Z?.aborted)return tt(n,T,W,B);if(!Rt(T,W))return null;F[T]={timestamp:Date.now(),expiresAt:b?Date.now()+b:null,data:xe},Ao(n),B({data:xe,loading:!1,error:null,status:"success",cached:!1,revalidating:!1}),Ze(n,"onSuccess",i,xe);let $r=Date.now()-Te;return S.lastMs=$r,S.avgMs=(S.avgMs*(S.requests-1)+$r)/S.requests,{raw:ve,transformed:xe}}catch(ve){if(O+=1,ve?.name==="AbortError")return tt(n,T,W,B);if(O<=Ir.retry){if(Z?.aborted||(await jo(Q,Z),Z?.aborted))return tt(n,T,W,B);Q=Math.min(Vr,Q*Ir.retryBackoff);continue}if(!Rt(T,W))return null;let xe=ve?.message||"Something went wrong";return B({data:z?J():null,loading:false,error:xe,status:"error",cached:z,revalidating:false}),Ze(n,"onError",a,xe),S.failures+=1,f(`fetchStore("${n}") failed: ${xe}`),null}}},ee=null,ne=new Promise((O,Q)=>{R||(ee=setTimeout(()=>{ee=null,Q(new Error("Timeout: async request hung for 60 seconds without an AbortSignal"));},6e4));}),Ne=Promise.race([q().finally(()=>{ee&&(clearTimeout(ee),ee=null);}),ne]).catch(O=>{let Q=O?.message||"Request timed out";return B({data:z?J():null,loading:false,error:Q,status:"error",cached:z,revalidating:false}),Ze(n,"onError",a,Q),S.failures+=1,f(`fetchStore("${n}") failed: ${Q}`),null}),we=Ne.then(O=>O?.transformed??null).finally(()=>{Wo(T),_o(T,W),Y&&Pr(n,Y);}),rt=Ne.then(O=>O?.raw);return zo(T,{promise:we,raw:rt,transform:s}),typeof t=="function"?h[n]={kind:"factory",factory:t,options:{...r,cacheKey:v}}:typeof t=="string"?h[n]={kind:"url",url:t,options:{...r,cacheKey:v}}:delete h[n],we}async function Xo(e){let t=ke(e);if(!he(t))return;let n=Xe()[t];if(!n){let s=`${t}:`,i=Qe(),a=Object.entries(i).filter(([u])=>u===t||u.startsWith(s));if(a.length>0){let[,u]=a.reduce((c,d)=>d[1].timestamp>=c[1].timestamp?d:c);return u.data}k()&&f(`refetchStore("${t}") - no previous fetch found.
|
|
33
|
+
Call fetchStore("${t}", url) first.`);return}let o={name:t};return n.kind==="factory"?Ct(o,n.factory,n.options):Ct(o,n.url,n.options)}function xi(e,t){if(typeof window>"u"||typeof window.addEventListener!="function")return ()=>{};let r=Ro(),n=vo(),s=(e==="*"?"*":e?ke(e):void 0)??"*";if(r.has(s))return n[s]??(()=>{});let i=M().revalidateOnFocus,a=Math.max(0,t?.debounceMs??i.debounceMs),u=Math.max(1,t?.maxConcurrent??i.maxConcurrent),c=Math.max(0,t?.staggerMs??i.staggerMs),d=null,x=()=>{let C=Xe(),l=s==="*"?Object.keys(C):[s];if(t?.priority==="high"&&s!=="*"&&(l=[s,...l.filter(R=>R!==s)]),l.length===0)return;let p=0,g=()=>{let R=l.slice(p,p+u);if(R.forEach((v,E)=>{let F=()=>{let S=Xe()[v];if(!S){Xo({name:v});return}S.kind==="factory"?Ct({name:v},S.factory,S.options):Ct({name:v},S.url,S.options);};c>0?setTimeout(F,E*c):F();}),p+=R.length,p<l.length){let v=c>0?c*Math.max(1,R.length):0;setTimeout(g,v);}};g();},b=()=>{if(a===0){x();return}d!==null&&clearTimeout(d),d=setTimeout(x,a);};window.addEventListener("focus",b),window.addEventListener("online",b),r.add(s);let m=()=>{window.removeEventListener("focus",b),window.removeEventListener("online",b),d!==null&&(clearTimeout(d),d=null),r.delete(s),delete n[s],Pr(s,m,"revalidate");};return n[s]=m,Dr(s,m,"revalidate"),m}var Ri=()=>({...vt()}),Ci=()=>{ki(),Eo();},ki=()=>{Mo("revalidate");};export{Ci as _resetAsyncStateForTests,xi as enableRevalidateOnFocus,Ct as fetchStore,Ri as getAsyncMetrics,Xo as refetchStore};//# sourceMappingURL=async.js.map
|
|
34
34
|
//# sourceMappingURL=async.js.map
|