stroid 0.1.0 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (163) hide show
  1. package/CHANGELOG.md +232 -108
  2. package/README.md +157 -577
  3. package/dist/async.d.ts +5 -3
  4. package/dist/async.js +28 -23
  5. package/dist/async.js.map +1 -0
  6. package/dist/cache.d.ts +12 -0
  7. package/dist/computed.d.ts +19 -8
  8. package/dist/computed.js +12 -10
  9. package/dist/computed.js.map +1 -0
  10. package/dist/core.d.ts +5 -5
  11. package/dist/core.js +16 -23
  12. package/dist/core.js.map +1 -0
  13. package/dist/devtools.d.ts +12 -1
  14. package/dist/devtools.js +2 -1
  15. package/dist/devtools.js.map +1 -0
  16. package/dist/feature.d.ts +92 -0
  17. package/dist/feature.js +2 -0
  18. package/dist/feature.js.map +1 -0
  19. package/dist/helpers.d.ts +13 -5
  20. package/dist/helpers.js +16 -13
  21. package/dist/helpers.js.map +1 -0
  22. package/dist/index-internal.d.ts +44 -0
  23. package/dist/index.d.cts +91 -52
  24. package/dist/index.d.ts +91 -52
  25. package/dist/index.js +27 -21
  26. package/dist/index.js.map +1 -0
  27. package/dist/install.d.ts +6 -0
  28. package/dist/install.js +2 -0
  29. package/dist/install.js.map +1 -0
  30. package/dist/{options-CB35e3Xo.d.cts → options.d.ts} +52 -2
  31. package/dist/persist.d.ts +1 -2
  32. package/dist/persist.js +2 -1
  33. package/dist/persist.js.map +1 -0
  34. package/dist/{react.d.cts → react/index.d.ts} +28 -10
  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.js +2 -1
  39. package/dist/runtime-admin.js.map +1 -0
  40. package/dist/runtime-tools.d.ts +44 -17
  41. package/dist/runtime-tools.js +3 -2
  42. package/dist/runtime-tools.js.map +1 -0
  43. package/dist/selectors.js +2 -1
  44. package/dist/selectors.js.map +1 -0
  45. package/dist/server.d.ts +27 -11
  46. package/dist/server.js +12 -9
  47. package/dist/server.js.map +1 -0
  48. package/dist/store-registry.d.ts +80 -0
  49. package/dist/sync.d.ts +1 -2
  50. package/dist/sync.js +2 -1
  51. package/dist/sync.js.map +1 -0
  52. package/dist/testing.d.ts +1 -1
  53. package/dist/testing.js +16 -13
  54. package/dist/testing.js.map +1 -0
  55. package/dist/tsdoc-metadata.json +11 -0
  56. package/dist/types/adapters/options.d.ts +90 -2
  57. package/dist/types/async/cache.d.ts +39 -0
  58. package/dist/types/async/clone.d.ts +9 -1
  59. package/dist/types/{async-fetch.d.ts → async/fetch.d.ts} +2 -2
  60. package/dist/types/async/inflight.d.ts +1 -1
  61. package/dist/types/{async-registry.d.ts → async/registry.d.ts} +25 -5
  62. package/dist/types/async/request.d.ts +9 -1
  63. package/dist/types/async.d.ts +10 -2
  64. package/dist/types/{computed-graph.d.ts → computed/computed-graph.d.ts} +4 -6
  65. package/dist/types/{computed.d.ts → computed/index.d.ts} +3 -2
  66. package/dist/types/config.d.ts +9 -1
  67. package/dist/types/core/index.d.ts +11 -0
  68. package/dist/types/core/lifecycle-hooks.d.ts +16 -0
  69. package/dist/types/core/store-admin-impl.d.ts +9 -0
  70. package/dist/types/core/store-admin.d.ts +9 -0
  71. package/dist/types/core/store-core.d.ts +13 -0
  72. package/dist/types/core/store-create.d.ts +16 -0
  73. package/dist/types/core/store-hydrate-impl.d.ts +35 -0
  74. package/dist/types/core/store-hydrate.d.ts +9 -0
  75. package/dist/types/core/store-lifecycle/hooks.d.ts +19 -0
  76. package/dist/types/{store-lifecycle → core/store-lifecycle}/identity.d.ts +3 -3
  77. package/dist/types/{store-lifecycle → core/store-lifecycle}/registry.d.ts +22 -8
  78. package/dist/types/{store-lifecycle → core/store-lifecycle}/types.d.ts +29 -1
  79. package/dist/types/{store-lifecycle → core/store-lifecycle}/validation.d.ts +11 -3
  80. package/dist/types/core/store-name.d.ts +28 -0
  81. package/dist/types/{store-notify.d.ts → core/store-notify.d.ts} +1 -1
  82. package/dist/types/{store-read.d.ts → core/store-read.d.ts} +8 -2
  83. package/dist/types/{store-registry.d.ts → core/store-registry.d.ts} +44 -10
  84. package/dist/types/core/store-replace-impl.d.ts +11 -0
  85. package/dist/types/core/store-replace.d.ts +9 -0
  86. package/dist/types/core/store-set-impl.d.ts +13 -0
  87. package/dist/types/core/store-set.d.ts +9 -0
  88. package/dist/types/core/store-shared/core.d.ts +13 -0
  89. package/dist/types/core/store-shared/notify.d.ts +12 -0
  90. package/dist/types/{store-transaction.d.ts → core/store-transaction.d.ts} +15 -1
  91. package/dist/types/core/store-write-shared.d.ts +19 -0
  92. package/dist/types/core/store-write.d.ts +13 -0
  93. package/dist/types/features/feature-registry.d.ts +91 -0
  94. package/dist/types/features/lifecycle.d.ts +12 -0
  95. package/dist/types/index.d.ts +13 -2
  96. package/dist/types/integrations/query.d.ts +2 -2
  97. package/dist/types/internals/computed-order.d.ts +3 -0
  98. package/dist/types/internals/config.d.ts +56 -2
  99. package/dist/types/internals/reporting.d.ts +1 -0
  100. package/dist/types/internals/store-admin.d.ts +1 -1
  101. package/dist/types/internals/store-ops.d.ts +13 -3
  102. package/dist/types/internals/test-reset.d.ts +2 -0
  103. package/dist/types/internals/write-context.d.ts +15 -0
  104. package/dist/types/notification/delivery.d.ts +3 -0
  105. package/dist/types/notification/index.d.ts +10 -0
  106. package/dist/types/notification/metrics.d.ts +12 -0
  107. package/dist/types/notification/priority.d.ts +9 -0
  108. package/dist/types/notification/scheduler.d.ts +11 -0
  109. package/dist/types/notification/snapshot.d.ts +8 -0
  110. package/dist/types/runtime-tools/index.d.ts +58 -0
  111. package/dist/types/store.d.ts +16 -7
  112. package/dist/types/types/utility.d.ts +17 -0
  113. package/dist/types/utils/devfreeze.d.ts +2 -0
  114. package/dist/types/utils.d.ts +8 -0
  115. package/dist/{types-grvlY4BX.d.cts → types.d.ts} +30 -2
  116. package/dist/utility.d.ts +15 -0
  117. package/package.json +35 -11
  118. package/dist/async-cache-DFHwcBQL.d.cts +0 -52
  119. package/dist/async-cache-DFHwcBQL.d.ts +0 -52
  120. package/dist/async.cjs +0 -29
  121. package/dist/async.d.cts +0 -40
  122. package/dist/computed-BbAZm1Dq.d.cts +0 -17
  123. package/dist/computed-CccdgY5j.d.ts +0 -17
  124. package/dist/computed.cjs +0 -11
  125. package/dist/computed.d.cts +0 -29
  126. package/dist/core.cjs +0 -30
  127. package/dist/core.d.cts +0 -5
  128. package/dist/devtools.cjs +0 -1
  129. package/dist/devtools.d.cts +0 -19
  130. package/dist/helpers.cjs +0 -20
  131. package/dist/helpers.d.cts +0 -29
  132. package/dist/index.cjs +0 -30
  133. package/dist/options-CB35e3Xo.d.ts +0 -245
  134. package/dist/persist.cjs +0 -1
  135. package/dist/persist.d.cts +0 -2
  136. package/dist/react.cjs +0 -31
  137. package/dist/react.d.ts +0 -52
  138. package/dist/react.js +0 -31
  139. package/dist/runtime-admin.cjs +0 -1
  140. package/dist/runtime-admin.d.cts +0 -4
  141. package/dist/runtime-tools.cjs +0 -3
  142. package/dist/runtime-tools.d.cts +0 -39
  143. package/dist/selectors.cjs +0 -1
  144. package/dist/selectors.d.cts +0 -4
  145. package/dist/server.cjs +0 -10
  146. package/dist/server.d.cts +0 -14
  147. package/dist/sync.cjs +0 -1
  148. package/dist/sync.d.cts +0 -2
  149. package/dist/testing.cjs +0 -20
  150. package/dist/testing.d.cts +0 -16
  151. package/dist/types/async-cache.d.ts +0 -57
  152. package/dist/types/core.d.ts +0 -1
  153. package/dist/types/devfreeze.d.ts +0 -1
  154. package/dist/types/feature-registry.d.ts +0 -69
  155. package/dist/types/internals/hooks-warnings.d.ts +0 -6
  156. package/dist/types/store-lifecycle/bind.d.ts +0 -3
  157. package/dist/types/store-lifecycle/hooks.d.ts +0 -44
  158. package/dist/types/store-lifecycle.d.ts +0 -20
  159. package/dist/types/store-name.d.ts +0 -19
  160. package/dist/types/store-write.d.ts +0 -45
  161. package/dist/types-grvlY4BX.d.ts +0 -37
  162. /package/dist/types/{async-retry.d.ts → async/retry.d.ts} +0 -0
  163. /package/dist/types/{runtime-admin.d.ts → runtime-admin/index.d.ts} +0 -0
