stroid 0.1.0 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +232 -108
- package/README.md +157 -577
- package/dist/async.d.ts +5 -3
- package/dist/async.js +28 -23
- package/dist/async.js.map +1 -0
- package/dist/cache.d.ts +12 -0
- package/dist/computed.d.ts +19 -8
- package/dist/computed.js +12 -10
- package/dist/computed.js.map +1 -0
- package/dist/core.d.ts +5 -5
- package/dist/core.js +16 -23
- package/dist/core.js.map +1 -0
- package/dist/devtools.d.ts +12 -1
- package/dist/devtools.js +2 -1
- package/dist/devtools.js.map +1 -0
- package/dist/feature.d.ts +92 -0
- package/dist/feature.js +2 -0
- package/dist/feature.js.map +1 -0
- package/dist/helpers.d.ts +13 -5
- package/dist/helpers.js +16 -13
- package/dist/helpers.js.map +1 -0
- package/dist/index-internal.d.ts +44 -0
- package/dist/index.d.cts +91 -52
- package/dist/index.d.ts +91 -52
- package/dist/index.js +27 -21
- package/dist/index.js.map +1 -0
- package/dist/install.d.ts +6 -0
- package/dist/install.js +2 -0
- package/dist/install.js.map +1 -0
- package/dist/{options-CB35e3Xo.d.cts → options.d.ts} +52 -2
- package/dist/persist.d.ts +1 -2
- package/dist/persist.js +2 -1
- package/dist/persist.js.map +1 -0
- package/dist/{react.d.cts → react/index.d.ts} +28 -10
- 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.js +2 -1
- package/dist/runtime-admin.js.map +1 -0
- package/dist/runtime-tools.d.ts +44 -17
- package/dist/runtime-tools.js +3 -2
- package/dist/runtime-tools.js.map +1 -0
- package/dist/selectors.js +2 -1
- package/dist/selectors.js.map +1 -0
- package/dist/server.d.ts +27 -11
- package/dist/server.js +12 -9
- package/dist/server.js.map +1 -0
- package/dist/store-registry.d.ts +80 -0
- package/dist/sync.d.ts +1 -2
- package/dist/sync.js +2 -1
- package/dist/sync.js.map +1 -0
- package/dist/testing.d.ts +1 -1
- package/dist/testing.js +16 -13
- package/dist/testing.js.map +1 -0
- package/dist/tsdoc-metadata.json +11 -0
- package/dist/types/adapters/options.d.ts +90 -2
- package/dist/types/async/cache.d.ts +39 -0
- package/dist/types/async/clone.d.ts +9 -1
- package/dist/types/{async-fetch.d.ts → async/fetch.d.ts} +2 -2
- package/dist/types/async/inflight.d.ts +1 -1
- package/dist/types/{async-registry.d.ts → async/registry.d.ts} +25 -5
- package/dist/types/async/request.d.ts +9 -1
- package/dist/types/async.d.ts +10 -2
- package/dist/types/{computed-graph.d.ts → computed/computed-graph.d.ts} +4 -6
- package/dist/types/{computed.d.ts → computed/index.d.ts} +3 -2
- package/dist/types/config.d.ts +9 -1
- package/dist/types/core/index.d.ts +11 -0
- package/dist/types/core/lifecycle-hooks.d.ts +16 -0
- package/dist/types/core/store-admin-impl.d.ts +9 -0
- package/dist/types/core/store-admin.d.ts +9 -0
- package/dist/types/core/store-core.d.ts +13 -0
- package/dist/types/core/store-create.d.ts +16 -0
- package/dist/types/core/store-hydrate-impl.d.ts +35 -0
- package/dist/types/core/store-hydrate.d.ts +9 -0
- package/dist/types/core/store-lifecycle/hooks.d.ts +19 -0
- package/dist/types/{store-lifecycle → core/store-lifecycle}/identity.d.ts +3 -3
- package/dist/types/{store-lifecycle → core/store-lifecycle}/registry.d.ts +22 -8
- package/dist/types/{store-lifecycle → core/store-lifecycle}/types.d.ts +29 -1
- package/dist/types/{store-lifecycle → core/store-lifecycle}/validation.d.ts +11 -3
- package/dist/types/core/store-name.d.ts +28 -0
- package/dist/types/{store-notify.d.ts → core/store-notify.d.ts} +1 -1
- package/dist/types/{store-read.d.ts → core/store-read.d.ts} +8 -2
- package/dist/types/{store-registry.d.ts → core/store-registry.d.ts} +44 -10
- package/dist/types/core/store-replace-impl.d.ts +11 -0
- package/dist/types/core/store-replace.d.ts +9 -0
- package/dist/types/core/store-set-impl.d.ts +13 -0
- package/dist/types/core/store-set.d.ts +9 -0
- package/dist/types/core/store-shared/core.d.ts +13 -0
- package/dist/types/core/store-shared/notify.d.ts +12 -0
- package/dist/types/{store-transaction.d.ts → core/store-transaction.d.ts} +15 -1
- package/dist/types/core/store-write-shared.d.ts +19 -0
- package/dist/types/core/store-write.d.ts +13 -0
- package/dist/types/features/feature-registry.d.ts +91 -0
- package/dist/types/features/lifecycle.d.ts +12 -0
- package/dist/types/index.d.ts +13 -2
- package/dist/types/integrations/query.d.ts +2 -2
- package/dist/types/internals/computed-order.d.ts +3 -0
- package/dist/types/internals/config.d.ts +56 -2
- package/dist/types/internals/reporting.d.ts +1 -0
- package/dist/types/internals/store-admin.d.ts +1 -1
- package/dist/types/internals/store-ops.d.ts +13 -3
- package/dist/types/internals/test-reset.d.ts +2 -0
- package/dist/types/internals/write-context.d.ts +15 -0
- package/dist/types/notification/delivery.d.ts +3 -0
- package/dist/types/notification/index.d.ts +10 -0
- package/dist/types/notification/metrics.d.ts +12 -0
- package/dist/types/notification/priority.d.ts +9 -0
- package/dist/types/notification/scheduler.d.ts +11 -0
- package/dist/types/notification/snapshot.d.ts +8 -0
- package/dist/types/runtime-tools/index.d.ts +58 -0
- package/dist/types/store.d.ts +16 -7
- package/dist/types/types/utility.d.ts +17 -0
- package/dist/types/utils/devfreeze.d.ts +2 -0
- package/dist/types/utils.d.ts +8 -0
- package/dist/{types-grvlY4BX.d.cts → types.d.ts} +30 -2
- package/dist/utility.d.ts +15 -0
- package/package.json +35 -11
- package/dist/async-cache-DFHwcBQL.d.cts +0 -52
- package/dist/async-cache-DFHwcBQL.d.ts +0 -52
- package/dist/async.cjs +0 -29
- package/dist/async.d.cts +0 -40
- package/dist/computed-BbAZm1Dq.d.cts +0 -17
- package/dist/computed-CccdgY5j.d.ts +0 -17
- package/dist/computed.cjs +0 -11
- package/dist/computed.d.cts +0 -29
- package/dist/core.cjs +0 -30
- package/dist/core.d.cts +0 -5
- package/dist/devtools.cjs +0 -1
- package/dist/devtools.d.cts +0 -19
- package/dist/helpers.cjs +0 -20
- package/dist/helpers.d.cts +0 -29
- package/dist/index.cjs +0 -30
- package/dist/options-CB35e3Xo.d.ts +0 -245
- package/dist/persist.cjs +0 -1
- package/dist/persist.d.cts +0 -2
- package/dist/react.cjs +0 -31
- package/dist/react.d.ts +0 -52
- package/dist/react.js +0 -31
- package/dist/runtime-admin.cjs +0 -1
- package/dist/runtime-admin.d.cts +0 -4
- package/dist/runtime-tools.cjs +0 -3
- package/dist/runtime-tools.d.cts +0 -39
- package/dist/selectors.cjs +0 -1
- package/dist/selectors.d.cts +0 -4
- package/dist/server.cjs +0 -10
- package/dist/server.d.cts +0 -14
- package/dist/sync.cjs +0 -1
- package/dist/sync.d.cts +0 -2
- package/dist/testing.cjs +0 -20
- package/dist/testing.d.cts +0 -16
- package/dist/types/async-cache.d.ts +0 -57
- package/dist/types/core.d.ts +0 -1
- package/dist/types/devfreeze.d.ts +0 -1
- package/dist/types/feature-registry.d.ts +0 -69
- package/dist/types/internals/hooks-warnings.d.ts +0 -6
- package/dist/types/store-lifecycle/bind.d.ts +0 -3
- package/dist/types/store-lifecycle/hooks.d.ts +0 -44
- package/dist/types/store-lifecycle.d.ts +0 -20
- package/dist/types/store-name.d.ts +0 -19
- package/dist/types/store-write.d.ts +0 -45
- package/dist/types-grvlY4BX.d.ts +0 -37
- /package/dist/types/{async-retry.d.ts → async/retry.d.ts} +0 -0
- /package/dist/types/{runtime-admin.d.ts → runtime-admin/index.d.ts} +0 -0
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { T as TraceContext } from './utility.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @module async-registry
|
|
5
|
+
*
|
|
6
|
+
* LAYER: Module
|
|
7
|
+
* OWNS: Module-level behavior and exports for async-registry.
|
|
8
|
+
*
|
|
9
|
+
* Consumers: Internal imports and public API.
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
type AsyncStateSnapshot = {
|
|
13
|
+
data?: unknown;
|
|
14
|
+
loading: boolean;
|
|
15
|
+
error: string | null;
|
|
16
|
+
status: "idle" | "loading" | "success" | "error" | "aborted";
|
|
17
|
+
cached?: boolean;
|
|
18
|
+
revalidating?: boolean;
|
|
19
|
+
correlationId?: string;
|
|
20
|
+
traceContext?: TraceContext;
|
|
21
|
+
};
|
|
22
|
+
type AsyncStateAdapter = (ctx: {
|
|
23
|
+
name: string;
|
|
24
|
+
prev: unknown;
|
|
25
|
+
next: AsyncStateSnapshot;
|
|
26
|
+
set: (value: unknown | ((draft: any) => void)) => void;
|
|
27
|
+
}) => void;
|
|
28
|
+
type WarnCategory = "noSignal" | "shape" | "autoCreate" | "mutableResult";
|
|
29
|
+
type StoreCleanupKind = "store" | "revalidate";
|
|
30
|
+
type StoreCleanupBucket = Partial<Record<StoreCleanupKind, Set<() => void>>>;
|
|
31
|
+
interface FetchOptions {
|
|
32
|
+
transform?: (result: unknown) => unknown;
|
|
33
|
+
onSuccess?: (data: unknown) => void;
|
|
34
|
+
onError?: (message: string) => void;
|
|
35
|
+
/**
|
|
36
|
+
* Optional adapter to write async state into a custom store shape.
|
|
37
|
+
* When provided, default AsyncState writes are skipped.
|
|
38
|
+
*/
|
|
39
|
+
stateAdapter?: AsyncStateAdapter;
|
|
40
|
+
method?: string;
|
|
41
|
+
headers?: Record<string, string>;
|
|
42
|
+
body?: unknown;
|
|
43
|
+
ttl?: number;
|
|
44
|
+
staleWhileRevalidate?: boolean;
|
|
45
|
+
dedupe?: boolean;
|
|
46
|
+
retry?: number;
|
|
47
|
+
retryDelay?: number;
|
|
48
|
+
retryBackoff?: number;
|
|
49
|
+
signal?: AbortSignal;
|
|
50
|
+
cacheKey?: string;
|
|
51
|
+
responseType?: "auto" | "json" | "text" | "arrayBuffer" | "blob" | "formData";
|
|
52
|
+
/**
|
|
53
|
+
* Optional correlation ID for tracing async writes.
|
|
54
|
+
* When provided, it is propagated into store metadata and middleware context.
|
|
55
|
+
*/
|
|
56
|
+
correlationId?: string;
|
|
57
|
+
/**
|
|
58
|
+
* Optional trace context (e.g. OpenTelemetry).
|
|
59
|
+
*/
|
|
60
|
+
traceContext?: TraceContext;
|
|
61
|
+
/**
|
|
62
|
+
* Auto-create the backing store if missing.
|
|
63
|
+
* Defaults to the global config setting (true by default).
|
|
64
|
+
*/
|
|
65
|
+
autoCreate?: boolean;
|
|
66
|
+
/**
|
|
67
|
+
* Clone strategy for transformed results.
|
|
68
|
+
* - "none" (default): store by reference.
|
|
69
|
+
* - "shallow": shallow clone objects/arrays.
|
|
70
|
+
* - "deep": deep clone objects/arrays.
|
|
71
|
+
*/
|
|
72
|
+
cloneResult?: "none" | "shallow" | "deep";
|
|
73
|
+
}
|
|
74
|
+
type InflightEntry = {
|
|
75
|
+
promise: Promise<unknown>;
|
|
76
|
+
raw: Promise<unknown>;
|
|
77
|
+
transform?: FetchOptions["transform"];
|
|
78
|
+
};
|
|
79
|
+
type AsyncRegistry = {
|
|
80
|
+
fetchRegistry: Record<string, {
|
|
81
|
+
kind: "url";
|
|
82
|
+
url: string;
|
|
83
|
+
options: FetchOptions;
|
|
84
|
+
} | {
|
|
85
|
+
kind: "factory";
|
|
86
|
+
factory: () => string | Promise<unknown>;
|
|
87
|
+
options: FetchOptions;
|
|
88
|
+
}>;
|
|
89
|
+
inflight: Partial<Record<string, InflightEntry>>;
|
|
90
|
+
requestVersion: Record<string, number>;
|
|
91
|
+
cacheMeta: Record<string, {
|
|
92
|
+
timestamp: number;
|
|
93
|
+
expiresAt: number | null;
|
|
94
|
+
data: unknown;
|
|
95
|
+
}>;
|
|
96
|
+
rateWindowStart: Record<string, number>;
|
|
97
|
+
rateCount: Record<string, number>;
|
|
98
|
+
ratePruneState: {
|
|
99
|
+
lastAt: number;
|
|
100
|
+
};
|
|
101
|
+
ratePruneTimer: ReturnType<typeof setTimeout> | null;
|
|
102
|
+
warnedOnce: Map<WarnCategory, Set<string>>;
|
|
103
|
+
storeCleanups: Record<string, StoreCleanupBucket>;
|
|
104
|
+
revalidateKeys: Set<string>;
|
|
105
|
+
revalidateHandlers: Record<string, () => void>;
|
|
106
|
+
asyncMetrics: {
|
|
107
|
+
cacheHits: number;
|
|
108
|
+
cacheMisses: number;
|
|
109
|
+
dedupes: number;
|
|
110
|
+
requests: number;
|
|
111
|
+
failures: number;
|
|
112
|
+
avgMs: number;
|
|
113
|
+
lastMs: number;
|
|
114
|
+
};
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
export type { AsyncRegistry as A, FetchOptions as F, AsyncStateAdapter as a, AsyncStateSnapshot as b };
|
package/dist/runtime-admin.js
CHANGED
|
@@ -1 +1,2 @@
|
|
|
1
|
-
var _e={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}`));}},Pe={logSink:_e,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",defaultSnapshotMode:"deep",middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0},$e={...Pe},C=()=>$e;var Ie=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Ne=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,se=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,We="production",ze=Ie??Ne??We,H=typeof se=="boolean"?se:ze!=="production",R=()=>H,ie=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},He=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},Be=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},X=(e,t)=>{if((C().logSink.critical??He)(e,t),C().assertRuntime)throw new Error(e)},f=(e,t)=>{if(!H)return;if((C().logSink.warn??ie)(e,t),C().assertRuntime)throw new Error(e)},O=(e,t)=>{if((C().logSink.warn??ie)(e,t),C().assertRuntime)throw new Error(e)};var _=(e,t)=>{if(!H)return;(C().logSink.log??Be)(e,t);};var ae=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",ce=()=>"Map detected; converting to plain object.",ue=()=>"Set detected; converting to array.";var $=new Set(["__proto__","constructor","prototype"]);var le=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,Ke=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null};var P=(e,t)=>{let r=Ke(e);if(r)throw new Error(`${r} values are not supported`);let n=le(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 R()&&f(ae()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),R()&&f(ce());let s={};for(let[i,a]of e){if(typeof i!="string")throw new Error("Map keys must be strings to remain JSON-safe");s[String(i)]=P(a,t);}return s}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),R()&&f(ue()),Array.from(e,s=>P(s,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s={},i=Object.getOwnPropertyDescriptors(e);for(let[a,g]of Object.entries(i))if(g.enumerable&&!$.has(a)){if("get"in g||"set"in g)throw new Error(`Accessor properties are not supported during sanitize ("${a}")`);s[a]=P(g.value,t);}return s}if(n==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(s=>P(s,t))}return e},G=e=>P(e,new WeakSet);var J=null,qe=()=>{if(J)return J;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 J=t,t},fe=e=>{let t=qe(),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},Ue=2166136261,Ye=2654435761,Xe=1e5,v=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},F=(e,t)=>{v(e,t.length);for(let r=0;r<t.length;r++)v(e,t.charCodeAt(r));},c=(e,t)=>{F(e,t);},de=(e,t)=>{if(Number.isNaN(t)){c(e,"NaN");return}if(!Number.isFinite(t)){c(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){c(e,"-0");return}let r=t|0;if(t===r){c(e,"int"),v(e,r);return}c(e,"num"),F(e,String(t));},j=(e,t)=>{if(e.nodes++>Xe){c(e,"[max]");return}if(t===null){c(e,"null");return}let r=typeof t;if(r==="string"){c(e,"string"),F(e,t);return}if(r==="number"){c(e,"number"),de(e,t);return}if(r==="boolean"){c(e,t?"true":"false");return}if(r==="undefined"){c(e,"undefined");return}if(r==="bigint"){c(e,"bigint"),F(e,t.toString());return}if(r==="symbol"){c(e,"symbol");let u=t;F(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){c(e,"function"),F(e,t.name||"anonymous");return}let n=t,s=e.seen.get(n);if(s!==void 0){c(e,"ref"),v(e,s);return}let i=e.nextId++;if(e.seen.set(n,i),Array.isArray(n)){c(e,"array"),v(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?j(e,n[u]):c(e,"hole");return}if(n instanceof Date){c(e,"date"),de(e,n.getTime());return}if(n instanceof Map){c(e,"map"),v(e,n.size),n.forEach((u,S)=>{j(e,S),j(e,u);});return}if(n instanceof Set){c(e,"set"),v(e,n.size),n.forEach(u=>{j(e,u);});return}c(e,"object");let a=Object.getOwnPropertyDescriptors(n),g=[];Object.entries(a).forEach(([u,S])=>{S?.enumerable&&($.has(u)||"get"in S||"set"in S||g.push([u,S]));}),v(e,g.length);for(let[u,S]of g)F(e,u),j(e,S.value);},Q=e=>{if(typeof e=="string")return fe(JSON.stringify(e));let t={h1:Ue,h2:Ye,seen:new WeakMap,nextId:1,nodes:0};j(t,e);let r=t.h1>>>0,n=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,n^=n>>>16,n=Math.imul(n,668265261),n^=n>>>15,n=Math.imul(n,374761393),n^=n>>>16,(r&2097151)*4294967296+(n>>>0)};var Ge=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function";var T=(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 i=new Map;return t.set(e,i),e.forEach((a,g)=>{i.set(T(g,t),T(a,t));}),i}if(e instanceof Set){let i=new Set;return t.set(e,i),e.forEach(a=>{i.add(T(a,t));}),i}if(Array.isArray(e)){let i=[];return t.set(e,i),e.forEach((a,g)=>{i[g]=T(a,t);}),i}let r=globalThis?.WeakRef;if(r&&e instanceof r)return O("WeakRef values cannot be deep-cloned. Returning the original reference."),e;let n={};t.set(e,n);let s;try{s=Object.getOwnPropertyDescriptors(e);}catch{return O("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(s).forEach(([i,a])=>{!a.enumerable||$.has(i)||"get"in a||"set"in a||(n[i]=T(a.value,t));}),n},Z=e=>{try{if(Ge)return structuredClone(e)}catch{}return T(e)};var pe=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,noSignalWarned:new Set,shapeWarned:new Set,autoCreateWarned:new Set,cleanupSubs:Object.create(null),storeCleanupFns:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}}),ee=e=>{Object.values(e.revalidateHandlers).forEach(t=>{try{t();}catch{}}),Object.values(e.cleanupSubs).forEach(t=>{try{t();}catch{}}),Object.values(e.storeCleanupFns).forEach(t=>{t.forEach(r=>{try{r();}catch{}});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.cleanupSubs).forEach(t=>delete e.cleanupSubs[t]),Object.keys(e.storeCleanupFns).forEach(t=>delete e.storeCleanupFns[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.noSignalWarned.clear(),e.shapeWarned.clear(),e.autoCreateWarned.clear(),e.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 ge=new Map,Je=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,te=e=>(Je||e).replace(/\.ts(\?|$)/,".js$1"),D=te(new URL("./store.js",import.meta.url).href);var Ze=()=>({stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:{depth:0,pending:[],stagedValues:new Map,failed:false,error:void 0},async:pe()}),I=e=>{let t=te(e),r=ge.get(t);if(r)return r;let n=Ze();return ge.set(t,n),n},N=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var B=e=>e||I(D);var ye=new Map;var re=e=>ye.get(e),W=()=>Array.from(ye.keys());var he=({name:e,label:t,fn:r,args:n,reportIssue:s})=>{if(typeof r=="function")try{r(...n);}catch(i){let a=`${t} for "${e}" failed: ${i?.message??i}`;s(a,"always");}};var L=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:s}=t;if(s?.(e),r==="critical"){n==="dev"&&f(e),X(e);return}if(n==="always"){O(e);return}f(e);};var rt=()=>B(I(D)),nt=()=>rt().computedEntries;var me=e=>Object.prototype.hasOwnProperty.call(nt(),e);var ot=()=>b().computedCleanups;var be=e=>{let t=ot(),r=t.get(e);if(!r){R()&&f(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var we=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,s=e.initialFactories,i=e.metaEntries,a=e.snapshotCache,g=e.featureRuntimes,u=e.deletingStores,S=(o,d)=>{L(d,{onError:i[o]?.options?.onError,severity:"warn",visibility:"dev"});},ne=({name:o,prev:d,options:l,initialState:h,getMeta:x,getStoreValue:M,hasStore:m})=>({name:o,options:l,prev:d,getMeta:x,getStoreValue:M,getAllStores:()=>t,getInitialState:()=>h,hasStore:m,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:y=>{L(y,{onError:l.onError,severity:"warn",visibility:"dev"});},warn:f,log:_,hashState:Q,deepClone:Z,sanitize:G,validate:()=>({ok:true,value:d}),isDev:R}),oe=({name:o,prev:d,options:l,initialState:h,phase:x})=>{let M=ne({name:o,prev:d,options:l,initialState:h,getMeta:()=>i[o],getStoreValue:()=>t[o],hasStore:()=>N(e,o)}),m=ne({name:o,prev:d,options:l,initialState:h,getMeta:()=>{},getStoreValue:()=>d,hasStore:()=>false});W().forEach(y=>{let E=g.get(y);x==="before"?E?.beforeStoreDelete?.(M):E?.afterStoreDelete?.(m);});},Y=o=>{if(!N(e,o))return;let d=t[o],l=i[o].options,h=n[o],x=r[o];u.add(o);try{x?.forEach(y=>{try{y(null);}catch(E){f(`Subscriber for "${o}" threw during delete: ${E?.message??E}`);}}),he({name:o,label:"onDelete",fn:l.onDelete,args:[d],reportIssue:(y,E)=>{L(y,{onError:l.onError,severity:"warn",visibility:E});}}),oe({name:o,prev:d,options:l,initialState:h,phase:"before"}),delete t[o],delete r[o],delete n[o],delete s[o],delete i[o],delete a[o],me(o)&&be(o);let m=e.computedDependents[o];if(m)for(let y of m)f(`[stroid] source store "${o}" was deleted. Computed store "${y}" depends on it and will return stale data. Call deleteComputed("${y}") to clean up.`);oe({name:o,prev:d,options:l,initialState:h,phase:"after"}),_(`Store "${o}" deleted`);}finally{u.delete(o);}};return {deleteExistingStore:Y,clearAllStores:()=>{let o=[],l=0,h=Number.POSITIVE_INFINITY;for(;l<20;){let M=Object.keys(t);if(M.length===0)break;M.forEach(y=>{N(e,y)&&(Y(y),o.push(y));}),l+=1;let m=Object.keys(t).length;if(m===0||m>=h)break;h=m;}let x=Object.keys(t).length;return x>0?f(`clearAllStores stopped after ${l} pass${l===1?"":"es"}; ${x} store(s) still registered (likely recreated during deletion).`):f(`All stores cleared (${o.length} stores removed)`),o},clearStores:o=>{let d=Object.keys(t).filter(l=>o?o.endsWith("*")?l.startsWith(o.slice(0,-1)):l===o:true);return d.forEach(l=>Y(l)),d},reportStoreError:S}};var st=D,it=I(st),Re=new WeakSet,ct=e=>{Re.has(e)||(Re.add(e),W().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=re(t);r&&e.featureRuntimes.set(t,r());}}));},w=()=>{let e=B(it);return ct(e),e};var b=()=>w(),A=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}}}),ut=e=>new Proxy(new Map,{get:(t,r)=>{let n=e();if(r==="size")return n.size;if(r===Symbol.iterator)return n[Symbol.iterator].bind(n);let s=n[r];return typeof s=="function"?s.bind(n):s},set:(t,r,n)=>(e()[r]=n,true)}),lt=e=>new Proxy({},{get:(t,r)=>{let n=e(),s=n[r];return typeof s=="function"?s.bind(n):s},set:(t,r,n)=>(e()[r]=n,true)});A(()=>w().stores);A(()=>w().subscribers);A(()=>w().initialStates);A(()=>w().initialFactories);A(()=>w().metaEntries);A(()=>w().snapshotCache);var z=ut(()=>w().featureRuntimes),ke=new WeakMap,Fe=e=>{let t=ke.get(e);return t||(t=we(e),ke.set(e,t)),t};lt(()=>Fe(w()));var K=()=>Fe(w()),Oe=e=>{let t=z.get(e);if(t)return t;let r=re(e);if(!r)return;let n=r();return z.set(e,n),n},gt=()=>{W().forEach(e=>{Oe(e);});};gt();var je=new WeakMap,Te=new WeakMap;var q=e=>{let t=je.get(e);return t||(t=new Map,je.set(e,t)),t},De=e=>{let t=Te.get(e);return t||(t=new Map,Te.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=q(b());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)=>(q(b())[t]=r,true)});var U=()=>{let e=b();q(e).clear(),De(e).clear();};var p=()=>b().async,k=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}}}),V=e=>new Proxy({},{get:(t,r)=>{let n=e(),s=n[r];return typeof s=="function"?s.bind(n):s},set:(t,r,n)=>(e()[r]=n,true),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}}});k(()=>p().fetchRegistry);k(()=>p().inflight);k(()=>p().requestVersion);k(()=>p().cacheMeta);k(()=>p().rateWindowStart);k(()=>p().rateCount);V(()=>p().ratePruneState);k(()=>p().cleanupSubs);k(()=>p().storeCleanupFns);k(()=>p().revalidateHandlers);V(()=>p().noSignalWarned);V(()=>p().shapeWarned);V(()=>p().autoCreateWarned);V(()=>p().revalidateKeys);V(()=>p().asyncMetrics);var Ve=()=>{ee(p());};var an=()=>{K().clearAllStores(),Ve(),U();},cn=e=>{K().clearStores(e),U();};export{an as clearAllStores,cn as clearStores};
|
|
1
|
+
var rt=new Map;var ge=e=>rt.get(e),J=()=>Array.from(rt.keys());var ot=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),st=()=>({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:ot(),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}}),ye=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(n=>{try{n();}catch{}});});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.storeCleanups).forEach(t=>delete e.storeCleanups[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),ot().forEach((t,r)=>{e.warnedOnce.set(r,t);}),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var Xt=new Map,M=(e,t,r=0)=>{!e||typeof t!="function"||Xt.set(e,{name:e,order:r,fn:t});};var xe=new Map,it=new WeakSet,Me=e=>{it.has(e)||(it.add(e),J().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ge(t);r&&e.featureRuntimes.set(t,r());}}));},Jt=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,at,Ee=e=>(at||Jt||e).replace(/\.ts(\?|$)/,".js$1"),Q=Ee(new URL("../../store.js",import.meta.url).href);var Qt=()=>{at=void 0,xe.clear();};M("registry.scope-override",Qt,110);var Zt=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),er=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},tr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),rr=(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:tr(),async:st(),notify:Zt(),lifecycleListener:null};return Me(t),t},Z=e=>{let t=Ee(e),r=xe.get(t);if(r)return r;let n=rr();return xe.set(t,n),n},ue=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var ct=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,er(e.notify),ye(e.async),e.lifecycleListener=null;};var Te=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var H=[],lt={run:(e,t)=>{H.push(e);try{return t()}finally{H.pop();}},get:()=>H.length>0?H[H.length-1]:null,enterWith:e=>{if(H.length>0){H[H.length-1]=e;return}H.push(e);}};var L=e=>(lt).get()||e||Z(Q);var or={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}`));}},ft={logSink:or,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},Ae=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}),je=new WeakMap,pt=Ae(ft),sr=e=>{let t=je.get(e);return t||(t=Ae(pt),je.set(e,t)),t};var A=()=>sr(L());var ur=()=>{je=new WeakMap,pt=Ae(ft);};M("config.reset",ur,90);var lr=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,dr=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,gt=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,fr="production",pr=lr??dr??fr,he=typeof gt=="boolean"?gt:pr!=="production",v=()=>he,yt=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},gr=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},yr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},Oe=(e,t)=>{if((A().logSink.critical??gr)(e,t),A().assertRuntime)throw new Error(e)},d=(e,t)=>{if(!he)return;if((A().logSink.warn??yt)(e,t),A().assertRuntime)throw new Error(e)},ee=(e,t)=>{if((A().logSink.warn??yt)(e,t),A().assertRuntime)throw new Error(e)};var le=(e,t)=>{if(!he)return;(A().logSink.log??yr)(e,t);};var ht=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",St=()=>"Map detected; converting to plain object.",mt=()=>"Set detected; converting to array.";var te=new Set(["__proto__","constructor","prototype"]);var bt=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,Sr=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null};var de=(e,t)=>{let r=Sr(e);if(r)throw new Error(`${r} values are not supported`);let n=bt(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date")return v()&&d(ht()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),v()&&d(St());let o={};for(let[c,f]of e){if(typeof c!="string")throw new Error("Map keys must be strings to remain JSON-safe");o[String(c)]=de(f,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),v()&&d(mt()),Array.from(e,o=>de(o,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let o={},c=Object.getOwnPropertyDescriptors(e);for(let[f,g]of Object.entries(c))if(g.enumerable&&!te.has(f)){if("get"in g||"set"in g)throw new Error(`Accessor properties are not supported during sanitize ("${f}")`);o[f]=de(g.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=>de(o,t))}return e},De=e=>de(e,new WeakSet);var Ve=null,mr=()=>{if(Ve)return Ve;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 Ve=t,t},Rt=e=>{let t=mr(),r=-1;for(let n=0;n<e.length;n++)r=r>>>0,r=r>>>8^t[(r^e.charCodeAt(n))&255];return (r^-1)>>>0},br=2166136261,wr=2654435761,Rr=1e5,B=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},G=(e,t)=>{B(e,t.length);for(let r=0;r<t.length;r++)B(e,t.charCodeAt(r));},w=(e,t)=>{G(e,t);},wt=(e,t)=>{if(Number.isNaN(t)){w(e,"NaN");return}if(!Number.isFinite(t)){w(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){w(e,"-0");return}let r=t|0;if(t===r){w(e,"int"),B(e,r);return}w(e,"num"),G(e,String(t));},re=(e,t)=>{if(e.nodes++>Rr){w(e,"[max]");return}if(t===null){w(e,"null");return}let r=typeof t;if(r==="string"){w(e,"string"),G(e,t);return}if(r==="number"){w(e,"number"),wt(e,t);return}if(r==="boolean"){w(e,t?"true":"false");return}if(r==="undefined"){w(e,"undefined");return}if(r==="bigint"){w(e,"bigint"),G(e,t.toString());return}if(r==="symbol"){w(e,"symbol");let l=t;G(e,Symbol.keyFor(l)??l.description??String(l));return}if(r==="function"){w(e,"function"),G(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){w(e,"ref"),B(e,o);return}let c=e.nextId++;if(e.seen.set(n,c),Array.isArray(n)){w(e,"array"),B(e,n.length);for(let l=0;l<n.length;l++)Object.prototype.hasOwnProperty.call(n,l)?re(e,n[l]):w(e,"hole");return}if(n instanceof Date){w(e,"date"),wt(e,n.getTime());return}if(n instanceof Map){w(e,"map"),B(e,n.size),n.forEach((l,m)=>{re(e,m),re(e,l);});return}if(n instanceof Set){w(e,"set"),B(e,n.size),n.forEach(l=>{re(e,l);});return}w(e,"object");let f=Object.getOwnPropertyDescriptors(n),g=[];Object.entries(f).forEach(([l,m])=>{m?.enumerable&&(te.has(l)||"get"in m||"set"in m||g.push([l,m]));}),B(e,g.length);for(let[l,m]of g)G(e,l),re(e,m.value);},Ne=e=>{if(typeof e=="string")return Rt(JSON.stringify(e));let t={h1:br,h2:wr,seen:new WeakMap,nextId:1,nodes:0};re(t,e);let r=t.h1>>>0,n=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,n^=n>>>16,n=Math.imul(n,668265261),n^=n>>>15,n=Math.imul(n,374761393),n^=n>>>16,(r&2097151)*4294967296+(n>>>0)};var kr=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Pe=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=[["WeakMap",globalThis.WeakMap],["WeakSet",globalThis.WeakSet],["WeakRef",globalThis.WeakRef],["Promise",globalThis.Promise],["ReadableStream",globalThis.ReadableStream],["WritableStream",globalThis.WritableStream],["TransformStream",globalThis.TransformStream],["EventTarget",globalThis.EventTarget]];for(let[n,o]of t)if(typeof o=="function"&&e instanceof o)return n;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},Cr=e=>Pe(e)===null,vr=e=>{let t=Pe(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},Y=(e,t=new WeakMap)=>{if(vr(e),e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let o=new Map;return t.set(e,o),e.forEach((c,f)=>{o.set(Y(f,t),Y(c,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(c=>{o.add(Y(c,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((c,f)=>{o[f]=Y(c,t);}),o}let r={};t.set(e,r);let n;try{n=Object.getOwnPropertyDescriptors(e);}catch(o){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${o?.message??o}`)}return Object.entries(n).forEach(([o,c])=>{!c.enumerable||te.has(o)||"get"in c||"set"in c||(r[o]=Y(c.value,t));}),r},K=e=>{if(kr)try{return structuredClone(e)}catch(t){if(!Cr(e)){let r=Pe(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return d(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),Y(e)}return Y(e)};var kt=({name:e,label:t,fn:r,args:n,reportIssue:o})=>{if(typeof r=="function")try{r(...n);}catch(c){let f=`${t} for "${e}" failed: ${c?.message??c}`;o(f,"always");}};var xr=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(n){let o=n?.message??n;ee(`${t} callback threw: ${String(o)}`);}},Se=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(xr(o,"onError",e),r==="critical"){n==="dev"&&d(e),Oe(e);return}if(n==="always"){ee(e);return}d(e);};M("computed.order-resolver",()=>{},105);var xt=()=>L(Z(Q)),Mt=()=>xt().computedEntries;var Et=e=>Object.prototype.hasOwnProperty.call(Mt(),e);var Tt=new WeakMap,Ft=new WeakMap;var be=e=>{let t=Tt.get(e);return t||(t=new Map,Tt.set(e,t)),t},jt=e=>{let t=Ft.get(e);return t||(t=new Map,Ft.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=be(P());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let n=r[t];return typeof n=="function"?n.bind(r):n},set:(e,t,r)=>(be(P())[t]=r,true)});var we=()=>{let e=P();be(e).clear(),jt(e).clear();};M("validation.path-cache",we,50);var _t=new Map;var pe=(e,t,r)=>{let n=_t.get(e);!n||n.size===0||n.forEach(o=>{try{o(t,r);}catch(c){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,c);}});};var Or=()=>{let e=P().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0;};M("notify.reset",Or,40);var Dr=()=>P().computedCleanups;var Ht=e=>{let t=Dr(),r=t.get(e);if(!r){v()&&d(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Wt=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,c=e.metaEntries,f=e.snapshotCache,g=e.featureRuntimes,l=e.deletingStores,m=(i,k)=>{Se(k,{onError:c[i]?.options?.onError,severity:"warn",visibility:"dev"});},y=({name:i,prev:k,options:h,initialState:T,getMeta:F,getStoreValue:_,hasStore:j})=>({name:i,options:h,prev:k,getMeta:F,getStoreValue:_,getAllStores:()=>t,getInitialState:()=>T,hasStore:j,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:C=>{Se(C,{onError:h.onError,severity:"warn",visibility:"dev"});},warn:d,warnAlways:ee,log:le,hashState:Ne,deepClone:K,sanitize:De,validate:()=>({ok:true,value:k}),isDev:v}),S=({name:i,prev:k,options:h,initialState:T,phase:F})=>{let _=y({name:i,prev:k,options:h,initialState:T,getMeta:()=>c[i],getStoreValue:()=>t[i],hasStore:()=>ue(e,i)}),j=y({name:i,prev:k,options:h,initialState:T,getMeta:()=>{},getStoreValue:()=>k,hasStore:()=>false});J().forEach(C=>{let N=g.get(C);F==="before"?N?.beforeStoreDelete?.(_):N?.afterStoreDelete?.(j);});},p=i=>{if(!ue(e,i))return;let k=t[i],h=c[i].options,T=n[i],F=r[i];l.add(i);try{F?.forEach(C=>{try{C(null);}catch(N){d(`Subscriber for "${i}" threw during delete: ${N?.message??N}`);}}),kt({name:i,label:"onDelete",fn:h.onDelete,args:[k],reportIssue:(C,N)=>{Se(C,{onError:h.onError,severity:"warn",visibility:N});}}),S({name:i,prev:k,options:h,initialState:T,phase:"before"}),delete t[i],delete r[i],delete n[i],delete o[i],delete c[i],delete f[i],Et(i)&&Ht(i);let j=e.computedDependents[i];if(j)for(let C of j)d(`[stroid] source store "${i}" was deleted. Computed store "${C}" depends on it and will return stale data. Call deleteComputed("${C}") to clean up.`);S({name:i,prev:k,options:h,initialState:T,phase:"after"}),pe("afterStoreDelete",i,{type:"afterStoreDelete",prev:k}),Te(e,{type:"deleted",name:i}),le(`Store "${i}" deleted`);}finally{l.delete(i);}};return {deleteExistingStore:p,clearAllStores:()=>{let i=[],h=0,T=Number.POSITIVE_INFINITY;for(;h<20;){let _=Object.keys(t);if(_.length===0)break;_.forEach(C=>{ue(e,C)&&(p(C),i.push(C));}),h+=1;let j=Object.keys(t).length;if(j===0||j>=T)break;T=j;}let F=Object.keys(t).length;return F>0?d(`clearAllStores stopped after ${h} pass${h===1?"":"es"}; ${F} store(s) still registered (likely recreated during deletion).`):d(`All stores cleared (${i.length} stores removed)`),i},clearStores:i=>{let k=Object.keys(t).filter(h=>i?i.endsWith("*")?h.startsWith(i.slice(0,-1)):h===i:true);return k.forEach(h=>p(h)),k},reportStoreError:m}};var Ge=Q,Bt=Z(Ge),V=()=>{let e=L(Bt);return Me(e),e};var P=()=>V();var oe=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}}}),Nr=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)}),Ir=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)});oe(()=>V().stores);oe(()=>V().subscribers);oe(()=>V().initialStates);oe(()=>V().initialFactories);oe(()=>V().metaEntries);oe(()=>V().snapshotCache);var ne=Nr(()=>V().featureRuntimes),Lt=new WeakMap,Kt=e=>{let t=Lt.get(e);return t||(t=Wt(e),Lt.set(e,t)),t};Ir(()=>Kt(V()));var Ye=()=>Kt(V()),Pr=e=>{let t=ne.get(e);if(t)return t;let r=ge(e);if(!r)return;let n=r();return ne.set(e,n),n},_r=()=>{J().forEach(e=>{Pr(e);});};_r();var $r=()=>{ct(V());},zr=()=>{ne.forEach(e=>{try{e.resetAll?.();}catch{}}),ne.clear();};M("features.reset",zr,10);M("registries.clear",$r,20);M("registry.default",()=>{Ge=Q,Bt=Z(Ge);},115);var Ut=()=>L().async;var qt=()=>{ye(Ut());};var us=()=>{Ye().clearAllStores(),qt(),we();},ls=e=>{Ye().clearStores(e),we();};export{us as clearAllStores,ls as clearStores};//# sourceMappingURL=runtime-admin.js.map
|
|
2
|
+
//# sourceMappingURL=runtime-admin.js.map
|