stroid 0.1.1 → 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.
Files changed (180) hide show
  1. package/CHANGELOG.md +210 -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 +40 -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 +169 -33
  24. package/dist/index.d.ts +169 -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 +80 -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/adapters/options.d.ts +335 -0
  59. package/dist/types/async/cache.d.ts +39 -0
  60. package/dist/types/async/clone.d.ts +10 -0
  61. package/dist/types/async/errors.d.ts +3 -0
  62. package/dist/types/async/fetch.d.ts +37 -0
  63. package/dist/types/async/inflight.d.ts +13 -0
  64. package/dist/types/async/rate.d.ts +5 -0
  65. package/dist/types/async/registry.d.ts +116 -0
  66. package/dist/types/async/request.d.ts +11 -0
  67. package/dist/types/async/retry.d.ts +10 -0
  68. package/dist/types/async.d.ts +10 -0
  69. package/dist/types/computed/computed-graph.d.ts +29 -0
  70. package/dist/types/computed/index.d.ts +16 -0
  71. package/dist/types/config.d.ts +10 -0
  72. package/dist/types/core/index.d.ts +11 -0
  73. package/dist/types/core/lifecycle-hooks.d.ts +16 -0
  74. package/dist/types/core/store-admin-impl.d.ts +9 -0
  75. package/dist/types/core/store-admin.d.ts +9 -0
  76. package/dist/types/core/store-core.d.ts +13 -0
  77. package/dist/types/core/store-create.d.ts +16 -0
  78. package/dist/types/core/store-hydrate-impl.d.ts +35 -0
  79. package/dist/types/core/store-hydrate.d.ts +9 -0
  80. package/dist/types/core/store-lifecycle/hooks.d.ts +19 -0
  81. package/dist/types/core/store-lifecycle/identity.d.ts +23 -0
  82. package/dist/types/core/store-lifecycle/registry.d.ts +53 -0
  83. package/dist/types/core/store-lifecycle/types.d.ts +67 -0
  84. package/dist/types/core/store-lifecycle/validation.d.ts +53 -0
  85. package/dist/types/core/store-name.d.ts +28 -0
  86. package/dist/types/core/store-notify.d.ts +12 -0
  87. package/dist/types/core/store-read.d.ts +18 -0
  88. package/dist/types/core/store-registry.d.ts +108 -0
  89. package/dist/types/core/store-replace-impl.d.ts +11 -0
  90. package/dist/types/core/store-replace.d.ts +9 -0
  91. package/dist/types/core/store-set-impl.d.ts +13 -0
  92. package/dist/types/core/store-set.d.ts +9 -0
  93. package/dist/types/core/store-shared/core.d.ts +13 -0
  94. package/dist/types/core/store-shared/notify.d.ts +12 -0
  95. package/dist/types/core/store-transaction.d.ts +26 -0
  96. package/dist/types/core/store-write-shared.d.ts +19 -0
  97. package/dist/types/core/store-write.d.ts +13 -0
  98. package/dist/types/features/feature-registry.d.ts +91 -0
  99. package/dist/types/features/lifecycle.d.ts +40 -0
  100. package/dist/types/index.d.ts +17 -0
  101. package/dist/types/integrations/query.d.ts +8 -0
  102. package/dist/types/internals/computed-order.d.ts +3 -0
  103. package/dist/types/internals/config.d.ts +116 -0
  104. package/dist/types/internals/diagnostics.d.ts +21 -0
  105. package/dist/types/internals/reporting.d.ts +9 -0
  106. package/dist/types/internals/store-admin.d.ts +7 -0
  107. package/dist/types/internals/store-ops.d.ts +13 -0
  108. package/dist/types/internals/test-reset.d.ts +2 -0
  109. package/dist/types/internals/write-context.d.ts +15 -0
  110. package/dist/types/notification/delivery.d.ts +3 -0
  111. package/dist/types/notification/index.d.ts +10 -0
  112. package/dist/types/notification/metrics.d.ts +12 -0
  113. package/dist/types/notification/priority.d.ts +9 -0
  114. package/dist/types/notification/scheduler.d.ts +11 -0
  115. package/dist/types/notification/snapshot.d.ts +8 -0
  116. package/dist/types/runtime-admin/index.d.ts +2 -0
  117. package/dist/types/runtime-tools/index.d.ts +58 -0
  118. package/dist/types/store.d.ts +16 -0
  119. package/dist/types/types/utility.d.ts +17 -0
  120. package/dist/types/utils/clone.d.ts +4 -0
  121. package/dist/types/utils/devfreeze.d.ts +2 -0
  122. package/dist/types/utils/hash.d.ts +8 -0
  123. package/dist/types/utils/path.d.ts +5 -0
  124. package/dist/types/utils/validation.d.ts +14 -0
  125. package/dist/types/utils.d.ts +13 -0
  126. package/dist/types.d.ts +65 -0
  127. package/dist/utility.d.ts +15 -0
  128. package/package.json +26 -11
  129. package/dist/_tsup-dts-rollup.d.cts +0 -2411
  130. package/dist/_tsup-dts-rollup.d.ts +0 -2411
  131. package/dist/async.cjs +0 -34
  132. package/dist/async.cjs.map +0 -1
  133. package/dist/async.d.cts +0 -9
  134. package/dist/computed.cjs +0 -13
  135. package/dist/computed.cjs.map +0 -1
  136. package/dist/computed.d.cts +0 -7
  137. package/dist/core.cjs +0 -24
  138. package/dist/core.cjs.map +0 -1
  139. package/dist/core.d.cts +0 -15
  140. package/dist/devtools.cjs +0 -2
  141. package/dist/devtools.cjs.map +0 -1
  142. package/dist/devtools.d.cts +0 -5
  143. package/dist/feature.cjs +0 -2
  144. package/dist/feature.cjs.map +0 -1
  145. package/dist/feature.d.cts +0 -14
  146. package/dist/helpers.cjs +0 -24
  147. package/dist/helpers.cjs.map +0 -1
  148. package/dist/helpers.d.cts +0 -3
  149. package/dist/index.cjs +0 -35
  150. package/dist/index.cjs.map +0 -1
  151. package/dist/install.cjs +0 -2
  152. package/dist/install.cjs.map +0 -1
  153. package/dist/install.d.cts +0 -4
  154. package/dist/persist.cjs +0 -2
  155. package/dist/persist.cjs.map +0 -1
  156. package/dist/persist.d.cts +0 -1
  157. package/dist/react.cjs +0 -36
  158. package/dist/react.cjs.map +0 -1
  159. package/dist/react.d.cts +0 -7
  160. package/dist/react.d.ts +0 -7
  161. package/dist/react.js +0 -36
  162. package/dist/react.js.map +0 -1
  163. package/dist/runtime-admin.cjs +0 -2
  164. package/dist/runtime-admin.cjs.map +0 -1
  165. package/dist/runtime-admin.d.cts +0 -2
  166. package/dist/runtime-tools.cjs +0 -4
  167. package/dist/runtime-tools.cjs.map +0 -1
  168. package/dist/runtime-tools.d.cts +0 -9
  169. package/dist/selectors.cjs +0 -2
  170. package/dist/selectors.cjs.map +0 -1
  171. package/dist/selectors.d.cts +0 -2
  172. package/dist/server.cjs +0 -12
  173. package/dist/server.cjs.map +0 -1
  174. package/dist/server.d.cts +0 -2
  175. package/dist/sync.cjs +0 -2
  176. package/dist/sync.cjs.map +0 -1
  177. package/dist/sync.d.cts +0 -1
  178. package/dist/testing.cjs +0 -24
  179. package/dist/testing.cjs.map +0 -1
  180. 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 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
2
  //# sourceMappingURL=runtime-admin.js.map