@@ -1,39 +0,0 @@
1
- import { N as NormalizedOptions } from './options-CB35e3Xo.cjs';
2
-
3
- interface FeatureMetrics {
4
- notifyCount: number;
5
- totalNotifyMs: number;
6
- lastNotifyMs: number;
7
- }
8
- interface StoreFeatureMeta {
9
- createdAt: string;
10
- updatedAt: string;
11
- updatedAtMs: number;
12
- updateCount: number;
13
- version: number;
14
- metrics: FeatureMetrics;
15
- options: NormalizedOptions;
16
- }
17
-
18
- declare const listStores: (pattern?: string) => string[];
19
- declare const getStoreMeta: (name: string) => StoreFeatureMeta | null;
20
- declare const getInitialState: () => Record<string, unknown>;
21
- declare const getMetrics: (name: string) => StoreFeatureMeta["metrics"] | null;
22
- declare const getSubscriberCount: (name: string) => number;
23
- declare const getAsyncInflightCount: (name: string) => number;
24
- declare const getPersistQueueDepth: (name: string) => number;
25
- declare const getComputedGraph: () => {
26
- nodes: string[];
27
- edges: Array<{
28
- from: string;
29
- to: string;
30
- }>;
31
- dependencies: Record<string, string[]>;
32
- dependents: Record<string, string[]>;
33
- };
34
- declare const getComputedDeps: (name: string) => {
35
- deps: string[];
36
- dependents: string[];
37
- } | null;
38
-
39
- export { getAsyncInflightCount, getComputedDeps, getComputedGraph, getInitialState, getMetrics, getPersistQueueDepth, getStoreMeta, getSubscriberCount, listStores };
@@ -1 +0,0 @@
1
- 'use strict';var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var de=e=>{if(typeof e!="object"||e===null||e.$$typeof||typeof window<"u"&&e instanceof Element||e.constructor&&e.constructor.name!=="Object"&&e.constructor.name!=="Array")return e;let t=[e],r=new WeakSet;for(;t.length>0;){let n=t.pop();if(!r.has(n)){r.add(n),Object.isFrozen(n)||Object.freeze(n);for(let o of Object.keys(n)){let s=n[o];typeof s=="object"&&s!==null&&!r.has(s)&&t.push(s);}}}return e};var He={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}`));}},Be={logSink:He,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",defaultSnapshotMode:"deep",middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0},qe={...Be},w=()=>qe;var Le=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Ke=typeof ({ url: (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('selectors.cjs', document.baseURI).href)) })<"u"&&undefined?.MODE?undefined.MODE:void 0,fe=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,Ue="production",Ye=Le??Ke??Ue,U=typeof fe=="boolean"?fe:Ye!=="production",x=()=>U,pe=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Ge=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},Je=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},Y=(e,t)=>{if((w().logSink.critical??Ge)(e,t),w().assertRuntime)throw new Error(e)},d=(e,t)=>{if(!U)return;if((w().logSink.warn??pe)(e,t),w().assertRuntime)throw new Error(e)},T=(e,t)=>{if((w().logSink.warn??pe)(e,t),w().assertRuntime)throw new Error(e)};var z=(e,t)=>{if(!U)return;(w().logSink.log??Je)(e,t);};var ge=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Se=()=>"Map detected; converting to plain object.",ye=()=>"Set detected; converting to array.";var he=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,me=e=>`Cannot go deeper at "${e}" - value is not an object`;var O=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,Xe=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 H=(e,t)=>{let r=Xe(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 x()&&d(ge()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),x()&&d(Se());let o={};for(let[s,a]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");o[String(s)]=H(a,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),x()&&d(ye()),Array.from(e,o=>H(o,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let o={},s=Object.getOwnPropertyDescriptors(e);for(let[a,c]of Object.entries(s))if(c.enumerable&&!O.has(a)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${a}")`);o[a]=H(c.value,t);}return o}if(n==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(o=>H(o,t))}return e},ne=e=>H(e,new WeakSet);var oe=null,Qe=()=>{if(oe)return oe;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 oe=t,t},ke=e=>{let t=Qe(),r=-1;for(let n=0;n<e.length;n++)r=r>>>0,r=r>>>8^t[(r^e.charCodeAt(n))&255];return (r^-1)>>>0},Ze=2166136261,et=2654435761,tt=1e5,F=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},D=(e,t)=>{F(e,t.length);for(let r=0;r<t.length;r++)F(e,t.charCodeAt(r));},f=(e,t)=>{D(e,t);},Re=(e,t)=>{if(Number.isNaN(t)){f(e,"NaN");return}if(!Number.isFinite(t)){f(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){f(e,"-0");return}let r=t|0;if(t===r){f(e,"int"),F(e,r);return}f(e,"num"),D(e,String(t));},A=(e,t)=>{if(e.nodes++>tt){f(e,"[max]");return}if(t===null){f(e,"null");return}let r=typeof t;if(r==="string"){f(e,"string"),D(e,t);return}if(r==="number"){f(e,"number"),Re(e,t);return}if(r==="boolean"){f(e,t?"true":"false");return}if(r==="undefined"){f(e,"undefined");return}if(r==="bigint"){f(e,"bigint"),D(e,t.toString());return}if(r==="symbol"){f(e,"symbol");let u=t;D(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){f(e,"function"),D(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){f(e,"ref"),F(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){f(e,"array"),F(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?A(e,n[u]):f(e,"hole");return}if(n instanceof Date){f(e,"date"),Re(e,n.getTime());return}if(n instanceof Map){f(e,"map"),F(e,n.size),n.forEach((u,l)=>{A(e,l),A(e,u);});return}if(n instanceof Set){f(e,"set"),F(e,n.size),n.forEach(u=>{A(e,u);});return}f(e,"object");let a=Object.getOwnPropertyDescriptors(n),c=[];Object.entries(a).forEach(([u,l])=>{l?.enumerable&&(O.has(u)||"get"in l||"set"in l||c.push([u,l]));}),F(e,c.length);for(let[u,l]of c)D(e,u),A(e,l.value);},se=e=>{if(typeof e=="string")return ke(JSON.stringify(e));let t={h1:Ze,h2:et,seen:new WeakMap,nextId:1,nodes:0};A(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 rt=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",B=e=>{if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map)return new Map(e);if(e instanceof Set)return new Set(e);if(Array.isArray(e))return e.slice();let t={},r=Object.getOwnPropertyDescriptors(e);return Object.entries(r).forEach(([n,o])=>{o.enumerable&&(O.has(n)||"get"in o||"set"in o||(t[n]=o.value));}),t},V=(e,t=new WeakMap)=>{if(e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let s=new Map;return t.set(e,s),e.forEach((a,c)=>{s.set(V(c,t),V(a,t));}),s}if(e instanceof Set){let s=new Set;return t.set(e,s),e.forEach(a=>{s.add(V(a,t));}),s}if(Array.isArray(e)){let s=[];return t.set(e,s),e.forEach((a,c)=>{s[c]=V(a,t);}),s}let r=globalThis?.WeakRef;if(r&&e instanceof r)return T("WeakRef values cannot be deep-cloned. Returning the original reference."),e;let n={};t.set(e,n);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch{return T("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(o).forEach(([s,a])=>{!a.enumerable||O.has(s)||"get"in a||"set"in a||(n[s]=V(a.value,t));}),n},j=e=>{try{if(rt)return structuredClone(e)}catch{}return V(e)};var nt=e=>{let t=[],r="",n=false;for(let o of e){if(n){r+=o,n=false;continue}if(o==="\\"){n=true;continue}if(o==="."){t.push(r),r="";continue}r+=o;}return n&&(r+="\\"),t.push(r),t},xe=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?nt(e):[String(e)];var G=(e,t)=>{let r=xe(t),n=e;for(let o of r){if(n==null){d(he(r,o));return}if(typeof n!="object"){d(me(o));return}n=n[o];}return n};var Ce=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,noSignalWarned:new Set,shapeWarned:new Set,autoCreateWarned:new Set,cleanupSubs:Object.create(null),storeCleanupFns:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}});var Me=new Map,ot=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,ie=e=>(ot||e).replace(/\.ts(\?|$)/,".js$1"),_=ie(new URL("./store.js",(typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('selectors.cjs', document.baseURI).href))).href);var it=()=>({stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:{depth:0,pending:[],stagedValues:new Map,failed:false,error:void 0},async:Ce()}),q=e=>{let t=ie(e),r=Me.get(t);if(r)return r;let n=it();return Me.set(t,n),n},N=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var Fe=()=>null;var I=e=>e||q(_);var ve=new Map;var ae=e=>ve.get(e),L=()=>Array.from(ve.keys());var Te=({name:e,label:t,fn:r,args:n,reportIssue:o})=>{if(typeof r=="function")try{r(...n);}catch(s){let a=`${t} for "${e}" failed: ${s?.message??s}`;o(a,"always");}};var J=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(o?.(e),r==="critical"){n==="dev"&&d(e),Y(e);return}if(n==="always"){T(e);return}d(e);};var lt=()=>I(q(_)),dt=()=>lt().computedEntries;var De=e=>Object.prototype.hasOwnProperty.call(dt(),e);var je=e=>(e??I()).transaction;var X=()=>je().depth>0;var Oe=e=>{let t=je();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var ft=e=>{let t=$[e]?.options?.snapshot??w().defaultSnapshotMode;return t==="shallow"||t==="ref"?t:"deep"},Ae=(e,t)=>t==="ref"?e:t==="shallow"?B(e):j(e),ce=(e,t)=>{t!=="deep"&&t!=="ref"||e&&typeof e=="object"&&de(e);};var Ve=e=>{if(!ue(e))return null;let t=$[e]?.updateCount??0,r=ft(e),n=Q[e];if(n&&n.version===t){let a=n.snapshot;return ce(a,r),a}if(X()){let a=Z(e);if(a===void 0)return null;let c=Ae(a,r);return ce(c,r),c}let o=Z(e),s=Ae(o,r);return ce(s,r),Q[e]={version:t,snapshot:s},s};var pt=()=>ee().computedCleanups;var _e=e=>{let t=pt(),r=t.get(e);if(!r){x()&&d(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Ne=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,s=e.metaEntries,a=e.snapshotCache,c=e.featureRuntimes,u=e.deletingStores,l=(i,S)=>{J(S,{onError:s[i]?.options?.onError,severity:"warn",visibility:"dev"});},g=({name:i,prev:S,options:p,initialState:m,getMeta:M,getStoreValue:v,hasStore:b})=>({name:i,options:p,prev:S,getMeta:M,getStoreValue:v,getAllStores:()=>t,getInitialState:()=>m,hasStore:b,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:y=>{J(y,{onError:p.onError,severity:"warn",visibility:"dev"});},warn:d,log:z,hashState:se,deepClone:j,sanitize:ne,validate:()=>({ok:true,value:S}),isDev:x}),k=({name:i,prev:S,options:p,initialState:m,phase:M})=>{let v=g({name:i,prev:S,options:p,initialState:m,getMeta:()=>s[i],getStoreValue:()=>t[i],hasStore:()=>N(e,i)}),b=g({name:i,prev:S,options:p,initialState:m,getMeta:()=>{},getStoreValue:()=>S,hasStore:()=>false});L().forEach(y=>{let E=c.get(y);M==="before"?E?.beforeStoreDelete?.(v):E?.afterStoreDelete?.(b);});},h=i=>{if(!N(e,i))return;let S=t[i],p=s[i].options,m=n[i],M=r[i];u.add(i);try{M?.forEach(y=>{try{y(null);}catch(E){d(`Subscriber for "${i}" threw during delete: ${E?.message??E}`);}}),Te({name:i,label:"onDelete",fn:p.onDelete,args:[S],reportIssue:(y,E)=>{J(y,{onError:p.onError,severity:"warn",visibility:E});}}),k({name:i,prev:S,options:p,initialState:m,phase:"before"}),delete t[i],delete r[i],delete n[i],delete o[i],delete s[i],delete a[i],De(i)&&_e(i);let b=e.computedDependents[i];if(b)for(let y of b)d(`[stroid] source store "${i}" was deleted. Computed store "${y}" depends on it and will return stale data. Call deleteComputed("${y}") to clean up.`);k({name:i,prev:S,options:p,initialState:m,phase:"after"}),z(`Store "${i}" deleted`);}finally{u.delete(i);}};return {deleteExistingStore:h,clearAllStores:()=>{let i=[],p=0,m=Number.POSITIVE_INFINITY;for(;p<20;){let v=Object.keys(t);if(v.length===0)break;v.forEach(y=>{N(e,y)&&(h(y),i.push(y));}),p+=1;let b=Object.keys(t).length;if(b===0||b>=m)break;m=b;}let M=Object.keys(t).length;return M>0?d(`clearAllStores stopped after ${p} pass${p===1?"":"es"}; ${M} store(s) still registered (likely recreated during deletion).`):d(`All stores cleared (${i.length} stores removed)`),i},clearStores:i=>{let S=Object.keys(t).filter(p=>i?i.endsWith("*")?p.startsWith(i.slice(0,-1)):p===i:true);return S.forEach(p=>h(p)),S},reportStoreError:l}};var gt=_,St=q(gt);var Ie=new WeakSet,yt=e=>{Ie.has(e)||(Ie.add(e),L().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ae(t);r&&e.featureRuntimes.set(t,r());}}));},R=()=>{let e=I(St);return yt(e),e};var ee=()=>R();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}}}),ht=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)}),mt=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)}),P=W(()=>R().stores),C=W(()=>R().subscribers);W(()=>R().initialStates);W(()=>R().initialFactories);var $=W(()=>R().metaEntries),Q=W(()=>R().snapshotCache),K=ht(()=>R().featureRuntimes),Pe=new WeakMap,Rt=e=>{let t=Pe.get(e);return t||(t=Ne(e),Pe.set(e,t)),t};mt(()=>Rt(R()));var $e=e=>{let t=K.get(e);if(t)return t;let r=ae(e);if(!r)return;let n=r();return K.set(e,n),n},xt=()=>{L().forEach(e=>{$e(e);});};xt();var ue=e=>N(R(),e),Z=e=>{if(X()){let r=Oe(e);if(r.has)return r.value}let t=Fe();return t&&Object.prototype.hasOwnProperty.call(t,e)?t[e]:P[e]};var le=e=>Object.prototype.hasOwnProperty.call(P,e),We=e=>P[e],ze=(e,t)=>(C[e]||(C[e]=new Set),C[e].add(t),()=>{C[e]?.delete(t),C[e]?.size===0&&delete C[e];});var Ct=(e,t)=>{let r=new WeakMap,n=new Set,o="\0",s=(c,u)=>{if(!c||typeof c!="object")return c;let l=r.get(c);if(l)return l;let g=new Proxy(c,{get(k,h,te){if(typeof h!="string")return Reflect.get(k,h,te);let re=[...u,h],i=Reflect.get(k,h,te);return (!i||typeof i!="object")&&n.add(re.join(o)),s(i,re)}});return r.set(c,g),g};return {result:t(s(e,[])),deps:Array.from(n,c=>c.split(o))}},Mt=(e,t,r)=>r.some(n=>!Object.is(G(e,n),G(t,n))),Ft=(e,t)=>{let r,n,o=[];return ()=>{let s=We(e);if(s===void 0)return null;if(s===r)return n??null;if(r!==void 0&&o.length>0&&!Mt(r,s,o))return r=s,n??null;let a=Ct(s,t);return r=s,o=a.deps,n=a.result,n??null}},vt=(e,t,r=Object.is,n)=>{if(typeof t!="function"||typeof n!="function")return d(`subscribeWithSelector("${e}") requires selector and listener functions.`),()=>{};let o=false,s,a=()=>{let l=$[e]?.options?.snapshot;return l==="shallow"||l==="ref"?l:"deep"},c=l=>{let g=l!==void 0?l:Ve(e);if(g===null||typeof g!="object")return g;let k=a();return k==="ref"?g:k==="shallow"?B(g):j(g)};return le(e)&&(s=t(c()),o=true),ze(e,l=>{if(l===null||!le(e)){o=false,s=void 0;return}let g=t(c(l));if(!o){o=true,s=g,n(g,g);return}if(!r(g,s)){let h=s;s=g,n(g,h);}})};exports.createSelector=Ft;exports.subscribeWithSelector=vt;
@@ -1,4 +0,0 @@
1
- declare const createSelector: <TState, TResult>(storeName: string, selectorFn: (state: TState) => TResult) => () => NonNullable<TResult> | null;
2
- declare const subscribeWithSelector: <R>(name: string, selector: (state: any) => R, equality: ((a: R, b: R) => boolean) | undefined, listener: (next: R, prev: R) => void) => (() => void);
3
-
4
- export { createSelector, subscribeWithSelector };
package/dist/server.cjs DELETED
@@ -1,10 +0,0 @@
1
- 'use strict';var async_hooks=require('async_hooks');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var ir={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}`));}},ar={logSink:ir,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",defaultSnapshotMode:"deep",middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0},cr={...ar},R=()=>cr;var ur=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,lr=typeof ({ url: (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('server.cjs', document.baseURI).href)) })<"u"&&undefined?.MODE?undefined.MODE:void 0,ot=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,dr="production",fr=ur??lr??dr,se=typeof ot=="boolean"?ot:fr!=="production",x=()=>se,Fe=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},pr=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},gr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},G=(e,t)=>{if((R().logSink.critical??pr)(e,t),R().assertRuntime)throw new Error(e)},S=(e,t)=>{if(!se)return;if((R().logSink.warn??Fe)(e,t),R().assertRuntime)throw new Error(e)},O=(e,t)=>{if((R().logSink.warn??Fe)(e,t),R().assertRuntime)throw new Error(e)},j=(e,t)=>{if(se&&(R().logSink.warn??Fe)(e,t),G(e,t),R().assertRuntime)throw new Error(e)},T=(e,t)=>{if(!se)return;(R().logSink.log??gr)(e,t);},st=()=>`Functions cannot be stored in stroid.
2
- Store data only - handle functions outside the store.`,it=()=>`Map/Set detected. stroid converts these to plain objects.
3
- Use arrays or plain objects for best results.`,at=()=>`Date object detected. stroid stores it as ISO string.
4
- Use new Date(value) to convert back when reading.`,ct=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",ut=()=>"Map detected; converting to plain object.",lt=()=>"Set detected; converting to array.";var dt=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,ft=e=>`Store name "${e}" contains spaces.
5
- Use camelCase or kebab-case: "userName" or "user-name"`,pt=e=>`Store name "${e}" is not allowed.
6
- Reserved names: "__proto__", "constructor", "prototype".`,Sr=128,yr=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=Sr,hr=(e,t)=>{if(e===t)return 0;if(e.length===0)return t.length;if(t.length===0)return e.length;let r=Array.from({length:e.length+1},(s,o)=>o),n=new Array(e.length+1);for(let s=1;s<=t.length;s++){n[0]=s;for(let o=1;o<=e.length;o++)n[o]=t[s-1]===e[o-1]?r[o-1]:Math.min(r[o-1],n[o-1],r[o])+1;[r,n]=[n,r];}return r[e.length]},Ee=(e,t)=>{let r=t.find(n=>{let s=n.toLowerCase(),o=e.toLowerCase();return s.includes(o)||o.includes(s)||yr(s,o)&&hr(s,o)<=2});if(r){S(`Store "${e}" not found. Did you mean "${r}"?`);return}j(`Store "${e}" not found.
7
- Available stores: [${t.join(", ")}]
8
- Call createStore("${e}", data) first.`);};var _=new Set(["__proto__","constructor","prototype"]),Oe=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let s=r.error,o=s?.details?.[0]?.message||s?.message||r.message||e.errors;if(o)return {ok:!1,error:o};if(s)return {ok:!1,error:s}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var ae=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,gt=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},De=e=>{let t=ae(e);return t==="function"?(j(st()),false):t==="map"||t==="set"?(S(it()),true):(t==="date"&&S(at()),true)},Ve=(e,t)=>{let r=gt(e);if(r)throw new Error(`${r} values are not supported`);let n=ae(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return true}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date"||n==="map"||n==="set")return false;if(n==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s=Object.keys(e);for(let o of s){let i=Number(o);if(!Number.isInteger(i))return false}for(let o=0;o<e.length;o+=1)if(o in e&&!Ve(e[o],t))return false;return true}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");if(t.add(e),Object.getOwnPropertySymbols(e).length>0)return false;let s=Object.getOwnPropertyDescriptors(e);for(let[o,i]of Object.entries(s)){if(!i.enumerable||_.has(o))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${o}")`);if(!Ve(i.value,t))return false}return true}return true},Ae=e=>Ve(e,new WeakSet),ie=(e,t)=>{let r=gt(e);if(r)throw new Error(`${r} values are not supported`);let n=ae(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date")return x()&&S(ct()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),x()&&S(ut());let s={};for(let[o,i]of e){if(typeof o!="string")throw new Error("Map keys must be strings to remain JSON-safe");s[String(o)]=ie(i,t);}return s}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),x()&&S(lt()),Array.from(e,s=>ie(s,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s={},o=Object.getOwnPropertyDescriptors(e);for(let[i,c]of Object.entries(o))if(c.enumerable&&!_.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);s[i]=ie(c.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=>ie(s,t))}return e},H=e=>ie(e,new WeakSet),Se=e=>typeof e!="string"||e.trim()===""?(j(dt(e)),false):_.has(e)?(j(pt(e)),false):e.includes(" ")?(j(ft(e)),false):true;var Te=null,mr=()=>{if(Te)return Te;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 Te=t,t},yt=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,vr=2654435761,wr=1e5,I=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},B=(e,t)=>{I(e,t.length);for(let r=0;r<t.length;r++)I(e,t.charCodeAt(r));},k=(e,t)=>{B(e,t);},St=(e,t)=>{if(Number.isNaN(t)){k(e,"NaN");return}if(!Number.isFinite(t)){k(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){k(e,"-0");return}let r=t|0;if(t===r){k(e,"int"),I(e,r);return}k(e,"num"),B(e,String(t));},Y=(e,t)=>{if(e.nodes++>wr){k(e,"[max]");return}if(t===null){k(e,"null");return}let r=typeof t;if(r==="string"){k(e,"string"),B(e,t);return}if(r==="number"){k(e,"number"),St(e,t);return}if(r==="boolean"){k(e,t?"true":"false");return}if(r==="undefined"){k(e,"undefined");return}if(r==="bigint"){k(e,"bigint"),B(e,t.toString());return}if(r==="symbol"){k(e,"symbol");let l=t;B(e,Symbol.keyFor(l)??l.description??String(l));return}if(r==="function"){k(e,"function"),B(e,t.name||"anonymous");return}let n=t,s=e.seen.get(n);if(s!==void 0){k(e,"ref"),I(e,s);return}let o=e.nextId++;if(e.seen.set(n,o),Array.isArray(n)){k(e,"array"),I(e,n.length);for(let l=0;l<n.length;l++)Object.prototype.hasOwnProperty.call(n,l)?Y(e,n[l]):k(e,"hole");return}if(n instanceof Date){k(e,"date"),St(e,n.getTime());return}if(n instanceof Map){k(e,"map"),I(e,n.size),n.forEach((l,p)=>{Y(e,p),Y(e,l);});return}if(n instanceof Set){k(e,"set"),I(e,n.size),n.forEach(l=>{Y(e,l);});return}k(e,"object");let i=Object.getOwnPropertyDescriptors(n),c=[];Object.entries(i).forEach(([l,p])=>{p?.enumerable&&(_.has(l)||"get"in p||"set"in p||c.push([l,p]));}),I(e,c.length);for(let[l,p]of c)B(e,l),Y(e,p.value);},ce=e=>{if(typeof e=="string")return yt(JSON.stringify(e));let t={h1:br,h2:vr,seen:new WeakMap,nextId:1,nodes:0};Y(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(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map)return new Map(e);if(e instanceof Set)return new Set(e);if(Array.isArray(e))return e.slice();let t={},r=Object.getOwnPropertyDescriptors(e);return Object.entries(r).forEach(([n,s])=>{s.enumerable&&(_.has(n)||"get"in s||"set"in s||(t[n]=s.value));}),t},J=(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 o=new Map;return t.set(e,o),e.forEach((i,c)=>{o.set(J(c,t),J(i,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(i=>{o.add(J(i,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((i,c)=>{o[c]=J(i,t);}),o}let r=globalThis?.WeakRef;if(r&&e instanceof r)return O("WeakRef values cannot be deep-cloned. Returning the original reference."),e;let n={};t.set(e,n);let s;try{s=Object.getOwnPropertyDescriptors(e);}catch{return O("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(s).forEach(([o,i])=>{!i.enumerable||_.has(o)||"get"in i||"set"in i||(n[o]=J(i.value,t));}),n},F=e=>{try{if(kr)return structuredClone(e)}catch{}return J(e)};var je=(e,t)=>{try{let r=F(e);return t(r),r}catch(r){throw new Error(`produceClone failed (possible circular reference or unserializable data): ${r?.message??r}`)}};var ht=new Set;var ye=(()=>{let e=new Map;return {getItem:t=>e.has(t)?e.get(t):null,setItem:(t,r)=>{e.set(t,r);},removeItem:t=>{e.delete(t);},type:"memory"}})(),Ne=e=>{try{return typeof window>"u"?ye:e==="session"||e==="sessionStorage"?window.sessionStorage??ye:window.localStorage??ye}catch{return ye}},he=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),X=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),bt=e=>{try{let t=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`,r=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`;return e(t)!==t?!1:e(r)===r}catch{return false}},xr=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",mt=e=>{try{e[xr]=!0;}catch{}return e},Rr={allowSSRGlobalStore:'scope: "global"',schema:"validate",validator:"validate",version:"persist.version",migrations:"persist.migrations",historyLimit:"devtools.historyLimit",redactor:"devtools.redactor",middleware:"lifecycle.middleware",onCreate:"lifecycle.onCreate",onSet:"lifecycle.onSet",onReset:"lifecycle.onReset",onDelete:"lifecycle.onDelete"},Cr=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:mt(f=>f),decrypt:mt(f=>f),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Ne("localStorage"),...r};if(typeof e=="string")return {driver:Ne(e),...r};let n=e.encrypt||r.encrypt,s=e.decrypt||r.decrypt,o=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,l=e.allowPlaintext===true,p=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(o&&!i||!o&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(c&&bt(n)&&!o)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`);return {driver:e.driver||e.storage||Ne("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:n,decrypt:s,encryptAsync:o,decryptAsync:i,allowPlaintext:l,sensitiveData:c,checksum:p,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},vt=e=>{if(!he(e))return [];let t=[];return Object.entries(Rr).forEach(([r,n])=>{X(e,r)&&(ht.has(r)||(ht.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},wt=(e={},t)=>{let r=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,o=he(e.lifecycle)?e.lifecycle:void 0,i=he(e.persist)?e.persist:void 0,c=he(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,p=e.snapshot==="shallow"||e.snapshot==="ref"?e.snapshot:"deep",f=X(e,"persist"),d=X(e,"sync"),u=X(e,"devtools")||X(e,"historyLimit")||X(e,"redactor"),h=r==="global"?true:e.allowSSRGlobalStore??false,{persist:y=false,devtools:a=false,onError:b,sync:m}=e;if(i?.sensitiveData===true){let v=i.encrypt,C=i.encryptAsync;if((!v||bt(v))&&!C)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:r,lazy:n,pathCreate:s,persist:r==="temp"&&!f?null:Cr(y,t),devtools:r==="temp"&&!u?false:typeof a=="boolean"?a:c?.enabled??true,middleware:o?.middleware??e.middleware??[],onSet:o?.onSet??e.onSet,onReset:o?.onReset??e.onReset,onDelete:o?.onDelete??e.onDelete,onCreate:o?.onCreate??e.onCreate,onError:b,validate:l,migrations:i?.migrations??e.migrations??{},version:i?.version??e.version??1,redactor:r==="temp"&&!u?void 0:c?.redactor??e.redactor,historyLimit:r==="temp"&&!u?0:c?.historyLimit??e.historyLimit??50,sync:r==="temp"&&!d?false:m??false,allowSSRGlobalStore:h,snapshot:p,explicitPersist:f,explicitSync:d,explicitDevtools:u}};var kt=e=>{if(typeof e!="object"||e===null||e.$$typeof||typeof window<"u"&&e instanceof Element||e.constructor&&e.constructor.name!=="Object"&&e.constructor.name!=="Array")return e;let t=[e],r=new WeakSet;for(;t.length>0;){let n=t.pop();if(!r.has(n)){r.add(n),Object.isFrozen(n)||Object.freeze(n);for(let s of Object.keys(n)){let o=n[s];typeof o=="object"&&o!==null&&!r.has(o)&&t.push(o);}}}return e};var xt=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,noSignalWarned:new Set,shapeWarned:new Set,autoCreateWarned:new Set,cleanupSubs:Object.create(null),storeCleanupFns:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}});var Rt=new Map,Mr=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,$e=e=>(Mr||e).replace(/\.ts(\?|$)/,".js$1"),L=$e(new URL("./store.js",(typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('server.cjs', document.baseURI).href))).href);var _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:{depth:0,pending:[],stagedValues:new Map,failed:false,error:void 0},async:xt()}),ue=e=>{let t=$e(e),r=Rt.get(t);if(r)return r;let n=_e();return Rt.set(t,n),n},Q=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),Ct=(e,t)=>e.deletingStores.has(t);var Mt=null,Ft=e=>{Mt=e;},Et=()=>Mt?.get()||null,Vt=null,Ot=e=>{Vt=e;};var Z=e=>Vt?.get()||e||ue(L);var Ie=new Map;var me=e=>Ie.has(e),ze=e=>Ie.get(e),le=()=>Array.from(Ie.keys());var be=Symbol("stroid.middleware.abort"),At=({name:e,payload:t,middlewares:r,reportIssue:n,warn:s})=>{if(!Array.isArray(r)||r.length===0)return t.next;let o=new WeakSet,i=F(t.next);for(let c of r){if(typeof c!="function")continue;let l,p=i;try{l=c({action:t.action,name:e,prev:t.prev,next:p,path:t.path});}catch(f){let d=`Middleware for "${e}" failed: ${f?.message??f}`;return n(d,"dev"),be}if(l&&typeof l.then=="function"){let f=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(f,"dev"),be}l===void 0?(x()&&!o.has(c)&&(o.add(c),s(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=p):i=l;}return i},ve=({name:e,label:t,fn:r,args:n,reportIssue:s})=>{if(typeof r=="function")try{r(...n);}catch(o){let i=`${t} for "${e}" failed: ${o?.message??o}`;s(i,"always");}};var q=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:s}=t;if(s?.(e),r==="critical"){n==="dev"&&S(e),G(e);return}if(n==="always"){O(e);return}S(e);};var Tt=()=>Z(ue(L)),Pt=()=>Tt().computedEntries,Vr=()=>Tt().computedDependents;var jt=e=>Object.prototype.hasOwnProperty.call(Pt(),e);var Nt=e=>{let t=Pt(),r=Vr(),n=new Set,s=[...e];for(;s.length>0;){let f=s.shift(),d=r[f];if(d)for(let u of d)n.has(u)||(n.add(u),s.push(u));}if(n.size===0)return [];let o=f=>{let d=t[f];if(d)for(let u of d.deps)t[u]&&(n.has(u)||(n.add(u),o(u)));};Array.from(n).forEach(f=>o(f));let i=new Map,c=new Map;for(let f of n){let d=t[f];if(!d)continue;let u=0;for(let h of d.deps)n.has(h)&&(u++,c.has(h)||c.set(h,[]),c.get(h).push(f));i.set(f,u);}let l=[];for(let[f,d]of i)d===0&&l.push(f);l.sort();let p=[];for(;l.length>0;){let f=l.shift();p.push(f);let d=c.get(f)??[];for(let u of d){let h=(i.get(u)??1)-1;if(i.set(u,h),h===0){let y=l.findIndex(a=>a>u);y===-1?l.push(u):l.splice(y,0,u);}}}return p};var $t=e=>(e??Z()).transaction,Or=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var We=()=>$t().depth>0,He=(e,t)=>{let r=$t(t);r.failed=true,r.error||(r.error=Or(e));};var te=new Set,de=[],Le=false,_t=e=>{let t=g[e]?.options?.snapshot??R().defaultSnapshotMode;return t==="shallow"||t==="ref"?t:"deep"},It=(e,t)=>t==="ref"?e:t==="shallow"?Pe(e):F(e);var Be=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Ar=()=>{de.length=0;for(let d of te)de.push(d);te.clear();let e=R().flush,t=e.priorityStores||[],r=new Set(de),n=t.length?new Set(t):null,s=[];if(n){for(let d of t)r.has(d)&&s.push(d);for(let d of de)n.has(d)||s.push(d);}else s.push(...de);let o=Nt(s),i=new Set(s);for(let d of o)r.has(d)&&!i.has(d)&&(s.push(d),i.add(d));let c=Number.isFinite(e.chunkSize)&&e.chunkSize>0?e.chunkSize:Number.POSITIVE_INFINITY,l=e.chunkDelayMs,p=c===Number.POSITIVE_INFINITY&&l===0;return {names:s.slice(),sliceSize:c,chunkDelayMs:l,runInline:p,prioritySet:n}},zt=()=>{let{names:e,sliceSize:t,chunkDelayMs:r,runInline:n,prioritySet:s}=Ar(),o=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),i=()=>{Le=false,te.size>0&&Wt();};if(n){for(let u of e){let h=z[u];if(!h||h.size===0)continue;let y=g[u]?.updateCount??0,a=_t(u),b=ee[u],m=b&&b.version===y?b.snapshot:(()=>{let w=It(V[u],a);return ee[u]={version:y,snapshot:w},w})(),v=o();for(let w of h)try{w(m);}catch(A){S(`Subscriber for "${u}" threw: ${A?.message??A}`);}let C=o()-v,M=g[u]?.metrics||{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0};M.notifyCount+=1,M.totalNotifyMs+=C,M.lastNotifyMs=C,g[u]&&(g[u].metrics=M),(g[u]?.updateCount??y)!==y&&te.add(u);}i();return}let c=u=>{let h=[];for(let y of e){if(u&&!u(y))continue;let a=z[y];if(!a||a.size===0)continue;let b=g[y]?.updateCount??0,m=_t(y),v=ee[y],C=v&&v.version===b?v.snapshot:(()=>{let M=It(V[y],m);return ee[y]={version:b,snapshot:M},M})();h.push({name:y,subsArray:Array.from(a),index:0,snapshot:C,version:b,notified:new Set,metrics:g[y]?.metrics?{...g[y].metrics}:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},totalMs:0});}return h},l=s?c(u=>s.has(u)):[],p=c(u=>!s||!s.has(u)),f=u=>{let h=z[u.name];if(!h||h.size===0){u.subsArray=[],u.index=0;return}u.subsArray=Array.from(h),u.index=0;},d=(u,h)=>{let y=()=>{if(u.length===0){h();return}let a=u.shift();if((g[a.name]?.updateCount??a.version)!==a.version){if(te.add(a.name),u.length===0){h();return}n?y():Be(y,r);return}if(f(a),a.subsArray.length===0){if(u.length===0){h();return}n?y():Be(y,r);return}let m=o(),v=0;for(;a.index<a.subsArray.length&&v<t;){let E=a.subsArray[a.index++];if(!a.notified.has(E)){a.notified.add(E);try{E(a.snapshot);}catch(w){S(`Subscriber for "${a.name}" threw: ${w?.message??w}`);}v+=1;}}a.totalMs+=o()-m;let C=z[a.name],M=C?Array.from(C).some(E=>!a.notified.has(E)):false;if(a.index<a.subsArray.length||M?u.push(a):(a.metrics.notifyCount+=1,a.metrics.totalNotifyMs+=a.totalMs,a.metrics.lastNotifyMs=a.totalMs,g[a.name]&&(g[a.name].metrics=a.metrics)),u.length===0){h();return}n?y():Be(y,r);};y();};l.length>0?d(l,()=>d(p,i)):d(p,i);},Wt=()=>{Le||(Le=true,typeof queueMicrotask=="function"?queueMicrotask(zt):Promise.resolve().then(zt));},fe=e=>{te.add(e),Wt();};var Tr=()=>P().computedCleanups;var Bt=e=>{let t=Tr(),r=t.get(e);if(!r){x()&&S(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Lt=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,s=e.initialFactories,o=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,l=e.deletingStores,p=(a,b)=>{q(b,{onError:o[a]?.options?.onError,severity:"warn",visibility:"dev"});},f=({name:a,prev:b,options:m,initialState:v,getMeta:C,getStoreValue:M,hasStore:E})=>({name:a,options:m,prev:b,getMeta:C,getStoreValue:M,getAllStores:()=>t,getInitialState:()=>v,hasStore:E,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:w=>{q(w,{onError:m.onError,severity:"warn",visibility:"dev"});},warn:S,log:T,hashState:ce,deepClone:F,sanitize:H,validate:()=>({ok:true,value:b}),isDev:x}),d=({name:a,prev:b,options:m,initialState:v,phase:C})=>{let M=f({name:a,prev:b,options:m,initialState:v,getMeta:()=>o[a],getStoreValue:()=>t[a],hasStore:()=>Q(e,a)}),E=f({name:a,prev:b,options:m,initialState:v,getMeta:()=>{},getStoreValue:()=>b,hasStore:()=>false});le().forEach(w=>{let A=c.get(w);C==="before"?A?.beforeStoreDelete?.(M):A?.afterStoreDelete?.(E);});},u=a=>{if(!Q(e,a))return;let b=t[a],m=o[a].options,v=n[a],C=r[a];l.add(a);try{C?.forEach(w=>{try{w(null);}catch(A){S(`Subscriber for "${a}" threw during delete: ${A?.message??A}`);}}),ve({name:a,label:"onDelete",fn:m.onDelete,args:[b],reportIssue:(w,A)=>{q(w,{onError:m.onError,severity:"warn",visibility:A});}}),d({name:a,prev:b,options:m,initialState:v,phase:"before"}),delete t[a],delete r[a],delete n[a],delete s[a],delete o[a],delete i[a],jt(a)&&Bt(a);let E=e.computedDependents[a];if(E)for(let w of E)S(`[stroid] source store "${a}" was deleted. Computed store "${w}" depends on it and will return stale data. Call deleteComputed("${w}") to clean up.`);d({name:a,prev:b,options:m,initialState:v,phase:"after"}),T(`Store "${a}" deleted`);}finally{l.delete(a);}};return {deleteExistingStore:u,clearAllStores:()=>{let a=[],m=0,v=Number.POSITIVE_INFINITY;for(;m<20;){let M=Object.keys(t);if(M.length===0)break;M.forEach(w=>{Q(e,w)&&(u(w),a.push(w));}),m+=1;let E=Object.keys(t).length;if(E===0||E>=v)break;v=E;}let C=Object.keys(t).length;return C>0?S(`clearAllStores stopped after ${m} pass${m===1?"":"es"}; ${C} store(s) still registered (likely recreated during deletion).`):S(`All stores cleared (${a.length} stores removed)`),a},clearStores:a=>{let b=Object.keys(t).filter(m=>a?a.endsWith("*")?m.startsWith(a.slice(0,-1)):m===a:true);return b.forEach(m=>u(m)),b},reportStoreError:p}};var Pr=L,jr=ue(Pr),Kt=null,qt=new WeakSet,Nr=e=>{qt.has(e)||(qt.add(e),le().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ze(t);r&&e.featureRuntimes.set(t,r());}}));},D=()=>{let e=Z(jr);return Nr(e),e};var P=()=>D(),Gt=e=>{Kt=e;},re=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 s=n[r];return typeof s=="function"?s.bind(n):s},set:(t,r,n)=>(e()[r]=n,true)}),_r=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)}),V=re(()=>D().stores),z=re(()=>D().subscribers),ne=re(()=>D().initialStates),we=re(()=>D().initialFactories),g=re(()=>D().metaEntries),ee=re(()=>D().snapshotCache),$=$r(()=>D().featureRuntimes),Ut=new WeakMap,Ir=e=>{let t=Ut.get(e);return t||(t=Lt(e),Ut.set(e,t)),t};_r(()=>Ir(D()));var Jt=e=>{let t=$.get(e);if(t)return t;let r=ze(e);if(!r)return;let n=r();return $.set(e,n),n},zr=()=>{le().forEach(e=>{Jt(e);});};zr();var N=e=>Q(D(),e);var W=(e,t)=>{let r=Et(),n=x()?kt(t):t;r?(r[e]=n,Object.prototype.hasOwnProperty.call(V,e)||(V[e]=void 0)):V[e]=n;},qe=(e,t,r=Date.now())=>{W(e,t),g[e]&&(g[e].updatedAt=new Date(r).toISOString(),g[e].updatedAtMs=r,g[e].updateCount++,Kt?.(e));};var Xt=e=>Ct(D(),e);var Ue=new Set,Ke=e=>e?Ue.has(e):Ue.size>0,Ge=e=>{e&&Ue.add(e);};var Ye=e=>N(e)&&!Xt(e)?true:(Ee(e,Object.keys(V)),false),Qt=(e,t,r={})=>{q(t,{...r,onError:g[e]?.options?.onError});},Zt=(e,t,r={})=>{q(e,{...r,onError:t});},U=(e,t,r="dev")=>{Qt(e,t,{severity:"warn",visibility:r});},er=(e,t,r="dev")=>{Zt(e,t,{severity:"warn",visibility:r});},ke=(e,t)=>Qt(e,t,{severity:"critical",visibility:"always"}),oe=(e,t)=>Zt(e,t,{severity:"critical",visibility:"always"}),pe=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
9
- Import "stroid/${t}" before calling createStore("${e}", ...).`;if(er(n,r,"always"),R().strictMissingFeatures)throw new Error(n)};var tr=new WeakMap,rr=new WeakMap;var Je=e=>{let t=tr.get(e);return t||(t=new Map,tr.set(e,t)),t},Wr=e=>{let t=rr.get(e);return t||(t=new Map,rr.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=Je(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)=>(Je(P())[t]=r,true)});var ge=(e,t,r,n)=>{try{return n?.reuseInput&&Ae(t)?{ok:!0,value:t}:{ok:!0,value:H(t)}}catch(s){let o=`Sanitize failed for "${e}": ${s?.message??s}`;return g[e]?.options?.onError?.(o),r?.(o),S(o),{ok:false}}},Br=(e,t)=>{let r=new Set,n=g[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},xe=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let s=Br(e,n),o=(c,l)=>{s.forEach(p=>p(c)),l==="critical"?G(c):S(c);};if(typeof r=="function")try{let c=r(t);return c===!1?(o(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:c===!0?t:c}}catch(c){return o(`Validation for "${e}" failed: ${c?.message??c}`,"critical"),{ok:false}}let i=Oe(r,t);return i.ok?{ok:true,value:i.data??t}:(o(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Re=(e,t,r,n,s)=>{let o=ge(e,t,n,s);if(!o.ok)return {ok:false};let i=xe(e,o.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},K=e=>{let t=P();Je(t).delete(e),Wr(t).delete(e);};Gt(K);var nr=new WeakMap,Lr=e=>{let t=nr.get(e);return t||(t=new Map,nr.set(e,t)),t};var Xe=e=>{let t=P(),r=Lr(t),n=r.get(e);if(n)return n;let s=g[e];if(!s)return S(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let o={name:e,options:s.options,getMeta:()=>g[e],getStoreValue:()=>V[e],getAllStores:()=>V,getInitialState:()=>ne[e],hasStore:()=>N(e),setStoreValue:i=>{W(e,i);},applyFeatureState:(i,c)=>{qe(e,i,c),K(e);},notify:()=>{},reportStoreError:i=>{ke(e,i);},warn:S,log:T,hashState:ce,deepClone:F,sanitize:H,validate:i=>xe(e,i,g[e]?.options?.validate),isDev:x};return r.set(e,o),o},Qe=(e,t)=>{let r=Xe(e);r&&(r.notify=()=>t(e),$.forEach(n=>{n.onStoreCreate?.(r);}));},Ze=(e,t,r,n,s)=>{let o=Xe(e);if(!o)return;o.notify=()=>s(e);let i=Object.assign(Object.create(o),{action:t,prev:r,next:n});$.forEach(c=>{c.onStoreWrite?.(i);});};var et=(e,t)=>At({name:e,payload:t,middlewares:(()=>{let r=g[e]?.options?.middleware||[],n=R().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{U(e,r,n);},warn:S}),Ce=(e,t,r,n)=>ve({name:e,label:t,fn:r,args:n,reportIssue:(s,o)=>{U(e,s,o);}}),tt=(e,t)=>{let r={...t};return r.persist&&!me("persist")&&(r.explicitPersist&&pe(e,"persist",r.onError),r.persist=null),r.sync&&!me("sync")&&(r.explicitSync&&pe(e,"sync",r.onError),r.sync=false),me("devtools")||(r.explicitDevtools&&pe(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var or=(e,t,r={})=>{if(We()){let a=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;oe(a,r.onError),He(a);return}if(!Se(e)){oe(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!De(t)){oe(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&x()&&S(`createStore("${e}") received an undefined initial value. This can be indistinguishable from a missing store in some consumers; consider null or an explicit shape if that is intentional.`),vt(r).forEach(a=>{S(a);});let s=tt(e,wt(r,e));if(s.scope==="temp"&&r.persist){let a=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;s.onError?.(a),x()||O(a),j(a);}let o=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=o&&i==="production",l=s.allowSSRGlobalStore??false;if(c&&!l){let a=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
10
- Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;oe(a,r.onError);return}if(N(e)){let a=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return U(e,a),{name:e}}o&&!l&&!Ke(e)&&x()&&(Ge(e),S(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let p=ge(e,t,s.onError);if(!p.ok)return;let f=p.value,d=s.lazy===true&&typeof t=="function",u=(z[e]?.size??0)>0;if(d)V[e]=void 0,we[e]=t;else {let a=Re(e,f,s.validate,s.onError);if(!a.ok)return;W(e,a.value),ne[e]=F(a.value);}let h=Date.now(),y=new Date(h).toISOString();return g[e]={createdAt:y,updatedAt:y,updatedAtMs:h,updateCount:0,version:s.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},options:s},K(e),Qe(e,fe),Ce(e,"onCreate",g[e].options.onCreate,[f]),u&&fe(e),T(`Store "${e}" created -> ${JSON.stringify(f)}`),{name:e}};var Zr=(e,t,r="hydrate")=>{if(!Ye(e))return {ok:false,reason:"not-found"};let n=V[e],s=ge(e,t);if(!s.ok)return {ok:false,reason:"sanitize"};let o=s.value;if(o===void 0){let f=`Whole-store undefined replacement is blocked for "${e}". Use null for intentional empty state.`;return U(e,f),{ok:false,reason:"undefined"}}let i=g[e]?.options?.validate,c=et(e,{action:r,prev:n,next:o,path:null});if(c===be)return {ok:false,reason:"middleware"};let l=Re(e,c,i);if(!l.ok)return {ok:false,reason:"validate"};W(e,l.value),K(e);let p=Date.now();return g[e].updatedAt=new Date(p).toISOString(),g[e].updatedAtMs=p,g[e].updateCount++,Ze(e,r,n,l.value,fe),Ce(e,"onSet",g[e].options.onSet,[n,l.value]),fe(e),T(`Store "${e}" ${r==="hydrate"?"hydrated":"replaced"}`),{ok:true}};var rt=(e,t={},r={})=>{if(We()){let o="hydrateStores(...) cannot be called inside setStoreBatch.";return S(o),He(o),{hydrated:[],created:[],failed:{_batch:"transaction"}}}let n={hydrated:[],created:[],failed:Object.create(null)};if(!e||typeof e!="object")return n;if(!(r.allowUntrusted===true||R().allowUntrustedHydration===true))return O("hydrateStores(...) requires explicit trust. Pass { allowUntrusted: true } as the third argument or configureStroid({ allowUntrustedHydration: true })."),n.failed._hydration="untrusted",n;if(typeof r.validate=="function"){let o=false;try{o=!!r.validate(e);}catch(i){return O(`hydrateStores(...) trust validation threw: ${i?.message??i}`),n.failed._hydration="validation-error",n}if(!o)return O("hydrateStores(...) rejected by trust validation."),n.failed._hydration="validation-failed",n}return Object.entries(e).forEach(([o,i])=>{if(!Se(o)){n.failed[o]="invalid-name";return}if(N(o)){let c=Zr(o,i,"hydrate");c.ok?n.hydrated.push(o):n.failed[o]=c.reason??"hydrate-failed";}else {let c=t;or(o,i,c[o]||c.default||{})?n.created.push(o):n.failed[o]="create-failed";}}),n};var nt=new async_hooks.AsyncLocalStorage,Me=new async_hooks.AsyncLocalStorage;Ft({run:(e,t)=>nt.run(e,t),get:()=>nt.getStore()||null});Ot({run:(e,t)=>Me.run(e,t),get:()=>Me.getStore()||null,enterWith:e=>Me.enterWith(e)});var ps=e=>{let t=_e(),r={},n={},s=i=>Object.prototype.hasOwnProperty.call(r,i);return typeof e=="function"&&e({create:(i,c,l={})=>(r[i]=F(c),n[i]={...l},r[i]),set:(i,c)=>{if(!s(i))throw new Error(`createStoreForRequest.set("${i}") requires create("${i}", initialState) first.`);return r[i]=typeof c=="function"?je(r[i],c):c,r[i]},get:i=>s(i)?F(r[i]):void 0}),{snapshot:()=>F(r),hydrate:(i,c={})=>{let l={...c,default:c.default};return Object.keys(r).forEach(p=>{l[p]={...c.default||{},...c[p]||{},...n[p]||{}};}),Me.run(t,()=>nt.run(F(r),()=>(rt(r,l,{allowUntrusted:true}),i())))}}};exports.createStoreForRequest=ps;
package/dist/server.d.cts DELETED
@@ -1,14 +0,0 @@
1
- import { S as StoreOptions } from './options-CB35e3Xo.cjs';
2
-
3
- declare const createStoreForRequest: (initializer?: (api: {
4
- create: (name: string, data: any, options?: StoreOptions) => any;
5
- set: (name: string, updater: any) => any;
6
- get: (name: string) => any;
7
- }) => void) => {
8
- snapshot: () => Record<string, any>;
9
- hydrate: <T>(renderFn: () => T, options?: Partial<Record<string, StoreOptions>> & {
10
- default?: StoreOptions;
11
- }) => T;
12
- };
13
-
14
- export { createStoreForRequest };
package/dist/sync.cjs DELETED
@@ -1 +0,0 @@
1
- 'use strict';var U=new Map,D=(e,t)=>{U.set(e,t);};var E=({value:e,sanitize:t,validate:o,onSanitizeError:s})=>{let i;if(t)try{i=t(e);}catch(d){return s?.(d),{ok:false}}else i=e;let l=o(i);return l.ok?{ok:true,value:l.value??i}:{ok:false}},h=({value:e,fallbackMs:t=Date.now(),onInvalid:o})=>{if(typeof e=="number")return Number.isFinite(e)?e:(o?.(),t);if(typeof e=="string"){let s=Date.parse(e);return Number.isFinite(s)?s:(o?.(),t)}return o?.(),t};var z=false,b=1,P=e=>typeof e?.v=="number"?e.v:typeof e?.protocol=="number"?e.protocol:void 0,H=e=>typeof TextEncoder<"u"?new TextEncoder().encode(e).length:typeof Buffer<"u"?Buffer.byteLength(e):e.length,J=({incoming:e,accepted:t})=>{let o=t?.clock??0,s=typeof e.clock=="number"?e.clock:0;if(s!==o)return s-o;let i=e.source??"",l=t?.source??"";return i===l?0:i.localeCompare(l,"en",{sensitivity:"variant"})},Q=e=>e?.updatedAtMs??h({value:e?.updatedAt,fallbackMs:0}),Y=e=>{if(typeof e!="object"||e===null)return false;let t=e;return (typeof t.v=="number"||typeof t.protocol=="number")&&typeof t.type=="string"&&typeof t.name=="string"&&typeof t.clock=="number"&&typeof t.source=="string"},B=({name:e,syncChannels:t,instanceId:o,authToken:s,reportStoreError:i})=>{let l=t[e];if(l)try{let d={v:b,protocol:b,type:"sync-request",source:o,name:e,clock:0,requestedAt:Date.now()};s&&(d.token=s),l.postMessage(d);}catch(d){i(e,`Failed to request sync snapshot for "${e}": ${d?.message??d}`);}},G=(e,t)=>(t[e]=(t[e]??0)+1,t[e]),K=(e,t,o)=>(o[e]=Math.max(o[e]??0,t)+1,o[e]),X=({name:e,syncChannels:t,syncWindowCleanup:o,syncClocks:s,syncVersions:i})=>{t[e]?.close(),delete t[e],o[e]?.(),delete o[e],delete s[e],delete i[e];},Z=({syncChannels:e,syncWindowCleanup:t})=>{Object.values(t).forEach(o=>{try{o();}catch{}}),Object.values(e).forEach(o=>{try{o.close();}catch{}});},ee=({name:e,syncOption:t,syncChannels:o,syncClocks:s,syncVersions:i,syncWindowCleanup:l,instanceId:d,getMeta:n,getAcceptedSyncVersion:r,getStoreValue:u,hasStoreEntry:c,notify:p,validate:F,reportStoreError:y,warn:f,setStoreValue:V,normalizeIncomingState:C,acceptIncomingSyncVersion:L,resolveSyncVersion:_,broadcastSync:w})=>{if(!t)return;if(typeof window>"u"||typeof BroadcastChannel>"u"){y(e,`Sync enabled for "${e}" but BroadcastChannel not available in this environment.`);return}let k=typeof t=="object"?t.authToken:void 0,A=false,I=typeof t=="object"&&t.channel?t.channel:`stroid_sync_${e}`;try{let g=new BroadcastChannel(I);if(o[e]=g,g.onmessage=S=>{let a=S.data;if(!a||a.source===d||a.name!==e||o[e]!==g||!c(e)||!n(e))return;if(!Y(a)){y(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(k&&a.token!==k){A||(y(e,`Sync message for "${e}" failed auth token verification; ignoring.`),A=!0);return}let M=P(a);if(M!==b){y(e,`Sync protocol mismatch for "${e}". Expected v${b} but received ${String(M??"unknown")}. Ignoring message.`);return}if(a.type==="sync-state"&&(typeof a.data>"u"||typeof a.clock!="number")){y(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(typeof t=="object"&&typeof t.verify=="function"){let m=!1;try{m=!!t.verify(a);}catch(v){y(e,`Sync message verification failed for "${e}": ${v?.message??v}`);return}if(!m){y(e,`Sync message for "${e}" failed verification; ignoring.`);return}}if(a.type==="sync-request"){w(e);return}let x=typeof t=="object"?t.conflictResolver:null;if(J({incoming:{clock:a.clock,source:a.source},accepted:r(e)})<=0){let m=Q(n(e)),v=typeof a.updatedAt=="number"?a.updatedAt:Date.now();if(x){let j=x({local:u(e),incoming:a.data,localUpdated:m,incomingUpdated:v});if(j!==void 0){let N=C(e,j);if(N===null)return;V(e,N);let R=typeof t=="object"?t.resolveUpdatedAt:null,q=R?R({localUpdated:m,incomingUpdated:v,now:Date.now()}):Math.max(Date.now(),m,v);_(e,q,typeof a.clock=="number"?a.clock:0),p(e),w(e);}}return}let $=C(e,a.data);$!==null&&(V(e,$),L(e,typeof a.updatedAt=="number"?a.updatedAt:Date.now(),typeof a.clock=="number"?a.clock:0,typeof a.source=="string"?a.source:""),p(e));},typeof window<"u"&&typeof window.addEventListener=="function"){l[e]?.();let S=window,a=()=>{B({name:e,syncChannels:o,instanceId:d,authToken:k,reportStoreError:y});};S.addEventListener("focus",a),S.addEventListener("online",a),l[e]=()=>{S.removeEventListener("focus",a),S.removeEventListener("online",a);};}queueMicrotask(()=>{B({name:e,syncChannels:o,instanceId:d,authToken:k,reportStoreError:y});});}catch(g){f(`Failed to setup sync for "${e}": ${g?.message||g}`);}},T=({name:e,syncOption:t,syncChannels:o,syncClocks:s,instanceId:i,updatedAt:l,data:d,hashState:n,reportStoreError:r})=>{let u=o[e];if(u)try{let c=typeof t=="object"&&t.checksum==="none"?"none":"hash",p={v:b,protocol:b,type:"sync-state",source:i,name:e,clock:s[e]??0,updatedAt:h({value:l,fallbackMs:Date.now()}),data:d,checksum:c==="hash"?n(d):null};if(typeof t=="object"&&t.authToken&&(p.token=t.authToken),typeof t=="object"&&typeof t.sign=="function")try{let f=t.sign(p);if(f&&typeof f.then=="function"){r(e,`Sync signer for "${e}" returned a Promise. "sign" must be synchronous.`);return}f!==void 0&&(p.auth=f);}catch(f){r(e,`Failed to sign sync payload for "${e}": ${f?.message??f}`);return}let F=typeof t=="object"&&typeof t.maxPayloadBytes=="number"?t.maxPayloadBytes:64*1024,y=H(JSON.stringify(p));if(y>F){r(e,`Sync payload for "${e}" exceeds ${F} bytes (${y} bytes). Skipping BroadcastChannel sync.`);return}u.postMessage(p);}catch(c){r(e,`Failed to broadcast sync for "${e}": ${c?.message??c}`);}},te=()=>{let e=Object.create(null),t=Object.create(null),o=Object.create(null),s=Object.create(null),i=`stroid_${Math.random().toString(16).slice(2)}`,l=(n,r)=>{o[n]={clock:t[n]??0,updatedAt:h({value:r,fallbackMs:Date.now()}),source:i};},d=(n,r)=>{G(n,t),l(n,r);};return {onStoreCreate(n){if(n.options.sync&&(ee({name:n.name,syncOption:n.options.sync,syncChannels:e,syncClocks:t,syncVersions:o,syncWindowCleanup:s,instanceId:i,getMeta:n.getMeta,getAcceptedSyncVersion:r=>o[r],getStoreValue:r=>n.getStoreValue(),hasStoreEntry:()=>n.hasStore(),notify:()=>n.notify(),validate:(r,u)=>n.validate(u),reportStoreError:(r,u)=>n.reportStoreError(u),warn:n.warn,setStoreValue:(r,u)=>n.setStoreValue(u),normalizeIncomingState:(r,u)=>{let c=E({value:u,sanitize:n.sanitize,validate:n.validate,onSanitizeError:p=>{n.reportStoreError(`Sanitize failed for incoming sync "${r}": ${p?.message??p}`);}});return c.ok?c.value:null},acceptIncomingSyncVersion:(r,u,c,p)=>{n.applyFeatureState(n.getStoreValue(),u),t[n.name]=Math.max(t[n.name]??0,c),o[n.name]={clock:c,updatedAt:u,source:p};},resolveSyncVersion:(r,u,c)=>{n.applyFeatureState(n.getStoreValue(),u);let p=K(n.name,c,t);return o[n.name]={clock:p,updatedAt:u,source:i},p},broadcastSync:()=>{let r=n.getMeta();r&&T({name:n.name,syncOption:n.options.sync,syncChannels:e,syncClocks:t,instanceId:i,updatedAt:r.updatedAtMs??r.updatedAt,data:n.getStoreValue(),hashState:n.hashState,reportStoreError:(u,c)=>n.reportStoreError(c)});}}),e[n.name])){let r=n.getMeta();l(n.name,r?.updatedAtMs??r?.updatedAt??new Date().toISOString());}},onStoreWrite(n){if(!n.options.sync)return;let r=n.getMeta();r&&(d(n.name,r.updatedAtMs??r.updatedAt),T({name:n.name,syncOption:n.options.sync,syncChannels:e,syncClocks:t,instanceId:i,updatedAt:r.updatedAtMs??r.updatedAt,data:n.next,hashState:n.hashState,reportStoreError:(u,c)=>n.reportStoreError(c)}));},beforeStoreDelete(n){X({name:n.name,syncChannels:e,syncWindowCleanup:s,syncClocks:t,syncVersions:o});},resetAll(){Z({syncChannels:e,syncWindowCleanup:s}),Object.keys(e).forEach(n=>delete e[n]),Object.keys(t).forEach(n=>delete t[n]),Object.keys(o).forEach(n=>delete o[n]),Object.keys(s).forEach(n=>delete s[n]);}}},W=()=>{z||(z=true,D("sync",te));};W();
package/dist/sync.d.cts DELETED
@@ -1,2 +0,0 @@
1
-
2
- export { }
package/dist/testing.cjs DELETED
@@ -1,20 +0,0 @@
1
- 'use strict';var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var tn={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}`));}},_t={logSink:tn,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",defaultSnapshotMode:"deep",middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0},Je={..._t},M=()=>Je;var It=()=>{Je={..._t};};var Wt=()=>Je.namespace;var rn=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,nn=typeof ({ url: (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('testing.cjs', document.baseURI).href)) })<"u"&&undefined?.MODE?undefined.MODE:void 0,zt=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,on="production",sn=rn??nn??on,we=typeof zt=="boolean"?zt:sn!=="production",R=()=>we,Qe=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},an=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},cn=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},O=(e,t)=>{if((M().logSink.critical??an)(e,t),M().assertRuntime)throw new Error(e)},w=(e,t)=>{if(!we)return;if((M().logSink.warn??Qe)(e,t),M().assertRuntime)throw new Error(e)},K=(e,t)=>{if((M().logSink.warn??Qe)(e,t),M().assertRuntime)throw new Error(e)},j=(e,t)=>{if(we&&(M().logSink.warn??Qe)(e,t),O(e,t),M().assertRuntime)throw new Error(e)},$=(e,t)=>{if(!we)return;(M().logSink.log??cn)(e,t);},Ht=()=>`Functions cannot be stored in stroid.
2
- Store data only - handle functions outside the store.`,Bt=()=>`Map/Set detected. stroid converts these to plain objects.
3
- Use arrays or plain objects for best results.`,Lt=()=>`Date object detected. stroid stores it as ISO string.
4
- Use new Date(value) to convert back when reading.`,qt=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Kt=()=>"Map detected; converting to plain object.",Ut=()=>"Set detected; converting to array.",Gt=(e,t,r)=>`Path depth of ${e} exceeded maximum of ${t}.
5
- "${r.join(".")}"
6
- This is a data design issue. Split into separate stores:
7
- createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,Yt=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
8
- Consider splitting into separate stores for better readability.`;var Xt=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Jt=e=>`Store name "${e}" contains spaces.
9
- Use camelCase or kebab-case: "userName" or "user-name"`,Qt=e=>`Store name "${e}" is not allowed.
10
- Reserved names: "__proto__", "constructor", "prototype".`,un=128,ln=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=un,dn=(e,t)=>{if(e===t)return 0;if(e.length===0)return t.length;if(t.length===0)return e.length;let r=Array.from({length:e.length+1},(s,o)=>o),n=new Array(e.length+1);for(let s=1;s<=t.length;s++){n[0]=s;for(let o=1;o<=e.length;o++)n[o]=t[s-1]===e[o-1]?r[o-1]:Math.min(r[o-1],n[o-1],r[o])+1;[r,n]=[n,r];}return r[e.length]},Ze=(e,t)=>{let r=t.find(n=>{let s=n.toLowerCase(),o=e.toLowerCase();return s.includes(o)||o.includes(s)||ln(s,o)&&dn(s,o)<=2});if(r){w(`Store "${e}" not found. Did you mean "${r}"?`);return}j(`Store "${e}" not found.
11
- Available stores: [${t.join(", ")}]
12
- Call createStore("${e}", data) first.`);};var H=new Set(["__proto__","constructor","prototype"]),tt=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let s=r.error,o=s?.details?.[0]?.message||s?.message||r.message||e.errors;if(o)return {ok:!1,error:o};if(s)return {ok:!1,error:s}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var J=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,Zt=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},xe=e=>{let t=J(e);return t==="function"?(j(Ht()),false):t==="map"||t==="set"?(w(Bt()),true):(t==="date"&&w(Lt()),true)},et=(e,t)=>{let r=Zt(e);if(r)throw new Error(`${r} values are not supported`);let n=J(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return true}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date"||n==="map"||n==="set")return false;if(n==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s=Object.keys(e);for(let o of s){let a=Number(o);if(!Number.isInteger(a))return false}for(let o=0;o<e.length;o+=1)if(o in e&&!et(e[o],t))return false;return true}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");if(t.add(e),Object.getOwnPropertySymbols(e).length>0)return false;let s=Object.getOwnPropertyDescriptors(e);for(let[o,a]of Object.entries(s)){if(!a.enumerable||H.has(o))return false;if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${o}")`);if(!et(a.value,t))return false}return true}return true},rt=e=>et(e,new WeakSet),ve=(e,t)=>{let r=Zt(e);if(r)throw new Error(`${r} values are not supported`);let n=J(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date")return R()&&w(qt()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),R()&&w(Kt());let s={};for(let[o,a]of e){if(typeof o!="string")throw new Error("Map keys must be strings to remain JSON-safe");s[String(o)]=ve(a,t);}return s}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),R()&&w(Ut()),Array.from(e,s=>ve(s,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s={},o=Object.getOwnPropertyDescriptors(e);for(let[a,u]of Object.entries(o))if(u.enumerable&&!H.has(a)){if("get"in u||"set"in u)throw new Error(`Accessor properties are not supported during sanitize ("${a}")`);s[a]=ve(u.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=>ve(s,t))}return e},ee=e=>ve(e,new WeakSet),nt=e=>typeof e!="string"||e.trim()===""?(j(Xt(e)),false):H.has(e)?(j(Qt(e)),false):e.includes(" ")?(j(Jt(e)),false):true;var ot=null,fn=()=>{if(ot)return ot;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 ot=t,t},tr=e=>{let t=fn(),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},pn=2166136261,gn=2654435761,Sn=1e5,Q=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},te=(e,t)=>{Q(e,t.length);for(let r=0;r<t.length;r++)Q(e,t.charCodeAt(r));},F=(e,t)=>{te(e,t);},er=(e,t)=>{if(Number.isNaN(t)){F(e,"NaN");return}if(!Number.isFinite(t)){F(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){F(e,"-0");return}let r=t|0;if(t===r){F(e,"int"),Q(e,r);return}F(e,"num"),te(e,String(t));},de=(e,t)=>{if(e.nodes++>Sn){F(e,"[max]");return}if(t===null){F(e,"null");return}let r=typeof t;if(r==="string"){F(e,"string"),te(e,t);return}if(r==="number"){F(e,"number"),er(e,t);return}if(r==="boolean"){F(e,t?"true":"false");return}if(r==="undefined"){F(e,"undefined");return}if(r==="bigint"){F(e,"bigint"),te(e,t.toString());return}if(r==="symbol"){F(e,"symbol");let l=t;te(e,Symbol.keyFor(l)??l.description??String(l));return}if(r==="function"){F(e,"function"),te(e,t.name||"anonymous");return}let n=t,s=e.seen.get(n);if(s!==void 0){F(e,"ref"),Q(e,s);return}let o=e.nextId++;if(e.seen.set(n,o),Array.isArray(n)){F(e,"array"),Q(e,n.length);for(let l=0;l<n.length;l++)Object.prototype.hasOwnProperty.call(n,l)?de(e,n[l]):F(e,"hole");return}if(n instanceof Date){F(e,"date"),er(e,n.getTime());return}if(n instanceof Map){F(e,"map"),Q(e,n.size),n.forEach((l,p)=>{de(e,p),de(e,l);});return}if(n instanceof Set){F(e,"set"),Q(e,n.size),n.forEach(l=>{de(e,l);});return}F(e,"object");let a=Object.getOwnPropertyDescriptors(n),u=[];Object.entries(a).forEach(([l,p])=>{p?.enumerable&&(H.has(l)||"get"in p||"set"in p||u.push([l,p]));}),Q(e,u.length);for(let[l,p]of u)te(e,l),de(e,p.value);},ke=e=>{if(typeof e=="string")return tr(JSON.stringify(e));let t={h1:pn,h2:gn,seen:new WeakMap,nextId:1,nodes:0};de(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 yn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",st=e=>{if(e===null||typeof e!="object")return e;if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map)return new Map(e);if(e instanceof Set)return new Set(e);if(Array.isArray(e))return e.slice();let t={},r=Object.getOwnPropertyDescriptors(e);return Object.entries(r).forEach(([n,s])=>{s.enumerable&&(H.has(n)||"get"in s||"set"in s||(t[n]=s.value));}),t},fe=(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 o=new Map;return t.set(e,o),e.forEach((a,u)=>{o.set(fe(u,t),fe(a,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(a=>{o.add(fe(a,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((a,u)=>{o[u]=fe(a,t);}),o}let r=globalThis?.WeakRef;if(r&&e instanceof r)return K("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 K("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(s).forEach(([o,a])=>{!a.enumerable||H.has(o)||"get"in a||"set"in a||(n[o]=fe(a.value,t));}),n},P=e=>{try{if(yn)return structuredClone(e)}catch{}return fe(e)};var rr=10,mn=5,hn=e=>{let t=[],r="",n=false;for(let s of e){if(n){r+=s,n=false;continue}if(s==="\\"){n=true;continue}if(s==="."){t.push(r),r="";continue}r+=s;}return n&&(r+="\\"),t.push(r),t},Re=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?hn(e):[String(e)],at=e=>{let t=Re(e),r=t.length;return r>rr?(j(Gt(r,rr,t)),false):(r>mn&&w(Yt(r,t)),true)};var it=(e,t,r)=>{let n=Re(t);if(n.length===0)return e;for(let o of n)if(H.has(o))return O(`Blocked forbidden path segment "${String(o)}" in setStore path "${n.join(".")}".`),e;let s=(o,a)=>{let u=n[a],l=a===n.length-1;if(Array.isArray(o)){let p=Number(u);if(!Number.isInteger(p))return o;let g=[...o];return l?(g[p]=r,g):(g[p]=s(g[p],a+1),g)}if(o&&typeof o=="object"){if(H.has(u))return O(`Blocked unsafe path segment "${String(u)}" while setting "${n.join(".")}".`),o;let p={...o};return l?(p[u]=r,p):(p[u]=s(p[u],a+1),p)}if(o==null&&!l){let p=Number.isInteger(Number(u)),g=p?[]:{};if(p){let f=g,c=Number(u);return f[c]=s(void 0,a+1),f}return g[u]=s(void 0,a+1),g}return l?r:o};return s(e,0)};var ut=new Set,or=()=>{ut.clear();},$e=(()=>{let e=new Map;return {getItem:t=>e.has(t)?e.get(t):null,setItem:(t,r)=>{e.set(t,r);},removeItem:t=>{e.delete(t);},type:"memory"}})(),ct=e=>{try{return typeof window>"u"?$e:e==="session"||e==="sessionStorage"?window.sessionStorage??$e:window.localStorage??$e}catch{return $e}},_e=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),pe=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),sr=e=>{try{let t=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`,r=`__stroid_plaintext_probe_${Math.random().toString(36).slice(2)}__`;return e(t)!==t?!1:e(r)===r}catch{return false}},bn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",nr=e=>{try{e[bn]=!0;}catch{}return e},wn={allowSSRGlobalStore:'scope: "global"',schema:"validate",validator:"validate",version:"persist.version",migrations:"persist.migrations",historyLimit:"devtools.historyLimit",redactor:"devtools.redactor",middleware:"lifecycle.middleware",onCreate:"lifecycle.onCreate",onSet:"lifecycle.onSet",onReset:"lifecycle.onReset",onDelete:"lifecycle.onDelete"},vn=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:nr(g=>g),decrypt:nr(g=>g),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:ct("localStorage"),...r};if(typeof e=="string")return {driver:ct(e),...r};let n=e.encrypt||r.encrypt,s=e.decrypt||r.decrypt,o=e.encryptAsync,a=e.decryptAsync,u=e.sensitiveData===true,l=e.allowPlaintext===true,p=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(o&&!a||!o&&a)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(u&&sr(n)&&!o)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`);return {driver:e.driver||e.storage||ct("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:n,decrypt:s,encryptAsync:o,decryptAsync:a,allowPlaintext:l,sensitiveData:u,checksum:p,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},ar=e=>{if(!_e(e))return [];let t=[];return Object.entries(wn).forEach(([r,n])=>{pe(e,r)&&(ut.has(r)||(ut.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},ir=(e={},t)=>{let r=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,o=_e(e.lifecycle)?e.lifecycle:void 0,a=_e(e.persist)?e.persist:void 0,u=_e(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,p=e.snapshot==="shallow"||e.snapshot==="ref"?e.snapshot:"deep",g=pe(e,"persist"),f=pe(e,"sync"),c=pe(e,"devtools")||pe(e,"historyLimit")||pe(e,"redactor"),y=r==="global"?true:e.allowSSRGlobalStore??false,{persist:S=false,devtools:i=false,onError:h,sync:x}=e;if(a?.sensitiveData===true){let m=a.encrypt,v=a.encryptAsync;if((!m||sr(m))&&!v)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`)}return {scope:r,lazy:n,pathCreate:s,persist:r==="temp"&&!g?null:vn(S,t),devtools:r==="temp"&&!c?false:typeof i=="boolean"?i:u?.enabled??true,middleware:o?.middleware??e.middleware??[],onSet:o?.onSet??e.onSet,onReset:o?.onReset??e.onReset,onDelete:o?.onDelete??e.onDelete,onCreate:o?.onCreate??e.onCreate,onError:h,validate:l,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:r==="temp"&&!c?void 0:u?.redactor??e.redactor,historyLimit:r==="temp"&&!c?0:u?.historyLimit??e.historyLimit??50,sync:r==="temp"&&!f?false:x??false,allowSSRGlobalStore:y,snapshot:p,explicitPersist:g,explicitSync:f,explicitDevtools:c}};var cr=e=>{if(typeof e!="object"||e===null||e.$$typeof||typeof window<"u"&&e instanceof Element||e.constructor&&e.constructor.name!=="Object"&&e.constructor.name!=="Array")return e;let t=[e],r=new WeakSet;for(;t.length>0;){let n=t.pop();if(!r.has(n)){r.add(n),Object.isFrozen(n)||Object.freeze(n);for(let s of Object.keys(n)){let o=n[s];typeof o=="object"&&o!==null&&!r.has(o)&&t.push(o);}}}return e};var ur=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,noSignalWarned:new Set,shapeWarned:new Set,autoCreateWarned:new Set,cleanupSubs:Object.create(null),storeCleanupFns:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}}),Ie=e=>{Object.values(e.revalidateHandlers).forEach(t=>{try{t();}catch{}}),Object.values(e.cleanupSubs).forEach(t=>{try{t();}catch{}}),Object.values(e.storeCleanupFns).forEach(t=>{t.forEach(r=>{try{r();}catch{}});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.cleanupSubs).forEach(t=>delete e.cleanupSubs[t]),Object.keys(e.storeCleanupFns).forEach(t=>delete e.storeCleanupFns[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.noSignalWarned.clear(),e.shapeWarned.clear(),e.autoCreateWarned.clear(),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var lt=new Map,xn=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,lr,We=e=>(lr||xn||e).replace(/\.ts(\?|$)/,".js$1"),U=We(new URL("./store.js",(typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('testing.cjs', document.baseURI).href))).href);var dr=()=>{lr=void 0,lt.clear();},kn=()=>({stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:{depth:0,pending:[],stagedValues:new Map,failed:false,error:void 0},async:ur()}),re=e=>{let t=We(e),r=lt.get(t);if(r)return r;let n=kn();return lt.set(t,n),n},ge=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),fr=(e,t)=>e.deletingStores.has(t),pr=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.failed=false,e.transaction.error=void 0,Ie(e.async);};var dt=()=>null;var gr=(e,t)=>t(),ne=e=>e||re(U);var ft=new Map;var ze=e=>ft.has(e),pt=e=>ft.get(e),Me=()=>Array.from(ft.keys());var He=Symbol("stroid.middleware.abort"),mr=({name:e,payload:t,middlewares:r,reportIssue:n,warn:s})=>{if(!Array.isArray(r)||r.length===0)return t.next;let o=new WeakSet,a=P(t.next);for(let u of r){if(typeof u!="function")continue;let l,p=a;try{l=u({action:t.action,name:e,prev:t.prev,next:p,path:t.path});}catch(g){let f=`Middleware for "${e}" failed: ${g?.message??g}`;return n(f,"dev"),He}if(l&&typeof l.then=="function"){let g=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(g,"dev"),He}l===void 0?(R()&&!o.has(u)&&(o.add(u),s(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),a=p):a=l;}return a},Be=({name:e,label:t,fn:r,args:n,reportIssue:s})=>{if(typeof r=="function")try{r(...n);}catch(o){let a=`${t} for "${e}" failed: ${o?.message??o}`;s(a,"always");}};var oe=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:s}=t;if(s?.(e),r==="critical"){n==="dev"&&w(e),O(e);return}if(n==="always"){K(e);return}w(e);};var hr=()=>ne(re(U)),br=()=>hr().computedEntries,Mn=()=>hr().computedDependents;var wr=e=>Object.prototype.hasOwnProperty.call(br(),e);var vr=e=>{let t=br(),r=Mn(),n=new Set,s=[...e];for(;s.length>0;){let g=s.shift(),f=r[g];if(f)for(let c of f)n.has(c)||(n.add(c),s.push(c));}if(n.size===0)return [];let o=g=>{let f=t[g];if(f)for(let c of f.deps)t[c]&&(n.has(c)||(n.add(c),o(c)));};Array.from(n).forEach(g=>o(g));let a=new Map,u=new Map;for(let g of n){let f=t[g];if(!f)continue;let c=0;for(let y of f.deps)n.has(y)&&(c++,u.has(y)||u.set(y,[]),u.get(y).push(g));a.set(g,c);}let l=[];for(let[g,f]of a)f===0&&l.push(g);l.sort();let p=[];for(;l.length>0;){let g=l.shift();p.push(g);let f=u.get(g)??[];for(let c of f){let y=(a.get(c)??1)-1;if(a.set(c,y),y===0){let S=l.findIndex(i=>i>c);S===-1?l.push(c):l.splice(S,0,c);}}}return p};var gt=e=>({name:e});var Fe=e=>(e??ne()).transaction,Fn=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var k=()=>Fe().depth>0,V=(e,t)=>{let r=Fe(t);r.failed=true,r.error||(r.error=Fn(e));},Ee=e=>{let t=ne();Fe(t).pending.push(()=>gr(t,e));},Ae=(e,t)=>{Fe().stagedValues.set(e,t);},se=e=>{let t=Fe();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var ae=new Set,De=[],Le=false,Cr=0,xr=e=>{let t=d[e]?.options?.snapshot??M().defaultSnapshotMode;return t==="shallow"||t==="ref"?t:"deep"},kr=(e,t)=>t==="ref"?e:t==="shallow"?st(e):P(e);var St=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},En=()=>{De.length=0;for(let f of ae)De.push(f);ae.clear();let e=M().flush,t=e.priorityStores||[],r=new Set(De),n=t.length?new Set(t):null,s=[];if(n){for(let f of t)r.has(f)&&s.push(f);for(let f of De)n.has(f)||s.push(f);}else s.push(...De);let o=vr(s),a=new Set(s);for(let f of o)r.has(f)&&!a.has(f)&&(s.push(f),a.add(f));let u=Number.isFinite(e.chunkSize)&&e.chunkSize>0?e.chunkSize:Number.POSITIVE_INFINITY,l=e.chunkDelayMs,p=u===Number.POSITIVE_INFINITY&&l===0;return {names:s.slice(),sliceSize:u,chunkDelayMs:l,runInline:p,prioritySet:n}},Rr=()=>{let{names:e,sliceSize:t,chunkDelayMs:r,runInline:n,prioritySet:s}=En(),o=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),a=()=>{Le=false,ae.size>0&&Mr();};if(n){for(let c of e){let y=Z[c];if(!y||y.size===0)continue;let S=d[c]?.updateCount??0,i=xr(c),h=Se[c],x=h&&h.version===S?h.snapshot:(()=>{let b=kr(D[c],i);return Se[c]={version:S,snapshot:b},b})(),m=o();for(let b of y)try{b(x);}catch(A){w(`Subscriber for "${c}" threw: ${A?.message??A}`);}let v=o()-m,C=d[c]?.metrics||{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0};C.notifyCount+=1,C.totalNotifyMs+=v,C.lastNotifyMs=v,d[c]&&(d[c].metrics=C),(d[c]?.updateCount??S)!==S&&ae.add(c);}a();return}let u=c=>{let y=[];for(let S of e){if(c&&!c(S))continue;let i=Z[S];if(!i||i.size===0)continue;let h=d[S]?.updateCount??0,x=xr(S),m=Se[S],v=m&&m.version===h?m.snapshot:(()=>{let C=kr(D[S],x);return Se[S]={version:h,snapshot:C},C})();y.push({name:S,subsArray:Array.from(i),index:0,snapshot:v,version:h,notified:new Set,metrics:d[S]?.metrics?{...d[S].metrics}:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},totalMs:0});}return y},l=s?u(c=>s.has(c)):[],p=u(c=>!s||!s.has(c)),g=c=>{let y=Z[c.name];if(!y||y.size===0){c.subsArray=[],c.index=0;return}c.subsArray=Array.from(y),c.index=0;},f=(c,y)=>{let S=()=>{if(c.length===0){y();return}let i=c.shift();if((d[i.name]?.updateCount??i.version)!==i.version){if(ae.add(i.name),c.length===0){y();return}n?S():St(S,r);return}if(g(i),i.subsArray.length===0){if(c.length===0){y();return}n?S():St(S,r);return}let x=o(),m=0;for(;i.index<i.subsArray.length&&m<t;){let E=i.subsArray[i.index++];if(!i.notified.has(E)){i.notified.add(E);try{E(i.snapshot);}catch(b){w(`Subscriber for "${i.name}" threw: ${b?.message??b}`);}m+=1;}}i.totalMs+=o()-x;let v=Z[i.name],C=v?Array.from(v).some(E=>!i.notified.has(E)):false;if(i.index<i.subsArray.length||C?c.push(i):(i.metrics.notifyCount+=1,i.metrics.totalNotifyMs+=i.totalMs,i.metrics.lastNotifyMs=i.totalMs,d[i.name]&&(d[i.name].metrics=i.metrics)),c.length===0){y();return}n?S():St(S,r);};S();};l.length>0?f(l,()=>f(p,a)):f(p,a);},Mr=()=>{Le||(Le=true,typeof queueMicrotask=="function"?queueMicrotask(Rr):Promise.resolve().then(Rr));},B=e=>{ae.add(e),Cr===0&&Mr();};var Fr=()=>{ae.clear(),Le=false,Cr=0;};var An=()=>N().computedCleanups;var Er=e=>{let t=An(),r=t.get(e);if(!r){R()&&w(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Ar=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,s=e.initialFactories,o=e.metaEntries,a=e.snapshotCache,u=e.featureRuntimes,l=e.deletingStores,p=(i,h)=>{oe(h,{onError:o[i]?.options?.onError,severity:"warn",visibility:"dev"});},g=({name:i,prev:h,options:x,initialState:m,getMeta:v,getStoreValue:C,hasStore:E})=>({name:i,options:x,prev:h,getMeta:v,getStoreValue:C,getAllStores:()=>t,getInitialState:()=>m,hasStore:E,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:b=>{oe(b,{onError:x.onError,severity:"warn",visibility:"dev"});},warn:w,log:$,hashState:ke,deepClone:P,sanitize:ee,validate:()=>({ok:true,value:h}),isDev:R}),f=({name:i,prev:h,options:x,initialState:m,phase:v})=>{let C=g({name:i,prev:h,options:x,initialState:m,getMeta:()=>o[i],getStoreValue:()=>t[i],hasStore:()=>ge(e,i)}),E=g({name:i,prev:h,options:x,initialState:m,getMeta:()=>{},getStoreValue:()=>h,hasStore:()=>false});Me().forEach(b=>{let A=u.get(b);v==="before"?A?.beforeStoreDelete?.(C):A?.afterStoreDelete?.(E);});},c=i=>{if(!ge(e,i))return;let h=t[i],x=o[i].options,m=n[i],v=r[i];l.add(i);try{v?.forEach(b=>{try{b(null);}catch(A){w(`Subscriber for "${i}" threw during delete: ${A?.message??A}`);}}),Be({name:i,label:"onDelete",fn:x.onDelete,args:[h],reportIssue:(b,A)=>{oe(b,{onError:x.onError,severity:"warn",visibility:A});}}),f({name:i,prev:h,options:x,initialState:m,phase:"before"}),delete t[i],delete r[i],delete n[i],delete s[i],delete o[i],delete a[i],wr(i)&&Er(i);let E=e.computedDependents[i];if(E)for(let b of E)w(`[stroid] source store "${i}" was deleted. Computed store "${b}" depends on it and will return stale data. Call deleteComputed("${b}") to clean up.`);f({name:i,prev:h,options:x,initialState:m,phase:"after"}),$(`Store "${i}" deleted`);}finally{l.delete(i);}};return {deleteExistingStore:c,clearAllStores:()=>{let i=[],x=0,m=Number.POSITIVE_INFINITY;for(;x<20;){let C=Object.keys(t);if(C.length===0)break;C.forEach(b=>{ge(e,b)&&(c(b),i.push(b));}),x+=1;let E=Object.keys(t).length;if(E===0||E>=m)break;m=E;}let v=Object.keys(t).length;return v>0?w(`clearAllStores stopped after ${x} pass${x===1?"":"es"}; ${v} store(s) still registered (likely recreated during deletion).`):w(`All stores cleared (${i.length} stores removed)`),i},clearStores:i=>{let h=Object.keys(t).filter(x=>i?i.endsWith("*")?x.startsWith(i.slice(0,-1)):x===i:true);return h.forEach(x=>c(x)),h},reportStoreError:p}};var Ke=U,Pr=re(Ke),Vr=null,Dr=new WeakSet,Dn=e=>{Dr.has(e)||(Dr.add(e),Me().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=pt(t);r&&e.featureRuntimes.set(t,r());}}));},W=()=>{let e=ne(Pr);return Dn(e),e},Tr=(e,t)=>{Ke=e,Pr=t;},N=()=>W(),Nr=e=>{Vr=e;},ye=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,n)=>(e()[r]=n,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let n=Object.getOwnPropertyDescriptor(e(),r);if(n)return {...n,configurable:true}}}),On=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)}),Pn=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)}),D=ye(()=>W().stores),Z=ye(()=>W().subscribers),q=ye(()=>W().initialStates),ie=ye(()=>W().initialFactories),d=ye(()=>W().metaEntries),Se=ye(()=>W().snapshotCache),L=On(()=>W().featureRuntimes),Or=new WeakMap,Vn=e=>{let t=Or.get(e);return t||(t=Ar(e),Or.set(e,t)),t};Pn(()=>Vn(W()));var $r=e=>{let t=L.get(e);if(t)return t;let r=pt(e);if(!r)return;let n=r();return L.set(e,n),n},yt=()=>{Me().forEach(e=>{$r(e);});};yt();var G=e=>ge(W(),e),qe=e=>{if(k()){let r=se(e);if(r.has)return r.value}let t=dt();return t&&Object.prototype.hasOwnProperty.call(t,e)?t[e]:D[e]},_=(e,t)=>{let n=R()?cr(t):t;D[e]=n;},mt=(e,t,r=Date.now())=>{_(e,t),d[e]&&(d[e].updatedAt=new Date(r).toISOString(),d[e].updatedAtMs=r,d[e].updateCount++,Vr?.(e));},ht=()=>{pr(W());},bt=()=>{L.forEach(e=>{try{e.resetAll?.();}catch{}}),L.clear();};var _r=e=>fr(W(),e),Ir=e=>{let t=typeof e=="string"?We(e):Ke,r=typeof e=="string"?re(t):e??re(Ke);return {scope:t,registry:r}};var Ue=new Set,wt=e=>e?Ue.has(e):Ue.size>0,vt=e=>{e&&Ue.add(e);},Oe=()=>{Ue.clear();},Wr=new Set,zr=e=>{let t=Wt();return !t||e.includes("::")?e:(R()&&!Wr.has(e)&&(Wr.add(e),w(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},Ge=e=>zr(typeof e=="string"?e:e.name),xt=e=>G(e)&&!_r(e)?true:(Ze(e,Object.keys(D)),false),Hr=(e,t,r={})=>{oe(t,{...r,onError:d[e]?.options?.onError});},Br=(e,t,r={})=>{oe(e,{...r,onError:t});},ce=(e,t,r="dev")=>{Hr(e,t,{severity:"warn",visibility:r});},Lr=(e,t,r="dev")=>{Br(e,t,{severity:"warn",visibility:r});},Y=(e,t)=>Hr(e,t,{severity:"critical",visibility:"always"}),me=(e,t)=>Br(e,t,{severity:"critical",visibility:"always"}),Pe=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
13
- Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Lr(n,r,"always"),M().strictMissingFeatures)throw new Error(n)};var kt=new WeakMap,Rt=new WeakMap,Tn=500,Nn="",Ve=e=>{let t=kt.get(e);return t||(t=new Map,kt.set(e,t)),t},Ct=e=>{let t=Rt.get(e);return t||(t=new Map,Rt.set(e,t)),t},jn=(e,t)=>{let r=Ct(e),n=r.get(t);return n||(n=new Map,r.set(t,n)),n},qr=(e,t,r)=>{for(e.has(t)&&e.delete(t),e.set(t,r);e.size>Tn;){let n=e.keys().next().value;if(!n)break;let s=e.get(n);e.delete(n),s?.node.verdicts&&(s.node.verdicts.delete(s.type),s.node.verdicts.size===0&&delete s.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=Ve(N());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)=>(Ve(N())[t]=r,true)});var Kr=e=>{kt.set(e,new Map),Rt.set(e,new Map);},Mt=(e,t,r,n)=>{let s=d[e];if(!s)return {ok:true};let o=Re(r);if(o.length===0)return {ok:true};let a=J(n),u=N(),l=Ve(u),p=jn(u,e),g=o.join(Nn),f=l.get(e);f||(f={children:new Map},l.set(e,f));let c=f;for(let m of o){let v=c.children.get(m);v||(v={children:new Map},c.children.set(m,v)),c=v;}let y=c.verdicts?.get(a);if(y){let m=`${g}|${a}`;return qr(p,m,{node:c,type:a}),y}let S=s.options?.pathCreate===true,i=t,h={ok:true};for(let m=0;m<o.length;m++){let v=o[m],C=m===o.length-1;if(i==null){let b=`Path "${o.join(".")}" is invalid for "${e}" - "${o.slice(0,m).join(".")||"root"}" is ${i===null?"null":"undefined"}.`;O(b),h={ok:false,reason:b};break}if(typeof i!="object"){let b=`Path "${o.join(".")}" is invalid for "${e}" - "${o.slice(0,m).join(".")||"root"}" is not an object.`;O(b),h={ok:false,reason:b};break}if(Array.isArray(i)){let b=Number(v);if(!Number.isInteger(b)||b<0){let I=`Path "${o.join(".")}" targets non-numeric index "${v}" on an array in "${e}".`;O(I),h={ok:false,reason:I};break}let A=i;if(b>=A.length){let I=`Path "${o.join(".")}" is invalid for "${e}" - index ${b} is out of bounds (length ${A.length}).`;O(I),h={ok:false,reason:I};break}if(C){let I=A[b];if(I!=null){let jt=J(I);if(jt!==a){let $t=`Type mismatch setting "${o.join(".")}" on "${e}": expected ${jt}, received ${a}.`;O($t),h={ok:false,reason:$t};break}}h={ok:true};break}i=A[b];continue}if(!Object.prototype.hasOwnProperty.call(i,v)){if(S&&C){h={ok:true};break}let b=`Path "${o.join(".")}" is invalid for "${e}" - unknown key "${v}" at "${o.slice(0,m).join(".")||"root"}".`;O(b),h={ok:false,reason:b};break}if(C){let b=i[v];if(b!=null){let A=J(b);if(A!==a){let I=`Type mismatch setting "${o.join(".")}" on "${e}": expected ${A}, received ${a}.`;O(I),h={ok:false,reason:I};break}}h={ok:true};break}i=i[v];}c.verdicts||(c.verdicts=new Map);let x=c.verdicts.has(a);if(c.verdicts.set(a,h),!x){let m=`${g}|${a}`;qr(p,m,{node:c,type:a});}return h},ue=(e,t,r,n)=>{try{return n?.reuseInput&&rt(t)?{ok:!0,value:t}:{ok:!0,value:ee(t)}}catch(s){let o=`Sanitize failed for "${e}": ${s?.message??s}`;return d[e]?.options?.onError?.(o),r?.(o),w(o),{ok:false}}},_n=(e,t)=>{let r=new Set,n=d[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},Ye=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let s=_n(e,n),o=(u,l)=>{s.forEach(p=>p(u)),l==="critical"?O(u):w(u);};if(typeof r=="function")try{let u=r(t);return u===!1?(o(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:u===!0?t:u}}catch(u){return o(`Validation for "${e}" failed: ${u?.message??u}`,"critical"),{ok:false}}let a=tt(r,t);return a.ok?{ok:true,value:a.data??t}:(o(`Validation failed for "${e}": ${a.error}`,"critical"),{ok:false})},Te=(e,t,r,n,s)=>{let o=ue(e,t,n,s);if(!o.ok)return {ok:false};let a=Ye(e,o.value,r,n);return a.ok?{ok:true,value:a.value}:{ok:false}},z=e=>{let t=N();Ve(t).delete(e),Ct(t).delete(e);},Ft=()=>{let e=N();Ve(e).clear(),Ct(e).clear();};Nr(z);var Xe=e=>{if((k()?se(e):{has:false}).has||D[e]!==void 0)return true;let r=ie[e];if(!r)return true;try{let n=r(),s=ue(e,n,d[e]?.options?.onError);if(!s.ok)return !1;let o=d[e]?.options?.validate,a=Te(e,s.value,o,d[e]?.options?.onError);if(!a.ok)return !1;if(k()){let u=a.value;Ae(e,u),Ee(()=>{_(e,u),q[e]=P(u),delete ie[e],z(e);});}else _(e,a.value),q[e]=P(a.value),delete ie[e],z(e);return !0}catch(n){return Y(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var Ur=new WeakMap,Gr=e=>{let t=Ur.get(e);return t||(t=new Map,Ur.set(e,t)),t},Ne=()=>{Gr(N()).clear();},Et=e=>{let t=N(),r=Gr(t),n=r.get(e);if(n)return n;let s=d[e];if(!s)return w(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let o={name:e,options:s.options,getMeta:()=>d[e],getStoreValue:()=>D[e],getAllStores:()=>D,getInitialState:()=>q[e],hasStore:()=>G(e),setStoreValue:a=>{_(e,a);},applyFeatureState:(a,u)=>{mt(e,a,u),z(e);},notify:()=>{},reportStoreError:a=>{Y(e,a);},warn:w,log:$,hashState:ke,deepClone:P,sanitize:ee,validate:a=>Ye(e,a,d[e]?.options?.validate),isDev:R};return r.set(e,o),o},At=(e,t)=>{let r=Et(e);r&&(r.notify=()=>t(e),L.forEach(n=>{n.onStoreCreate?.(r);}));},he=(e,t,r,n,s)=>{let o=Et(e);if(!o)return;o.notify=()=>s(e);let a=Object.assign(Object.create(o),{action:t,prev:r,next:n});L.forEach(u=>{u.onStoreWrite?.(a);});};var Dt=(e,t)=>mr({name:e,payload:t,middlewares:(()=>{let r=d[e]?.options?.middleware||[],n=M().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{ce(e,r,n);},warn:w}),le=(e,t,r,n)=>Be({name:e,label:t,fn:r,args:n,reportIssue:(s,o)=>{ce(e,s,o);}}),Ot=(e,t)=>{let r={...t};return r.persist&&!ze("persist")&&(r.explicitPersist&&Pe(e,"persist",r.onError),r.persist=null),r.sync&&!ze("sync")&&(r.explicitSync&&Pe(e,"sync",r.onError),r.sync=false),ze("devtools")||(r.explicitDevtools&&Pe(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var Pt=e=>{let{scope:t,registry:r}=Ir(e);Tr(t,r),Kr(r),Ne(),Oe(),yt();};var Wn=new Set,zn=new Set;var Yr=()=>{Wn.clear();},Xr=()=>{zn.clear();};var Hn=32,Jr=new Set,Bn=(e,t)=>{R()&&(t<Hn||Jr.has(e)||(Jr.add(e),w(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},Vt=(e,t,r={})=>{if(k()){let i=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;me(i,r.onError),V(i);return}if(!nt(e)){me(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!xe(t)){me(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&R()&&w(`createStore("${e}") received an undefined initial value. This can be indistinguishable from a missing store in some consumers; consider null or an explicit shape if that is intentional.`),ar(r).forEach(i=>{w(i);});let s=Ot(e,ir(r,e));if(s.scope==="temp"&&r.persist){let i=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;s.onError?.(i),R()||K(i),j(i);}let o=typeof window>"u",a=typeof process<"u"?process.env?.NODE_ENV:void 0,u=o&&a==="production",l=s.allowSSRGlobalStore??false;if(u&&!l){let i=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
14
- Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;me(i,r.onError);return}if(G(e)){let i=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return ce(e,i),{name:e}}o&&!l&&!wt(e)&&R()&&(vt(e),w(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let p=ue(e,t,s.onError);if(!p.ok)return;let g=p.value,f=s.lazy===true&&typeof t=="function",c=(Z[e]?.size??0)>0;if(f)D[e]=void 0,ie[e]=t;else {let i=Te(e,g,s.validate,s.onError);if(!i.ok)return;_(e,i.value),q[e]=P(i.value);}let y=Date.now(),S=new Date(y).toISOString();return d[e]={createdAt:S,updatedAt:S,updatedAtMs:y,updateCount:0,version:s.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},options:s},z(e),At(e,B),le(e,"onCreate",d[e].options.onCreate,[g]),c&&B(e),$(`Store "${e}" created -> ${JSON.stringify(g)}`),{name:e}};function je(e,t,r){let n=Ge(e);if(!Xe(n))return {ok:false,reason:"validate"};if(!G(n)){let c=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return Y(n,c),k()&&V(c),{ok:false,reason:"not-found"}}let s,o=k()?se(n):{has:false,value:void 0},a=o.has?o.value:qe(n),u=typeof t=="function"&&r===void 0;if(u){let c=R()?Date.now():0;try{let y=M().mutatorProduce,S=!1,i,h=m=>{let v=t(m);return v!==void 0&&(S=!0,i=v),v},x=y?y(a,h):(()=>{let m=P(a);return h(m),m})();if(S&&M().strictMutatorReturns){let m=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return Y(n,m),k()&&V(m),{ok:!1,reason:"validate"}}S&&R()&&!M().strictMutatorReturns&&w(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),s=S&&!M().strictMutatorReturns?i:x;}catch(y){return Y(n,`Mutator for "${n}" failed: ${y?.message??y}`),k()&&V(y),{ok:false,reason:"validate"}}finally{c&&Bn(n,Date.now()-c);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!xe(t))return k()&&V(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof a!="object"||a===null||Array.isArray(a))return j(`setStore("${n}", data) only merges into object stores.
15
- Use setStore("${n}", "path", value) or recreate the store with an object shape.`),k()&&V(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let c=ue(n,t);if(!c.ok)return k()&&V(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};s={...a,...c.value};}else if(typeof t=="string"||Array.isArray(t)){if(!at(t))return k()&&V(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let c=ue(n,r);if(!c.ok)return k()&&V(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let y=c.value,S=Mt(n,a,t,y);if(!S.ok)return d[n]?.options?.onError?.(S.reason??`Invalid path for "${n}".`),k()&&V(S.reason),{ok:false,reason:"path"};s=it(a,t,y);}else {let c=`setStore("${n}") - invalid arguments.
16
- Usage:
17
- setStore("${n}", "field", value)
18
- setStore("${n}", "nested.field", value)
19
- setStore("${n}", { field: value })
20
- setStore(storeDef, draft => { draft.field = value })`;return j(c),d[n]?.options?.onError?.(c),k()&&V(c),{ok:false,reason:"invalid-args"}}if(!xe(s))return k()&&V(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let l=d[n]?.options?.validate,p=Dt(n,{action:"set",prev:a,next:s,path:t});if(p===He)return k()&&V(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let f=Te(n,p,l,void 0,u&&p===s?{reuseInput:true}:void 0);if(!f.ok)return k()&&V(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};if(k()){let c=f.value,y=a;Ae(n,c),Ee(()=>{_(n,c),z(n);let S=Date.now();d[n].updatedAt=new Date(S).toISOString(),d[n].updatedAtMs=S,d[n].updateCount++,he(n,"set",y,c,B),le(n,"onSet",d[n].options.onSet,[y,c]),B(n),$(`Store "${n}" updated`);});}else {_(n,f.value),z(n);let c=Date.now();d[n].updatedAt=new Date(c).toISOString(),d[n].updatedAtMs=c,d[n].updateCount++,he(n,"set",a,f.value,B),le(n,"onSet",d[n].options.onSet,[a,f.value]),B(n);}return k()||$(`Store "${n}" updated`),{ok:true}}function Tt(e){let t=Ge(e);if(!xt(t))return {ok:false,reason:"not-found"};if(!Xe(t))return {ok:false,reason:"validate"};if(!q[t]){let a=`resetStore("${t}") has no initial state to reset to. If this is a lazy store, ensure it has been initialized before calling resetStore.`;return ce(t,a),k()&&V(a),{ok:false,reason:"not-found"}}let r=k()?se(t):{has:false,value:void 0},n=r.has?r.value:D[t],s=P(q[t]);if(k())return Ae(t,s),Ee(()=>{_(t,s),z(t);let a=Date.now();d[t].updatedAt=new Date(a).toISOString(),d[t].updatedAtMs=a,d[t].updateCount++,he(t,"reset",n,s,B),le(t,"onReset",d[t].options.onReset,[n,s]),B(t),$(`Store "${t}" reset to initial state/value`);}),{ok:true};_(t,s),z(t);let o=Date.now();return d[t].updatedAt=new Date(o).toISOString(),d[t].updatedAtMs=o,d[t].updateCount++,he(t,"reset",n,s,B),le(t,"onReset",d[t].options.onReset,[n,s]),B(t),$(`Store "${t}" reset to initial state/value`),{ok:true}}var Qr=()=>{bt(),ht(),or(),Fr(),Ft(),Oe(),Yr(),Xr(),It(),Ne(),dr(),Pt(U);};var T=()=>N().async,X=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}}}),be=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}}});X(()=>T().fetchRegistry);X(()=>T().inflight);X(()=>T().requestVersion);X(()=>T().cacheMeta);X(()=>T().rateWindowStart);X(()=>T().rateCount);be(()=>T().ratePruneState);X(()=>T().cleanupSubs);X(()=>T().storeCleanupFns);X(()=>T().revalidateHandlers);be(()=>T().noSignalWarned);be(()=>T().shapeWarned);be(()=>T().autoCreateWarned);be(()=>T().revalidateKeys);be(()=>T().asyncMetrics);var Zr=()=>{Ie(T());};var en=[];var Nt=()=>{Ln(),Zr();},Ln=()=>{en.forEach(e=>e()),en.length=0;};var Ta=(e="mock",t={})=>{let r=gt(e);return Vt(e,t),{set:n=>typeof n=="function"?je(r,n):je(r,n),reset:()=>Tt(r),use:()=>r}},Na=(e,t)=>{let r=Date.now;Date.now=()=>e;try{return t()}finally{Date.now=r;}},ja=()=>{Qr(),Nt();},$a=(e,t=1e3,r=n=>({value:n}))=>{let n=typeof performance<"u"&&performance.now?performance.now():Date.now();for(let a=0;a<t;a++)je(e,r(a));let o=(typeof performance<"u"&&performance.now?performance.now():Date.now())-n;return {iterations:t,totalMs:o,avgMs:o/t}};exports.benchmarkStoreSet=$a;exports.createMockStore=Ta;exports.resetAllStoresForTest=ja;exports.withMockedTime=Na;
@@ -1,16 +0,0 @@
1
- import { a as StoreDefinition, c as StoreKey, P as PartialDeep, W as WriteResult } from './types-grvlY4BX.cjs';
2
-
3
- declare const createMockStore: <Name extends string, State extends Record<string, unknown> = Record<string, unknown>>(name?: Name, initial?: State) => {
4
- set: (update: PartialDeep<State> | ((draft: State) => void)) => WriteResult;
5
- reset: () => WriteResult;
6
- use: () => StoreDefinition<Name, State>;
7
- };
8
- declare const withMockedTime: <T>(nowMs: number, fn: () => T) => T;
9
- declare const resetAllStoresForTest: () => void;
10
- declare const benchmarkStoreSet: <Name extends string, State extends Record<string, unknown>>(name: StoreDefinition<Name, State> | StoreKey<Name, State>, iterations?: number, makeUpdate?: (i: number) => PartialDeep<State>) => {
11
- iterations: number;
12
- totalMs: number;
13
- avgMs: number;
14
- };
15
-
16
- export { benchmarkStoreSet, createMockStore, resetAllStoresForTest, withMockedTime };
@@ -1,57 +0,0 @@
1
- import type { FetchOptions } from "./async-registry.js";
2
- export type { FetchOptions, AsyncStateSnapshot, AsyncStateAdapter } from "./async-registry.js";
3
- export type FetchInput = string | Promise<unknown> | (() => string | Promise<unknown>);
4
- export declare const MAX_CACHE_SLOTS_PER_STORE = 100;
5
- export declare const MAX_INFLIGHT_SLOTS_PER_STORE = 100;
6
- export declare const MAX_WARNED_ENTRIES = 1000;
7
- export declare const getActiveAsyncRegistry: () => import("./async-registry.js").AsyncRegistry;
8
- export declare const fetchRegistry: Record<string, {
9
- kind: "url";
10
- url: string;
11
- options: FetchOptions;
12
- } | {
13
- kind: "factory";
14
- factory: () => string | Promise<unknown>;
15
- options: FetchOptions;
16
- }>;
17
- export declare const inflight: Partial<Record<string, {
18
- promise: Promise<unknown>;
19
- raw: Promise<unknown>;
20
- transform?: FetchOptions["transform"];
21
- }>>;
22
- export declare const requestVersion: Record<string, number>;
23
- export declare const cacheMeta: Record<string, {
24
- timestamp: number;
25
- expiresAt: number | null;
26
- data: unknown;
27
- }>;
28
- export declare const rateWindowStart: Record<string, number>;
29
- export declare const rateCount: Record<string, number>;
30
- export declare const ratePruneState: {
31
- lastAt: number;
32
- };
33
- export declare const cleanupSubs: Record<string, () => void>;
34
- export declare const storeCleanupFns: Record<string, Set<() => void>>;
35
- export declare const revalidateHandlers: Record<string, () => void>;
36
- export declare const noSignalWarned: Set<string>;
37
- export declare const shapeWarned: Set<string>;
38
- export declare const autoCreateWarned: Set<string>;
39
- export declare const revalidateKeys: Set<string>;
40
- export declare const asyncMetrics: {
41
- cacheHits: number;
42
- cacheMisses: number;
43
- dedupes: number;
44
- requests: number;
45
- failures: number;
46
- avgMs: number;
47
- lastMs: number;
48
- };
49
- export declare const markWarned: (set: Set<string>, key: string) => void;
50
- export declare const resetAsyncState: () => void;
51
- export declare const shouldUseCache: (cacheSlot: string, ttl?: number) => boolean;
52
- export declare const clearAsyncMeta: (name: string) => void;
53
- export declare const pruneAsyncCache: (name: string) => void;
54
- export declare const countInflightSlots: (name: string) => number;
55
- export declare const registerStoreCleanup: (name: string, fn: () => void) => void;
56
- export declare const unregisterStoreCleanup: (name: string, fn: () => void) => void;
57
- export declare const ensureCleanupSubscription: (name: string) => void;
@@ -1 +0,0 @@
1
- export * from "./index.js";
@@ -1 +0,0 @@
1
- export declare const devDeepFreeze: <T>(value: T) => T;
@@ -1,69 +0,0 @@
1
- import type { NormalizedOptions, StoreValue } from "./adapters/options.js";
2
- export type FeatureName = "persist" | "sync" | "devtools";
3
- export interface FeatureMetrics {
4
- notifyCount: number;
5
- totalNotifyMs: number;
6
- lastNotifyMs: number;
7
- }
8
- export interface StoreFeatureMeta {
9
- createdAt: string;
10
- updatedAt: string;
11
- updatedAtMs: number;
12
- updateCount: number;
13
- version: number;
14
- metrics: FeatureMetrics;
15
- options: NormalizedOptions;
16
- }
17
- export interface BaseFeatureContext {
18
- name: string;
19
- options: NormalizedOptions;
20
- getMeta: () => StoreFeatureMeta | undefined;
21
- getStoreValue: () => StoreValue;
22
- getAllStores: () => Record<string, StoreValue>;
23
- getInitialState: () => StoreValue;
24
- hasStore: () => boolean;
25
- setStoreValue: (value: StoreValue) => void;
26
- applyFeatureState: (value: StoreValue, updatedAtMs?: number) => void;
27
- notify: () => void;
28
- reportStoreError: (message: string) => void;
29
- warn: (message: string) => void;
30
- log: (message: string) => void;
31
- hashState: (value: unknown) => number;
32
- deepClone: <T>(value: T) => T;
33
- sanitize: (value: unknown) => unknown;
34
- validate: (next: StoreValue) => {
35
- ok: boolean;
36
- value?: StoreValue;
37
- };
38
- isDev: () => boolean;
39
- }
40
- export interface FeatureCreateContext extends BaseFeatureContext {
41
- }
42
- export interface FeatureWriteContext extends BaseFeatureContext {
43
- action: string;
44
- prev: StoreValue;
45
- next: StoreValue;
46
- }
47
- export interface FeatureDeleteContext extends BaseFeatureContext {
48
- prev: StoreValue;
49
- }
50
- export interface DevtoolsFeatureApi {
51
- getHistory?: (name: string, limit?: number) => unknown[];
52
- clearHistory?: (name?: string) => void;
53
- getPersistQueueDepth?: (name: string) => number;
54
- }
55
- export interface StoreFeatureRuntime {
56
- onStoreCreate?: (ctx: FeatureCreateContext) => void;
57
- onStoreWrite?: (ctx: FeatureWriteContext) => void;
58
- beforeStoreDelete?: (ctx: FeatureDeleteContext) => void;
59
- afterStoreDelete?: (ctx: FeatureDeleteContext) => void;
60
- resetAll?: () => void;
61
- api?: DevtoolsFeatureApi;
62
- }
63
- export type StoreFeatureFactory = () => StoreFeatureRuntime;
64
- export declare const registerStoreFeature: (name: FeatureName, factory: StoreFeatureFactory) => void;
65
- export declare const hasRegisteredStoreFeature: (name: FeatureName) => boolean;
66
- export declare const getStoreFeatureFactory: (name: FeatureName) => StoreFeatureFactory | undefined;
67
- export declare const getRegisteredFeatureNames: () => FeatureName[];
68
- export declare const setFeatureRegistrationHook: (hook: ((name: FeatureName, factory: StoreFeatureFactory) => void) | null) => void;
69
- export declare const resetRegisteredStoreFeaturesForTests: () => void;
@@ -1,6 +0,0 @@
1
- export declare const hasBroadUseStoreWarning: (name: string) => boolean;
2
- export declare const markBroadUseStoreWarning: (name: string) => void;
3
- export declare const hasMissingUseStoreWarning: (name: string) => boolean;
4
- export declare const markMissingUseStoreWarning: (name: string) => void;
5
- export declare const resetBroadUseStoreWarnings: () => void;
6
- export declare const resetMissingUseStoreWarnings: () => void;
@@ -1,3 +0,0 @@
1
- import type { StoreRegistry } from "../store-registry.js";
2
- export declare const bindRegistry: (scopeOrRegistry?: string | StoreRegistry) => void;
3
- export declare const useRegistry: (scopeId: string) => void;
@@ -1,44 +0,0 @@
1
- import { warn, log, hashState, deepClone, sanitize, isDev } from "../utils.js";
2
- import { MIDDLEWARE_ABORT } from "../features/lifecycle.js";
3
- import { type StoreFeatureMeta } from "../feature-registry.js";
4
- import type { NormalizedOptions } from "../adapters/options.js";
5
- import type { StoreValue } from "./types.js";
6
- type BaseFeatureContext = {
7
- name: string;
8
- options: StoreFeatureMeta["options"];
9
- getMeta: () => StoreFeatureMeta | undefined;
10
- getStoreValue: () => StoreValue;
11
- getAllStores: () => Record<string, StoreValue>;
12
- getInitialState: () => StoreValue | undefined;
13
- hasStore: () => boolean;
14
- setStoreValue: (value: StoreValue) => void;
15
- applyFeatureState: (value: StoreValue, updatedAtMs?: number) => void;
16
- notify: () => void;
17
- reportStoreError: (message: string) => void;
18
- warn: typeof warn;
19
- log: typeof log;
20
- hashState: typeof hashState;
21
- deepClone: typeof deepClone;
22
- sanitize: typeof sanitize;
23
- validate: (next: StoreValue) => {
24
- ok: true;
25
- value: StoreValue;
26
- } | {
27
- ok: false;
28
- };
29
- isDev: typeof isDev;
30
- };
31
- export declare const clearFeatureContexts: () => void;
32
- export declare const createBaseFeatureContext: (name: string) => BaseFeatureContext | null;
33
- export declare const runFeatureCreateHooks: (name: string, notify: (name: string) => void) => void;
34
- export declare const runFeatureWriteHooks: (name: string, action: string, prev: StoreValue, next: StoreValue, notify: (name: string) => void) => void;
35
- export declare const runFeatureDeleteHooks: (name: string, prev: StoreValue, notify: (name: string) => void) => void;
36
- export declare const runMiddlewareForStore: (name: string, payload: {
37
- action: string;
38
- prev: StoreValue;
39
- next: StoreValue;
40
- path: unknown;
41
- }) => StoreValue | typeof MIDDLEWARE_ABORT;
42
- export declare const runStoreHookSafe: (name: string, label: "onCreate" | "onSet" | "onReset" | "onDelete", fn: ((...args: any[]) => void) | undefined, args: any[]) => void;
43
- export declare const resolveFeatureAvailability: (name: string, options: NormalizedOptions) => NormalizedOptions;
44
- export {};
@@ -1,20 +0,0 @@
1
- /**
2
- * @module store-lifecycle
3
- *
4
- * LAYER: Core Engine
5
- * OWNS: Registry state variables (stores, meta, subscribers, ...) and all
6
- * pure primitives that operate on them (sanitize, validate, path-safety,
7
- * feature hook dispatch).
8
- *
9
- * DOES NOT KNOW about: createStore(), setStore(), React hooks,
10
- * or any specific feature plugin by name.
11
- *
12
- * Consumers: store-write (write API), store-read, store-notify,
13
- * hooks-core.
14
- */
15
- export type { Path, PathDepth, PathValue, PartialDeep, StoreValue, StoreKey, StoreDefinition, StoreName, StateFor, WriteResult, Subscriber, StoreStateMap, StrictStoreMap, UnregisteredStoreName, } from "./store-lifecycle/types.js";
16
- export { stores, meta, subscribers, initialStates, initialFactories, snapshotCache, featureRuntimes, storeAdmin, getStoreAdmin, getFeatureRuntime, hasStoreEntryInternal, getStoreValueRef, setStoreValueInternal, applyFeatureState, clearAllRegistries, resetFeaturesForTests, getMetaEntry, getRegistry, defaultRegistryScope, } from "./store-lifecycle/registry.js";
17
- export { sanitizeValue, normalizeCommittedState, runValidation, validatePathSafety, invalidatePathCache, clearPathValidationCache, materializeInitial, pathValidationCache, } from "./store-lifecycle/validation.js";
18
- export { runFeatureCreateHooks, runFeatureWriteHooks, runFeatureDeleteHooks, runMiddlewareForStore, runStoreHookSafe, resolveFeatureAvailability, clearFeatureContexts, createBaseFeatureContext, } from "./store-lifecycle/hooks.js";
19
- export { nameOf, qualifyName, exists, getFeatureApi, reportStoreCreationError, reportStoreError, reportStoreWarning, reportStoreCreationWarning, getSsrWarningIssued, markSsrWarningIssued, resetSsrWarningFlag, warnMissingFeature, } from "./store-lifecycle/identity.js";
20
- export { bindRegistry, useRegistry } from "./store-lifecycle/bind.js";