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.
Files changed (112) hide show
  1. package/CHANGELOG.md +235 -119
  2. package/README.md +104 -431
  3. package/dist/async.d.ts +42 -9
  4. package/dist/async.js +26 -26
  5. package/dist/async.js.map +1 -1
  6. package/dist/cache.d.ts +12 -0
  7. package/dist/computed.d.ts +46 -7
  8. package/dist/computed.js +11 -11
  9. package/dist/computed.js.map +1 -1
  10. package/dist/core.d.ts +5 -15
  11. package/dist/core.js +14 -15
  12. package/dist/core.js.map +1 -1
  13. package/dist/devtools.d.ts +30 -5
  14. package/dist/devtools.js +1 -1
  15. package/dist/devtools.js.map +1 -1
  16. package/dist/feature.d.ts +92 -14
  17. package/dist/feature.js +1 -1
  18. package/dist/feature.js.map +1 -1
  19. package/dist/helpers.d.ts +37 -3
  20. package/dist/helpers.js +14 -15
  21. package/dist/helpers.js.map +1 -1
  22. package/dist/index-internal.d.ts +44 -0
  23. package/dist/index.d.cts +170 -33
  24. package/dist/index.d.ts +170 -33
  25. package/dist/index.js +24 -23
  26. package/dist/index.js.map +1 -1
  27. package/dist/install.d.ts +6 -4
  28. package/dist/install.js +1 -1
  29. package/dist/install.js.map +1 -1
  30. package/dist/options.d.ts +295 -0
  31. package/dist/persist.d.ts +1 -1
  32. package/dist/persist.js +1 -1
  33. package/dist/persist.js.map +1 -1
  34. package/dist/react/index.d.ts +70 -0
  35. package/dist/react/index.js +38 -0
  36. package/dist/react/index.js.map +1 -0
  37. package/dist/registry.d.ts +117 -0
  38. package/dist/runtime-admin.d.ts +4 -2
  39. package/dist/runtime-admin.js +1 -1
  40. package/dist/runtime-admin.js.map +1 -1
  41. package/dist/runtime-tools.d.ts +66 -9
  42. package/dist/runtime-tools.js +2 -2
  43. package/dist/runtime-tools.js.map +1 -1
  44. package/dist/selectors.d.ts +4 -2
  45. package/dist/selectors.js +1 -1
  46. package/dist/selectors.js.map +1 -1
  47. package/dist/server.d.ts +30 -2
  48. package/dist/server.js +11 -10
  49. package/dist/server.js.map +1 -1
  50. package/dist/store-registry.d.ts +79 -0
  51. package/dist/sync.d.ts +1 -1
  52. package/dist/sync.js +1 -1
  53. package/dist/sync.js.map +1 -1
  54. package/dist/testing.d.ts +16 -4
  55. package/dist/testing.js +14 -15
  56. package/dist/testing.js.map +1 -1
  57. package/dist/tsdoc-metadata.json +11 -0
  58. package/dist/types.d.ts +65 -0
  59. package/dist/utility.d.ts +15 -0
  60. package/package.json +29 -11
  61. package/dist/_tsup-dts-rollup.d.cts +0 -2411
  62. package/dist/_tsup-dts-rollup.d.ts +0 -2411
  63. package/dist/async.cjs +0 -34
  64. package/dist/async.cjs.map +0 -1
  65. package/dist/async.d.cts +0 -9
  66. package/dist/computed.cjs +0 -13
  67. package/dist/computed.cjs.map +0 -1
  68. package/dist/computed.d.cts +0 -7
  69. package/dist/core.cjs +0 -24
  70. package/dist/core.cjs.map +0 -1
  71. package/dist/core.d.cts +0 -15
  72. package/dist/devtools.cjs +0 -2
  73. package/dist/devtools.cjs.map +0 -1
  74. package/dist/devtools.d.cts +0 -5
  75. package/dist/feature.cjs +0 -2
  76. package/dist/feature.cjs.map +0 -1
  77. package/dist/feature.d.cts +0 -14
  78. package/dist/helpers.cjs +0 -24
  79. package/dist/helpers.cjs.map +0 -1
  80. package/dist/helpers.d.cts +0 -3
  81. package/dist/index.cjs +0 -35
  82. package/dist/index.cjs.map +0 -1
  83. package/dist/install.cjs +0 -2
  84. package/dist/install.cjs.map +0 -1
  85. package/dist/install.d.cts +0 -4
  86. package/dist/persist.cjs +0 -2
  87. package/dist/persist.cjs.map +0 -1
  88. package/dist/persist.d.cts +0 -1
  89. package/dist/react.cjs +0 -36
  90. package/dist/react.cjs.map +0 -1
  91. package/dist/react.d.cts +0 -7
  92. package/dist/react.d.ts +0 -7
  93. package/dist/react.js +0 -36
  94. package/dist/react.js.map +0 -1
  95. package/dist/runtime-admin.cjs +0 -2
  96. package/dist/runtime-admin.cjs.map +0 -1
  97. package/dist/runtime-admin.d.cts +0 -2
  98. package/dist/runtime-tools.cjs +0 -4
  99. package/dist/runtime-tools.cjs.map +0 -1
  100. package/dist/runtime-tools.d.cts +0 -9
  101. package/dist/selectors.cjs +0 -2
  102. package/dist/selectors.cjs.map +0 -1
  103. package/dist/selectors.d.cts +0 -2
  104. package/dist/server.cjs +0 -12
  105. package/dist/server.cjs.map +0 -1
  106. package/dist/server.d.cts +0 -2
  107. package/dist/sync.cjs +0 -2
  108. package/dist/sync.cjs.map +0 -1
  109. package/dist/sync.d.cts +0 -1
  110. package/dist/testing.cjs +0 -24
  111. package/dist/testing.cjs.map +0 -1
  112. package/dist/testing.d.cts +0 -4
