stroid 0.1.1 → 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 +235 -119
- package/README.md +104 -431
- package/dist/async.d.ts +42 -9
- package/dist/async.js +26 -26
- package/dist/async.js.map +1 -1
- package/dist/cache.d.ts +12 -0
- package/dist/computed.d.ts +46 -7
- package/dist/computed.js +11 -11
- package/dist/computed.js.map +1 -1
- package/dist/core.d.ts +5 -15
- package/dist/core.js +14 -15
- package/dist/core.js.map +1 -1
- package/dist/devtools.d.ts +30 -5
- package/dist/devtools.js +1 -1
- package/dist/devtools.js.map +1 -1
- package/dist/feature.d.ts +92 -14
- package/dist/feature.js +1 -1
- package/dist/feature.js.map +1 -1
- package/dist/helpers.d.ts +37 -3
- package/dist/helpers.js +14 -15
- package/dist/helpers.js.map +1 -1
- package/dist/index-internal.d.ts +44 -0
- package/dist/index.d.cts +170 -33
- package/dist/index.d.ts +170 -33
- package/dist/index.js +24 -23
- package/dist/index.js.map +1 -1
- package/dist/install.d.ts +6 -4
- package/dist/install.js +1 -1
- package/dist/install.js.map +1 -1
- package/dist/options.d.ts +295 -0
- package/dist/persist.d.ts +1 -1
- package/dist/persist.js +1 -1
- package/dist/persist.js.map +1 -1
- package/dist/react/index.d.ts +70 -0
- package/dist/react/index.js +38 -0
- package/dist/react/index.js.map +1 -0
- package/dist/registry.d.ts +117 -0
- package/dist/runtime-admin.d.ts +4 -2
- package/dist/runtime-admin.js +1 -1
- package/dist/runtime-admin.js.map +1 -1
- package/dist/runtime-tools.d.ts +66 -9
- package/dist/runtime-tools.js +2 -2
- package/dist/runtime-tools.js.map +1 -1
- package/dist/selectors.d.ts +4 -2
- package/dist/selectors.js +1 -1
- package/dist/selectors.js.map +1 -1
- package/dist/server.d.ts +30 -2
- package/dist/server.js +11 -10
- package/dist/server.js.map +1 -1
- package/dist/store-registry.d.ts +79 -0
- package/dist/sync.d.ts +1 -1
- package/dist/sync.js +1 -1
- package/dist/sync.js.map +1 -1
- package/dist/testing.d.ts +16 -4
- package/dist/testing.js +14 -15
- package/dist/testing.js.map +1 -1
- package/dist/tsdoc-metadata.json +11 -0
- package/dist/types.d.ts +65 -0
- package/dist/utility.d.ts +15 -0
- package/package.json +29 -11
- package/dist/_tsup-dts-rollup.d.cts +0 -2411
- package/dist/_tsup-dts-rollup.d.ts +0 -2411
- package/dist/async.cjs +0 -34
- package/dist/async.cjs.map +0 -1
- package/dist/async.d.cts +0 -9
- package/dist/computed.cjs +0 -13
- package/dist/computed.cjs.map +0 -1
- package/dist/computed.d.cts +0 -7
- package/dist/core.cjs +0 -24
- package/dist/core.cjs.map +0 -1
- package/dist/core.d.cts +0 -15
- package/dist/devtools.cjs +0 -2
- package/dist/devtools.cjs.map +0 -1
- package/dist/devtools.d.cts +0 -5
- package/dist/feature.cjs +0 -2
- package/dist/feature.cjs.map +0 -1
- package/dist/feature.d.cts +0 -14
- package/dist/helpers.cjs +0 -24
- package/dist/helpers.cjs.map +0 -1
- package/dist/helpers.d.cts +0 -3
- package/dist/index.cjs +0 -35
- package/dist/index.cjs.map +0 -1
- package/dist/install.cjs +0 -2
- package/dist/install.cjs.map +0 -1
- package/dist/install.d.cts +0 -4
- package/dist/persist.cjs +0 -2
- package/dist/persist.cjs.map +0 -1
- package/dist/persist.d.cts +0 -1
- package/dist/react.cjs +0 -36
- package/dist/react.cjs.map +0 -1
- package/dist/react.d.cts +0 -7
- package/dist/react.d.ts +0 -7
- package/dist/react.js +0 -36
- package/dist/react.js.map +0 -1
- package/dist/runtime-admin.cjs +0 -2
- package/dist/runtime-admin.cjs.map +0 -1
- package/dist/runtime-admin.d.cts +0 -2
- package/dist/runtime-tools.cjs +0 -4
- package/dist/runtime-tools.cjs.map +0 -1
- package/dist/runtime-tools.d.cts +0 -9
- package/dist/selectors.cjs +0 -2
- package/dist/selectors.cjs.map +0 -1
- package/dist/selectors.d.cts +0 -2
- package/dist/server.cjs +0 -12
- package/dist/server.cjs.map +0 -1
- package/dist/server.d.cts +0 -2
- package/dist/sync.cjs +0 -2
- package/dist/sync.cjs.map +0 -1
- package/dist/sync.d.cts +0 -1
- package/dist/testing.cjs +0 -24
- package/dist/testing.cjs.map +0 -1
- package/dist/testing.d.cts +0 -4
package/dist/feature.d.ts
CHANGED
|
@@ -1,14 +1,92 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
1
|
+
import { N as NormalizedOptions, a as StoreValue } from './options.js';
|
|
2
|
+
import { T as TraceContext } from './utility.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* @module feature-registry
|
|
6
|
+
*
|
|
7
|
+
* LAYER: Module
|
|
8
|
+
* OWNS: Module-level behavior and exports for feature-registry.
|
|
9
|
+
*
|
|
10
|
+
* Consumers: Internal imports and public API.
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
type BuiltInFeatureName = "persist" | "sync" | "devtools";
|
|
14
|
+
type FeatureName = BuiltInFeatureName | (string & {});
|
|
15
|
+
interface FeatureMetrics {
|
|
16
|
+
notifyCount: number;
|
|
17
|
+
totalNotifyMs: number;
|
|
18
|
+
lastNotifyMs: number;
|
|
19
|
+
resetCount: number;
|
|
20
|
+
totalResetMs: number;
|
|
21
|
+
lastResetMs: number;
|
|
22
|
+
}
|
|
23
|
+
interface StoreFeatureMeta {
|
|
24
|
+
createdAt: string;
|
|
25
|
+
updatedAt: string;
|
|
26
|
+
updatedAtMs: number;
|
|
27
|
+
updateCount: number;
|
|
28
|
+
version: number;
|
|
29
|
+
metrics: FeatureMetrics;
|
|
30
|
+
options: NormalizedOptions;
|
|
31
|
+
readCount: number;
|
|
32
|
+
lastReadAt: string | null;
|
|
33
|
+
lastReadAtMs: number | null;
|
|
34
|
+
lastCorrelationId: string | null;
|
|
35
|
+
lastCorrelationAt: string | null;
|
|
36
|
+
lastCorrelationAtMs: number | null;
|
|
37
|
+
lastTraceContext: TraceContext | null;
|
|
38
|
+
}
|
|
39
|
+
interface FeatureHookContext {
|
|
40
|
+
name: string;
|
|
41
|
+
options: NormalizedOptions;
|
|
42
|
+
getMeta: () => StoreFeatureMeta | undefined;
|
|
43
|
+
getStoreValue: () => StoreValue;
|
|
44
|
+
getAllStores: () => Record<string, StoreValue>;
|
|
45
|
+
getInitialState: () => StoreValue;
|
|
46
|
+
hasStore: () => boolean;
|
|
47
|
+
setStoreValue: (value: StoreValue) => void;
|
|
48
|
+
applyFeatureState: (value: StoreValue, updatedAtMs?: number) => void;
|
|
49
|
+
notify: () => void;
|
|
50
|
+
reportStoreError: (message: string) => void;
|
|
51
|
+
warn: (message: string) => void;
|
|
52
|
+
warnAlways: (message: string) => void;
|
|
53
|
+
log: (message: string) => void;
|
|
54
|
+
hashState: (value: unknown) => number;
|
|
55
|
+
deepClone: <T>(value: T) => T;
|
|
56
|
+
sanitize: (value: unknown) => unknown;
|
|
57
|
+
validate: (next: StoreValue) => {
|
|
58
|
+
ok: boolean;
|
|
59
|
+
value?: StoreValue;
|
|
60
|
+
};
|
|
61
|
+
isDev: () => boolean;
|
|
62
|
+
}
|
|
63
|
+
/** @deprecated Use FeatureHookContext instead. */
|
|
64
|
+
type BaseFeatureContext = FeatureHookContext;
|
|
65
|
+
type FeatureCreateContext<Ext extends object = {}> = FeatureHookContext & Ext;
|
|
66
|
+
type FeatureWriteContext<Ext extends object = {}> = FeatureHookContext & Ext & {
|
|
67
|
+
action: string;
|
|
68
|
+
prev: StoreValue;
|
|
69
|
+
next: StoreValue;
|
|
70
|
+
};
|
|
71
|
+
type FeatureDeleteContext<Ext extends object = {}> = FeatureHookContext & Ext & {
|
|
72
|
+
prev: StoreValue;
|
|
73
|
+
};
|
|
74
|
+
interface DevtoolsFeatureApi {
|
|
75
|
+
getHistory?: (name: string, limit?: number) => unknown[];
|
|
76
|
+
clearHistory?: (name?: string) => void;
|
|
77
|
+
getPersistQueueDepth?: (name: string) => number;
|
|
78
|
+
}
|
|
79
|
+
interface StoreFeatureRuntime<Ext extends object = {}> {
|
|
80
|
+
onStoreCreate?: (ctx: FeatureCreateContext<Ext>) => void;
|
|
81
|
+
onStoreWrite?: (ctx: FeatureWriteContext<Ext>) => void;
|
|
82
|
+
beforeStoreDelete?: (ctx: FeatureDeleteContext<Ext>) => void;
|
|
83
|
+
afterStoreDelete?: (ctx: FeatureDeleteContext<Ext>) => void;
|
|
84
|
+
resetAll?: () => void;
|
|
85
|
+
api?: DevtoolsFeatureApi;
|
|
86
|
+
}
|
|
87
|
+
type StoreFeatureFactory<Ext extends object = {}> = () => StoreFeatureRuntime<Ext>;
|
|
88
|
+
declare const registerStoreFeature: <Ext extends object = {}>(name: FeatureName, factory: StoreFeatureFactory<Ext>) => void;
|
|
89
|
+
declare const hasRegisteredStoreFeature: (name: FeatureName) => boolean;
|
|
90
|
+
declare const getRegisteredFeatureNames: () => FeatureName[];
|
|
91
|
+
|
|
92
|
+
export { type BaseFeatureContext, type BuiltInFeatureName, type DevtoolsFeatureApi, type FeatureCreateContext, type FeatureDeleteContext, type FeatureHookContext, type FeatureMetrics, type FeatureName, type FeatureWriteContext, type StoreFeatureFactory, type StoreFeatureMeta, type StoreFeatureRuntime, getRegisteredFeatureNames, hasRegisteredStoreFeature, registerStoreFeature };
|
package/dist/feature.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var t=new Map,
|
|
1
|
+
var t=new Map,a=(e,r)=>{t.set(e,r);},n=e=>t.has(e);var u=()=>Array.from(t.keys());export{u as getRegisteredFeatureNames,n as hasRegisteredStoreFeature,a as registerStoreFeature};//# sourceMappingURL=feature.js.map
|
|
2
2
|
//# sourceMappingURL=feature.js.map
|
package/dist/feature.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/feature-registry.ts"],"names":["_featureFactories","registerStoreFeature","name","factory","hasRegisteredStoreFeature","getRegisteredFeatureNames"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../src/features/feature-registry.ts"],"names":["_featureFactories","registerStoreFeature","name","factory","hasRegisteredStoreFeature","getRegisteredFeatureNames"],"mappings":"AA8FA,IAAMA,CAAAA,CAAoB,IAAI,GAAA,CAGjBC,CAAAA,CAAuB,CAChCC,CAAAA,CACAC,CAAAA,GACO,CACPH,CAAAA,CAAkB,GAAA,CAAIE,CAAAA,CAAMC,CAAmC,EAEnE,CAAA,CAEaC,CAAAA,CAA6BF,CAAAA,EACtCF,EAAkB,GAAA,CAAIE,CAAI,EAKvB,IAAMG,EAA4B,IACrC,KAAA,CAAM,IAAA,CAAKL,CAAAA,CAAkB,MAAM","file":"feature.js","sourcesContent":["/**\r\n * @module feature-registry\r\n *\r\n * LAYER: Module\r\n * OWNS: Module-level behavior and exports for feature-registry.\r\n *\r\n * Consumers: Internal imports and public API.\r\n */\r\nimport type { NormalizedOptions, StoreValue } from \"../adapters/options.js\";\r\nimport type { TraceContext } from \"../types/utility.js\";\r\n\r\nexport type BuiltInFeatureName = \"persist\" | \"sync\" | \"devtools\";\r\nexport type FeatureName = BuiltInFeatureName | (string & {});\r\n\r\nexport interface FeatureMetrics {\r\n notifyCount: number;\r\n totalNotifyMs: number;\r\n lastNotifyMs: number;\r\n resetCount: number;\r\n totalResetMs: number;\r\n lastResetMs: number;\r\n}\r\n\r\nexport interface StoreFeatureMeta {\r\n createdAt: string;\r\n updatedAt: string;\r\n updatedAtMs: number;\r\n updateCount: number;\r\n version: number;\r\n metrics: FeatureMetrics;\r\n options: NormalizedOptions;\r\n readCount: number;\r\n lastReadAt: string | null;\r\n lastReadAtMs: number | null;\r\n lastCorrelationId: string | null;\r\n lastCorrelationAt: string | null;\r\n lastCorrelationAtMs: number | null;\r\n lastTraceContext: TraceContext | null;\r\n}\r\n\r\nexport interface FeatureHookContext {\r\n name: string;\r\n options: NormalizedOptions;\r\n getMeta: () => StoreFeatureMeta | undefined;\r\n getStoreValue: () => StoreValue;\r\n getAllStores: () => Record<string, StoreValue>;\r\n getInitialState: () => StoreValue;\r\n hasStore: () => boolean;\r\n setStoreValue: (value: StoreValue) => void;\r\n applyFeatureState: (value: StoreValue, updatedAtMs?: number) => void;\r\n notify: () => void;\r\n reportStoreError: (message: string) => void;\r\n warn: (message: string) => void;\r\n warnAlways: (message: string) => void;\r\n log: (message: string) => void;\r\n hashState: (value: unknown) => number;\r\n deepClone: <T>(value: T) => T;\r\n sanitize: (value: unknown) => unknown;\r\n validate: (next: StoreValue) => { ok: boolean; value?: StoreValue };\r\n isDev: () => boolean;\r\n}\r\n\r\n/** @deprecated Use FeatureHookContext instead. */\r\nexport type BaseFeatureContext = FeatureHookContext;\r\n\r\nexport type FeatureCreateContext<Ext extends object = {}> = FeatureHookContext & Ext;\r\n\r\nexport type FeatureWriteContext<Ext extends object = {}> = FeatureHookContext & Ext & {\r\n action: string;\r\n prev: StoreValue;\r\n next: StoreValue;\r\n};\r\n\r\nexport type FeatureDeleteContext<Ext extends object = {}> = FeatureHookContext & Ext & {\r\n prev: StoreValue;\r\n};\r\n\r\nexport interface DevtoolsFeatureApi {\r\n getHistory?: (name: string, limit?: number) => unknown[];\r\n clearHistory?: (name?: string) => void;\r\n getPersistQueueDepth?: (name: string) => number;\r\n}\r\n\r\nexport interface StoreFeatureRuntime<Ext extends object = {}> {\r\n onStoreCreate?: (ctx: FeatureCreateContext<Ext>) => void;\r\n onStoreWrite?: (ctx: FeatureWriteContext<Ext>) => void;\r\n beforeStoreDelete?: (ctx: FeatureDeleteContext<Ext>) => void;\r\n afterStoreDelete?: (ctx: FeatureDeleteContext<Ext>) => void;\r\n resetAll?: () => void;\r\n api?: DevtoolsFeatureApi;\r\n}\r\n\r\nexport type StoreFeatureFactory<Ext extends object = {}> = () => StoreFeatureRuntime<Ext>;\r\n\r\nconst _featureFactories = new Map<FeatureName, StoreFeatureFactory<any>>();\r\nlet _onFeatureRegistered: ((name: FeatureName, factory: StoreFeatureFactory<any>) => void) | null = null;\r\n\r\nexport const registerStoreFeature = <Ext extends object = {}>(\r\n name: FeatureName,\r\n factory: StoreFeatureFactory<Ext>\r\n): void => {\r\n _featureFactories.set(name, factory as StoreFeatureFactory<any>);\r\n _onFeatureRegistered?.(name, factory as StoreFeatureFactory<any>);\r\n};\r\n\r\nexport const hasRegisteredStoreFeature = (name: FeatureName): boolean =>\r\n _featureFactories.has(name);\r\n\r\nexport const getStoreFeatureFactory = (name: FeatureName): StoreFeatureFactory<any> | undefined =>\r\n _featureFactories.get(name);\r\n\r\nexport const getRegisteredFeatureNames = (): FeatureName[] =>\r\n Array.from(_featureFactories.keys());\r\n\r\nexport const setFeatureRegistrationHook = (hook: ((name: FeatureName, factory: StoreFeatureFactory<any>) => void) | null): void => {\r\n _onFeatureRegistered = hook;\r\n};\r\n\r\nexport const resetRegisteredStoreFeaturesForTests = (): void => {\r\n _featureFactories.clear();\r\n _onFeatureRegistered = null;\r\n};\r\n\r\n\r\n"]}
|
package/dist/helpers.d.ts
CHANGED
|
@@ -1,3 +1,37 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { W as WriteResult } from './types.js';
|
|
2
|
+
import { S as StoreOptions } from './options.js';
|
|
3
|
+
import './utility.js';
|
|
4
|
+
|
|
5
|
+
declare const createCounterStore: (name: string, initial?: number, options?: StoreOptions<{
|
|
6
|
+
value: number;
|
|
7
|
+
}>) => {
|
|
8
|
+
inc: (n?: number) => WriteResult;
|
|
9
|
+
dec: (n?: number) => WriteResult;
|
|
10
|
+
set: (v: number) => WriteResult;
|
|
11
|
+
reset: () => WriteResult;
|
|
12
|
+
get: () => number | null;
|
|
13
|
+
};
|
|
14
|
+
declare const createListStore: <T>(name: string, initial?: T[], options?: StoreOptions<{
|
|
15
|
+
items: T[];
|
|
16
|
+
}>) => {
|
|
17
|
+
push: (item: T) => WriteResult;
|
|
18
|
+
removeAt: (index: number) => WriteResult;
|
|
19
|
+
clear: () => WriteResult;
|
|
20
|
+
replace: (items: T[]) => WriteResult;
|
|
21
|
+
all: () => T[];
|
|
22
|
+
};
|
|
23
|
+
declare const createEntityStore: <T extends {
|
|
24
|
+
id?: string;
|
|
25
|
+
_id?: string;
|
|
26
|
+
}>(name: string, options?: StoreOptions<{
|
|
27
|
+
entities: Record<string, T>;
|
|
28
|
+
ids: string[];
|
|
29
|
+
}>) => {
|
|
30
|
+
upsert: (entity: T) => WriteResult;
|
|
31
|
+
remove: (id: string) => WriteResult;
|
|
32
|
+
all: () => T[];
|
|
33
|
+
get: (id: string) => T | null;
|
|
34
|
+
clear: () => WriteResult;
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
export { createCounterStore, createEntityStore, createListStore };
|
package/dist/helpers.js
CHANGED
|
@@ -1,24 +1,23 @@
|
|
|
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 Wo=new Map,F=(e,t,r=0)=>{!e||typeof t!="function"||Wo.set(e,{name:e,order:r,fn:t});};var Ft=new Map;var rt=e=>Ft.has(e),ot=e=>Ft.get(e),ve=()=>Array.from(Ft.keys());var dr=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),pr=()=>({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:dr(),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}}),fr=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(o=>{try{o();}catch{}});});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.storeCleanups).forEach(t=>delete e.storeCleanups[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),dr().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 Et=new Map,gr=new WeakSet,Vt=e=>{gr.has(e)||(gr.add(e),ve().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ot(t);r&&e.featureRuntimes.set(t,r());}}));},Lo=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,Sr,Dt=e=>(Sr||Lo||e).replace(/\.ts(\?|$)/,".js$1"),xe=Dt("stroid:default-registry");var Bo=()=>{Sr=void 0,Et.clear();};F("registry.scope-override",Bo,110);var Uo=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),qo=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},yr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),Ko=(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:yr(),async:pr(),notify:Uo(),lifecycleListener:null};return Vt(t),t},ke=e=>{let t=Dt(e),r=Et.get(t);if(r)return r;let o=Ko();return Et.set(t,o),o},ge=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),mr=(e,t)=>e.deletingStores.has(t),hr=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,qo(e.notify),fr(e.async),e.lifecycleListener=null;};var nt=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var $e=()=>null,ne=[],wr={run:(e,t)=>{ne.push(e);try{return t()}finally{ne.pop();}},get:()=>ne.length>0?ne[ne.length-1]:null,enterWith:e=>{if(ne.length>0){ne[ne.length-1]=e;return}ne.push(e);}};var st=(e,t)=>(wr).run(e,t),se=e=>(wr).get()||e||ke(xe);var Yo={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}`));}},vr={logSink:Yo,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},Nt=e=>({logSink:{...e.logSink},flush:{...e.flush},revalidateOnFocus:{...e.revalidateOnFocus},namespace:e.namespace,strictMissingFeatures:e.strictMissingFeatures,assertRuntime:e.assertRuntime,strictMutatorReturns:e.strictMutatorReturns,asyncAutoCreate:e.asyncAutoCreate,asyncCloneResult:e.asyncCloneResult,autoCorrelationIds:e.autoCorrelationIds,acknowledgeLooseTypes:e.acknowledgeLooseTypes,pathCacheSize:e.pathCacheSize,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce,selectorCloneFrozen:e.selectorCloneFrozen}),Ot=new WeakMap,xr=Nt(vr),Jo=e=>{let t=Ot.get(e);return t||(t=Nt(xr),Ot.set(e,t)),t};var C=()=>Jo(se());var en=()=>{Ot=new WeakMap,xr=Nt(vr);};F("config.reset",en,90);var kr=()=>C().namespace;var tn=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,rn=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,Rr=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,on="production",nn=tn??rn??on,ze=typeof Rr=="boolean"?Rr:nn!=="production",M=()=>ze,At=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},sn=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},an=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},$=(e,t)=>{if((C().logSink.critical??sn)(e,t),C().assertRuntime)throw new Error(e)},S=(e,t)=>{if(!ze)return;if((C().logSink.warn??At)(e,t),C().assertRuntime)throw new Error(e)},G=(e,t)=>{if((C().logSink.warn??At)(e,t),C().assertRuntime)throw new Error(e)},H=(e,t)=>{if(ze&&(C().logSink.warn??At)(e,t),$(e,t),C().assertRuntime)throw new Error(e)},B=(e,t)=>{if(!ze)return;(C().logSink.log??an)(e,t);},Cr=()=>`Functions cannot be stored in stroid.
|
|
2
|
+
Store data only - handle functions outside the store.`,Mr=()=>`Map/Set detected. stroid converts these to plain objects.
|
|
3
|
+
Use arrays or plain objects for best results.`,Tr=()=>`Date object detected. stroid stores it as ISO string.
|
|
4
|
+
Use new Date(value) to convert back when reading.`,Fr=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Er=()=>"Map detected; converting to plain object.",Vr=()=>"Set detected; converting to array.",Dr=(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]}", ...)`,Or=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
|
|
8
|
+
Consider splitting into separate stores for better readability.`,Nr=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,Ar=e=>`Cannot go deeper at "${e}" - value is not an object`,Pr=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,jr=e=>`Store name "${e}" contains spaces.
|
|
9
|
+
Use camelCase or kebab-case: "userName" or "user-name"`,Ir=e=>`Store name "${e}" is not allowed.
|
|
10
|
+
Reserved names: "__proto__", "constructor", "prototype".`,cn=128,ln=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=cn,un=(e,t)=>{if(e===t)return 0;if(e.length===0)return t.length;if(t.length===0)return e.length;let r=Array.from({length:e.length+1},(n,s)=>s),o=new Array(e.length+1);for(let n=1;n<=t.length;n++){o[0]=n;for(let s=1;s<=e.length;s++)o[s]=t[n-1]===e[s-1]?r[s-1]:Math.min(r[s-1],o[s-1],r[s])+1;[r,o]=[o,r];}return r[e.length]},Pt=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||ln(n,s)&&un(n,s)<=2});if(r){S(`Store "${e}" not found. Did you mean "${r}"?`);return}H(`Store "${e}" not found.
|
|
11
11
|
Available stores: [${t.join(", ")}]
|
|
12
|
-
Call createStore("${e}", data) first.`);};var I=new Set(["__proto__","constructor","prototype"]),rt=(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 G=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,It=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},he=e=>{let t=G(e);return t==="function"?($(Mt()),false):t==="map"||t==="set"?(b(Et()),true):(t==="date"&&b(Ft()),true)},tt=(e,t)=>{let r=It(e);if(r)throw new Error(`${r} values are not supported`);let n=G(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&&!tt(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||I.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!tt(i.value,t))return false}return true}return true},nt=e=>tt(e,new WeakSet),me=(e,t)=>{let r=It(e);if(r)throw new Error(`${r} values are not supported`);let n=G(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date")return x()&&b(Vt()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),x()&&b(Tt());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)]=me(i,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),x()&&b(Nt()),Array.from(e,o=>me(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,c]of Object.entries(s))if(c.enumerable&&!I.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);o[i]=me(c.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=>me(o,t))}return e},Q=e=>me(e,new WeakSet),ot=e=>typeof e!="string"||e.trim()===""?($(jt(e)),false):I.has(e)?($(_t(e)),false):e.includes(" ")?($($t(e)),false):true;var st=null,Zr=()=>{if(st)return st;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 st=t,t},Wt=e=>{let t=Zr(),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},en=2166136261,tn=2654435761,rn=1e5,Y=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},Z=(e,t)=>{Y(e,t.length);for(let r=0;r<t.length;r++)Y(e,t.charCodeAt(r));},V=(e,t)=>{Z(e,t);},zt=(e,t)=>{if(Number.isNaN(t)){V(e,"NaN");return}if(!Number.isFinite(t)){V(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){V(e,"-0");return}let r=t|0;if(t===r){V(e,"int"),Y(e,r);return}V(e,"num"),Z(e,String(t));},se=(e,t)=>{if(e.nodes++>rn){V(e,"[max]");return}if(t===null){V(e,"null");return}let r=typeof t;if(r==="string"){V(e,"string"),Z(e,t);return}if(r==="number"){V(e,"number"),zt(e,t);return}if(r==="boolean"){V(e,t?"true":"false");return}if(r==="undefined"){V(e,"undefined");return}if(r==="bigint"){V(e,"bigint"),Z(e,t.toString());return}if(r==="symbol"){V(e,"symbol");let d=t;Z(e,Symbol.keyFor(d)??d.description??String(d));return}if(r==="function"){V(e,"function"),Z(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){V(e,"ref"),Y(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){V(e,"array"),Y(e,n.length);for(let d=0;d<n.length;d++)Object.prototype.hasOwnProperty.call(n,d)?se(e,n[d]):V(e,"hole");return}if(n instanceof Date){V(e,"date"),zt(e,n.getTime());return}if(n instanceof Map){V(e,"map"),Y(e,n.size),n.forEach((d,g)=>{se(e,g),se(e,d);});return}if(n instanceof Set){V(e,"set"),Y(e,n.size),n.forEach(d=>{se(e,d);});return}V(e,"object");let i=Object.getOwnPropertyDescriptors(n),c=[];Object.entries(i).forEach(([d,g])=>{g?.enumerable&&(I.has(d)||"get"in g||"set"in g||c.push([d,g]));}),Y(e,c.length);for(let[d,g]of c)Z(e,d),se(e,g.value);},be=e=>{if(typeof e=="string")return Wt(JSON.stringify(e));let t={h1:en,h2:tn,seen:new WeakMap,nextId:1,nodes:0};se(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 nn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",it=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&&(I.has(n)||"get"in o||"set"in o||(t[n]=o.value));}),t},ie=(e,t=new WeakMap)=>{if(e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let s=new Map;return t.set(e,s),e.forEach((i,c)=>{s.set(ie(c,t),ie(i,t));}),s}if(e instanceof Set){let s=new Set;return t.set(e,s),e.forEach(i=>{s.add(ie(i,t));}),s}if(Array.isArray(e)){let s=[];return t.set(e,s),e.forEach((i,c)=>{s[c]=ie(i,t);}),s}let r=globalThis?.WeakRef;if(r&&e instanceof r)return z("WeakRef values cannot be deep-cloned. Returning the original reference."),e;let n={};t.set(e,n);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch{return z("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(o).forEach(([s,i])=>{!i.enumerable||I.has(s)||"get"in i||"set"in i||(n[s]=ie(i.value,t));}),n},N=e=>{try{if(nn)return structuredClone(e)}catch{}return ie(e)};var Ht=10,on=5,sn=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},ae=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?sn(e):[String(e)],ve=e=>{let t=ae(e),r=t.length;return r>Ht?($(Ot(r,Ht,t)),false):(r>on&&b(Dt(r,t)),true)},at=(e,t)=>{let r=ae(t),n=e;for(let o of r){if(n==null){b(Pt(r,o));return}if(typeof n!="object"){b(At(o));return}n=n[o];}return n},ct=(e,t,r)=>{let n=ae(t);if(n.length===0)return e;for(let s of n)if(I.has(s))return P(`Blocked forbidden path segment "${String(s)}" in setStore path "${n.join(".")}".`),e;let o=(s,i)=>{let c=n[i],d=i===n.length-1;if(Array.isArray(s)){let g=Number(c);if(!Number.isInteger(g))return s;let S=[...s];return d?(S[g]=r,S):(S[g]=o(S[g],i+1),S)}if(s&&typeof s=="object"){if(I.has(c))return P(`Blocked unsafe path segment "${String(c)}" while setting "${n.join(".")}".`),s;let g={...s};return d?(g[c]=r,g):(g[c]=o(g[c],i+1),g)}if(s==null&&!d){let g=Number.isInteger(Number(c)),S=g?[]:{};if(g){let v=S,p=Number(c);return v[p]=o(void 0,i+1),v}return S[c]=o(void 0,i+1),S}return d?r:s};return o(e,0)};var lt=new Set,an=()=>{lt.clear();};T("options.legacy-warnings",an,30);var De=(()=>{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"}})(),ut=e=>{try{return typeof window>"u"?De:e==="session"||e==="sessionStorage"?window.sessionStorage??De:window.localStorage??De}catch{return De}},we=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),ce=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Lt=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}},cn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Bt=e=>{try{e[cn]=!0;}catch{}return e},un={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"},ln=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Bt(S=>S),decrypt:Bt(S=>S),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:ut("localStorage"),...r};if(typeof e=="string")return {driver:ut(e),...r};let n=e.encrypt||r.encrypt,o=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,d=e.allowPlaintext===true,g=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(c&&Lt(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||ut("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:d,sensitiveData:c,checksum:g,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Ut=e=>{if(!we(e))return [];let t=[];return Object.entries(un).forEach(([r,n])=>{ce(e,r)&&(lt.has(r)||(lt.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},Kt=(e={},t,r="deep")=>{let n=e.scope??"request",o=e.lazy===true,s=e.pathCreate===true,i=we(e.lifecycle)?e.lifecycle:void 0,c=we(e.persist)?e.persist:void 0,d=we(e.devtools)?e.devtools:void 0,g=e.validate??e.validator??e.schema,S=e.snapshot==="shallow"||e.snapshot==="ref"?e.snapshot:r==="shallow"||r==="ref"?r:"deep",v=we(e.features)?{...e.features}:void 0,p=ce(e,"persist"),w=ce(e,"sync"),u=ce(e,"devtools")||ce(e,"historyLimit")||ce(e,"redactor"),a=n==="global"?true:e.allowSSRGlobalStore??false,{persist:f=false,devtools:l=false,onError:m,sync:k}=e;if(c?.sensitiveData===true){let M=c.encrypt,F=c.encryptAsync;if((!M||Lt(M))&&!F)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:n,lazy:o,pathCreate:s,persist:n==="temp"&&!p?null:ln(f,t),devtools:n==="temp"&&!u?false:typeof l=="boolean"?l:d?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:m,validate:g,migrations:c?.migrations??e.migrations??{},version:c?.version??e.version??1,redactor:n==="temp"&&!u?void 0:d?.redactor??e.redactor,historyLimit:n==="temp"&&!u?0:d?.historyLimit??e.historyLimit??50,sync:n==="temp"&&!w?false:k??false,features:v,allowSSRGlobalStore:a,snapshot:S,explicitPersist:p,explicitSync:w,explicitDevtools:u}};var qt=e=>{if(typeof e!="object"||e===null||e.$$typeof||typeof window<"u"&&e instanceof Element||e.constructor&&e.constructor.name!=="Object"&&e.constructor.name!=="Array")return e;let t=[e],r=new WeakSet;for(;t.length>0;){let n=t.pop();if(!r.has(n)){r.add(n),Object.isFrozen(n)||Object.freeze(n);for(let o of Object.keys(n)){let s=n[o];typeof s=="object"&&s!==null&&!r.has(s)&&t.push(s);}}}return e};var dt=new Map;var Pe=e=>dt.has(e),ft=e=>dt.get(e),ke=()=>Array.from(dt.keys());var Ae=Symbol("stroid.middleware.abort"),Yt=({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=N(t.next);for(let c of r){if(typeof c!="function")continue;let d,g=i;try{d=c({action:t.action,name:e,prev:t.prev,next:g,path:t.path});}catch(S){let v=`Middleware for "${e}" failed: ${S?.message??S}`;return n(v,"dev"),Ae}if(d&&typeof d.then=="function"){let S=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(S,"dev"),Ae}d===void 0?(x()&&!s.has(c)&&(s.add(c),o(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=g):i=d;}return i},je=({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 ee=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(o?.(e),r==="critical"){n==="dev"&&b(e),P(e);return}if(n==="always"){z(e);return}b(e);};var $e=null,Jt=e=>{$e=e;},Xt=e=>$e?$e(e):[];T("computed.order-resolver",()=>{$e=null;},105);var Qt=()=>U(Se(ge)),Zt=()=>Qt().computedEntries,fn=()=>Qt().computedDependents;var er=e=>Object.prototype.hasOwnProperty.call(Zt(),e);var pn=e=>{let t=Zt(),r=fn(),n=new Set,o=[...e];for(;o.length>0;){let S=o.shift(),v=r[S];if(v)for(let p of v)n.has(p)||(n.add(p),o.push(p));}if(n.size===0)return [];let s=S=>{let v=t[S];if(v)for(let p of v.deps)t[p]&&(n.has(p)||(n.add(p),s(p)));};Array.from(n).forEach(S=>s(S));let i=new Map,c=new Map;for(let S of n){let v=t[S];if(!v)continue;let p=0;for(let w of v.deps)n.has(w)&&(p++,c.has(w)||c.set(w,[]),c.get(w).push(S));i.set(S,p);}let d=[];for(let[S,v]of i)v===0&&d.push(S);d.sort();let g=[];for(;d.length>0;){let S=d.shift();g.push(S);let v=c.get(S)??[];for(let p of v){let w=(i.get(p)??1)-1;if(i.set(p,w),w===0){let u=d.findIndex(a=>a>p);u===-1?d.push(p):d.splice(u,0,p);}}}return g};Jt(pn);var _e=new Set,rr=e=>e?_e.has(e):_e.size>0,nr=e=>{e&&_e.add(e);},gn=()=>{_e.clear();};T("ssr.warnings",gn,60);var tr=new Set,Sn=e=>{let t=xt();return !t||e.includes("::")?e:(x()&&!tr.has(e)&&(tr.add(e),b(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},Re=e=>Sn(typeof e=="string"?e:e.name),Ie=e=>K(e)&&!ir(e)?true:(et(e,Object.keys(D)),false),or=(e,t,r={})=>{ee(t,{...r,onError:h[e]?.options?.onError});},sr=(e,t,r={})=>{ee(e,{...r,onError:t});},ue=(e,t,r="dev")=>{or(e,t,{severity:"warn",visibility:r});},yn=(e,t,r="dev")=>{sr(e,t,{severity:"warn",visibility:r});},J=(e,t)=>or(e,t,{severity:"critical",visibility:"always"}),xe=(e,t)=>sr(e,t,{severity:"critical",visibility:"always"}),ze=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
13
|
-
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(yn(n,r,"always"),R().strictMissingFeatures)throw new Error(n)};var Ce=e=>(e??U()).transaction,mn=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var C=()=>Ce().depth>0,A=(e,t)=>{let r=Ce(t);r.failed=true,r.error||(r.error=mn(e));},We=e=>{let t=U();Ce(t).pending.push(()=>Oe(t,e));},He=(e,t)=>{let r=Ce();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},te=e=>{let t=Ce();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var ar=new WeakMap,cr=new WeakMap,hn=500,bn="",Me=e=>{let t=ar.get(e);return t||(t=new Map,ar.set(e,t)),t},pt=e=>{let t=cr.get(e);return t||(t=new Map,cr.set(e,t)),t},vn=(e,t)=>{let r=pt(e),n=r.get(t);return n||(n=new Map,r.set(t,n)),n},ur=(e,t,r)=>{for(e.has(t)&&e.delete(t),e.set(t,r);e.size>hn;){let n=e.keys().next().value;if(!n)break;let o=e.get(n);e.delete(n),o?.node.verdicts&&(o.node.verdicts.delete(o.type),o.node.verdicts.size===0&&delete o.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=Me(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)=>(Me(j())[t]=r,true)});var lr=(e,t,r,n)=>{let o=h[e];if(!o)return {ok:true};let s=ae(r);if(s.length===0)return {ok:true};let i=G(n),c=j(),d=Me(c),g=vn(c,e),S=s.join(bn),v=d.get(e);v||(v={children:new Map},d.set(e,v));let p=v;for(let m of s){let k=p.children.get(m);k||(k={children:new Map},p.children.set(m,k)),p=k;}let w=p.verdicts?.get(i);if(w){let m=`${S}|${i}`;return ur(g,m,{node:p,type:i}),w}let u=o.options?.pathCreate===true,a=t,f={ok:true};for(let m=0;m<s.length;m++){let k=s[m],M=m===s.length-1;if(a==null){let y=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,m).join(".")||"root"}" is ${a===null?"null":"undefined"}.`;P(y),f={ok:false,reason:y};break}if(typeof a!="object"){let y=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,m).join(".")||"root"}" is not an object.`;P(y),f={ok:false,reason:y};break}if(Array.isArray(a)){let y=Number(k);if(!Number.isInteger(y)||y<0){let E=`Path "${s.join(".")}" targets non-numeric index "${k}" on an array in "${e}".`;P(E),f={ok:false,reason:E};break}let O=a;if(y>=O.length){let E=`Path "${s.join(".")}" is invalid for "${e}" - index ${y} is out of bounds (length ${O.length}).`;P(E),f={ok:false,reason:E};break}if(M){let E=O[y];if(E!=null){let ne=G(E);if(ne!==i){let pe=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${ne}, received ${i}.`;P(pe),f={ok:false,reason:pe};break}}f={ok:true};break}a=O[y];continue}if(!Object.prototype.hasOwnProperty.call(a,k)){if(u&&M){f={ok:true};break}let y=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${k}" at "${s.slice(0,m).join(".")||"root"}".`;P(y),f={ok:false,reason:y};break}if(M){let y=a[k];if(y!=null){let O=G(y);if(O!==i){let E=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${O}, received ${i}.`;P(E),f={ok:false,reason:E};break}}f={ok:true};break}a=a[k];}p.verdicts||(p.verdicts=new Map);let l=p.verdicts.has(i);if(p.verdicts.set(i,f),!l){let m=`${S}|${i}`;ur(g,m,{node:p,type:i});}return f},de=(e,t,r,n)=>{try{return n?.reuseInput&&nt(t)?{ok:!0,value:t}:{ok:!0,value:Q(t)}}catch(o){let s=`Sanitize failed for "${e}": ${o?.message??o}`;return h[e]?.options?.onError?.(s),r?.(s),b(s),{ok:false}}},wn=(e,t)=>{let r=new Set,n=h[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},gt=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let o=wn(e,n),s=(c,d)=>{o.forEach(g=>g(c)),d==="critical"?P(c):b(c);};if(typeof r=="function")try{let c=r(t);return c===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:c===!0?t:c}}catch(c){return s(`Validation for "${e}" failed: ${c?.message??c}`,"critical"),{ok:false}}let i=rt(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Be=(e,t,r,n,o)=>{let s=de(e,t,n,o);if(!s.ok)return {ok:false};let i=gt(e,s.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},X=e=>{let t=j();Me(t).delete(e),pt(t).delete(e);},kn=()=>{let e=j();Me(e).clear(),pt(e).clear();};T("validation.path-cache",kn,50);dr(X);var Ee=e=>{if((C()?te(e):{has:false}).has||D[e]!==void 0)return true;let r=le[e];if(!r)return true;try{let n=r(),o=de(e,n,h[e]?.options?.onError);if(!o.ok)return !1;let s=h[e]?.options?.validate,i=Be(e,o.value,s,h[e]?.options?.onError);if(!i.ok)return !1;if(C()){let c=i.value;He(e,c),We(()=>{q(e,c),B[e]=N(c),delete le[e],X(e);});}else q(e,i.value),B[e]=N(i.value),delete le[e],X(e);return !0}catch(n){return J(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};function Fe(e,t){let r=Re(e);if(!Ie(r)||!Ee(r))return null;let n=Ve(r);if(t===void 0)return n===null||typeof n!="object"?n:N(n);if(!ve(t))return null;let o=at(n,t);return o===null||typeof o!="object"?o:N(o)}var Le=e=>({name:e});var fr=e=>{let t=h[e]?.options?.snapshot??R().defaultSnapshotMode;return t==="shallow"||t==="ref"?t:"deep"},pr=(e,t)=>t==="ref"?e:t==="shallow"?it(e):N(e);var Ue=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Rn=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:n}=e;r.length=0;for(let u of t)r.push(u);t.clear();let o=R().flush,s=o.priorityStores||[],i=new Set(r),c=s.length?new Set(s):null;if(n.length=0,c){for(let u of s)i.has(u)&&n.push(u);for(let u of r)c.has(u)||n.push(u);}else n.push(...r);let d=Xt(n),g=new Set(n);for(let u of d)i.has(u)&&!g.has(u)&&(n.push(u),g.add(u));let S=Number.isFinite(o.chunkSize)&&o.chunkSize>0?o.chunkSize:Number.POSITIVE_INFINITY,v=o.chunkDelayMs,p=S===Number.POSITIVE_INFINITY&&v===0;return {names:n.slice(),sliceSize:S,chunkDelayMs:v,runInline:p,prioritySet:c}},xn=e=>{let t=e.notify,{names:r,sliceSize:n,chunkDelayMs:o,runInline:s,prioritySet:i}=Rn(t),c=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),d=()=>{t.notifyScheduled=false,t.pendingNotifications.size>0&&gr(e);};if(s){for(let u of r){let a=re[u];if(!a||a.size===0)continue;let f=h[u]?.updateCount??0,l=fr(u),m=Te[u],k=m&&m.version===f?m.snapshot:(()=>{let E=pr(D[u],l);return Te[u]={version:f,snapshot:E},E})(),M=c();for(let E of a)try{E(k);}catch(ne){b(`Subscriber for "${u}" threw: ${ne?.message??ne}`);}let F=c()-M,y=h[u]?.metrics||{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0};y.notifyCount+=1,y.totalNotifyMs+=F,y.lastNotifyMs=F,h[u]&&(h[u].metrics=y),(h[u]?.updateCount??f)!==f&&t.pendingNotifications.add(u);}d();return}let g=u=>{let a=[];for(let f of r){if(u&&!u(f))continue;let l=re[f];if(!l||l.size===0)continue;let m=h[f]?.updateCount??0,k=fr(f),M=Te[f],F=M&&M.version===m?M.snapshot:(()=>{let y=pr(D[f],k);return Te[f]={version:m,snapshot:y},y})();a.push({name:f,subsArray:Array.from(l),index:0,snapshot:F,version:m,notified:new Set,metrics:h[f]?.metrics?{...h[f].metrics}:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},totalMs:0});}return a},S=i?g(u=>i.has(u)):[],v=g(u=>!i||!i.has(u)),p=u=>{let a=re[u.name];if(!a||a.size===0){u.subsArray=[],u.index=0;return}u.subsArray=Array.from(a),u.index=0;},w=(u,a)=>{let f=()=>{if(u.length===0){a();return}let l=u.shift();if((h[l.name]?.updateCount??l.version)!==l.version){if(t.pendingNotifications.add(l.name),u.length===0){a();return}s?f():Ue(f,o);return}if(p(l),l.subsArray.length===0){if(u.length===0){a();return}s?f():Ue(f,o);return}let k=c(),M=0,F=false;for(;l.index<l.subsArray.length&&M<n;){let E=l.subsArray[l.index++];if(l.notified.has(E))continue;l.notified.add(E);try{E(l.snapshot);}catch(pe){b(`Subscriber for "${l.name}" threw: ${pe?.message??pe}`);}if(M+=1,(h[l.name]?.updateCount??l.version)!==l.version){F=true,t.pendingNotifications.add(l.name);break}}if(l.totalMs+=c()-k,F){if(u.length===0){a();return}s?f():Ue(f,o);return}let y=re[l.name],O=y?Array.from(y).some(E=>!l.notified.has(E)):false;if(l.index<l.subsArray.length||O?u.push(l):(l.metrics.notifyCount+=1,l.metrics.totalNotifyMs+=l.totalMs,l.metrics.lastNotifyMs=l.totalMs,h[l.name]&&(h[l.name].metrics=l.metrics)),u.length===0){a();return}s?f():Ue(f,o);};f();};S.length>0?w(S,()=>w(v,d)):w(v,d);},gr=e=>{let t=e.notify;if(t.notifyScheduled)return;t.notifyScheduled=true;let r=()=>Oe(e,()=>xn(e));typeof queueMicrotask=="function"?queueMicrotask(r):Promise.resolve().then(r);},Ne=e=>{let t=j(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&gr(t);};var Cn=()=>{let e=j().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};T("notify.reset",Cn,40);var Mn=()=>j().computedCleanups;var Sr=e=>{let t=Mn(),r=t.get(e);if(!r){x()&&b(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var yr=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,d=e.deletingStores,g=(a,f)=>{ee(f,{onError:s[a]?.options?.onError,severity:"warn",visibility:"dev"});},S=({name:a,prev:f,options:l,initialState:m,getMeta:k,getStoreValue:M,hasStore:F})=>({name:a,options:l,prev:f,getMeta:k,getStoreValue:M,getAllStores:()=>t,getInitialState:()=>m,hasStore:F,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:y=>{ee(y,{onError:l.onError,severity:"warn",visibility:"dev"});},warn:b,log:W,hashState:be,deepClone:N,sanitize:Q,validate:()=>({ok:true,value:f}),isDev:x}),v=({name:a,prev:f,options:l,initialState:m,phase:k})=>{let M=S({name:a,prev:f,options:l,initialState:m,getMeta:()=>s[a],getStoreValue:()=>t[a],hasStore:()=>oe(e,a)}),F=S({name:a,prev:f,options:l,initialState:m,getMeta:()=>{},getStoreValue:()=>f,hasStore:()=>false});ke().forEach(y=>{let O=c.get(y);k==="before"?O?.beforeStoreDelete?.(M):O?.afterStoreDelete?.(F);});},p=a=>{if(!oe(e,a))return;let f=t[a],l=s[a].options,m=n[a],k=r[a];d.add(a);try{k?.forEach(y=>{try{y(null);}catch(O){b(`Subscriber for "${a}" threw during delete: ${O?.message??O}`);}}),je({name:a,label:"onDelete",fn:l.onDelete,args:[f],reportIssue:(y,O)=>{ee(y,{onError:l.onError,severity:"warn",visibility:O});}}),v({name:a,prev:f,options:l,initialState:m,phase:"before"}),delete t[a],delete r[a],delete n[a],delete o[a],delete s[a],delete i[a],er(a)&&Sr(a);let F=e.computedDependents[a];if(F)for(let y of F)b(`[stroid] source store "${a}" was deleted. Computed store "${y}" depends on it and will return stale data. Call deleteComputed("${y}") to clean up.`);v({name:a,prev:f,options:l,initialState:m,phase:"after"}),W(`Store "${a}" deleted`);}finally{d.delete(a);}};return {deleteExistingStore:p,clearAllStores:()=>{let a=[],l=0,m=Number.POSITIVE_INFINITY;for(;l<20;){let M=Object.keys(t);if(M.length===0)break;M.forEach(y=>{oe(e,y)&&(p(y),a.push(y));}),l+=1;let F=Object.keys(t).length;if(F===0||F>=m)break;m=F;}let k=Object.keys(t).length;return k>0?b(`clearAllStores stopped after ${l} pass${l===1?"":"es"}; ${k} store(s) still registered (likely recreated during deletion).`):b(`All stores cleared (${a.length} stores removed)`),a},clearStores:a=>{let f=Object.keys(t).filter(l=>a?a.endsWith("*")?l.startsWith(a.slice(0,-1)):l===a:true);return f.forEach(l=>p(l)),f},reportStoreError:g}};var En=ge,Fn=Se(En),br=null,mr=new WeakSet,Vn=e=>{mr.has(e)||(mr.add(e),ke().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ft(t);r&&e.featureRuntimes.set(t,r());}}));},_=()=>{let e=U(Fn);return Vn(e),e};var j=()=>_();function dr(e){br=e;}var fe=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}}}),Tn=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)}),Nn=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)}),D=fe(()=>_().stores),re=fe(()=>_().subscribers),B=fe(()=>_().initialStates),le=fe(()=>_().initialFactories),h=fe(()=>_().metaEntries),Te=fe(()=>_().snapshotCache),H=Tn(()=>_().featureRuntimes),hr=new WeakMap,On=e=>{let t=hr.get(e);return t||(t=yr(e),hr.set(e,t)),t};Nn(()=>On(_()));var Pn=e=>{let t=H.get(e);if(t)return t;let r=ft(e);if(!r)return;let n=r();return H.set(e,n),n},An=()=>{ke().forEach(e=>{Pn(e);});};An();var K=e=>oe(_(),e),Ve=e=>{if(C()){let r=te(e);if(r.has)return r.value}let t=Je();return t&&Object.prototype.hasOwnProperty.call(t,e)?t[e]:D[e]},q=(e,t)=>{let n=x()?qt(t):t;D[e]=n;},vr=(e,t,r=Date.now())=>{q(e,t),h[e]&&(h[e].updatedAt=new Date(r).toISOString(),h[e].updatedAtMs=r,h[e].updateCount++,br?.(e));},jn=()=>{wt(_());},$n=()=>{H.forEach(e=>{try{e.resetAll?.();}catch{}}),H.clear();};T("features.reset",$n,10);T("registries.clear",jn,20);var ir=e=>vt(_(),e);var wr=new WeakMap,kr=e=>{let t=wr.get(e);return t||(t=new Map,wr.set(e,t)),t},_n=()=>{kr(j()).clear();};T("features.contexts",_n,100);var Rr=e=>{let t=j(),r=kr(t),n=r.get(e);if(n)return n;let o=h[e];if(!o)return b(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:o.options,getMeta:()=>h[e],getStoreValue:()=>D[e],getAllStores:()=>D,getInitialState:()=>B[e],hasStore:()=>K(e),setStoreValue:i=>{q(e,i);},applyFeatureState:(i,c)=>{vr(e,i,c),X(e);},notify:()=>{},reportStoreError:i=>{J(e,i);},warn:b,log:W,hashState:be,deepClone:N,sanitize:Q,validate:i=>gt(e,i,h[e]?.options?.validate),isDev:x};return r.set(e,s),s},xr=(e,t)=>{let r=Rr(e);r&&(r.notify=()=>t(e),H.forEach(n=>{n.onStoreCreate?.(r);}));},Cr=(e,t,r,n,o)=>{let s=Rr(e);if(!s)return;s.notify=()=>o(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:n});H.forEach(c=>{c.onStoreWrite?.(i);});};var Mr=(e,t)=>Yt({name:e,payload:t,middlewares:(()=>{let r=h[e]?.options?.middleware||[],n=R().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{ue(e,r,n);},warn:b}),St=(e,t,r,n)=>je({name:e,label:t,fn:r,args:n,reportIssue:(o,s)=>{ue(e,o,s);}}),Er=(e,t)=>{let r={...t};return r.persist&&!Pe("persist")&&(r.explicitPersist&&ze(e,"persist",r.onError),r.persist=null),r.sync&&!Pe("sync")&&(r.explicitSync&&ze(e,"sync",r.onError),r.sync=false),Pe("devtools")||(r.explicitDevtools&&ze(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var In=32,Fr=new Set,Vr=new Set,zn=(e,t)=>{x()&&(t<In||Fr.has(e)||(Fr.add(e),b(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},Tr=({name:e,prev:t,next:r,action:n,hookLabel:o,logMessage:s})=>{q(e,r),X(e);let i=Date.now();h[e].updatedAt=new Date(i).toISOString(),h[e].updatedAtMs=i,h[e].updateCount++,Cr(e,n,t,r,Ne),St(e,o,h[e].options[o],[t,r]),Ne(e),W(s);},Nr=e=>{if(C()){He(e.name,e.next),We(()=>Tr(e));return}Tr(e);},Ke=(e,t,r={})=>{if(C()){let a=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;xe(a,r.onError),A(a);return}if(!ot(e)){xe(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!he(t)){xe(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&x()&&b(`createStore("${e}") received an undefined initial value. This can be indistinguishable from a missing store in some consumers; consider null or an explicit shape if that is intentional.`),Ut(r).forEach(a=>{b(a);});let o=Er(e,Kt(r,e,R().defaultSnapshotMode));if(o.scope==="temp"&&r.persist){let a=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;o.onError?.(a),x()||z(a),$(a);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=s&&i==="production",d=o.allowSSRGlobalStore??false;if(c&&!d){let a=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
|
|
14
|
-
|
|
15
|
-
This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),K(e)){let a=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return ue(e,a),{name:e}}s&&!d&&!rr(e)&&x()&&(nr(e),b(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let g=de(e,t,o.onError);if(!g.ok)return;let S=g.value,v=o.lazy===true&&typeof t=="function",p=(re[e]?.size??0)>0;if(v)D[e]=void 0,le[e]=t;else {let a=Be(e,S,o.validate,o.onError);if(!a.ok)return;q(e,a.value),B[e]=N(a.value);}let w=Date.now(),u=new Date(w).toISOString();return h[e]={createdAt:u,updatedAt:u,updatedAtMs:w,updateCount:0,version:o.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},options:o},X(e),xr(e,Ne),St(e,"onCreate",h[e].options.onCreate,[S]),p&&Ne(e),W(`Store "${e}" created -> ${JSON.stringify(S)}`),{name:e}};function L(e,t,r){let n=Re(e);if(!Ee(n))return {ok:false,reason:"validate"};if(!K(n)){let p=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return J(n,p),C()&&A(p),{ok:false,reason:"not-found"}}let o,s=C()?te(n):{has:false,value:void 0},i=s.has?s.value:Ve(n),c=typeof t=="function"&&r===void 0;if(c){let p=x()?Date.now():0;try{let w=R().mutatorProduce,u=!1,a,f=m=>{let k=t(m);return k!==void 0&&(u=!0,a=k),k},l=w?w(i,f):(()=>{let m=N(i);return f(m),m})();if(u&&R().strictMutatorReturns){let m=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return J(n,m),C()&&A(m),{ok:!1,reason:"validate"}}u&&x()&&!R().strictMutatorReturns&&b(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),o=u&&!R().strictMutatorReturns?a:l;}catch(w){return J(n,`Mutator for "${n}" failed: ${w?.message??w}`),C()&&A(w),{ok:false,reason:"validate"}}finally{p&&zn(n,Date.now()-p);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!he(t))return C()&&A(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof i!="object"||i===null||Array.isArray(i))return $(`setStore("${n}", data) only merges into object stores.
|
|
16
|
-
Use setStore("${n}", "path", value) or recreate the store with an object shape.`),C()&&A(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let p=de(n,t);if(!p.ok)return C()&&A(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};o={...i,...p.value};}else if(typeof t=="string"||Array.isArray(t)){if(!ve(t))return C()&&A(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let p=de(n,r);if(!p.ok)return C()&&A(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let w=p.value,u=lr(n,i,t,w);if(!u.ok)return h[n]?.options?.onError?.(u.reason??`Invalid path for "${n}".`),C()&&A(u.reason),{ok:false,reason:"path"};o=ct(i,t,w);}else {let p=`setStore("${n}") - invalid arguments.
|
|
12
|
+
Call createStore("${e}", data) first.`);};var Y=new Set(["__proto__","constructor","prototype"]),It=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let n=r.error,s=n?.details?.[0]?.message||n?.message||r.message||e.errors;if(s)return {ok:!1,error:s};if(n)return {ok:!1,error:n}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var ce=e=>e===null?"null":Array.isArray(e)?"array":e instanceof Map?"map":e instanceof Set?"set":e instanceof Date?"date":typeof e=="function"?"function":typeof e,$r=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},Re=e=>{let t=ce(e);return t==="function"?(H(Cr()),false):t==="map"||t==="set"?(S(Mr()),true):(t==="date"&&S(Tr()),true)},jt=(e,t)=>{let r=$r(e);if(r)throw new Error(`${r} values are not supported`);let o=ce(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return true}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date"||o==="map"||o==="set")return false;if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n=Object.keys(e);for(let s of n){let i=Number(s);if(!Number.isInteger(i))return false}for(let s=0;s<e.length;s+=1)if(s in e&&!jt(e[s],t))return false;return true}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");if(t.add(e),Object.getOwnPropertySymbols(e).length>0)return false;let n=Object.getOwnPropertyDescriptors(e);for(let[s,i]of Object.entries(n)){if(!i.enumerable||Y.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!jt(i.value,t))return false}return true}return true},$t=e=>jt(e,new WeakSet),_e=(e,t)=>{let r=$r(e);if(r)throw new Error(`${r} values are not supported`);let o=ce(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date")return M()&&S(Fr()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),M()&&S(Er());let n={};for(let[s,i]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");n[String(s)]=_e(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),M()&&S(Vr()),Array.from(e,n=>_e(n,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n={},s=Object.getOwnPropertyDescriptors(e);for(let[i,a]of Object.entries(s))if(a.enumerable&&!Y.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=_e(a.value,t);}return n}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(n=>_e(n,t))}return e},Se=e=>_e(e,new WeakSet),zt=e=>typeof e!="string"||e.trim()===""?(H(Pr(e)),false):Y.has(e)?(H(Ir(e)),false):e.includes(" ")?(H(jr(e)),false):true;var _t=null,dn=()=>{if(_t)return _t;let e,t=[];for(let r=0;r<256;r++){e=r;for(let o=0;o<8;o++)e=e&1?3988292384^e>>>1:e>>>1;t[r]=e>>>0;}return _t=t,t},_r=e=>{let t=dn(),r=-1;for(let o=0;o<e.length;o++)r=r>>>0,r=r>>>8^t[(r^e.charCodeAt(o))&255];return (r^-1)>>>0},pn=2166136261,fn=2654435761,gn=1e5,le=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},ye=(e,t)=>{le(e,t.length);for(let r=0;r<t.length;r++)le(e,t.charCodeAt(r));},A=(e,t)=>{ye(e,t);},zr=(e,t)=>{if(Number.isNaN(t)){A(e,"NaN");return}if(!Number.isFinite(t)){A(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){A(e,"-0");return}let r=t|0;if(t===r){A(e,"int"),le(e,r);return}A(e,"num"),ye(e,String(t));},Ce=(e,t)=>{if(e.nodes++>gn){A(e,"[max]");return}if(t===null){A(e,"null");return}let r=typeof t;if(r==="string"){A(e,"string"),ye(e,t);return}if(r==="number"){A(e,"number"),zr(e,t);return}if(r==="boolean"){A(e,t?"true":"false");return}if(r==="undefined"){A(e,"undefined");return}if(r==="bigint"){A(e,"bigint"),ye(e,t.toString());return}if(r==="symbol"){A(e,"symbol");let c=t;ye(e,Symbol.keyFor(c)??c.description??String(c));return}if(r==="function"){A(e,"function"),ye(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){A(e,"ref"),le(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){A(e,"array"),le(e,o.length);for(let c=0;c<o.length;c++)Object.prototype.hasOwnProperty.call(o,c)?Ce(e,o[c]):A(e,"hole");return}if(o instanceof Date){A(e,"date"),zr(e,o.getTime());return}if(o instanceof Map){A(e,"map"),le(e,o.size),o.forEach((c,l)=>{Ce(e,l),Ce(e,c);});return}if(o instanceof Set){A(e,"set"),le(e,o.size),o.forEach(c=>{Ce(e,c);});return}A(e,"object");let i=Object.getOwnPropertyDescriptors(o),a=[];Object.entries(i).forEach(([c,l])=>{l?.enumerable&&(Y.has(c)||"get"in l||"set"in l||a.push([c,l]));}),le(e,a.length);for(let[c,l]of a)ye(e,c),Ce(e,l.value);},We=e=>{if(typeof e=="string")return _r(JSON.stringify(e));let t={h1:pn,h2:fn,seen:new WeakMap,nextId:1,nodes:0};Ce(t,e);let r=t.h1>>>0,o=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,o^=o>>>16,o=Math.imul(o,668265261),o^=o>>>15,o=Math.imul(o,374761393),o^=o>>>16,(r&2097151)*4294967296+(o>>>0)};var Sn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",He=e=>{if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map)return new Map(e);if(e instanceof Set)return new Set(e);if(Array.isArray(e))return e.slice();let t={},r=Object.getOwnPropertyDescriptors(e);return Object.entries(r).forEach(([o,n])=>{n.enumerable&&(Y.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},Wt=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=[["WeakMap",globalThis.WeakMap],["WeakSet",globalThis.WeakSet],["WeakRef",globalThis.WeakRef],["Promise",globalThis.Promise],["ReadableStream",globalThis.ReadableStream],["WritableStream",globalThis.WritableStream],["TransformStream",globalThis.TransformStream],["EventTarget",globalThis.EventTarget]];for(let[o,n]of t)if(typeof n=="function"&&e instanceof n)return o;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},yn=e=>Wt(e)===null,mn=e=>{let t=Wt(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},me=(e,t=new WeakMap)=>{if(mn(e),e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let n=new Map;return t.set(e,n),e.forEach((s,i)=>{n.set(me(i,t),me(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(me(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=me(s,t);}),n}let r={};t.set(e,r);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch(n){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${n?.message??n}`)}return Object.entries(o).forEach(([n,s])=>{!s.enumerable||Y.has(n)||"get"in s||"set"in s||(r[n]=me(s.value,t));}),r},O=e=>{if(Sn)try{return structuredClone(e)}catch(t){if(!yn(e)){let r=Wt(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return S(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),me(e)}return me(e)},Ht=(e,t)=>{if(Object.is(e,t))return true;if(!e||!t||typeof e!="object"||typeof t!="object")return false;let r=e,o=t,n=Object.keys(r),s=Object.keys(o);if(n.length!==s.length)return false;for(let i of n)if(!Object.prototype.hasOwnProperty.call(o,i)||!Object.is(r[i],o[i]))return false;return true};var Wr=10,hn=5,bn=e=>{let t=[],r="",o=false;for(let n of e){if(o){r+=n,o=false;continue}if(n==="\\"){o=true;continue}if(n==="."){t.push(r),r="";continue}r+=n;}return o&&(r+="\\"),t.push(r),t},Me=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?bn(e):[String(e)],Le=e=>{let t=Me(e),r=t.length;return r>Wr?(H(Dr(r,Wr,t)),false):(r>hn&&S(Or(r,t)),true)},Lt=(e,t)=>{let r=Me(t),o=e;for(let n of r){if(o==null){S(Nr(r,n));return}if(typeof o!="object"){S(Ar(n));return}o=o[n];}return o},Bt=(e,t,r)=>{let o=Me(t);if(o.length===0)return e;for(let s of o)if(Y.has(s))return $(`Blocked forbidden path segment "${String(s)}" in setStore path "${o.join(".")}".`),e;let n=(s,i)=>{let a=o[i],c=i===o.length-1;if(Array.isArray(s)){let l=Number(a);if(!Number.isInteger(l))return s;let u=[...s];return c?(u[l]=r,u):(u[l]=n(u[l],i+1),u)}if(s&&typeof s=="object"){if(Y.has(a))return $(`Blocked unsafe path segment "${String(a)}" while setting "${o.join(".")}".`),s;let l={...s};return c?(l[a]=r,l):(l[a]=n(l[a],i+1),l)}if(s==null&&!c){let l=Number.isInteger(Number(a)),u=l?[]:{};if(l){let w=u,b=Number(a);return w[b]=n(void 0,i+1),w}return u[a]=n(void 0,i+1),u}return c?r:s};return n(e,0)};var qt=new Set,wn=()=>{qt.clear();};F("options.legacy-warnings",wn,30);var it=(()=>{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"}})(),Ut=e=>{try{return typeof window>"u"?it:e==="session"||e==="sessionStorage"?window.sessionStorage??it:window.localStorage??it}catch{return it}},Be=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Te=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Lr=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}},vn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Hr=e=>{try{e[vn]=!0;}catch{}return e},xn={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"},kn=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Hr(w=>w),decrypt:Hr(w=>w),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Ut("localStorage"),...r};if(typeof e=="string")return {driver:Ut(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,a=e.sensitiveData===true,c=e.allowPlaintext===true,l=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,u=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&&Lr(o)&&!s)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`);return {driver:e.driver||e.storage||Ut("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:o,decrypt:n,encryptAsync:s,decryptAsync:i,allowPlaintext:c,sensitiveData:a,maxSize:l,checksum:u,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Br=e=>{if(!Be(e))return [];let t=[];return Object.entries(xn).forEach(([r,o])=>{Te(e,r)&&(qt.has(r)||(qt.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},Ur=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=Be(e.lifecycle)?e.lifecycle:void 0,a=Be(e.persist)?e.persist:void 0,c=Be(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,u=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",w=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,b=Be(e.features)?{...e.features}:void 0,h=Te(e,"persist"),x=Te(e,"sync"),d=Te(e,"devtools")||Te(e,"historyLimit")||Te(e,"redactor"),p=o==="global"?true:e.allowSSRGlobalStore??false,{persist:g=false,devtools:R=false,onError:k,sync:T}=e;if(a?.sensitiveData===true){let V=a.encrypt,y=a.encryptAsync;if((!V||Lr(V))&&!y)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:o,lazy:n,pathCreate:s,persist:o==="temp"&&!h?null:kn(g,t),devtools:o==="temp"&&!d?false:typeof R=="boolean"?R:c?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:k,validate:l,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:o==="temp"&&!d?void 0:c?.redactor??e.redactor,historyLimit:o==="temp"&&!d?0:c?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!x?false:T??false,features:b,allowSSRGlobalStore:p,snapshot:u,snapshotSafety:w,explicitPersist:h,explicitSync:x,explicitDevtools:d}};var at=Symbol("stroid.middleware.abort"),qr=({name:e,payload:t,middlewares:r,reportIssue:o,warn:n})=>{if(!Array.isArray(r)||r.length===0)return t.next;let s=new WeakSet,i=O(t.next);for(let a of r){if(typeof a!="function")continue;let c,l=i;try{c=a({action:t.action,name:e,prev:t.prev,next:l,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(u){let w=`Middleware for "${e}" failed: ${u?.message??u}`;return o(w,"dev"),at}if(c&&typeof c.then=="function"){let u=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(u,"dev"),at}c===void 0?(M()&&!s.has(a)&&(s.add(a),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=l):i=c;}return i},ct=({name:e,label:t,fn:r,args:o,reportIssue:n})=>{if(typeof r=="function")try{r(...o);}catch(s){let i=`${t} for "${e}" failed: ${s?.message??s}`;n(i,"always");}};var X=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;G(`${t} callback threw: ${String(n)}`);}},he=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(X(n,"onError",e),r==="critical"){o==="dev"&&S(e),$(e);return}if(o==="always"){G(e);return}S(e);};var lt=null,Kr=e=>{lt=e;},Gr=e=>lt?lt(e):[];F("computed.order-resolver",()=>{lt=null;},105);var Yr=()=>se(ke(xe)),Kt=()=>Yr().computedEntries,Jr=()=>Yr().computedDependents;var Xr=e=>Object.prototype.hasOwnProperty.call(Kt(),e);var Rn=e=>{let t=Kt(),r=Jr(),o=new Set,n=[...e];for(;n.length>0;){let u=n.shift(),w=r[u];if(w)for(let b of w)o.has(b)||(o.add(b),n.push(b));}if(o.size===0)return [];let s=u=>{let w=t[u];if(w)for(let b of w.deps)t[b]&&(o.has(b)||(o.add(b),s(b)));};Array.from(o).forEach(u=>s(u));let i=new Map,a=new Map;for(let u of o){let w=t[u];if(!w)continue;let b=0;for(let h of w.deps)o.has(h)&&(b++,a.has(h)||a.set(h,[]),a.get(h).push(u));i.set(u,b);}let c=[];for(let[u,w]of i)w===0&&c.push(u);c.sort();let l=[];for(;c.length>0;){let u=c.shift();l.push(u);let w=a.get(u)??[];for(let b of w){let h=(i.get(b)??1)-1;if(i.set(b,h),h===0){let x=c.findIndex(d=>d>b);x===-1?c.push(b):c.splice(x,0,b);}}}return l};Kr(Rn);var Gt=e=>{let t=Kt()[e];if(!t)return null;let r=Jr()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Qr=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")},Yt=e=>(Qr(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Zr=e=>{if(!Qr(e))return e;let t=[e],r=new WeakSet;for(;t.length>0;){let o=t.pop();if(!r.has(o)){r.add(o),Object.isFrozen(o)||Object.freeze(o);for(let n of Object.keys(o)){let s=o[n];typeof s=="object"&&s!==null&&!r.has(s)&&t.push(s);}}}return e};var ut=null;var Cn=()=>{ut=null;};F("transaction.runner",Cn,120);var Ue=e=>{let t=ut?.get();return t||(e??se()).transaction},Mn=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var E=()=>ut?(ut.get()?.depth??0)>0:Ue().depth>0,j=(e,t)=>{let r=Ue(t);r.failed=true,r.error||(r.error=Mn(e));},dt=e=>{let t=se();Ue(t).pending.push(()=>st(t,e));},pt=(e,t)=>{let r=Ue();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},ue=e=>{let t=Ue();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var eo=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Jt=(e,t)=>{if(t==="ref"){if(!M())return e;try{return Yt(e)}catch{return e}}if(t==="shallow"){let o=He(e);if(!M())return o;try{return Yt(o)}catch{return o}}let r=O(e);if(!M())return r;try{return Zr(r)}catch{return r}};var to=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:o}=e,n=C().flush,s=n.priorityStores||[],i=s.length?new Set(s):null;o.length=0,r.length=0;let a=new Set;if(i){for(let x of t)r.push(x),a.add(x);for(let x of s)a.has(x)&&o.push(x);for(let x of r)i.has(x)||o.push(x);}else for(let x of t)r.push(x),a.add(x),o.push(x);t.clear();let c=Gr(o),l=new Set(o);for(let x of c)l.has(x)||(o.push(x),l.add(x));let u=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,w=n.chunkDelayMs,b=u===Number.POSITIVE_INFINITY&&w===0;return {names:o,sliceSize:u,chunkDelayMs:w,runInline:b,prioritySet:i}};var Xt=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}),Qt=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),Zt=(e,t)=>{e&&(e.metrics=t);};var qe=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},ro=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>st(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var oo=new Map;var er=e=>{let t=oo.get(e);return !!t&&t.size>0},Ke=(e,t,r)=>{let o=oo.get(e);!o||o.size===0||o.forEach(n=>{try{n(t,r);}catch(s){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,s);}});};var Ge=null,ft=null;var Tn=()=>{Ge=null,ft=null;};F("write-context.runner",Tn,121);var gt=()=>ft?.get()??Ge,tr=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(ft)return ft.run(e,t);let r=Ge;Ge=e;try{return t()}finally{Ge=r;}};var no=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)},so=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:c,prioritySet:l}=t,w=e.stores,b=e.subscribers,h=e.metaEntries,x=e.snapshotCache,d=C().defaultSnapshotMode,p=m=>eo(h[m],d),g=m=>w[m],R=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),k=er("beforeFlush"),T=er("afterFlush"),V=m=>{k&&Ke("beforeFlush",m,{type:"beforeFlush"});},y=(m,I)=>{T&&Ke("afterFlush",m,{type:"afterFlush",elapsedMs:I});},v=m=>{let I=h[m];if(!I)return null;let N=I.lastCorrelationId??void 0,f=I.lastTraceContext??void 0;return !N&&!f?null:{correlationId:N,traceContext:f}},L=()=>{o();};if(c){for(let m of s){let I=b[m];if(!I||I.size===0)continue;let N=h[m]?.updateCount??0,f=p(m),we=g(m),q=x[m],K=q&&q.source===we&&q.mode===f?q.snapshot:(()=>{let _=Jt(we,f);return x[m]={version:r,snapshot:_,source:we,mode:f},_})(),re=Xt(h[m]?.metrics);V(m);let pe=R(),ae=Array.from(I),Ae=v(m),Pe=()=>{for(let _ of ae)try{_(K);}catch(fe){let oe=h[m]?.options?.snapshotSafety??"warn";if(M()&&(f==="ref"||f==="shallow")&&no(fe)){if(oe==="throw")throw fe;if(oe==="auto-clone")try{let Ie=O(K);S(`Snapshot mutation detected for "${m}". Delivered a cloned snapshot to the subscriber.`);try{_(Ie);}catch(Tt){S(`Subscriber for "${m}" threw on cloned snapshot: ${Tt?.message??Tt}`);}continue}catch{}S(`Snapshot mutation detected for "${m}": ${fe?.message??fe}`);continue}S(`Subscriber for "${m}" threw: ${fe?.message??fe}`);}};Ae?tr(Ae,Pe):Pe();let je=R()-pe;y(m,je),Qt(re,je),Zt(h[m],re),(h[m]?.updateCount??N)!==N&&n.pendingNotifications.add(m);}L();return}let z=m=>{let I=[];for(let N of s){if(m&&!m(N))continue;let f=b[N];if(!f||f.size===0)continue;let we=h[N]?.updateCount??0,q=p(N),K=g(N),re=x[N],pe=re&&re.source===K&&re.mode===q?re.snapshot:(()=>{let ae=Jt(K,q);return x[N]={version:r,snapshot:ae,source:K,mode:q},ae})();I.push({name:N,snapshot:pe,version:we,subscribers:Array.from(f),subscriberSet:new Set(f),notified:new Set,metrics:Xt(h[N]?.metrics),totalMs:0,beforeHooked:false});}return I},Oe=l?z(m=>l.has(m)):[],Ne=z(m=>!l||!l.has(m)),Ct=(m,I)=>{let N=()=>{if(m.length===0){I();return}let f=m.shift();if((h[f.name]?.updateCount??f.version)!==f.version){if(n.pendingNotifications.add(f.name),m.length===0){I();return}qe(N,a);return}let q=()=>{let J=b[f.name];if(!(!J||J.size===0))for(let _ of J)f.subscriberSet.has(_)||(f.subscriberSet.add(_),f.subscribers.push(_));};q();let K=f.subscribers;if(K.length===0){if(m.length===0){I();return}qe(N,a);return}f.beforeHooked||(f.beforeHooked=true,V(f.name));let re=R(),pe=0,ae=false,Ae=v(f.name),Pe=()=>{for(let J=0;J<K.length&&pe<i;J+=1){let _=K[J];if(f.notified.has(_))continue;f.notified.add(_);try{_(f.snapshot);}catch(oe){let Mt=h[f.name]?.options?.snapshotSafety??"warn",Ie=p(f.name);if(M()&&(Ie==="ref"||Ie==="shallow")&&no(oe)){if(Mt==="throw")throw oe;if(Mt==="auto-clone")try{let cr=O(f.snapshot);S(`Snapshot mutation detected for "${f.name}". Delivered a cloned snapshot to the subscriber.`);try{_(cr);}catch(lr){S(`Subscriber for "${f.name}" threw on cloned snapshot: ${lr?.message??lr}`);}if(f.notified.add(_),pe+=1,(h[f.name]?.updateCount??f.version)!==f.version){ae=!0,n.pendingNotifications.add(f.name);break}continue}catch{}S(`Snapshot mutation detected for "${f.name}": ${oe?.message??oe}`);continue}S(`Subscriber for "${f.name}" threw: ${oe?.message??oe}`);}if(pe+=1,(h[f.name]?.updateCount??f.version)!==f.version){ae=true,n.pendingNotifications.add(f.name);break}}};if(Ae?tr(Ae,Pe):Pe(),f.totalMs+=R()-re,ae){if(m.length===0){I();return}qe(N,a);return}q();let je=false;for(let J of K)if(!f.notified.has(J)){je=true;break}if(je?m.push(f):(Qt(f.metrics,f.totalMs),Zt(h[f.name],f.metrics),y(f.name,f.totalMs)),m.length===0){I();return}qe(N,a);};N();};Oe.length>0?Ct(Oe,()=>Ct(Ne,L)):Ct(Ne,L);};var Fn=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=to(t);so(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&rr(e);});},rr=e=>{ro(e,Fn);};var St=null,io=e=>(St=e,()=>{St===e&&(St=null);}),Fe=e=>{St?.(e);};var En=e=>{let t=D(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&rr(t);};io(En);var Vn=()=>{let e=D().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};F("notify.reset",Vn,40);var yt=new Set,co=e=>e?yt.has(e):yt.size>0,lo=e=>{e&&yt.add(e);},Dn=()=>{yt.clear();};F("ssr.warnings",Dn,60);var ao=new Set,On=e=>{let t=kr();return !t||e.includes("::")?e:(M()&&!ao.has(e)&&(ao.add(e),S(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},Ee=e=>On(typeof e=="string"?e:e.name),mt=e=>Q(e)&&!fo(e)?true:(Pt(e,Object.keys(Xe)),false),uo=(e,t,r={})=>{he(t,{...r,onError:P[e]?.options?.onError});},po=(e,t,r={})=>{he(e,{...r,onError:t});},de=(e,t,r="dev")=>{uo(e,t,{severity:"warn",visibility:r});},Nn=(e,t,r="dev")=>{po(e,t,{severity:"warn",visibility:r});},ie=(e,t)=>uo(e,t,{severity:"critical",visibility:"always"}),Je=(e,t)=>po(e,t,{severity:"critical",visibility:"always"}),ht=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
13
|
+
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Nn(o,r,"always"),C().strictMissingFeatures)throw new Error(o)};var go=new WeakMap,So=new WeakMap,An=500,Pn="",Qe=e=>{let t=go.get(e);return t||(t=new Map,go.set(e,t)),t},nr=e=>{let t=So.get(e);return t||(t=new Map,So.set(e,t)),t},jn=(e,t)=>{let r=nr(e),o=r.get(t);return o||(o=new Map,r.set(t,o)),o},In=()=>{let e=C().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?An:Math.max(0,Math.floor(e))},yo=(e,t,r,o)=>{if(o<=0){e.has(t)&&e.delete(t);return}for(e.has(t)&&e.delete(t),e.set(t,r);e.size>o;){let n=e.keys().next().value;if(!n)break;let s=e.get(n);e.delete(n),s?.node.verdicts&&(s.node.verdicts.delete(s.type),s.node.verdicts.size===0&&delete s.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=Qe(D());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let o=r[t];return typeof o=="function"?o.bind(r):o},set:(e,t,r)=>(Qe(D())[t]=r,true)});var mo=(e,t,r,o)=>{let n=P[e];if(!n)return {ok:true};let s=Me(r);if(s.length===0)return {ok:true};let i=ce(o),a=In(),c=D(),l=Qe(c),u=jn(c,e),w=s.join(Pn),b=l.get(e);b||(b={children:new Map},l.set(e,b));let h=b;for(let k of s){let T=h.children.get(k);T||(T={children:new Map},h.children.set(k,T)),h=T;}let x=h.verdicts?.get(i);if(x){let k=`${w}|${i}`;return yo(u,k,{node:h,type:i},a),x}let d=n.options?.pathCreate===true,p=t,g={ok:true};for(let k=0;k<s.length;k++){let T=s[k],V=k===s.length-1;if(p==null){let v=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,k).join(".")||"root"}" is ${p===null?"null":"undefined"}.`;$(v),g={ok:false,reason:v};break}if(typeof p!="object"){let v=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,k).join(".")||"root"}" is not an object.`;$(v),g={ok:false,reason:v};break}if(Array.isArray(p)){let v=Number(T);if(!Number.isInteger(v)||v<0){let z=`Path "${s.join(".")}" targets non-numeric index "${T}" on an array in "${e}".`;$(z),g={ok:false,reason:z};break}let L=p;if(v>=L.length){let z=`Path "${s.join(".")}" is invalid for "${e}" - index ${v} is out of bounds (length ${L.length}).`;$(z),g={ok:false,reason:z};break}if(V){let z=L[v];if(z!=null){let Oe=ce(z);if(Oe!==i){let Ne=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${Oe}, received ${i}.`;$(Ne),g={ok:false,reason:Ne};break}}g={ok:true};break}p=L[v];continue}if(!Object.prototype.hasOwnProperty.call(p,T)){if(d&&V){g={ok:true};break}let v=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${T}" at "${s.slice(0,k).join(".")||"root"}".`;$(v),g={ok:false,reason:v};break}if(V){let v=p[T];if(v!=null){let L=ce(v);if(L!==i){let z=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${L}, received ${i}.`;$(z),g={ok:false,reason:z};break}}g={ok:true};break}p=p[T];}h.verdicts||(h.verdicts=new Map);let R=h.verdicts.has(i);if(h.verdicts.set(i,g),!R){let k=`${w}|${i}`;yo(u,k,{node:h,type:i},a);}return g},be=(e,t,r,o)=>{try{return o?.reuseInput&&$t(t)?{ok:!0,value:t}:{ok:!0,value:Se(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return X(P[e]?.options?.onError,`onError(${e})`,s),X(r,`onError(${e})`,s),S(s),{ok:false}}},$n=(e,t)=>{let r=new Set,o=P[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},sr=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=$n(e,o),s=(a,c)=>{n.forEach(l=>X(l,`onError(${e})`,a)),c==="critical"?$(a):S(a);};if(typeof r=="function")try{let a=r(t);return a===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:a===!0?t:a}}catch(a){return s(`Validation for "${e}" failed: ${a?.message??a}`,"critical"),{ok:false}}let i=It(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Ze=(e,t,r,o,n)=>{let s=be(e,t,o,n);if(!s.ok)return {ok:false};let i=sr(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},ee=e=>{let t=D();Qe(t).delete(e),nr(t).delete(e);},zn=()=>{let e=D();Qe(e).clear(),nr(e).clear();};F("validation.path-cache",zn,50);ho(ee);var Ve=(e,t=D())=>{if((E()?ue(e):{has:false}).has||t.stores[e]!==void 0)return true;let o=t.initialFactories[e];if(!o)return true;try{let n=o(),s=be(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=Ze(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(E()){let c=a.value;pt(e,c),dt(()=>{te(e,c,t),t.initialStates[e]=O(c),delete t.initialFactories[e],ee(e);});}else te(e,a.value,t),t.initialStates[e]=O(a.value),delete t.initialFactories[e],ee(e);return !0}catch(n){return ie(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var bo=new WeakMap,wo=e=>{let t=bo.get(e);return t||(t=new Map,bo.set(e,t)),t},_n=()=>{wo(D()).clear();};F("features.contexts",_n,100);var vo=e=>{let t=D(),r=wo(t),o=r.get(e);if(o)return o;let n=P[e];if(!n)return S(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>P[e],getStoreValue:()=>Xe[e],getAllStores:()=>Xe,getInitialState:()=>To[e],hasStore:()=>Q(e),setStoreValue:i=>{te(e,i);},applyFeatureState:(i,a)=>{Fo(e,i,a),ee(e);},notify:()=>{},reportStoreError:i=>{ie(e,i);},warn:S,warnAlways:G,log:B,hashState:We,deepClone:O,sanitize:Se,validate:i=>sr(e,i,P[e]?.options?.validate),isDev:M};return r.set(e,s),s},xo=(e,t)=>{let r=C();if(!r.strictMissingFeatures&&!r.assertRuntime)return;let o=[];if(typeof t.getMeta!="function"&&o.push("getMeta"),typeof t.getStoreValue!="function"&&o.push("getStoreValue"),typeof t.getAllStores!="function"&&o.push("getAllStores"),typeof t.getInitialState!="function"&&o.push("getInitialState"),typeof t.hasStore!="function"&&o.push("hasStore"),typeof t.setStoreValue!="function"&&o.push("setStoreValue"),typeof t.applyFeatureState!="function"&&o.push("applyFeatureState"),typeof t.notify!="function"&&o.push("notify"),typeof t.reportStoreError!="function"&&o.push("reportStoreError"),typeof t.warn!="function"&&o.push("warn"),typeof t.warnAlways!="function"&&o.push("warnAlways"),typeof t.log!="function"&&o.push("log"),typeof t.hashState!="function"&&o.push("hashState"),typeof t.deepClone!="function"&&o.push("deepClone"),typeof t.sanitize!="function"&&o.push("sanitize"),typeof t.validate!="function"&&o.push("validate"),typeof t.isDev!="function"&&o.push("isDev"),o.length===0)return;let n=`Feature hook context missing fields for "${e}": ${o.join(", ")}.`;if(ie(e,n),r.assertRuntime)throw new Error(n)},ko=(e,t)=>{wt();let r=vo(e);r&&(r.notify=()=>t(e),xo(e,r),Z.forEach(o=>{o.onStoreCreate?.(r);}));},Ro=(e,t,r,o,n)=>{wt();let s=vo(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});xo(e,i),Z.forEach(a=>{a.onStoreWrite?.(i);});};var Co=(e,t)=>qr({name:e,payload:t,middlewares:(()=>{let r=P[e]?.options?.middleware||[],o=C().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{de(e,r,o);},warn:S}),bt=(e,t,r,o)=>ct({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{de(e,n,s);}}),Mo=(e,t)=>{let r={...t};return r.persist&&!rt("persist")&&(r.explicitPersist&&ht(e,"persist",r.onError),r.persist=null),r.sync&&!rt("sync")&&(r.explicitSync&&ht(e,"sync",r.onError),r.sync=false),rt("devtools")||(r.explicitDevtools&&ht(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var Wn=32,ir=new Set;F("store-write.slow-mutator-warned",()=>ir.clear(),65);var Hn=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var Vo=(e,t)=>{M()&&(t<Wn||ir.has(e)||(ir.add(e),S(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},Do=e=>gt(),Eo=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:a})=>{let c=e.metaEntries;te(t,o,e),ee(t);let l=Date.now();c[t].updatedAt=new Date(l).toISOString(),c[t].updatedAtMs=l;let u=a??gt();u&&(u.correlationId||u.traceContext)?(c[t].lastCorrelationId=u.correlationId??null,c[t].lastCorrelationAt=new Date(l).toISOString(),c[t].lastCorrelationAtMs=l,c[t].lastTraceContext=u.traceContext??null):(c[t].lastCorrelationId=null,c[t].lastCorrelationAt=null,c[t].lastCorrelationAtMs=null,c[t].lastTraceContext=null),Hn(c[t]),Ro(t,n,r,o,Fe),bt(t,s,c[t].options[s],[r,o]),Fe(t),B(i);},vt=(e,t)=>{let r=t.context??gt();if(E()){pt(t.name,t.next),dt(()=>Eo(e,{...t,context:r}));return}Eo(e,{...t,context:r});};function U(e,t,r){return Ln(e,t,r)}var Ln=(e,t,r,o)=>{let n=Ee(e),s=D(),i=s.metaEntries;if(!Ve(n,s))return {ok:false,reason:"validate"};if(!Q(n,s)){let p=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return ie(n,p),E()&&j(p),{ok:false,reason:"not-found"}}let a,c=E()?ue(n):{has:false,value:void 0},l=c.has?c.value:Ye(n,s),u=typeof t=="function"&&r===void 0;if(u){let p=M()?Date.now():0;try{let g=C().mutatorProduce,R=!1,k,T=y=>{let v=t(y);return v!==void 0&&(R=!0,k=v),v},V=g?g(l,T):(()=>{let y=O(l);return T(y),y})();if(R&&C().strictMutatorReturns){let y=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return ie(n,y),E()&&j(y),{ok:!1,reason:"validate"}}R&&M()&&!C().strictMutatorReturns&&S(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=R&&!C().strictMutatorReturns?k:V;}catch(g){return ie(n,`Mutator for "${n}" failed: ${g?.message??g}`),E()&&j(g),{ok:false,reason:"validate"}}finally{p&&Vo(n,Date.now()-p);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!Re(t))return E()&&j(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof l!="object"||l===null||Array.isArray(l))return H(`setStore("${n}", data) only merges into object stores.
|
|
14
|
+
Use setStore("${n}", "path", value) or recreate the store with an object shape.`),E()&&j(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let p=be(n,t);if(!p.ok)return E()&&j(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};a={...l,...p.value};}else if(typeof t=="string"||Array.isArray(t)){if(!Le(t))return E()&&j(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let p=be(n,r);if(!p.ok)return E()&&j(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let g=p.value,R=mo(n,l,t,g);if(!R.ok)return X(i[n]?.options?.onError,`onError(${n})`,R.reason??`Invalid path for "${n}".`),E()&&j(R.reason),{ok:false,reason:"path"};a=Bt(l,t,g);}else {let p=`setStore("${n}") - invalid arguments.
|
|
17
15
|
Usage:
|
|
18
16
|
setStore("${n}", "field", value)
|
|
19
17
|
setStore("${n}", "nested.field", value)
|
|
20
18
|
setStore("${n}", { field: value })
|
|
21
19
|
setStore(storeDef, draft => { draft.field = value })
|
|
22
|
-
replaceStore("${n}", value) // full-store replace`;return
|
|
23
|
-
|
|
20
|
+
replaceStore("${n}", value) // full-store replace`;return H(p),X(i[n]?.options?.onError,`onError(${n})`,p),E()&&j(p),{ok:false,reason:"invalid-args"}}if(!Re(a))return E()&&j(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let w=i[n]?.options?.validate,b=Do(),h=Co(n,{action:"set",prev:l,next:a,path:t,correlationId:b?.correlationId,traceContext:b?.traceContext});if(h===at)return E()&&j(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let d=Ze(n,h,w,void 0,u&&h===a?{reuseInput:true}:void 0);if(!d.ok)return E()&&j(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};try{if(Ht(l,d.value))return {ok:!0}}catch{}return vt(s,{name:n,prev:l,next:d.value,action:"set",hookLabel:"onSet",logMessage:`Store "${n}" updated`,context:b}),{ok:true}};var Un=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Oo=(e,t)=>t==="ref"?e:t==="shallow"?He(e):O(e);function et(e,t){let r=Ee(e);if(!mt(r))return null;let o=D();if(!Ve(r,o))return null;or(r,o);let n=Ye(r,o),s=Un(o.metaEntries[r],C().defaultSnapshotMode);if(t===void 0)return n===null||typeof n!="object"?n:Oo(n,s);if(!Le(t))return null;let i=Lt(n,t);return i===null||typeof i!="object"?i:Oo(i,s)}function tt(e){let t=Ee(e);if(!mt(t))return {ok:false,reason:"not-found"};let r=D();if(r.metaEntries[t]?.options?.lazy===true&&!!r.initialFactories[t]){let u=`resetStore("${t}") cannot run on a lazy store before it is initialized. Read the store once (getStore) to materialize it before resetting.`;return de(t,u),E()&&j(u),{ok:false,reason:"lazy-uninitialized"}}if(!Ve(t,r))return {ok:false,reason:"validate"};if(!Object.prototype.hasOwnProperty.call(r.initialStates,t)){let u=`resetStore("${t}") has no initial state to reset to. If this is a lazy store, ensure it has been initialized before calling resetStore.`;return de(t,u),E()&&j(u),{ok:false,reason:"not-found"}}let n=E()?ue(t):{has:false,value:void 0},s=n.has?n.value:r.stores[t],i=typeof performance<"u"&&performance.now?performance.now():Date.now(),a=O(r.initialStates[t]),c=(typeof performance<"u"&&performance.now?performance.now():Date.now())-i,l=r.metaEntries[t]?.metrics;return l&&(l.resetCount=(l.resetCount??0)+1,l.totalResetMs=(l.totalResetMs??0)+c,l.lastResetMs=c),vt(r,{name:t,prev:s,next:a,action:"reset",hookLabel:"onReset",logMessage:`Store "${t}" reset to initial state/value`}),{ok:true}}var xt=e=>({name:e});var Yn=()=>D().computedCleanups,No=new WeakMap;var Jn=e=>{let t=No.get(e);return t||(t=new Map,No.set(e,t)),t};var Ao=e=>{let t=Yn(),r=t.get(e);if(!r){M()&&S(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Po=(e,t=D())=>Jn(t).get(e)?.autoDispose===true;var jo=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,a=e.featureRuntimes,c=e.deletingStores,l=(d,p)=>{he(p,{onError:s[d]?.options?.onError,severity:"warn",visibility:"dev"});},u=({name:d,prev:p,options:g,initialState:R,getMeta:k,getStoreValue:T,hasStore:V})=>({name:d,options:g,prev:p,getMeta:k,getStoreValue:T,getAllStores:()=>t,getInitialState:()=>R,hasStore:V,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:y=>{he(y,{onError:g.onError,severity:"warn",visibility:"dev"});},warn:S,warnAlways:G,log:B,hashState:We,deepClone:O,sanitize:Se,validate:()=>({ok:true,value:p}),isDev:M}),w=({name:d,prev:p,options:g,initialState:R,phase:k})=>{let T=u({name:d,prev:p,options:g,initialState:R,getMeta:()=>s[d],getStoreValue:()=>t[d],hasStore:()=>ge(e,d)}),V=u({name:d,prev:p,options:g,initialState:R,getMeta:()=>{},getStoreValue:()=>p,hasStore:()=>false});ve().forEach(y=>{let v=a.get(y);k==="before"?v?.beforeStoreDelete?.(T):v?.afterStoreDelete?.(V);});},b=d=>{if(!ge(e,d))return;let p=t[d],g=s[d].options,R=o[d],k=r[d];c.add(d);try{k?.forEach(y=>{try{y(null);}catch(v){S(`Subscriber for "${d}" threw during delete: ${v?.message??v}`);}}),ct({name:d,label:"onDelete",fn:g.onDelete,args:[p],reportIssue:(y,v)=>{he(y,{onError:g.onError,severity:"warn",visibility:v});}}),w({name:d,prev:p,options:g,initialState:R,phase:"before"}),delete t[d],delete r[d],delete o[d],delete n[d],delete s[d],delete i[d],Xr(d)&&Ao(d);let V=e.computedDependents[d];if(V)for(let y of [...V]){let v=Gt(y);if(v&&Po(y,e)&&v.deps.every(L=>!ge(e,L))){b(y);continue}S(`[stroid] source store "${d}" was deleted. Computed store "${y}" depends on it and will return stale data. Call deleteComputed("${y}") to clean up.`);}w({name:d,prev:p,options:g,initialState:R,phase:"after"}),Ke("afterStoreDelete",d,{type:"afterStoreDelete",prev:p}),nt(e,{type:"deleted",name:d}),B(`Store "${d}" deleted`);}finally{c.delete(d);}};return {deleteExistingStore:b,clearAllStores:()=>{let d=[],g=0,R=Number.POSITIVE_INFINITY;for(;g<20;){let T=Object.keys(t);if(T.length===0)break;T.forEach(y=>{ge(e,y)&&(b(y),d.push(y));}),g+=1;let V=Object.keys(t).length;if(V===0||V>=R)break;R=V;}let k=Object.keys(t).length;return k>0?S(`clearAllStores stopped after ${g} pass${g===1?"":"es"}; ${k} store(s) still registered (likely recreated during deletion).`):B(`All stores cleared (${d.length} stores removed)`),d},clearStores:d=>{let p=Object.keys(t).filter(g=>d?d.endsWith("*")?g.startsWith(d.slice(0,-1)):g===d:true);return p.forEach(g=>b(g)),p},reportStoreError:l}};var ar=xe,$o=ke(ar),zo=null,W=()=>{let e=se($o);return Vt(e),e};var D=()=>W();var _o=(e,t)=>{nt(e,t);};function ho(e){zo=e;}var De=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,o)=>(e()[r]=o,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let o=Object.getOwnPropertyDescriptor(e(),r);if(o)return {...o,configurable:true}}}),Xn=e=>new Proxy(new Map,{get:(t,r)=>{let o=e();if(r==="size")return o.size;if(r===Symbol.iterator)return o[Symbol.iterator].bind(o);let n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),Qn=e=>new Proxy({},{get:(t,r)=>{let o=e(),n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),Xe=De(()=>W().stores);De(()=>W().subscribers);var To=De(()=>W().initialStates);De(()=>W().initialFactories);var P=De(()=>W().metaEntries);De(()=>W().snapshotCache);var Z=Xn(()=>W().featureRuntimes),Io=new WeakMap,Zn=e=>{let t=Io.get(e);return t||(t=jo(e),Io.set(e,t)),t};Qn(()=>Zn(W()));var es=e=>{let t=Z.get(e);if(t)return t;let r=ot(e);if(!r)return;let o=r();return Z.set(e,o),o},wt=()=>{ve().forEach(e=>{es(e);});};wt();var Q=(e,t)=>ge(t??W(),e),Ye=(e,t=W())=>{if(E()){let o=ue(e);if(o.has)return o.value}let r=$e();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},te=(e,t,r=W())=>{r.stores[e]=t;},Fo=(e,t,r=Date.now())=>{te(e,t),P[e]&&(P[e].updatedAt=new Date(r).toISOString(),P[e].updatedAtMs=r,P[e].lastCorrelationId=null,P[e].lastCorrelationAt=null,P[e].lastCorrelationAtMs=null,P[e].lastTraceContext=null,P[e].updateCount>=Number.MAX_SAFE_INTEGER?P[e].updateCount=0:P[e].updateCount+=1,zo?.(e));},or=(e,t=W())=>{let r=t.metaEntries[e];if(!r)return;r.readCount=(r.readCount??0)+1;let o=Date.now();r.lastReadAtMs=o,r.lastReadAt=new Date(o).toISOString();},ts=()=>{hr(W());},rs=()=>{Z.forEach(e=>{try{e.resetAll?.();}catch{}}),Z.clear();};F("features.reset",rs,10);F("registries.clear",ts,20);F("registry.default",()=>{ar=xe,$o=ke(ar);},115);var fo=e=>mr(W(),e);var kt=new Set,os=e=>{kt.clear();};F("store-create.ssr-global-warned",()=>os(),65);function Rt(e,t,r={}){if(E()){let y=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;Je(y,r.onError),j(y);return}if(!zt(e)){Je(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Re(t)){Je(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&M()&&S(`createStore("${e}") received an undefined initial value. This can be indistinguishable from a missing store in some consumers; consider null or an explicit shape if that is intentional.`),Br(r).forEach(y=>{S(y);});let n=Mo(e,Ur(r,e,C().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let y=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;X(n.onError,`onError(${e})`,y),M()||G(y),H(y);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",c=n.allowSSRGlobalStore??false,l=D(),u=l.stores,w=l.subscribers,b=l.initialStates,h=l.initialFactories,x=l.metaEntries,d=l.scope==="request";if(a&&!c&&!d){let y=`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.`;Je(y,r.onError);return}if(a&&c&&!d&&!kt.has(e)&&(kt.add(e),G(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
|
|
22
|
+
This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),Q(e,l)){let y=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return de(e,y),{name:e}}s&&!c&&!d&&!co(e)&&M()&&(lo(e),S(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let p=be(e,t,n.onError);if(!p.ok)return;let g=p.value,R=n.lazy===true&&typeof t=="function",k=(w[e]?.size??0)>0;if(R)u[e]=void 0,h[e]=t;else {let y=Ze(e,g,n.validate,n.onError);if(!y.ok)return;te(e,y.value,l),b[e]=O(y.value);}let T=Date.now(),V=new Date(T).toISOString();return x[e]={createdAt:V,updatedAt:V,updatedAtMs:T,updateCount:0,version:n.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0,resetCount:0,totalResetMs:0,lastResetMs:0},options:n,readCount:0,lastReadAt:null,lastReadAtMs:null,lastCorrelationId:null,lastCorrelationAt:null,lastCorrelationAtMs:null,lastTraceContext:null},ee(e),ko(e,Fe),bt(e,"onCreate",x[e].options.onCreate,[g]),_o(l,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),k&&Fe(e),B(`Store "${e}" created -> ${JSON.stringify(g)}`),{name:e}}var ns=0,_c=(e,t=0,r={})=>{let o=xt(e);return Rt(e,{value:t},r),{inc:(n=1)=>U(o,s=>{s.value+=n;}),dec:(n=1)=>U(o,s=>{s.value-=n;}),set:n=>U(o,"value",n),reset:()=>tt(o),get:()=>et(o,"value")}},Wc=(e,t=[],r={})=>{let o=xt(e);return Rt(e,{items:t},r),{push:n=>U(o,s=>{s.items.push(n);}),removeAt:n=>U(o,s=>{s.items.splice(n,1);}),clear:()=>U(o,n=>{n.items=[];}),replace:n=>U(o,s=>{s.items=n;}),all:()=>{let n=et(o,"items");return n?[...n]:[]}}},Hc=(e,t={})=>{let r=xt(e);return Rt(e,{entities:{},ids:[]},t),{upsert:o=>U(r,n=>{let s=o.id??o._id??(typeof crypto<"u"&&crypto.randomUUID?crypto.randomUUID():`e_${++ns}_${Date.now()}`);n.ids.includes(s)||n.ids.push(s),n.entities[s]=o;}),remove:o=>U(r,n=>{n.ids=n.ids.filter(s=>s!==o),delete n.entities[o];}),all:()=>{let n=et(r);return n?n.ids.map(s=>n.entities[s]):[]},get:o=>{let n=et(r,"entities");return n?n[o]??null:null},clear:()=>tt(r)}};export{_c as createCounterStore,Hc as createEntityStore,Wc as createListStore};//# sourceMappingURL=helpers.js.map
|
|
24
23
|
//# sourceMappingURL=helpers.js.map
|