@@ -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 };
@@ -1,2 +1,4 @@
1
- export { clearAllStores } from './_tsup-dts-rollup.js';
2
- export { clearStores } from './_tsup-dts-rollup.js';
1
+ declare const clearAllStores: () => void;
2
+ declare const clearStores: (pattern?: string) => void;
3
+
4
+ export { clearAllStores, clearStores };
@@ -1,2 +1,2 @@
1
- var He=new Map,R=(e,t,r=0)=>{!e||typeof t!="function"||He.set(e,{name:e,order:r,fn:t});};var le=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,noSignalWarned:new Set,shapeWarned:new Set,autoCreateWarned:new Set,mutableResultWarned:new Set,cleanupSubs:Object.create(null),storeCleanupFns:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}}),Y=e=>{Object.values(e.revalidateHandlers).forEach(t=>{try{t();}catch{}}),Object.values(e.cleanupSubs).forEach(t=>{try{t();}catch{}}),Object.values(e.storeCleanupFns).forEach(t=>{t.forEach(r=>{try{r();}catch{}});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.cleanupSubs).forEach(t=>delete e.cleanupSubs[t]),Object.keys(e.storeCleanupFns).forEach(t=>delete e.storeCleanupFns[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.noSignalWarned.clear(),e.shapeWarned.clear(),e.autoCreateWarned.clear(),e.mutableResultWarned.clear(),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var ee=new Map,Be=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,fe,te=e=>(fe||Be||e).replace(/\.ts(\?|$)/,".js$1"),z=te(new URL("./store.js",import.meta.url).href);var Le=()=>{fe=void 0,ee.clear();};R("registry.scope-override",Le,110);var Ue=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0}),Ke=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;},qe=()=>({stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:{depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0},async:le(),notify:Ue()}),H=e=>{let t=te(e),r=ee.get(t);if(r)return r;let n=qe();return ee.set(t,n),n},B=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var pe=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,Ke(e.notify),Y(e.async);};var V=e=>e||H(z);var Xe={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}`));}},ge={logSink:Xe,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0},ne=e=>({logSink:{...e.logSink},flush:{...e.flush},revalidateOnFocus:{...e.revalidateOnFocus},namespace:e.namespace,strictMissingFeatures:e.strictMissingFeatures,assertRuntime:e.assertRuntime,strictMutatorReturns:e.strictMutatorReturns,asyncAutoCreate:e.asyncAutoCreate,asyncCloneResult:e.asyncCloneResult,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce}),re=new WeakMap,ye=ne(ge),Ge=e=>{let t=re.get(e);return t||(t=ne(ye),re.set(e,t)),t};var T=()=>Ge(V());var Ze=()=>{re=new WeakMap,ye=ne(ge);};R("config.reset",Ze,90);var et=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,tt=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,Se=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,rt="production",nt=et??tt??rt,X=typeof Se=="boolean"?Se:nt!=="production",v=()=>X,he=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},ot=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},st=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},oe=(e,t)=>{if((T().logSink.critical??ot)(e,t),T().assertRuntime)throw new Error(e)},y=(e,t)=>{if(!X)return;if((T().logSink.warn??he)(e,t),T().assertRuntime)throw new Error(e)},P=(e,t)=>{if((T().logSink.warn??he)(e,t),T().assertRuntime)throw new Error(e)};var L=(e,t)=>{if(!X)return;(T().logSink.log??st)(e,t);};var me=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",be=()=>"Map detected; converting to plain object.",Re=()=>"Set detected; converting to array.";var K=new Set(["__proto__","constructor","prototype"]);var we=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,at=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 U=(e,t)=>{let r=at(e);if(r)throw new Error(`${r} values are not supported`);let n=we(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()&&y(me()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),v()&&y(be());let s={};for(let[i,c]of e){if(typeof i!="string")throw new Error("Map keys must be strings to remain JSON-safe");s[String(i)]=U(c,t);}return s}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),v()&&y(Re()),Array.from(e,s=>U(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[c,f]of Object.entries(i))if(f.enumerable&&!K.has(c)){if("get"in f||"set"in f)throw new Error(`Accessor properties are not supported during sanitize ("${c}")`);s[c]=U(f.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=>U(s,t))}return e},se=e=>U(e,new WeakSet);var ie=null,ct=()=>{if(ie)return ie;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 ie=t,t},xe=e=>{let t=ct(),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},ut=2166136261,dt=2654435761,lt=1e5,F=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},A=(e,t)=>{F(e,t.length);for(let r=0;r<t.length;r++)F(e,t.charCodeAt(r));},d=(e,t)=>{A(e,t);},ke=(e,t)=>{if(Number.isNaN(t)){d(e,"NaN");return}if(!Number.isFinite(t)){d(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){d(e,"-0");return}let r=t|0;if(t===r){d(e,"int"),F(e,r);return}d(e,"num"),A(e,String(t));},$=(e,t)=>{if(e.nodes++>lt){d(e,"[max]");return}if(t===null){d(e,"null");return}let r=typeof t;if(r==="string"){d(e,"string"),A(e,t);return}if(r==="number"){d(e,"number"),ke(e,t);return}if(r==="boolean"){d(e,t?"true":"false");return}if(r==="undefined"){d(e,"undefined");return}if(r==="bigint"){d(e,"bigint"),A(e,t.toString());return}if(r==="symbol"){d(e,"symbol");let a=t;A(e,Symbol.keyFor(a)??a.description??String(a));return}if(r==="function"){d(e,"function"),A(e,t.name||"anonymous");return}let n=t,s=e.seen.get(n);if(s!==void 0){d(e,"ref"),F(e,s);return}let i=e.nextId++;if(e.seen.set(n,i),Array.isArray(n)){d(e,"array"),F(e,n.length);for(let a=0;a<n.length;a++)Object.prototype.hasOwnProperty.call(n,a)?$(e,n[a]):d(e,"hole");return}if(n instanceof Date){d(e,"date"),ke(e,n.getTime());return}if(n instanceof Map){d(e,"map"),F(e,n.size),n.forEach((a,b)=>{$(e,b),$(e,a);});return}if(n instanceof Set){d(e,"set"),F(e,n.size),n.forEach(a=>{$(e,a);});return}d(e,"object");let c=Object.getOwnPropertyDescriptors(n),f=[];Object.entries(c).forEach(([a,b])=>{b?.enumerable&&(K.has(a)||"get"in b||"set"in b||f.push([a,b]));}),F(e,f.length);for(let[a,b]of f)A(e,a),$(e,b.value);},ae=e=>{if(typeof e=="string")return xe(JSON.stringify(e));let t={h1:ut,h2:dt,seen:new WeakMap,nextId:1,nodes:0};$(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 ft=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function";var N=(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((c,f)=>{i.set(N(f,t),N(c,t));}),i}if(e instanceof Set){let i=new Set;return t.set(e,i),e.forEach(c=>{i.add(N(c,t));}),i}if(Array.isArray(e)){let i=[];return t.set(e,i),e.forEach((c,f)=>{i[f]=N(c,t);}),i}let r=globalThis?.WeakRef;if(r&&e instanceof r)return P("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 P("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(s).forEach(([i,c])=>{!c.enumerable||K.has(i)||"get"in c||"set"in c||(n[i]=N(c.value,t));}),n},ce=e=>{try{if(ft)return structuredClone(e)}catch{}return N(e)};var ve=new Map;var ue=e=>ve.get(e),q=()=>Array.from(ve.keys());var Me=({name:e,label:t,fn:r,args:n,reportIssue:s})=>{if(typeof r=="function")try{r(...n);}catch(i){let c=`${t} for "${e}" failed: ${i?.message??i}`;s(c,"always");}};var G=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:s}=t;if(s?.(e),r==="critical"){n==="dev"&&y(e),oe(e);return}if(n==="always"){P(e);return}y(e);};R("computed.order-resolver",()=>{},105);var Fe=()=>V(H(z)),Oe=()=>Fe().computedEntries;var je=e=>Object.prototype.hasOwnProperty.call(Oe(),e);var Ae=new WeakMap,De=new WeakMap;var J=e=>{let t=Ae.get(e);return t||(t=new Map,Ae.set(e,t)),t},_e=e=>{let t=De.get(e);return t||(t=new Map,De.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=J(C());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)=>(J(C())[t]=r,true)});var Q=()=>{let e=C();J(e).clear(),_e(e).clear();};R("validation.path-cache",Q,50);var wt=()=>C().computedCleanups;var Pe=e=>{let t=wt(),r=t.get(e);if(!r){v()&&y(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var $e=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,s=e.initialFactories,i=e.metaEntries,c=e.snapshotCache,f=e.featureRuntimes,a=e.deletingStores,b=(o,g)=>{G(g,{onError:i[o]?.options?.onError,severity:"warn",visibility:"dev"});},p=({name:o,prev:g,options:l,initialState:k,getMeta:E,getStoreValue:O,hasStore:x})=>({name:o,options:l,prev:g,getMeta:E,getStoreValue:O,getAllStores:()=>t,getInitialState:()=>k,hasStore:x,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:m=>{G(m,{onError:l.onError,severity:"warn",visibility:"dev"});},warn:y,log:L,hashState:ae,deepClone:ce,sanitize:se,validate:()=>({ok:true,value:g}),isDev:v}),S=({name:o,prev:g,options:l,initialState:k,phase:E})=>{let O=p({name:o,prev:g,options:l,initialState:k,getMeta:()=>i[o],getStoreValue:()=>t[o],hasStore:()=>B(e,o)}),x=p({name:o,prev:g,options:l,initialState:k,getMeta:()=>{},getStoreValue:()=>g,hasStore:()=>false});q().forEach(m=>{let j=f.get(m);E==="before"?j?.beforeStoreDelete?.(O):j?.afterStoreDelete?.(x);});},u=o=>{if(!B(e,o))return;let g=t[o],l=i[o].options,k=n[o],E=r[o];a.add(o);try{E?.forEach(m=>{try{m(null);}catch(j){y(`Subscriber for "${o}" threw during delete: ${j?.message??j}`);}}),Me({name:o,label:"onDelete",fn:l.onDelete,args:[g],reportIssue:(m,j)=>{G(m,{onError:l.onError,severity:"warn",visibility:j});}}),S({name:o,prev:g,options:l,initialState:k,phase:"before"}),delete t[o],delete r[o],delete n[o],delete s[o],delete i[o],delete c[o],je(o)&&Pe(o);let x=e.computedDependents[o];if(x)for(let m of x)y(`[stroid] source store "${o}" was deleted. Computed store "${m}" depends on it and will return stale data. Call deleteComputed("${m}") to clean up.`);S({name:o,prev:g,options:l,initialState:k,phase:"after"}),L(`Store "${o}" deleted`);}finally{a.delete(o);}};return {deleteExistingStore:u,clearAllStores:()=>{let o=[],l=0,k=Number.POSITIVE_INFINITY;for(;l<20;){let O=Object.keys(t);if(O.length===0)break;O.forEach(m=>{B(e,m)&&(u(m),o.push(m));}),l+=1;let x=Object.keys(t).length;if(x===0||x>=k)break;k=x;}let E=Object.keys(t).length;return E>0?y(`clearAllStores stopped after ${l} pass${l===1?"":"es"}; ${E} store(s) still registered (likely recreated during deletion).`):y(`All stores cleared (${o.length} stores removed)`),o},clearStores:o=>{let g=Object.keys(t).filter(l=>o?o.endsWith("*")?l.startsWith(o.slice(0,-1)):l===o:true);return g.forEach(l=>u(l)),g},reportStoreError:b}};var kt=z,xt=H(kt),Ne=new WeakSet,Ct=e=>{Ne.has(e)||(Ne.add(e),q().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ue(t);r&&e.featureRuntimes.set(t,r());}}));},w=()=>{let e=V(xt);return Ct(e),e};var C=()=>w();var W=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}}}),Mt=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)}),Et=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)});W(()=>w().stores);W(()=>w().subscribers);W(()=>w().initialStates);W(()=>w().initialFactories);W(()=>w().metaEntries);W(()=>w().snapshotCache);var I=Mt(()=>w().featureRuntimes),Ie=new WeakMap,We=e=>{let t=Ie.get(e);return t||(t=$e(e),Ie.set(e,t)),t};Et(()=>We(w()));var de=()=>We(w()),Tt=e=>{let t=I.get(e);if(t)return t;let r=ue(e);if(!r)return;let n=r();return I.set(e,n),n},Ft=()=>{q().forEach(e=>{Tt(e);});};Ft();var Ot=()=>{pe(w());},jt=()=>{I.forEach(e=>{try{e.resetAll?.();}catch{}}),I.clear();};R("features.reset",jt,10);R("registries.clear",Ot,20);var h=()=>C().async,D=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}}}),_=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}}});D(()=>h().inflight);D(()=>h().requestVersion);D(()=>h().rateWindowStart);D(()=>h().rateCount);_(()=>h().ratePruneState);D(()=>h().cleanupSubs);D(()=>h().storeCleanupFns);D(()=>h().revalidateHandlers);_(()=>h().noSignalWarned);_(()=>h().shapeWarned);_(()=>h().autoCreateWarned);_(()=>h().mutableResultWarned);_(()=>h().revalidateKeys);_(()=>h().asyncMetrics);var ze=()=>{Y(h());};var Rn=()=>{de().clearAllStores(),ze(),Q();},wn=e=>{de().clearStores(e),Q();};export{Rn as clearAllStores,wn as clearStores};//# sourceMappingURL=runtime-admin.js.map
1
+ var ot=new Map;var ye=e=>ot.get(e),J=()=>Array.from(ot.keys());var it=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),at=()=>({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:it(),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}}),he=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(),it().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 Zt=new Map,v=(e,t,r=0)=>{!e||typeof t!="function"||Zt.set(e,{name:e,order:r,fn:t});};var Me=new Map,ct=new WeakSet,Ee=e=>{ct.has(e)||(ct.add(e),J().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ye(t);r&&e.featureRuntimes.set(t,r());}}));},er=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,ut,Te=e=>(ut||er||e).replace(/\.ts(\?|$)/,".js$1"),Q=Te("stroid:default-registry");var tr=()=>{ut=void 0,Me.clear();};v("registry.scope-override",tr,110);var rr=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),nr=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},or=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),sr=(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:or(),async:at(),notify:rr(),lifecycleListener:null};return Ee(t),t},Z=e=>{let t=Te(e),r=Me.get(t);if(r)return r;let n=sr();return Me.set(t,n),n},ee=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var lt=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,nr(e.notify),he(e.async),e.lifecycleListener=null;};var Fe=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var z=[],ft={run:(e,t)=>{z.push(e);try{return t()}finally{z.pop();}},get:()=>z.length>0?z[z.length-1]:null,enterWith:e=>{if(z.length>0){z[z.length-1]=e;return}z.push(e);}};var L=e=>(ft).get()||e||Z(Q);var ar={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}`));}},gt={logSink:ar,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},Oe=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,yt=Oe(gt),cr=e=>{let t=je.get(e);return t||(t=Oe(yt),je.set(e,t)),t};var j=()=>cr(L());var fr=()=>{je=new WeakMap,yt=Oe(gt);};v("config.reset",fr,90);var pr=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,gr=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,ht=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,yr="production",hr=pr??gr??yr,Se=typeof ht=="boolean"?ht:hr!=="production",M=()=>Se,St=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Sr=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},mr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},De=(e,t)=>{if((j().logSink.critical??Sr)(e,t),j().assertRuntime)throw new Error(e)},f=(e,t)=>{if(!Se)return;if((j().logSink.warn??St)(e,t),j().assertRuntime)throw new Error(e)},te=(e,t)=>{if((j().logSink.warn??St)(e,t),j().assertRuntime)throw new Error(e)};var re=(e,t)=>{if(!Se)return;(j().logSink.log??mr)(e,t);};var mt=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",bt=()=>"Map detected; converting to plain object.",wt=()=>"Set detected; converting to array.";var ne=new Set(["__proto__","constructor","prototype"]);var Rt=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,wr=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null};var fe=(e,t)=>{let r=wr(e);if(r)throw new Error(`${r} values are not supported`);let n=Rt(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 M()&&f(mt()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),M()&&f(bt());let o={};for(let[c,d]of e){if(typeof c!="string")throw new Error("Map keys must be strings to remain JSON-safe");o[String(c)]=fe(d,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),M()&&f(wt()),Array.from(e,o=>fe(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[d,g]of Object.entries(c))if(g.enumerable&&!ne.has(d)){if("get"in g||"set"in g)throw new Error(`Accessor properties are not supported during sanitize ("${d}")`);o[d]=fe(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=>fe(o,t))}return e},Ve=e=>fe(e,new WeakSet);var Ne=null,Rr=()=>{if(Ne)return Ne;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 Ne=t,t},kt=e=>{let t=Rr(),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},Cr=2166136261,kr=2654435761,xr=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));},R=(e,t)=>{G(e,t);},Ct=(e,t)=>{if(Number.isNaN(t)){R(e,"NaN");return}if(!Number.isFinite(t)){R(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){R(e,"-0");return}let r=t|0;if(t===r){R(e,"int"),B(e,r);return}R(e,"num"),G(e,String(t));},oe=(e,t)=>{if(e.nodes++>xr){R(e,"[max]");return}if(t===null){R(e,"null");return}let r=typeof t;if(r==="string"){R(e,"string"),G(e,t);return}if(r==="number"){R(e,"number"),Ct(e,t);return}if(r==="boolean"){R(e,t?"true":"false");return}if(r==="undefined"){R(e,"undefined");return}if(r==="bigint"){R(e,"bigint"),G(e,t.toString());return}if(r==="symbol"){R(e,"symbol");let u=t;G(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){R(e,"function"),G(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){R(e,"ref"),B(e,o);return}let c=e.nextId++;if(e.seen.set(n,c),Array.isArray(n)){R(e,"array"),B(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?oe(e,n[u]):R(e,"hole");return}if(n instanceof Date){R(e,"date"),Ct(e,n.getTime());return}if(n instanceof Map){R(e,"map"),B(e,n.size),n.forEach((u,m)=>{oe(e,m),oe(e,u);});return}if(n instanceof Set){R(e,"set"),B(e,n.size),n.forEach(u=>{oe(e,u);});return}R(e,"object");let d=Object.getOwnPropertyDescriptors(n),g=[];Object.entries(d).forEach(([u,m])=>{m?.enumerable&&(ne.has(u)||"get"in m||"set"in m||g.push([u,m]));}),B(e,g.length);for(let[u,m]of g)G(e,u),oe(e,m.value);},Ie=e=>{if(typeof e=="string")return kt(JSON.stringify(e));let t={h1:Cr,h2:kr,seen:new WeakMap,nextId:1,nodes:0};oe(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 vr=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",_e=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},Mr=e=>_e(e)===null,Er=e=>{let t=_e(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(Er(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,d)=>{o.set(Y(d,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,d)=>{o[d]=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||ne.has(o)||"get"in c||"set"in c||(r[o]=Y(c.value,t));}),r},K=e=>{if(vr)try{return structuredClone(e)}catch(t){if(!Mr(e)){let r=_e(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return f(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),Y(e)}return Y(e)};var xt=({name:e,label:t,fn:r,args:n,reportIssue:o})=>{if(typeof r=="function")try{r(...n);}catch(c){let d=`${t} for "${e}" failed: ${c?.message??c}`;o(d,"always");}};var Tr=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(n){let o=n?.message??n;te(`${t} callback threw: ${String(o)}`);}},me=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(Tr(o,"onError",e),r==="critical"){n==="dev"&&f(e),De(e);return}if(n==="always"){te(e);return}f(e);};v("computed.order-resolver",()=>{},105);var Et=()=>L(Z(Q)),$e=()=>Et().computedEntries,Tt=()=>Et().computedDependents;var Ft=e=>Object.prototype.hasOwnProperty.call($e(),e);var We=e=>{let t=$e()[e];if(!t)return null;let r=Tt()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var At=new WeakMap,jt=new WeakMap;var we=e=>{let t=At.get(e);return t||(t=new Map,At.set(e,t)),t},Ot=e=>{let t=jt.get(e);return t||(t=new Map,jt.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=we(V());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)=>(we(V())[t]=r,true)});var Re=()=>{let e=V();we(e).clear(),Ot(e).clear();};v("validation.path-cache",Re,50);var Wt=new Map;var ge=(e,t,r)=>{let n=Wt.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=()=>{};v("write-context.runner",Or,121);var Nr=()=>{let e=V().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};v("notify.reset",Nr,40);var Ir=()=>V().computedCleanups,Lt=new WeakMap;var Pr=e=>{let t=Lt.get(e);return t||(t=new Map,Lt.set(e,t)),t};var Bt=e=>{let t=Ir(),r=t.get(e);if(!r){M()&&f(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Kt=(e,t=V())=>Pr(t).get(e)?.autoDispose===true;var qt=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,c=e.metaEntries,d=e.snapshotCache,g=e.featureRuntimes,u=e.deletingStores,m=(i,b)=>{me(b,{onError:c[i]?.options?.onError,severity:"warn",visibility:"dev"});},y=({name:i,prev:b,options:S,initialState:E,getMeta:I,getStoreValue:_,hasStore:F})=>({name:i,options:S,prev:b,getMeta:I,getStoreValue:_,getAllStores:()=>t,getInitialState:()=>E,hasStore:F,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:k=>{me(k,{onError:S.onError,severity:"warn",visibility:"dev"});},warn:f,warnAlways:te,log:re,hashState:Ie,deepClone:K,sanitize:Ve,validate:()=>({ok:true,value:b}),isDev:M}),C=({name:i,prev:b,options:S,initialState:E,phase:I})=>{let _=y({name:i,prev:b,options:S,initialState:E,getMeta:()=>c[i],getStoreValue:()=>t[i],hasStore:()=>ee(e,i)}),F=y({name:i,prev:b,options:S,initialState:E,getMeta:()=>{},getStoreValue:()=>b,hasStore:()=>false});J().forEach(k=>{let A=g.get(k);I==="before"?A?.beforeStoreDelete?.(_):A?.afterStoreDelete?.(F);});},l=i=>{if(!ee(e,i))return;let b=t[i],S=c[i].options,E=n[i],I=r[i];u.add(i);try{I?.forEach(k=>{try{k(null);}catch(A){f(`Subscriber for "${i}" threw during delete: ${A?.message??A}`);}}),xt({name:i,label:"onDelete",fn:S.onDelete,args:[b],reportIssue:(k,A)=>{me(k,{onError:S.onError,severity:"warn",visibility:A});}}),C({name:i,prev:b,options:S,initialState:E,phase:"before"}),delete t[i],delete r[i],delete n[i],delete o[i],delete c[i],delete d[i],Ft(i)&&Bt(i);let F=e.computedDependents[i];if(F)for(let k of [...F]){let A=We(k);if(A&&Kt(k,e)&&A.deps.every(ae=>!ee(e,ae))){l(k);continue}f(`[stroid] source store "${i}" was deleted. Computed store "${k}" depends on it and will return stale data. Call deleteComputed("${k}") to clean up.`);}C({name:i,prev:b,options:S,initialState:E,phase:"after"}),ge("afterStoreDelete",i,{type:"afterStoreDelete",prev:b}),Fe(e,{type:"deleted",name:i}),re(`Store "${i}" deleted`);}finally{u.delete(i);}};return {deleteExistingStore:l,clearAllStores:()=>{let i=[],S=0,E=Number.POSITIVE_INFINITY;for(;S<20;){let _=Object.keys(t);if(_.length===0)break;_.forEach(k=>{ee(e,k)&&(l(k),i.push(k));}),S+=1;let F=Object.keys(t).length;if(F===0||F>=E)break;E=F;}let I=Object.keys(t).length;return I>0?f(`clearAllStores stopped after ${S} pass${S===1?"":"es"}; ${I} store(s) still registered (likely recreated during deletion).`):re(`All stores cleared (${i.length} stores removed)`),i},clearStores:i=>{let b=Object.keys(t).filter(S=>i?i.endsWith("*")?S.startsWith(i.slice(0,-1)):S===i:true);return b.forEach(S=>l(S)),b},reportStoreError:m}};var Je=Q,Gt=Z(Je),N=()=>{let e=L(Gt);return Ee(e),e};var V=()=>N();var ie=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,n)=>(e()[r]=n,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let n=Object.getOwnPropertyDescriptor(e(),r);if(n)return {...n,configurable:true}}}),$r=e=>new Proxy(new Map,{get:(t,r)=>{let n=e();if(r==="size")return n.size;if(r===Symbol.iterator)return n[Symbol.iterator].bind(n);let o=n[r];return typeof o=="function"?o.bind(n):o},set:(t,r,n)=>(e()[r]=n,true)}),Wr=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)});ie(()=>N().stores);ie(()=>N().subscribers);ie(()=>N().initialStates);ie(()=>N().initialFactories);ie(()=>N().metaEntries);ie(()=>N().snapshotCache);var se=$r(()=>N().featureRuntimes),Ut=new WeakMap,Yt=e=>{let t=Ut.get(e);return t||(t=qt(e),Ut.set(e,t)),t};Wr(()=>Yt(N()));var Qe=()=>Yt(N()),zr=e=>{let t=se.get(e);if(t)return t;let r=ye(e);if(!r)return;let n=r();return se.set(e,n),n},Hr=()=>{J().forEach(e=>{zr(e);});};Hr();var Lr=()=>{lt(N());},Br=()=>{se.forEach(e=>{try{e.resetAll?.();}catch{}}),se.clear();};v("features.reset",Br,10);v("registries.clear",Lr,20);v("registry.default",()=>{Je=Q,Gt=Z(Je);},115);var Xt=()=>L().async;var Jt=()=>{he(Xt());};var hs=()=>{Qe().clearAllStores(),Jt(),Re();},Ss=e=>{Qe().clearStores(e),Re();};export{hs as clearAllStores,Ss as clearStores};//# sourceMappingURL=runtime-admin.js.map
2
2
  //# sourceMappingURL=runtime-admin.js.map