stroid 0.0.3 → 0.1.0

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 (118) hide show
  1. package/CHANGELOG.md +97 -1
  2. package/README.md +436 -884
  3. package/dist/async-cache-DFHwcBQL.d.cts +52 -0
  4. package/dist/async-cache-DFHwcBQL.d.ts +52 -0
  5. package/dist/async.cjs +29 -0
  6. package/dist/async.d.cts +40 -0
  7. package/dist/async.d.ts +30 -20
  8. package/dist/async.js +29 -1
  9. package/dist/computed-BbAZm1Dq.d.cts +17 -0
  10. package/dist/computed-CccdgY5j.d.ts +17 -0
  11. package/dist/computed.cjs +11 -0
  12. package/dist/computed.d.cts +29 -0
  13. package/dist/computed.d.ts +29 -0
  14. package/dist/computed.js +11 -0
  15. package/dist/core.cjs +30 -0
  16. package/dist/core.d.cts +5 -0
  17. package/dist/core.d.ts +5 -1
  18. package/dist/core.js +30 -1
  19. package/dist/devtools.cjs +1 -0
  20. package/dist/devtools.d.cts +19 -0
  21. package/dist/devtools.d.ts +19 -0
  22. package/dist/devtools.js +1 -0
  23. package/dist/helpers.cjs +20 -0
  24. package/dist/helpers.d.cts +29 -0
  25. package/dist/helpers.d.ts +29 -0
  26. package/dist/helpers.js +20 -0
  27. package/dist/index.cjs +30 -0
  28. package/dist/index.d.cts +130 -0
  29. package/dist/index.d.ts +125 -13
  30. package/dist/index.js +30 -1
  31. package/dist/options-CB35e3Xo.d.cts +245 -0
  32. package/dist/options-CB35e3Xo.d.ts +245 -0
  33. package/dist/persist.cjs +1 -0
  34. package/dist/persist.d.cts +2 -0
  35. package/dist/persist.d.ts +2 -0
  36. package/dist/persist.js +1 -0
  37. package/dist/react.cjs +31 -0
  38. package/dist/react.d.cts +52 -0
  39. package/dist/react.d.ts +51 -6
  40. package/dist/react.js +31 -1
  41. package/dist/runtime-admin.cjs +1 -0
  42. package/dist/runtime-admin.d.cts +4 -0
  43. package/dist/runtime-admin.d.ts +4 -0
  44. package/dist/runtime-admin.js +1 -0
  45. package/dist/runtime-tools.cjs +3 -0
  46. package/dist/runtime-tools.d.cts +39 -0
  47. package/dist/runtime-tools.d.ts +39 -0
  48. package/dist/runtime-tools.js +3 -0
  49. package/dist/selectors.cjs +1 -0
  50. package/dist/selectors.d.cts +4 -0
  51. package/dist/selectors.d.ts +4 -0
  52. package/dist/selectors.js +1 -0
  53. package/dist/server.cjs +10 -0
  54. package/dist/server.d.cts +14 -0
  55. package/dist/server.d.ts +14 -0
  56. package/dist/server.js +10 -0
  57. package/dist/sync.cjs +1 -0
  58. package/dist/sync.d.cts +2 -0
  59. package/dist/sync.d.ts +2 -0
  60. package/dist/sync.js +1 -0
  61. package/dist/testing.cjs +20 -0
  62. package/dist/testing.d.cts +16 -0
  63. package/dist/testing.d.ts +7 -7
  64. package/dist/testing.js +20 -1
  65. package/dist/types/adapters/options.d.ts +247 -0
  66. package/dist/types/async/clone.d.ts +2 -0
  67. package/dist/types/async/errors.d.ts +3 -0
  68. package/dist/types/async/inflight.d.ts +13 -0
  69. package/dist/types/async/rate.d.ts +5 -0
  70. package/dist/types/async/request.d.ts +3 -0
  71. package/dist/types/async-cache.d.ts +57 -0
  72. package/dist/types/async-fetch.d.ts +37 -0
  73. package/dist/types/async-registry.d.ts +96 -0
  74. package/dist/types/async-retry.d.ts +10 -0
  75. package/dist/types/async.d.ts +2 -0
  76. package/dist/types/computed-graph.d.ts +31 -0
  77. package/dist/types/computed.d.ts +15 -0
  78. package/dist/types/config.d.ts +2 -0
  79. package/dist/types/core.d.ts +1 -0
  80. package/dist/types/devfreeze.d.ts +1 -0
  81. package/dist/types/feature-registry.d.ts +69 -0
  82. package/dist/types/features/lifecycle.d.ts +28 -0
  83. package/dist/types/index.d.ts +6 -0
  84. package/dist/types/integrations/query.d.ts +8 -0
  85. package/dist/types/internals/config.d.ts +62 -0
  86. package/dist/types/internals/diagnostics.d.ts +21 -0
  87. package/dist/types/internals/hooks-warnings.d.ts +6 -0
  88. package/dist/types/internals/reporting.d.ts +8 -0
  89. package/dist/types/internals/store-admin.d.ts +7 -0
  90. package/dist/types/internals/store-ops.d.ts +3 -0
  91. package/dist/types/runtime-admin.d.ts +2 -0
  92. package/dist/types/store-lifecycle/bind.d.ts +3 -0
  93. package/dist/types/store-lifecycle/hooks.d.ts +44 -0
  94. package/dist/types/store-lifecycle/identity.d.ts +23 -0
  95. package/dist/types/store-lifecycle/registry.d.ts +39 -0
  96. package/dist/types/store-lifecycle/types.d.ts +39 -0
  97. package/dist/types/store-lifecycle/validation.d.ts +45 -0
  98. package/dist/types/store-lifecycle.d.ts +20 -0
  99. package/dist/types/store-name.d.ts +19 -0
  100. package/dist/types/store-notify.d.ts +12 -0
  101. package/dist/types/store-read.d.ts +12 -0
  102. package/dist/types/store-registry.d.ts +74 -0
  103. package/dist/types/store-transaction.d.ts +12 -0
  104. package/dist/types/store-write.d.ts +45 -0
  105. package/dist/types/store.d.ts +7 -0
  106. package/dist/types/utils/clone.d.ts +4 -0
  107. package/dist/types/utils/hash.d.ts +8 -0
  108. package/dist/types/utils/path.d.ts +5 -0
  109. package/dist/types/utils/validation.d.ts +14 -0
  110. package/dist/types/utils.d.ts +5 -0
  111. package/dist/types-grvlY4BX.d.cts +37 -0
  112. package/dist/types-grvlY4BX.d.ts +37 -0
  113. package/package.json +77 -6
  114. package/dist/chunk-3CAQKMKY.js +0 -5
  115. package/dist/chunk-KYAUSC7J.js +0 -1
  116. package/dist/chunk-VNLWP332.js +0 -17
  117. package/dist/chunk-Y52AULFH.js +0 -3
  118. package/dist/core-CLIi-SLm.d.ts +0 -205
@@ -0,0 +1,52 @@
1
+ type AsyncStateSnapshot = {
2
+ data?: unknown;
3
+ loading: boolean;
4
+ error: string | null;
5
+ status: "idle" | "loading" | "success" | "error" | "aborted";
6
+ cached?: boolean;
7
+ revalidating?: boolean;
8
+ };
9
+ type AsyncStateAdapter = (ctx: {
10
+ name: string;
11
+ prev: unknown;
12
+ next: AsyncStateSnapshot;
13
+ set: (value: unknown | ((draft: any) => void)) => void;
14
+ }) => void;
15
+ interface FetchOptions {
16
+ transform?: (result: unknown) => unknown;
17
+ onSuccess?: (data: unknown) => void;
18
+ onError?: (message: string) => void;
19
+ /**
20
+ * Optional adapter to write async state into a custom store shape.
21
+ * When provided, default AsyncState writes are skipped.
22
+ */
23
+ stateAdapter?: AsyncStateAdapter;
24
+ method?: string;
25
+ headers?: Record<string, string>;
26
+ body?: unknown;
27
+ ttl?: number;
28
+ staleWhileRevalidate?: boolean;
29
+ dedupe?: boolean;
30
+ retry?: number;
31
+ retryDelay?: number;
32
+ retryBackoff?: number;
33
+ signal?: AbortSignal;
34
+ cacheKey?: string;
35
+ responseType?: "auto" | "json" | "text" | "arrayBuffer" | "blob" | "formData";
36
+ /**
37
+ * Auto-create the backing store if missing.
38
+ * Defaults to the global config setting (true by default).
39
+ */
40
+ autoCreate?: boolean;
41
+ /**
42
+ * Clone strategy for transformed results.
43
+ * - "none" (default): store by reference.
44
+ * - "shallow": shallow clone objects/arrays.
45
+ * - "deep": deep clone objects/arrays.
46
+ */
47
+ cloneResult?: "none" | "shallow" | "deep";
48
+ }
49
+
50
+ type FetchInput = string | Promise<unknown> | (() => string | Promise<unknown>);
51
+
52
+ export type { AsyncStateAdapter as A, FetchOptions as F, FetchInput as a, AsyncStateSnapshot as b };
@@ -0,0 +1,52 @@
1
+ type AsyncStateSnapshot = {
2
+ data?: unknown;
3
+ loading: boolean;
4
+ error: string | null;
5
+ status: "idle" | "loading" | "success" | "error" | "aborted";
6
+ cached?: boolean;
7
+ revalidating?: boolean;
8
+ };
9
+ type AsyncStateAdapter = (ctx: {
10
+ name: string;
11
+ prev: unknown;
12
+ next: AsyncStateSnapshot;
13
+ set: (value: unknown | ((draft: any) => void)) => void;
14
+ }) => void;
15
+ interface FetchOptions {
16
+ transform?: (result: unknown) => unknown;
17
+ onSuccess?: (data: unknown) => void;
18
+ onError?: (message: string) => void;
19
+ /**
20
+ * Optional adapter to write async state into a custom store shape.
21
+ * When provided, default AsyncState writes are skipped.
22
+ */
23
+ stateAdapter?: AsyncStateAdapter;
24
+ method?: string;
25
+ headers?: Record<string, string>;
26
+ body?: unknown;
27
+ ttl?: number;
28
+ staleWhileRevalidate?: boolean;
29
+ dedupe?: boolean;
30
+ retry?: number;
31
+ retryDelay?: number;
32
+ retryBackoff?: number;
33
+ signal?: AbortSignal;
34
+ cacheKey?: string;
35
+ responseType?: "auto" | "json" | "text" | "arrayBuffer" | "blob" | "formData";
36
+ /**
37
+ * Auto-create the backing store if missing.
38
+ * Defaults to the global config setting (true by default).
39
+ */
40
+ autoCreate?: boolean;
41
+ /**
42
+ * Clone strategy for transformed results.
43
+ * - "none" (default): store by reference.
44
+ * - "shallow": shallow clone objects/arrays.
45
+ * - "deep": deep clone objects/arrays.
46
+ */
47
+ cloneResult?: "none" | "shallow" | "deep";
48
+ }
49
+
50
+ type FetchInput = string | Promise<unknown> | (() => string | Promise<unknown>);
51
+
52
+ export type { AsyncStateAdapter as A, FetchOptions as F, FetchInput as a, AsyncStateSnapshot as b };
package/dist/async.cjs ADDED
@@ -0,0 +1,29 @@
1
+ 'use strict';var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var so={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}`));}},io={logSink:so,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},br={...io},C=()=>br;var wr=()=>br.namespace;var ao=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,co=typeof ({ url: (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('async.cjs', document.baseURI).href)) })<"u"&&undefined?.MODE?undefined.MODE:void 0,vr=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,uo="production",lo=ao??co??uo,ze=typeof vr=="boolean"?vr:lo!=="production",R=()=>ze,Vt=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},fo=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},po=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},T=(e,t)=>{if((C().logSink.critical??fo)(e,t),C().assertRuntime)throw new Error(e)},f=(e,t)=>{if(!ze)return;if((C().logSink.warn??Vt)(e,t),C().assertRuntime)throw new Error(e)},J=(e,t)=>{if((C().logSink.warn??Vt)(e,t),C().assertRuntime)throw new Error(e)},O=(e,t)=>{if(ze&&(C().logSink.warn??Vt)(e,t),T(e,t),C().assertRuntime)throw new Error(e)},H=(e,t)=>{if(!ze)return;(C().logSink.log??po)(e,t);},xr=()=>`Functions cannot be stored in stroid.
2
+ Store data only - handle functions outside the store.`,kr=()=>`Map/Set detected. stroid converts these to plain objects.
3
+ Use arrays or plain objects for best results.`,Rr=()=>`Date object detected. stroid stores it as ISO string.
4
+ Use new Date(value) to convert back when reading.`,Cr=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Mr=()=>"Map detected; converting to plain object.",Er=()=>"Set detected; converting to array.",Fr=(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]}", ...)`,Ar=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
8
+ Consider splitting into separate stores for better readability.`,Or=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Vr=e=>`Store name "${e}" contains spaces.
9
+ Use camelCase or kebab-case: "userName" or "user-name"`,Tr=e=>`Store name "${e}" is not allowed.
10
+ Reserved names: "__proto__", "constructor", "prototype".`,go=128,So=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=go,yo=(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},(o,s)=>s),n=new Array(e.length+1);for(let o=1;o<=t.length;o++){n[0]=o;for(let s=1;s<=e.length;s++)n[s]=t[o-1]===e[s-1]?r[s-1]:Math.min(r[s-1],n[s-1],r[s])+1;[r,n]=[n,r];}return r[e.length]},Tt=(e,t)=>{let r=t.find(n=>{let o=n.toLowerCase(),s=e.toLowerCase();return o.includes(s)||s.includes(o)||So(o,s)&&yo(o,s)<=2});if(r){f(`Store "${e}" not found. Did you mean "${r}"?`);return}O(`Store "${e}" not found.
11
+ Available stores: [${t.join(", ")}]
12
+ Call createStore("${e}", data) first.`);};var B=new Set(["__proto__","constructor","prototype"]),jt=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let o=r.error,s=o?.details?.[0]?.message||o?.message||r.message||e.errors;if(s)return {ok:!1,error:s};if(o)return {ok:!1,error:o}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var 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,Nr=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},Be=e=>{let t=ae(e);return t==="function"?(O(xr()),false):t==="map"||t==="set"?(f(kr()),true):(t==="date"&&f(Rr()),true)},Nt=(e,t)=>{let r=Nr(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 o=Object.keys(e);for(let s of o){let i=Number(s);if(!Number.isInteger(i))return false}for(let s=0;s<e.length;s+=1)if(s in e&&!Nt(e[s],t))return false;return true}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");if(t.add(e),Object.getOwnPropertySymbols(e).length>0)return false;let o=Object.getOwnPropertyDescriptors(e);for(let[s,i]of Object.entries(o)){if(!i.enumerable||B.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Nt(i.value,t))return false}return true}return true},$t=e=>Nt(e,new WeakSet),He=(e,t)=>{let r=Nr(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 R()&&f(Cr()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),R()&&f(Mr());let o={};for(let[s,i]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");o[String(s)]=He(i,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),R()&&f(Er()),Array.from(e,o=>He(o,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let o={},s=Object.getOwnPropertyDescriptors(e);for(let[i,u]of Object.entries(s))if(u.enumerable&&!B.has(i)){if("get"in u||"set"in u)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);o[i]=He(u.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=>He(o,t))}return e},fe=e=>He(e,new WeakSet),_t=e=>typeof e!="string"||e.trim()===""?(O(Or(e)),false):B.has(e)?(O(Tr(e)),false):e.includes(" ")?(O(Vr(e)),false):true;var It=null,ho=()=>{if(It)return It;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 It=t,t},$r=e=>{let t=ho(),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},mo=2166136261,bo=2654435761,wo=1e5,ce=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},pe=(e,t)=>{ce(e,t.length);for(let r=0;r<t.length;r++)ce(e,t.charCodeAt(r));},A=(e,t)=>{pe(e,t);},jr=(e,t)=>{if(Number.isNaN(t)){A(e,"NaN");return}if(!Number.isFinite(t)){A(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){A(e,"-0");return}let r=t|0;if(t===r){A(e,"int"),ce(e,r);return}A(e,"num"),pe(e,String(t));},Re=(e,t)=>{if(e.nodes++>wo){A(e,"[max]");return}if(t===null){A(e,"null");return}let r=typeof t;if(r==="string"){A(e,"string"),pe(e,t);return}if(r==="number"){A(e,"number"),jr(e,t);return}if(r==="boolean"){A(e,t?"true":"false");return}if(r==="undefined"){A(e,"undefined");return}if(r==="bigint"){A(e,"bigint"),pe(e,t.toString());return}if(r==="symbol"){A(e,"symbol");let l=t;pe(e,Symbol.keyFor(l)??l.description??String(l));return}if(r==="function"){A(e,"function"),pe(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){A(e,"ref"),ce(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){A(e,"array"),ce(e,n.length);for(let l=0;l<n.length;l++)Object.prototype.hasOwnProperty.call(n,l)?Re(e,n[l]):A(e,"hole");return}if(n instanceof Date){A(e,"date"),jr(e,n.getTime());return}if(n instanceof Map){A(e,"map"),ce(e,n.size),n.forEach((l,g)=>{Re(e,g),Re(e,l);});return}if(n instanceof Set){A(e,"set"),ce(e,n.size),n.forEach(l=>{Re(e,l);});return}A(e,"object");let i=Object.getOwnPropertyDescriptors(n),u=[];Object.entries(i).forEach(([l,g])=>{g?.enumerable&&(B.has(l)||"get"in g||"set"in g||u.push([l,g]));}),ce(e,u.length);for(let[l,g]of u)pe(e,l),Re(e,g.value);},Le=e=>{if(typeof e=="string")return $r(JSON.stringify(e));let t={h1:mo,h2:bo,seen:new WeakMap,nextId:1,nodes:0};Re(t,e);let r=t.h1>>>0,n=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,n^=n>>>16,n=Math.imul(n,668265261),n^=n>>>15,n=Math.imul(n,374761393),n^=n>>>16,(r&2097151)*4294967296+(n>>>0)};var vo=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",qe=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&&(B.has(n)||"get"in o||"set"in o||(t[n]=o.value));}),t},Ce=(e,t=new WeakMap)=>{if(e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let s=new Map;return t.set(e,s),e.forEach((i,u)=>{s.set(Ce(u,t),Ce(i,t));}),s}if(e instanceof Set){let s=new Set;return t.set(e,s),e.forEach(i=>{s.add(Ce(i,t));}),s}if(Array.isArray(e)){let s=[];return t.set(e,s),e.forEach((i,u)=>{s[u]=Ce(i,t);}),s}let r=globalThis?.WeakRef;if(r&&e instanceof r)return J("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 J("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(o).forEach(([s,i])=>{!i.enumerable||B.has(s)||"get"in i||"set"in i||(n[s]=Ce(i.value,t));}),n},D=e=>{try{if(vo)return structuredClone(e)}catch{}return Ce(e)};var _r=10,xo=5,ko=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},Me=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?ko(e):[String(e)],Ke=e=>{let t=Me(e),r=t.length;return r>_r?(O(Fr(r,_r,t)),false):(r>xo&&f(Ar(r,t)),true)},zt=(e,t,r)=>{let n=Me(t);if(n.length===0)return e;for(let s of n)if(B.has(s))return T(`Blocked forbidden path segment "${String(s)}" in setStore path "${n.join(".")}".`),e;let o=(s,i)=>{let u=n[i],l=i===n.length-1;if(Array.isArray(s)){let g=Number(u);if(!Number.isInteger(g))return s;let p=[...s];return l?(p[g]=r,p):(p[g]=o(p[g],i+1),p)}if(s&&typeof s=="object"){if(B.has(u))return T(`Blocked unsafe path segment "${String(u)}" while setting "${n.join(".")}".`),s;let g={...s};return l?(g[u]=r,g):(g[u]=o(g[u],i+1),g)}if(s==null&&!l){let g=Number.isInteger(Number(u)),p=g?[]:{};if(g){let d=p,c=Number(u);return d[c]=o(void 0,i+1),d}return p[u]=o(void 0,i+1),p}return l?r:s};return o(e,0)};var Ir=new Set;var lt=(()=>{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"}})(),Ht=e=>{try{return typeof window>"u"?lt:e==="session"||e==="sessionStorage"?window.sessionStorage??lt:window.localStorage??lt}catch{return lt}},dt=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Ee=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),zr=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}},Ro=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Wr=e=>{try{e[Ro]=!0;}catch{}return e},Co={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"},Mo=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Wr(p=>p),decrypt:Wr(p=>p),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Ht("localStorage"),...r};if(typeof e=="string")return {driver:Ht(e),...r};let n=e.encrypt||r.encrypt,o=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,u=e.sensitiveData===true,l=e.allowPlaintext===true,g=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(u&&zr(n)&&!s)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`);return {driver:e.driver||e.storage||Ht("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:n,decrypt:o,encryptAsync:s,decryptAsync:i,allowPlaintext:l,sensitiveData:u,checksum:g,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Hr=e=>{if(!dt(e))return [];let t=[];return Object.entries(Co).forEach(([r,n])=>{Ee(e,r)&&(Ir.has(r)||(Ir.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},Br=(e={},t)=>{let r=e.scope??"request",n=e.lazy===true,o=e.pathCreate===true,s=dt(e.lifecycle)?e.lifecycle:void 0,i=dt(e.persist)?e.persist:void 0,u=dt(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,g=e.snapshot==="shallow"||e.snapshot==="ref"?e.snapshot:"deep",p=Ee(e,"persist"),d=Ee(e,"sync"),c=Ee(e,"devtools")||Ee(e,"historyLimit")||Ee(e,"redactor"),S=r==="global"?true:e.allowSSRGlobalStore??false,{persist:b=false,devtools:a=false,onError:m,sync:k}=e;if(i?.sensitiveData===true){let h=i.encrypt,v=i.encryptAsync;if((!h||zr(h))&&!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:o,persist:r==="temp"&&!p?null:Mo(b,t),devtools:r==="temp"&&!c?false:typeof a=="boolean"?a:u?.enabled??true,middleware:s?.middleware??e.middleware??[],onSet:s?.onSet??e.onSet,onReset:s?.onReset??e.onReset,onDelete:s?.onDelete??e.onDelete,onCreate:s?.onCreate??e.onCreate,onError:m,validate:l,migrations:i?.migrations??e.migrations??{},version:i?.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"&&!d?false:k??false,allowSSRGlobalStore:S,snapshot:g,explicitPersist:p,explicitSync:d,explicitDevtools:c}};var Lr=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 qr=()=>({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}}),Bt=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 Kr=new Map,Eo=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,qt=e=>(Eo||e).replace(/\.ts(\?|$)/,".js$1"),ge=qt(new URL("./store.js",(typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('async.cjs', document.baseURI).href))).href);var Ao=()=>({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:qr()}),Ue=e=>{let t=qt(e),r=Kr.get(t);if(r)return r;let n=Ao();return Kr.set(t,n),n},Fe=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),Ur=(e,t)=>e.deletingStores.has(t);var Kt=()=>null;var Yr=(e,t)=>t(),Se=e=>e||Ue(ge);var Ut=new Map;var ft=e=>Ut.has(e),Yt=e=>Ut.get(e),Ye=()=>Array.from(Ut.keys());var pt=Symbol("stroid.middleware.abort"),Xr=({name:e,payload:t,middlewares:r,reportIssue:n,warn:o})=>{if(!Array.isArray(r)||r.length===0)return t.next;let s=new WeakSet,i=D(t.next);for(let u of r){if(typeof u!="function")continue;let l,g=i;try{l=u({action:t.action,name:e,prev:t.prev,next:g,path:t.path});}catch(p){let d=`Middleware for "${e}" failed: ${p?.message??p}`;return n(d,"dev"),pt}if(l&&typeof l.then=="function"){let p=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(p,"dev"),pt}l===void 0?(R()&&!s.has(u)&&(s.add(u),o(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=g):i=l;}return i},gt=({name:e,label:t,fn:r,args:n,reportIssue:o})=>{if(typeof r=="function")try{r(...n);}catch(s){let i=`${t} for "${e}" failed: ${s?.message??s}`;o(i,"always");}};var ye=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(o?.(e),r==="critical"){n==="dev"&&f(e),T(e);return}if(n==="always"){J(e);return}f(e);};var Jr=()=>Se(Ue(ge)),Qr=()=>Jr().computedEntries,Oo=()=>Jr().computedDependents;var Zr=e=>Object.prototype.hasOwnProperty.call(Qr(),e);var en=e=>{let t=Qr(),r=Oo(),n=new Set,o=[...e];for(;o.length>0;){let p=o.shift(),d=r[p];if(d)for(let c of d)n.has(c)||(n.add(c),o.push(c));}if(n.size===0)return [];let s=p=>{let d=t[p];if(d)for(let c of d.deps)t[c]&&(n.has(c)||(n.add(c),s(c)));};Array.from(n).forEach(p=>s(p));let i=new Map,u=new Map;for(let p of n){let d=t[p];if(!d)continue;let c=0;for(let S of d.deps)n.has(S)&&(c++,u.has(S)||u.set(S,[]),u.get(S).push(p));i.set(p,c);}let l=[];for(let[p,d]of i)d===0&&l.push(p);l.sort();let g=[];for(;l.length>0;){let p=l.shift();g.push(p);let d=u.get(p)??[];for(let c of d){let S=(i.get(c)??1)-1;if(i.set(c,S),S===0){let b=l.findIndex(a=>a>c);b===-1?l.push(c):l.splice(b,0,c);}}}return g};function St(e,t){let r=ee(e);if(!yt(r)||!Ge(r))return null;let n=he(r);return n===null||typeof n!="object"?n:D(n);}var Q=e=>z(e);var Xe=e=>(e??Se()).transaction,Vo=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var E=()=>Xe().depth>0,$=(e,t)=>{let r=Xe(t);r.failed=true,r.error||(r.error=Vo(e));},ht=e=>{let t=Se();Xe(t).pending.push(()=>Yr(t,e));},mt=(e,t)=>{Xe().stagedValues.set(e,t);},Ae=e=>{let t=Xe();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var De=new Set,Je=[],Xt=false,rn=e=>{let t=w[e]?.options?.snapshot??C().defaultSnapshotMode;return t==="shallow"||t==="ref"?t:"deep"},nn=(e,t)=>t==="ref"?e:t==="shallow"?qe(e):D(e);var Gt=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},No=()=>{Je.length=0;for(let d of De)Je.push(d);De.clear();let e=C().flush,t=e.priorityStores||[],r=new Set(Je),n=t.length?new Set(t):null,o=[];if(n){for(let d of t)r.has(d)&&o.push(d);for(let d of Je)n.has(d)||o.push(d);}else o.push(...Je);let s=en(o),i=new Set(o);for(let d of s)r.has(d)&&!i.has(d)&&(o.push(d),i.add(d));let u=Number.isFinite(e.chunkSize)&&e.chunkSize>0?e.chunkSize:Number.POSITIVE_INFINITY,l=e.chunkDelayMs,g=u===Number.POSITIVE_INFINITY&&l===0;return {names:o.slice(),sliceSize:u,chunkDelayMs:l,runInline:g,prioritySet:n}},on=()=>{let{names:e,sliceSize:t,chunkDelayMs:r,runInline:n,prioritySet:o}=No(),s=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),i=()=>{Xt=false,De.size>0&&sn();};if(n){for(let c of e){let S=_[c];if(!S||S.size===0)continue;let b=w[c]?.updateCount??0,a=rn(c),m=Pe[c],k=m&&m.version===b?m.snapshot:(()=>{let y=nn(N[c],a);return Pe[c]={version:b,snapshot:y},y})(),h=s();for(let y of S)try{y(k);}catch(F){f(`Subscriber for "${c}" threw: ${F?.message??F}`);}let v=s()-h,M=w[c]?.metrics||{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0};M.notifyCount+=1,M.totalNotifyMs+=v,M.lastNotifyMs=v,w[c]&&(w[c].metrics=M),(w[c]?.updateCount??b)!==b&&De.add(c);}i();return}let u=c=>{let S=[];for(let b of e){if(c&&!c(b))continue;let a=_[b];if(!a||a.size===0)continue;let m=w[b]?.updateCount??0,k=rn(b),h=Pe[b],v=h&&h.version===m?h.snapshot:(()=>{let M=nn(N[b],k);return Pe[b]={version:m,snapshot:M},M})();S.push({name:b,subsArray:Array.from(a),index:0,snapshot:v,version:m,notified:new Set,metrics:w[b]?.metrics?{...w[b].metrics}:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},totalMs:0});}return S},l=o?u(c=>o.has(c)):[],g=u(c=>!o||!o.has(c)),p=c=>{let S=_[c.name];if(!S||S.size===0){c.subsArray=[],c.index=0;return}c.subsArray=Array.from(S),c.index=0;},d=(c,S)=>{let b=()=>{if(c.length===0){S();return}let a=c.shift();if((w[a.name]?.updateCount??a.version)!==a.version){if(De.add(a.name),c.length===0){S();return}n?b():Gt(b,r);return}if(p(a),a.subsArray.length===0){if(c.length===0){S();return}n?b():Gt(b,r);return}let k=s(),h=0;for(;a.index<a.subsArray.length&&h<t;){let x=a.subsArray[a.index++];if(!a.notified.has(x)){a.notified.add(x);try{x(a.snapshot);}catch(y){f(`Subscriber for "${a.name}" threw: ${y?.message??y}`);}h+=1;}}a.totalMs+=s()-k;let v=_[a.name],M=v?Array.from(v).some(x=>!a.notified.has(x)):false;if(a.index<a.subsArray.length||M?c.push(a):(a.metrics.notifyCount+=1,a.metrics.totalNotifyMs+=a.totalMs,a.metrics.lastNotifyMs=a.totalMs,w[a.name]&&(w[a.name].metrics=a.metrics)),c.length===0){S();return}n?b():Gt(b,r);};b();};l.length>0?d(l,()=>d(g,i)):d(g,i);},sn=()=>{Xt||(Xt=true,typeof queueMicrotask=="function"?queueMicrotask(on):Promise.resolve().then(on));},me=e=>{De.add(e),sn();};var jo=(e,t)=>(_[e]||(_[e]=new Set),_[e].add(t),()=>{_[e]?.delete(t),_[e]?.size===0&&delete _[e];});var an=jo;var $o=()=>W().computedCleanups;var cn=e=>{let t=$o(),r=t.get(e);if(!r){R()&&f(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var un=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,u=e.featureRuntimes,l=e.deletingStores,g=(a,m)=>{ye(m,{onError:s[a]?.options?.onError,severity:"warn",visibility:"dev"});},p=({name:a,prev:m,options:k,initialState:h,getMeta:v,getStoreValue:M,hasStore:x})=>({name:a,options:k,prev:m,getMeta:v,getStoreValue:M,getAllStores:()=>t,getInitialState:()=>h,hasStore:x,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:y=>{ye(y,{onError:k.onError,severity:"warn",visibility:"dev"});},warn:f,log:H,hashState:Le,deepClone:D,sanitize:fe,validate:()=>({ok:true,value:m}),isDev:R}),d=({name:a,prev:m,options:k,initialState:h,phase:v})=>{let M=p({name:a,prev:m,options:k,initialState:h,getMeta:()=>s[a],getStoreValue:()=>t[a],hasStore:()=>Fe(e,a)}),x=p({name:a,prev:m,options:k,initialState:h,getMeta:()=>{},getStoreValue:()=>m,hasStore:()=>false});Ye().forEach(y=>{let F=u.get(y);v==="before"?F?.beforeStoreDelete?.(M):F?.afterStoreDelete?.(x);});},c=a=>{if(!Fe(e,a))return;let m=t[a],k=s[a].options,h=n[a],v=r[a];l.add(a);try{v?.forEach(y=>{try{y(null);}catch(F){f(`Subscriber for "${a}" threw during delete: ${F?.message??F}`);}}),gt({name:a,label:"onDelete",fn:k.onDelete,args:[m],reportIssue:(y,F)=>{ye(y,{onError:k.onError,severity:"warn",visibility:F});}}),d({name:a,prev:m,options:k,initialState:h,phase:"before"}),delete t[a],delete r[a],delete n[a],delete o[a],delete s[a],delete i[a],Zr(a)&&cn(a);let x=e.computedDependents[a];if(x)for(let y of x)f(`[stroid] source store "${a}" was deleted. Computed store "${y}" depends on it and will return stale data. Call deleteComputed("${y}") to clean up.`);d({name:a,prev:m,options:k,initialState:h,phase:"after"}),H(`Store "${a}" deleted`);}finally{l.delete(a);}};return {deleteExistingStore:c,clearAllStores:()=>{let a=[],k=0,h=Number.POSITIVE_INFINITY;for(;k<20;){let M=Object.keys(t);if(M.length===0)break;M.forEach(y=>{Fe(e,y)&&(c(y),a.push(y));}),k+=1;let x=Object.keys(t).length;if(x===0||x>=h)break;h=x;}let v=Object.keys(t).length;return v>0?f(`clearAllStores stopped after ${k} pass${k===1?"":"es"}; ${v} store(s) still registered (likely recreated during deletion).`):f(`All stores cleared (${a.length} stores removed)`),a},clearStores:a=>{let m=Object.keys(t).filter(k=>a?a.endsWith("*")?k.startsWith(a.slice(0,-1)):k===a:true);return m.forEach(k=>c(k)),m},reportStoreError:g}};var _o=ge,Io=Ue(_o),fn=null,ln=new WeakSet,Wo=e=>{ln.has(e)||(ln.add(e),Ye().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Yt(t);r&&e.featureRuntimes.set(t,r());}}));},L=()=>{let e=Se(Io);return Wo(e),e};var W=()=>L(),pn=e=>{fn=e;},Oe=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,n)=>(e()[r]=n,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let n=Object.getOwnPropertyDescriptor(e(),r);if(n)return {...n,configurable:true}}}),zo=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)}),Ho=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)}),N=Oe(()=>L().stores),_=Oe(()=>L().subscribers),Z=Oe(()=>L().initialStates),be=Oe(()=>L().initialFactories),w=Oe(()=>L().metaEntries),Pe=Oe(()=>L().snapshotCache),te=zo(()=>L().featureRuntimes),dn=new WeakMap,Bo=e=>{let t=dn.get(e);return t||(t=un(e),dn.set(e,t)),t};Ho(()=>Bo(L()));var Sn=e=>{let t=te.get(e);if(t)return t;let r=Yt(e);if(!r)return;let n=r();return te.set(e,n),n},Lo=()=>{Ye().forEach(e=>{Sn(e);});};Lo();var z=e=>Fe(L(),e),he=e=>{if(E()){let r=Ae(e);if(r.has)return r.value}let t=Kt();return t&&Object.prototype.hasOwnProperty.call(t,e)?t[e]:N[e]},q=(e,t)=>{let n=R()?Lr(t):t;N[e]=n;},Jt=(e,t,r=Date.now())=>{q(e,t),w[e]&&(w[e].updatedAt=new Date(r).toISOString(),w[e].updatedAtMs=r,w[e].updateCount++,fn?.(e));};var yn=e=>Ur(L(),e);var Qt=new Set,Zt=e=>e?Qt.has(e):Qt.size>0,er=e=>{e&&Qt.add(e);};var hn=new Set,mn=e=>{let t=wr();return !t||e.includes("::")?e:(R()&&!hn.has(e)&&(hn.add(e),f(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},ee=e=>mn(typeof e=="string"?e:e.name),yt=e=>z(e)&&!yn(e)?true:(Tt(e,Object.keys(N)),false),bn=(e,t,r={})=>{ye(t,{...r,onError:w[e]?.options?.onError});},wn=(e,t,r={})=>{ye(e,{...r,onError:t});},Ve=(e,t,r="dev")=>{bn(e,t,{severity:"warn",visibility:r});},vn=(e,t,r="dev")=>{wn(e,t,{severity:"warn",visibility:r});},re=(e,t)=>bn(e,t,{severity:"critical",visibility:"always"}),Te=(e,t)=>wn(e,t,{severity:"critical",visibility:"always"}),Qe=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
13
+ Import "stroid/${t}" before calling createStore("${e}", ...).`;if(vn(n,r,"always"),C().strictMissingFeatures)throw new Error(n)};var xn=new WeakMap,kn=new WeakMap,qo=500,Ko="",bt=e=>{let t=xn.get(e);return t||(t=new Map,xn.set(e,t)),t},Cn=e=>{let t=kn.get(e);return t||(t=new Map,kn.set(e,t)),t},Uo=(e,t)=>{let r=Cn(e),n=r.get(t);return n||(n=new Map,r.set(t,n)),n},Rn=(e,t,r)=>{for(e.has(t)&&e.delete(t),e.set(t,r);e.size>qo;){let n=e.keys().next().value;if(!n)break;let o=e.get(n);e.delete(n),o?.node.verdicts&&(o.node.verdicts.delete(o.type),o.node.verdicts.size===0&&delete o.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=bt(W());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)=>(bt(W())[t]=r,true)});var tr=(e,t,r,n)=>{let o=w[e];if(!o)return {ok:true};let s=Me(r);if(s.length===0)return {ok:true};let i=ae(n),u=W(),l=bt(u),g=Uo(u,e),p=s.join(Ko),d=l.get(e);d||(d={children:new Map},l.set(e,d));let c=d;for(let h of s){let v=c.children.get(h);v||(v={children:new Map},c.children.set(h,v)),c=v;}let S=c.verdicts?.get(i);if(S){let h=`${p}|${i}`;return Rn(g,h,{node:c,type:i}),S}let b=o.options?.pathCreate===true,a=t,m={ok:true};for(let h=0;h<s.length;h++){let v=s[h],M=h===s.length-1;if(a==null){let y=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,h).join(".")||"root"}" is ${a===null?"null":"undefined"}.`;T(y),m={ok:false,reason:y};break}if(typeof a!="object"){let y=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,h).join(".")||"root"}" is not an object.`;T(y),m={ok:false,reason:y};break}if(Array.isArray(a)){let y=Number(v);if(!Number.isInteger(y)||y<0){let j=`Path "${s.join(".")}" targets non-numeric index "${v}" on an array in "${e}".`;T(j),m={ok:false,reason:j};break}let F=a;if(y>=F.length){let j=`Path "${s.join(".")}" is invalid for "${e}" - index ${y} is out of bounds (length ${F.length}).`;T(j),m={ok:false,reason:j};break}if(M){let j=F[y];if(j!=null){let Ie=ae(j);if(Ie!==i){let st=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${Ie}, received ${i}.`;T(st),m={ok:false,reason:st};break}}m={ok:true};break}a=F[y];continue}if(!Object.prototype.hasOwnProperty.call(a,v)){if(b&&M){m={ok:true};break}let y=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${v}" at "${s.slice(0,h).join(".")||"root"}".`;T(y),m={ok:false,reason:y};break}if(M){let y=a[v];if(y!=null){let F=ae(y);if(F!==i){let j=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${F}, received ${i}.`;T(j),m={ok:false,reason:j};break}}m={ok:true};break}a=a[v];}c.verdicts||(c.verdicts=new Map);let k=c.verdicts.has(i);if(c.verdicts.set(i,m),!k){let h=`${p}|${i}`;Rn(g,h,{node:c,type:i});}return m},we=(e,t,r,n)=>{try{return n?.reuseInput&&$t(t)?{ok:!0,value:t}:{ok:!0,value:fe(t)}}catch(o){let s=`Sanitize failed for "${e}": ${o?.message??o}`;return w[e]?.options?.onError?.(s),r?.(s),f(s),{ok:false}}},Go=(e,t)=>{let r=new Set,n=w[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},wt=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let o=Go(e,n),s=(u,l)=>{o.forEach(g=>g(u)),l==="critical"?T(u):f(u);};if(typeof r=="function")try{let u=r(t);return u===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:u===!0?t:u}}catch(u){return s(`Validation for "${e}" failed: ${u?.message??u}`,"critical"),{ok:false}}let i=jt(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Ze=(e,t,r,n,o)=>{let s=we(e,t,n,o);if(!s.ok)return {ok:false};let i=wt(e,s.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},Y=e=>{let t=W();bt(t).delete(e),Cn(t).delete(e);};pn(Y);var Ge=e=>{if((E()?Ae(e):{has:false}).has||N[e]!==void 0)return true;let r=be[e];if(!r)return true;try{let n=r(),o=we(e,n,w[e]?.options?.onError);if(!o.ok)return !1;let s=w[e]?.options?.validate,i=Ze(e,o.value,s,w[e]?.options?.onError);if(!i.ok)return !1;if(E()){let u=i.value;mt(e,u),ht(()=>{q(e,u),Z[e]=D(u),delete be[e],Y(e);});}else q(e,i.value),Z[e]=D(i.value),delete be[e],Y(e);return !0}catch(n){return re(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var Mn=new WeakMap,Xo=e=>{let t=Mn.get(e);return t||(t=new Map,Mn.set(e,t)),t};var rr=e=>{let t=W(),r=Xo(t),n=r.get(e);if(n)return n;let o=w[e];if(!o)return f(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:o.options,getMeta:()=>w[e],getStoreValue:()=>N[e],getAllStores:()=>N,getInitialState:()=>Z[e],hasStore:()=>z(e),setStoreValue:i=>{q(e,i);},applyFeatureState:(i,u)=>{Jt(e,i,u),Y(e);},notify:()=>{},reportStoreError:i=>{re(e,i);},warn:f,log:H,hashState:Le,deepClone:D,sanitize:fe,validate:i=>wt(e,i,w[e]?.options?.validate),isDev:R};return r.set(e,s),s},nr=(e,t)=>{let r=rr(e);r&&(r.notify=()=>t(e),te.forEach(n=>{n.onStoreCreate?.(r);}));},vt=(e,t,r,n,o)=>{let s=rr(e);if(!s)return;s.notify=()=>o(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:n});te.forEach(u=>{u.onStoreWrite?.(i);});};var or=(e,t)=>Xr({name:e,payload:t,middlewares:(()=>{let r=w[e]?.options?.middleware||[],n=C().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{Ve(e,r,n);},warn:f}),et=(e,t,r,n)=>gt({name:e,label:t,fn:r,args:n,reportIssue:(o,s)=>{Ve(e,o,s);}}),sr=(e,t)=>{let r={...t};return r.persist&&!ft("persist")&&(r.explicitPersist&&Qe(e,"persist",r.onError),r.persist=null),r.sync&&!ft("sync")&&(r.explicitSync&&Qe(e,"sync",r.onError),r.sync=false),ft("devtools")||(r.explicitDevtools&&Qe(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var rs=32,En=new Set,ns=(e,t)=>{R()&&(t<rs||En.has(e)||(En.add(e),f(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},ir=(e,t,r={})=>{if(E()){let a=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;Te(a,r.onError),$(a);return}if(!_t(e)){Te(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Be(t)){Te(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&R()&&f(`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.`),Hr(r).forEach(a=>{f(a);});let o=sr(e,Br(r,e));if(o.scope==="temp"&&r.persist){let a=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;o.onError?.(a),R()||J(a),O(a);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,u=s&&i==="production",l=o.allowSSRGlobalStore??false;if(u&&!l){let a=`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.`;Te(a,r.onError);return}if(z(e)){let a=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return Ve(e,a),{name:e}}s&&!l&&!Zt(e)&&R()&&(er(e),f(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let g=we(e,t,o.onError);if(!g.ok)return;let p=g.value,d=o.lazy===true&&typeof t=="function",c=(_[e]?.size??0)>0;if(d)N[e]=void 0,be[e]=t;else {let a=Ze(e,p,o.validate,o.onError);if(!a.ok)return;q(e,a.value),Z[e]=D(a.value);}let S=Date.now(),b=new Date(S).toISOString();return w[e]={createdAt:b,updatedAt:b,updatedAtMs:S,updateCount:0,version:o.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},options:o},Y(e),nr(e,me),et(e,"onCreate",w[e].options.onCreate,[p]),c&&me(e),H(`Store "${e}" created -> ${JSON.stringify(p)}`),{name:e}};function xt(e,t,r){let n=ee(e);if(!Ge(n))return {ok:false,reason:"validate"};if(!z(n)){let c=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return re(n,c),E()&&$(c),{ok:false,reason:"not-found"}}let o,s=E()?Ae(n):{has:false,value:void 0},i=s.has?s.value:he(n),u=typeof t=="function"&&r===void 0;if(u){let c=R()?Date.now():0;try{let S=C().mutatorProduce,b=!1,a,m=h=>{let v=t(h);return v!==void 0&&(b=!0,a=v),v},k=S?S(i,m):(()=>{let h=D(i);return m(h),h})();if(b&&C().strictMutatorReturns){let h=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return re(n,h),E()&&$(h),{ok:!1,reason:"validate"}}b&&R()&&!C().strictMutatorReturns&&f(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),o=b&&!C().strictMutatorReturns?a:k;}catch(S){return re(n,`Mutator for "${n}" failed: ${S?.message??S}`),E()&&$(S),{ok:false,reason:"validate"}}finally{c&&ns(n,Date.now()-c);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!Be(t))return E()&&$(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof i!="object"||i===null||Array.isArray(i))return O(`setStore("${n}", data) only merges into object stores.
15
+ Use setStore("${n}", "path", value) or recreate the store with an object shape.`),E()&&$(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let c=we(n,t);if(!c.ok)return E()&&$(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};o={...i,...c.value};}else if(typeof t=="string"||Array.isArray(t)){if(!Ke(t))return E()&&$(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let c=we(n,r);if(!c.ok)return E()&&$(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let S=c.value,b=tr(n,i,t,S);if(!b.ok)return w[n]?.options?.onError?.(b.reason??`Invalid path for "${n}".`),E()&&$(b.reason),{ok:false,reason:"path"};o=zt(i,t,S);}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 O(c),w[n]?.options?.onError?.(c),E()&&$(c),{ok:false,reason:"invalid-args"}}if(!Be(o))return E()&&$(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let l=w[n]?.options?.validate,g=or(n,{action:"set",prev:i,next:o,path:t});if(g===pt)return E()&&$(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let d=Ze(n,g,l,void 0,u&&g===o?{reuseInput:true}:void 0);if(!d.ok)return E()&&$(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};if(E()){let c=d.value,S=i;mt(n,c),ht(()=>{q(n,c),Y(n);let b=Date.now();w[n].updatedAt=new Date(b).toISOString(),w[n].updatedAtMs=b,w[n].updateCount++,vt(n,"set",S,c,me),et(n,"onSet",w[n].options.onSet,[S,c]),me(n),H(`Store "${n}" updated`);});}else {q(n,d.value),Y(n);let c=Date.now();w[n].updatedAt=new Date(c).toISOString(),w[n].updatedAtMs=c,w[n].updateCount++,vt(n,"set",i,d.value,me),et(n,"onSet",w[n].options.onSet,[i,d.value]),me(n);}return E()||H(`Store "${n}" updated`),{ok:true}}var Fn=100,ar=100,os=1e3,V=()=>W().async,oe=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,n)=>(e()[r]=n,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let n=Object.getOwnPropertyDescriptor(e(),r);if(n)return {...n,configurable:true}}}),je=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),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}}}),le=oe(()=>V().fetchRegistry),ue=oe(()=>V().inflight),ne=oe(()=>V().requestVersion),K=oe(()=>V().cacheMeta),tt=oe(()=>V().rateWindowStart),Ne=oe(()=>V().rateCount);je(()=>V().ratePruneState);var kt=oe(()=>V().cleanupSubs),ve=oe(()=>V().storeCleanupFns),Rt=oe(()=>V().revalidateHandlers),Ct=je(()=>V().noSignalWarned),Mt=je(()=>V().shapeWarned),Et=je(()=>V().autoCreateWarned),Ft=je(()=>V().revalidateKeys),I=je(()=>V().asyncMetrics),At=(e,t)=>{if(e.has(t)||(e.add(t),e.size<=os))return;let r=e.values().next().value;r!==void 0&&e.delete(r);},An=()=>{Bt(V());},Pn=(e,t)=>{if(!t)return false;let r=K[e];return r?r.expiresAt!==null&&r.expiresAt<=Date.now()?(delete K[e],false):Date.now()-r.timestamp<t:false},ss=e=>{delete le[e],Ct.delete(e),Mt.delete(e),Et.delete(e);let t=r=>r===e||r.startsWith(`${e}:`);Object.keys(ue).forEach(r=>{t(r)&&delete ue[r];}),Object.keys(ne).forEach(r=>{t(r)&&delete ne[r];}),Object.keys(K).forEach(r=>{t(r)&&delete K[r];}),Object.keys(tt).forEach(r=>{t(r)&&delete tt[r];}),Object.keys(Ne).forEach(r=>{t(r)&&delete Ne[r];});},Dn=e=>{let t=`${e}:`,r=Object.entries(K).filter(([o,s])=>o!==e&&!o.startsWith(t)?false:s.expiresAt!==null&&s.expiresAt<=Date.now()?(delete K[o],false):true).sort((o,s)=>o[1].timestamp-s[1].timestamp);if(r.length<=Fn)return;let n=r.length-Fn;r.slice(0,n).forEach(([o])=>{delete K[o],delete ne[o];});},On=e=>{let t=`${e}:`,r=0;return Object.keys(ue).forEach(n=>{(n===e||n.startsWith(t))&&(r+=1);}),r},cr=(e,t)=>{ve[e]||(ve[e]=new Set),ve[e].add(t),lr(e);},ur=(e,t)=>{let r=ve[e];r&&(r.delete(t),r.size===0&&delete ve[e]);},lr=e=>{kt[e]||(kt[e]=an(e,t=>{if(t!==null)return;let r=ve[e];r&&(r.forEach(n=>{try{n();}catch{}}),delete ve[e]),kt[e]?.(),delete kt[e],ss(e);}));};var Vn=10,is=10,dr=3e4,as=8,Nn=(e,t)=>new Promise(r=>{if(t?.aborted){r();return}let n=setTimeout(()=>{t?.removeEventListener("abort",o),r();},e),o=()=>{clearTimeout(n),t?.removeEventListener("abort",o),r();};t?.addEventListener("abort",o,{once:true});}),Tn=(e,t,r,n)=>Number.isFinite(r)?r:(f(`fetchStore("${e}") received non-finite ${t}; using ${n}.`),n),jn=(e,t,r,n)=>{let o=Number.isFinite(t)?t:t>0?Vn:0,s=Math.min(Vn,Math.max(0,Math.trunc(o)));Number.isFinite(t)||f(`fetchStore("${e}") received non-finite retry; using ${s}.`);let i=Math.min(dr,Math.max(is,Tn(e,"retryDelay",r,400))),u=Math.min(as,Math.max(1,Tn(e,"retryBackoff",n,1.7)));return s!==t&&f(`fetchStore("${e}") clamped retry attempts to ${s}.`),i!==r&&f(`fetchStore("${e}") clamped retryDelay to ${i}ms.`),u!==n&&f(`fetchStore("${e}") clamped retryBackoff to ${u}.`),{retry:s,retryDelay:i,retryBackoff:u}};var $n=(e,t)=>!t||t==="none"||e===null||typeof e!="object"?e:t==="shallow"?qe(e):D(e);var rt=(e,t,r,n)=>{if(typeof r=="function")try{r(n);}catch(o){f(`fetchStore("${e}") ${t} callback failed: ${o?.message??o}`);}},U=(e,t,r)=>(rt(e,"onError",r,t),R()?(O(t),null):(T(t),null));var Pt=(e,t)=>(ne[e]??0)===t,_n=e=>{let t=(ne[e]??0)+1;return ne[e]=t,t},In=(e,t)=>{ne[e]===t&&delete ne[e];},Wn=(e,t)=>{ue[e]=t;},zn=e=>{delete ue[e];},Hn=e=>!!ue[e],Bn=(e,t,r,n)=>{let o=ue[t];if(o)return I.dedupes+=1,r&&o.transform&&o.transform!==r?(U(e,`fetchStore("${e}") cannot dedupe callers that use different transform functions for cacheSlot "${t}".`,n),null):!r||o.transform===r?o.promise:o.raw.then(s=>r(s))};var $e=1e3,fr=100,Ln=(e,t)=>{t-e.ratePruneState.lastAt<$e||(e.ratePruneState.lastAt=t,Object.keys(e.rateWindowStart).forEach(r=>{t-(e.rateWindowStart[r]??0)>$e&&(delete e.rateWindowStart[r],delete e.rateCount[r]);}));},qn=e=>{Ln(V(),e);},Kn=(e=$e)=>{let t=V();t.ratePruneTimer||typeof setTimeout=="function"&&(t.ratePruneTimer=setTimeout(()=>{t.ratePruneTimer=null,Ln(t,Date.now());},e));},Un=(e,t)=>{let r=tt[e],n=Ne[e]??0;return r!==void 0&&t-r<$e?n>=fr?true:(Ne[e]=n+1,false):(tt[e]=t,Ne[e]=1,false)};var Yn=e=>{let t={};return e.method&&(t.method=e.method.toUpperCase()),e.headers?t.headers=e.headers:t.headers={"Content-Type":"application/json"},e.body&&(t.body=typeof e.body=="string"?e.body:JSON.stringify(e.body)),e.signal&&(t.signal=e.signal),t},Gn=async(e,t)=>{let r=t??"auto";if(r==="json")return e.json();if(r==="text")return e.text();if(r==="arrayBuffer")return e.arrayBuffer();if(r==="blob")return e.blob();if(r==="formData")return e.formData();let n=e.headers.get("content-type")||"";return n.includes("application/json")||n.includes("+json")?e.json():n.startsWith("text/")||n.includes("xml")||n.includes("html")?e.text():n.includes("form-data")?e.formData():e.arrayBuffer()};var nt=[],cs=e=>{if(!e||typeof e!="object")return false;let t=e;return "data"in t&&"loading"in t&&"error"in t&&"status"in t},us=(e,t,r,n)=>{if(Q(e)){if(n.stateAdapter){try{let o=St({name:e}),s=i=>{xt(t,i);};n.stateAdapter({name:e,prev:o,next:r,set:s});}catch(o){f(`fetchStore("${e}") stateAdapter failed: ${o?.message??o}`);}return}xt(t,r);}},_e=(e,t,r,n)=>(f(`fetchStore("${e}") aborted`),Pt(t,r)&&Q(e)&&n({loading:false,error:"aborted",status:"aborted",revalidating:false}),null);async function ot(e,t,r={}){let n=ee(e);if(!n||typeof n!="string"){O("fetchStore requires a store name as first argument");return}let o={name:n};if(!t){O(`fetchStore("${n}") requires a URL, Promise, or Promise factory as second argument`);return}let{transform:s,onSuccess:i,onError:u,stateAdapter:l,method:g,headers:p,body:d,ttl:c,staleWhileRevalidate:S=false,dedupe:b=true,retry:a=0,retryDelay:m=400,retryBackoff:k=1.7,signal:h,cacheKey:v,responseType:M="auto"}=r;!h&&R()&&!Ct.has(n)&&(At(Ct,n),f(`fetchStore("${n}") called without an AbortSignal. Provide "signal" to enable cancellation (recommended).`));let x=v?`${n}:${v}`:n,y=P=>us(n,o,P,r),F=typeof t!="string"&&typeof t!="function"&&typeof t?.then=="function",j=jn(n,a,m,k),Ie=false,st=F&&a>0,Jn=typeof window>"u"&&(typeof process<"u"?process.env?.NODE_ENV:void 0)==="production",Qn=r.autoCreate??C().asyncAutoCreate,Zn=r.cloneResult??C().asyncCloneResult;if(l&&!Q(n))return U(n,`fetchStore("${n}") with stateAdapter requires an existing backing store.
21
+ Call createStore("${n}", ...) first or omit stateAdapter to use the default AsyncState shape.`,u);if(!Q(n)&&Jn)return U(n,`fetchStore("${n}") cannot create a backing store on the server in production.
22
+ Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,u);if(!Q(n)){if(!Qn)return U(n,`fetchStore("${n}") requires an existing backing store when autoCreate is disabled.
23
+ Call createStore("${n}", ...) first or enable autoCreate.`,u);if(R()&&!Et.has(n)){At(Et,n);let P=`fetchStore("${n}") auto-created its backing store.
24
+ Call createStore("${n}", ...) first to avoid typos creating phantom stores.`;u?.(P),f(P);}if(ir(n,{data:null,loading:false,error:null,status:"idle"}),!Q(n))return U(n,`fetchStore("${n}") could not initialize its backing store.
25
+ On the server in production, use createStoreForRequest(...) inside the request scope or create the store with { allowSSRGlobalStore: true } before calling fetchStore.`,u)}if(!l){let P=St({name:n});if(P&&!cs(P))return Mt.has(n)||At(Mt,n),U(n,`fetchStore("${n}") cannot write AsyncState into an existing non-async store. Provide a stateAdapter or create the store with the async shape to avoid overwriting fields.`,u)}lr(n);let Dt=null,xe=false,Ot=()=>K[x]?.data??null;if(Pn(x,c)){if(I.cacheHits+=1,Dt=Ot(),y({data:Dt,loading:S,error:null,status:"success",cached:true,revalidating:S}),!S)return Dt;xe=true;}else I.cacheMisses+=1;if(b){let P=Bn(n,x,s,u);if(P!==void 0)return P}let pr=Date.now();if(qn(pr),Kn(),Un(x,pr))return U(n,`fetchStore("${n}") rate limited: ${fr} requests per ${$e}ms window for cacheSlot "${x}".`,u);if(!Hn(x)&&On(n)>=ar)return U(n,`fetchStore("${n}") exceeded ${ar} concurrent request slots. Reuse cacheKey values, wait for pending requests, or delete the store to clear async state.`,u);let G=_n(x);xe||y({loading:true,error:null,status:"loading",cached:false,revalidating:false}),I.requests+=1;let eo=Date.now(),it=!h&&typeof AbortController<"u"?new AbortController:null,de=h||it?.signal,at=it?()=>{it.signal.aborted||it.abort();}:null;at&&cr(n,at);let to=async()=>{let P=0,X=j.retryDelay;for(;;){if(de?.aborted)return _e(n,x,G,y);let ke=typeof t=="function"?t():t,yr=F||typeof ke!="string"&&typeof ke?.then=="function",hr=yr?{...j,retry:0}:j;yr&&(a>0||st)&&!Ie&&(f(`fetchStore("${n}") ignores retry settings for direct Promise inputs; pass a URL string or factory to use retries.`),Ie=true);try{let se;if(typeof ke=="string"){let oo=Yn({method:g,headers:p,body:d,signal:de,...r}),ut=await fetch(ke,oo);if(!ut.ok)throw new Error(`HTTP ${ut.status}: ${ut.statusText}`);se=await Gn(ut,M);}else if(typeof ke.then=="function")se=await ke;else return O(`fetchStore("${n}") - second argument must be a URL string, Promise, or Promise factory.
26
+ Examples:
27
+ fetchStore("users", "https://api.example.com/users")
28
+ fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(de?.aborted)return _e(n,x,G,y);let ct=s?s(se):se;if(ct&&typeof ct.then=="function")return U(n,`fetchStore("${n}") transform must be synchronous. Return the transformed value directly instead of a Promise.`,u);let ie=$n(ct,Zn);if(de?.aborted)return _e(n,x,G,y);if(!Pt(x,G))return null;K[x]={timestamp:Date.now(),expiresAt:c?Date.now()+c:null,data:ie},Dn(n),y({data:ie,loading:!1,error:null,status:"success",cached:!1,revalidating:!1}),rt(n,"onSuccess",i,ie);let mr=Date.now()-eo;return I.lastMs=mr,I.avgMs=(I.avgMs*(I.requests-1)+mr)/I.requests,{raw:se,transformed:ie}}catch(se){if(P+=1,se?.name==="AbortError")return _e(n,x,G,y);if(P<=hr.retry){if(de?.aborted||(await Nn(X,de),de?.aborted))return _e(n,x,G,y);X=Math.min(dr,X*hr.retryBackoff);continue}if(!Pt(x,G))return null;let ie=se?.message||"Something went wrong";return y({data:xe?Ot():null,loading:false,error:ie,status:"error",cached:xe,revalidating:false}),rt(n,"onError",u,ie),I.failures+=1,f(`fetchStore("${n}") failed: ${ie}`),null}}},We=null,ro=new Promise((P,X)=>{h||(We=setTimeout(()=>{We=null,X(new Error("Timeout: async request hung for 60 seconds without an AbortSignal"));},6e4));}),gr=Promise.race([to().finally(()=>{We&&(clearTimeout(We),We=null);}),ro]).catch(P=>{let X=P?.message||"Request timed out";return y({data:xe?Ot():null,loading:false,error:X,status:"error",cached:xe,revalidating:false}),rt(n,"onError",u,X),I.failures+=1,f(`fetchStore("${n}") failed: ${X}`),null}),Sr=gr.then(P=>P?.transformed??null).finally(()=>{zn(x),In(x,G),at&&ur(n,at);}),no=gr.then(P=>P?.raw);return Wn(x,{promise:Sr,raw:no,transform:s}),typeof t=="function"?le[n]={kind:"factory",factory:t,options:{...r,cacheKey:v}}:typeof t=="string"?le[n]={kind:"url",url:t,options:{...r,cacheKey:v}}:delete le[n],Sr}async function Xn(e){let t=ee(e);if(!Q(t))return;let r=le[t];if(!r){let o=`${t}:`,s=Object.entries(K).filter(([i])=>i===t||i.startsWith(o));if(s.length>0){let[,i]=s.reduce((u,l)=>l[1].timestamp>=u[1].timestamp?l:u);return i.data}R()&&f(`refetchStore("${t}") - no previous fetch found.
29
+ Call fetchStore("${t}", url) first.`);return}let n={name:t};return r.kind==="factory"?ot(n,r.factory,r.options):ot(n,r.url,r.options)}function ls(e,t){if(typeof window>"u"||typeof window.addEventListener!="function")return ()=>{};let n=(e==="*"?"*":e?ee(e):void 0)??"*";if(Ft.has(n))return Rt[n]??(()=>{});let o=C().revalidateOnFocus,s=Math.max(0,t?.debounceMs??o.debounceMs),i=Math.max(1,t?.maxConcurrent??o.maxConcurrent),u=Math.max(0,t?.staggerMs??o.staggerMs),l=null,g=()=>{let c=n==="*"?Object.keys(le):[n];if(t?.priority==="high"&&n!=="*"&&(c=[n,...c.filter(a=>a!==n)]),c.length===0)return;let S=0,b=()=>{let a=c.slice(S,S+i);if(a.forEach((m,k)=>{let h=()=>{let v=le[m];if(!v){Xn({name:m});return}v.kind==="factory"?ot({name:m},v.factory,v.options):ot({name:m},v.url,v.options);};u>0?setTimeout(h,k*u):h();}),S+=a.length,S<c.length){let m=u>0?u*Math.max(1,a.length):0;setTimeout(b,m);}};b();},p=()=>{if(s===0){g();return}l!==null&&clearTimeout(l),l=setTimeout(g,s);};window.addEventListener("focus",p),window.addEventListener("online",p),Ft.add(n);let d=()=>{if(window.removeEventListener("focus",p),window.removeEventListener("online",p),l!==null&&(clearTimeout(l),l=null),Ft.delete(n),delete Rt[n],n!=="*")ur(n,d);else {let c=nt.indexOf(d);c!==-1&&nt.splice(c,1);}};return Rt[n]=d,n!=="*"?cr(n,d):nt.push(d),d}var ds=()=>({...I}),fs=()=>{ps(),An();},ps=()=>{nt.forEach(e=>e()),nt.length=0;};exports._resetAsyncStateForTests=fs;exports.enableRevalidateOnFocus=ls;exports.fetchStore=ot;exports.getAsyncMetrics=ds;exports.refetchStore=Xn;
@@ -0,0 +1,40 @@
1
+ import { F as FetchOptions, a as FetchInput } from './async-cache-DFHwcBQL.cjs';
2
+ export { A as AsyncStateAdapter, b as AsyncStateSnapshot } from './async-cache-DFHwcBQL.cjs';
3
+ import { a as StoreDefinition, c as StoreKey, S as StoreName } from './types-grvlY4BX.cjs';
4
+
5
+ declare function fetchStore<Name extends string, State>(name: StoreDefinition<Name, State>, urlOrRequest: FetchInput, options?: FetchOptions): Promise<unknown>;
6
+ declare function fetchStore<Name extends string, State>(name: StoreKey<Name, State>, urlOrRequest: FetchInput, options?: FetchOptions): Promise<unknown>;
7
+ declare function fetchStore<Name extends StoreName>(name: Name, urlOrRequest: FetchInput, options?: FetchOptions): Promise<unknown>;
8
+ declare function refetchStore<Name extends string, State>(name: StoreDefinition<Name, State>): Promise<unknown>;
9
+ declare function refetchStore<Name extends string, State>(name: StoreKey<Name, State>): Promise<unknown>;
10
+ declare function refetchStore<Name extends StoreName>(name: Name): Promise<unknown>;
11
+ declare function enableRevalidateOnFocus<Name extends string, State>(name: StoreDefinition<Name, State>, overrides?: Partial<FetchOptions> & {
12
+ debounceMs?: number;
13
+ maxConcurrent?: number;
14
+ staggerMs?: number;
15
+ priority?: "high" | "normal";
16
+ }): (() => void);
17
+ declare function enableRevalidateOnFocus<Name extends string, State>(name: StoreKey<Name, State>, overrides?: Partial<FetchOptions> & {
18
+ debounceMs?: number;
19
+ maxConcurrent?: number;
20
+ staggerMs?: number;
21
+ priority?: "high" | "normal";
22
+ }): (() => void);
23
+ declare function enableRevalidateOnFocus<Name extends StoreName>(name?: Name | "*", overrides?: Partial<FetchOptions> & {
24
+ debounceMs?: number;
25
+ maxConcurrent?: number;
26
+ staggerMs?: number;
27
+ priority?: "high" | "normal";
28
+ }): (() => void);
29
+ declare const getAsyncMetrics: () => {
30
+ cacheHits: number;
31
+ cacheMisses: number;
32
+ dedupes: number;
33
+ requests: number;
34
+ failures: number;
35
+ avgMs: number;
36
+ lastMs: number;
37
+ };
38
+ declare const _resetAsyncStateForTests: () => void;
39
+
40
+ export { FetchInput, FetchOptions, _resetAsyncStateForTests, enableRevalidateOnFocus, fetchStore, getAsyncMetrics, refetchStore };
package/dist/async.d.ts CHANGED
@@ -1,22 +1,31 @@
1
- interface FetchOptions {
2
- transform?: (result: unknown) => unknown;
3
- onSuccess?: (data: unknown) => void;
4
- onError?: (message: string) => void;
5
- method?: string;
6
- headers?: Record<string, string>;
7
- body?: unknown;
8
- ttl?: number;
9
- staleWhileRevalidate?: boolean;
10
- dedupe?: boolean;
11
- retry?: number;
12
- retryDelay?: number;
13
- retryBackoff?: number;
14
- signal?: AbortSignal;
15
- cacheKey?: string;
16
- }
17
- declare const fetchStore: (name: string, urlOrPromise: string | Promise<unknown>, options?: FetchOptions) => Promise<unknown>;
18
- declare const refetchStore: (name: string) => Promise<unknown>;
19
- declare const enableRevalidateOnFocus: (name?: string) => (() => void);
1
+ import { F as FetchOptions, a as FetchInput } from './async-cache-DFHwcBQL.js';
2
+ export { A as AsyncStateAdapter, b as AsyncStateSnapshot } from './async-cache-DFHwcBQL.js';
3
+ import { a as StoreDefinition, c as StoreKey, S as StoreName } from './types-grvlY4BX.js';
4
+
5
+ declare function fetchStore<Name extends string, State>(name: StoreDefinition<Name, State>, urlOrRequest: FetchInput, options?: FetchOptions): Promise<unknown>;
6
+ declare function fetchStore<Name extends string, State>(name: StoreKey<Name, State>, urlOrRequest: FetchInput, options?: FetchOptions): Promise<unknown>;
7
+ declare function fetchStore<Name extends StoreName>(name: Name, urlOrRequest: FetchInput, options?: FetchOptions): Promise<unknown>;
8
+ declare function refetchStore<Name extends string, State>(name: StoreDefinition<Name, State>): Promise<unknown>;
9
+ declare function refetchStore<Name extends string, State>(name: StoreKey<Name, State>): Promise<unknown>;
10
+ declare function refetchStore<Name extends StoreName>(name: Name): Promise<unknown>;
11
+ declare function enableRevalidateOnFocus<Name extends string, State>(name: StoreDefinition<Name, State>, overrides?: Partial<FetchOptions> & {
12
+ debounceMs?: number;
13
+ maxConcurrent?: number;
14
+ staggerMs?: number;
15
+ priority?: "high" | "normal";
16
+ }): (() => void);
17
+ declare function enableRevalidateOnFocus<Name extends string, State>(name: StoreKey<Name, State>, overrides?: Partial<FetchOptions> & {
18
+ debounceMs?: number;
19
+ maxConcurrent?: number;
20
+ staggerMs?: number;
21
+ priority?: "high" | "normal";
22
+ }): (() => void);
23
+ declare function enableRevalidateOnFocus<Name extends StoreName>(name?: Name | "*", overrides?: Partial<FetchOptions> & {
24
+ debounceMs?: number;
25
+ maxConcurrent?: number;
26
+ staggerMs?: number;
27
+ priority?: "high" | "normal";
28
+ }): (() => void);
20
29
  declare const getAsyncMetrics: () => {
21
30
  cacheHits: number;
22
31
  cacheMisses: number;
@@ -26,5 +35,6 @@ declare const getAsyncMetrics: () => {
26
35
  avgMs: number;
27
36
  lastMs: number;
28
37
  };
38
+ declare const _resetAsyncStateForTests: () => void;
29
39
 
30
- export { type FetchOptions, enableRevalidateOnFocus, fetchStore, getAsyncMetrics, refetchStore };
40
+ export { FetchInput, FetchOptions, _resetAsyncStateForTests, enableRevalidateOnFocus, fetchStore, getAsyncMetrics, refetchStore };
package/dist/async.js CHANGED
@@ -1 +1,29 @@
1
- export{c as enableRevalidateOnFocus,a as fetchStore,d as getAsyncMetrics,b as refetchStore}from'./chunk-3CAQKMKY.js';import'./chunk-VNLWP332.js';
1
+ var so={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}`));}},io={logSink:so,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},br={...io},C=()=>br;var wr=()=>br.namespace;var ao=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,co=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,vr=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,uo="production",lo=ao??co??uo,ze=typeof vr=="boolean"?vr:lo!=="production",R=()=>ze,Vt=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},fo=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},po=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},T=(e,t)=>{if((C().logSink.critical??fo)(e,t),C().assertRuntime)throw new Error(e)},f=(e,t)=>{if(!ze)return;if((C().logSink.warn??Vt)(e,t),C().assertRuntime)throw new Error(e)},J=(e,t)=>{if((C().logSink.warn??Vt)(e,t),C().assertRuntime)throw new Error(e)},O=(e,t)=>{if(ze&&(C().logSink.warn??Vt)(e,t),T(e,t),C().assertRuntime)throw new Error(e)},H=(e,t)=>{if(!ze)return;(C().logSink.log??po)(e,t);},xr=()=>`Functions cannot be stored in stroid.
2
+ Store data only - handle functions outside the store.`,kr=()=>`Map/Set detected. stroid converts these to plain objects.
3
+ Use arrays or plain objects for best results.`,Rr=()=>`Date object detected. stroid stores it as ISO string.
4
+ Use new Date(value) to convert back when reading.`,Cr=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Mr=()=>"Map detected; converting to plain object.",Er=()=>"Set detected; converting to array.",Fr=(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]}", ...)`,Ar=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
8
+ Consider splitting into separate stores for better readability.`,Or=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Vr=e=>`Store name "${e}" contains spaces.
9
+ Use camelCase or kebab-case: "userName" or "user-name"`,Tr=e=>`Store name "${e}" is not allowed.
10
+ Reserved names: "__proto__", "constructor", "prototype".`,go=128,So=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=go,yo=(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},(o,s)=>s),n=new Array(e.length+1);for(let o=1;o<=t.length;o++){n[0]=o;for(let s=1;s<=e.length;s++)n[s]=t[o-1]===e[s-1]?r[s-1]:Math.min(r[s-1],n[s-1],r[s])+1;[r,n]=[n,r];}return r[e.length]},Tt=(e,t)=>{let r=t.find(n=>{let o=n.toLowerCase(),s=e.toLowerCase();return o.includes(s)||s.includes(o)||So(o,s)&&yo(o,s)<=2});if(r){f(`Store "${e}" not found. Did you mean "${r}"?`);return}O(`Store "${e}" not found.
11
+ Available stores: [${t.join(", ")}]
12
+ Call createStore("${e}", data) first.`);};var B=new Set(["__proto__","constructor","prototype"]),jt=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let o=r.error,s=o?.details?.[0]?.message||o?.message||r.message||e.errors;if(s)return {ok:!1,error:s};if(o)return {ok:!1,error:o}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var 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,Nr=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},Be=e=>{let t=ae(e);return t==="function"?(O(xr()),false):t==="map"||t==="set"?(f(kr()),true):(t==="date"&&f(Rr()),true)},Nt=(e,t)=>{let r=Nr(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 o=Object.keys(e);for(let s of o){let i=Number(s);if(!Number.isInteger(i))return false}for(let s=0;s<e.length;s+=1)if(s in e&&!Nt(e[s],t))return false;return true}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");if(t.add(e),Object.getOwnPropertySymbols(e).length>0)return false;let o=Object.getOwnPropertyDescriptors(e);for(let[s,i]of Object.entries(o)){if(!i.enumerable||B.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Nt(i.value,t))return false}return true}return true},$t=e=>Nt(e,new WeakSet),He=(e,t)=>{let r=Nr(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 R()&&f(Cr()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),R()&&f(Mr());let o={};for(let[s,i]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");o[String(s)]=He(i,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),R()&&f(Er()),Array.from(e,o=>He(o,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let o={},s=Object.getOwnPropertyDescriptors(e);for(let[i,u]of Object.entries(s))if(u.enumerable&&!B.has(i)){if("get"in u||"set"in u)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);o[i]=He(u.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=>He(o,t))}return e},fe=e=>He(e,new WeakSet),_t=e=>typeof e!="string"||e.trim()===""?(O(Or(e)),false):B.has(e)?(O(Tr(e)),false):e.includes(" ")?(O(Vr(e)),false):true;var It=null,ho=()=>{if(It)return It;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 It=t,t},$r=e=>{let t=ho(),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},mo=2166136261,bo=2654435761,wo=1e5,ce=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},pe=(e,t)=>{ce(e,t.length);for(let r=0;r<t.length;r++)ce(e,t.charCodeAt(r));},A=(e,t)=>{pe(e,t);},jr=(e,t)=>{if(Number.isNaN(t)){A(e,"NaN");return}if(!Number.isFinite(t)){A(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){A(e,"-0");return}let r=t|0;if(t===r){A(e,"int"),ce(e,r);return}A(e,"num"),pe(e,String(t));},Re=(e,t)=>{if(e.nodes++>wo){A(e,"[max]");return}if(t===null){A(e,"null");return}let r=typeof t;if(r==="string"){A(e,"string"),pe(e,t);return}if(r==="number"){A(e,"number"),jr(e,t);return}if(r==="boolean"){A(e,t?"true":"false");return}if(r==="undefined"){A(e,"undefined");return}if(r==="bigint"){A(e,"bigint"),pe(e,t.toString());return}if(r==="symbol"){A(e,"symbol");let l=t;pe(e,Symbol.keyFor(l)??l.description??String(l));return}if(r==="function"){A(e,"function"),pe(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){A(e,"ref"),ce(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){A(e,"array"),ce(e,n.length);for(let l=0;l<n.length;l++)Object.prototype.hasOwnProperty.call(n,l)?Re(e,n[l]):A(e,"hole");return}if(n instanceof Date){A(e,"date"),jr(e,n.getTime());return}if(n instanceof Map){A(e,"map"),ce(e,n.size),n.forEach((l,g)=>{Re(e,g),Re(e,l);});return}if(n instanceof Set){A(e,"set"),ce(e,n.size),n.forEach(l=>{Re(e,l);});return}A(e,"object");let i=Object.getOwnPropertyDescriptors(n),u=[];Object.entries(i).forEach(([l,g])=>{g?.enumerable&&(B.has(l)||"get"in g||"set"in g||u.push([l,g]));}),ce(e,u.length);for(let[l,g]of u)pe(e,l),Re(e,g.value);},Le=e=>{if(typeof e=="string")return $r(JSON.stringify(e));let t={h1:mo,h2:bo,seen:new WeakMap,nextId:1,nodes:0};Re(t,e);let r=t.h1>>>0,n=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,n^=n>>>16,n=Math.imul(n,668265261),n^=n>>>15,n=Math.imul(n,374761393),n^=n>>>16,(r&2097151)*4294967296+(n>>>0)};var vo=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",qe=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&&(B.has(n)||"get"in o||"set"in o||(t[n]=o.value));}),t},Ce=(e,t=new WeakMap)=>{if(e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let s=new Map;return t.set(e,s),e.forEach((i,u)=>{s.set(Ce(u,t),Ce(i,t));}),s}if(e instanceof Set){let s=new Set;return t.set(e,s),e.forEach(i=>{s.add(Ce(i,t));}),s}if(Array.isArray(e)){let s=[];return t.set(e,s),e.forEach((i,u)=>{s[u]=Ce(i,t);}),s}let r=globalThis?.WeakRef;if(r&&e instanceof r)return J("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 J("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(o).forEach(([s,i])=>{!i.enumerable||B.has(s)||"get"in i||"set"in i||(n[s]=Ce(i.value,t));}),n},D=e=>{try{if(vo)return structuredClone(e)}catch{}return Ce(e)};var _r=10,xo=5,ko=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},Me=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?ko(e):[String(e)],Ke=e=>{let t=Me(e),r=t.length;return r>_r?(O(Fr(r,_r,t)),false):(r>xo&&f(Ar(r,t)),true)},zt=(e,t,r)=>{let n=Me(t);if(n.length===0)return e;for(let s of n)if(B.has(s))return T(`Blocked forbidden path segment "${String(s)}" in setStore path "${n.join(".")}".`),e;let o=(s,i)=>{let u=n[i],l=i===n.length-1;if(Array.isArray(s)){let g=Number(u);if(!Number.isInteger(g))return s;let p=[...s];return l?(p[g]=r,p):(p[g]=o(p[g],i+1),p)}if(s&&typeof s=="object"){if(B.has(u))return T(`Blocked unsafe path segment "${String(u)}" while setting "${n.join(".")}".`),s;let g={...s};return l?(g[u]=r,g):(g[u]=o(g[u],i+1),g)}if(s==null&&!l){let g=Number.isInteger(Number(u)),p=g?[]:{};if(g){let d=p,c=Number(u);return d[c]=o(void 0,i+1),d}return p[u]=o(void 0,i+1),p}return l?r:s};return o(e,0)};var Ir=new Set;var lt=(()=>{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"}})(),Ht=e=>{try{return typeof window>"u"?lt:e==="session"||e==="sessionStorage"?window.sessionStorage??lt:window.localStorage??lt}catch{return lt}},dt=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Ee=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),zr=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}},Ro=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Wr=e=>{try{e[Ro]=!0;}catch{}return e},Co={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"},Mo=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Wr(p=>p),decrypt:Wr(p=>p),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Ht("localStorage"),...r};if(typeof e=="string")return {driver:Ht(e),...r};let n=e.encrypt||r.encrypt,o=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,u=e.sensitiveData===true,l=e.allowPlaintext===true,g=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(u&&zr(n)&&!s)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`);return {driver:e.driver||e.storage||Ht("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:n,decrypt:o,encryptAsync:s,decryptAsync:i,allowPlaintext:l,sensitiveData:u,checksum:g,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Hr=e=>{if(!dt(e))return [];let t=[];return Object.entries(Co).forEach(([r,n])=>{Ee(e,r)&&(Ir.has(r)||(Ir.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},Br=(e={},t)=>{let r=e.scope??"request",n=e.lazy===true,o=e.pathCreate===true,s=dt(e.lifecycle)?e.lifecycle:void 0,i=dt(e.persist)?e.persist:void 0,u=dt(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,g=e.snapshot==="shallow"||e.snapshot==="ref"?e.snapshot:"deep",p=Ee(e,"persist"),d=Ee(e,"sync"),c=Ee(e,"devtools")||Ee(e,"historyLimit")||Ee(e,"redactor"),S=r==="global"?true:e.allowSSRGlobalStore??false,{persist:b=false,devtools:a=false,onError:m,sync:k}=e;if(i?.sensitiveData===true){let h=i.encrypt,v=i.encryptAsync;if((!h||zr(h))&&!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:o,persist:r==="temp"&&!p?null:Mo(b,t),devtools:r==="temp"&&!c?false:typeof a=="boolean"?a:u?.enabled??true,middleware:s?.middleware??e.middleware??[],onSet:s?.onSet??e.onSet,onReset:s?.onReset??e.onReset,onDelete:s?.onDelete??e.onDelete,onCreate:s?.onCreate??e.onCreate,onError:m,validate:l,migrations:i?.migrations??e.migrations??{},version:i?.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"&&!d?false:k??false,allowSSRGlobalStore:S,snapshot:g,explicitPersist:p,explicitSync:d,explicitDevtools:c}};var Lr=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 qr=()=>({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}}),Bt=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 Kr=new Map,Eo=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,qt=e=>(Eo||e).replace(/\.ts(\?|$)/,".js$1"),ge=qt(new URL("./store.js",import.meta.url).href);var Ao=()=>({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:qr()}),Ue=e=>{let t=qt(e),r=Kr.get(t);if(r)return r;let n=Ao();return Kr.set(t,n),n},Fe=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),Ur=(e,t)=>e.deletingStores.has(t);var Kt=()=>null;var Yr=(e,t)=>t(),Se=e=>e||Ue(ge);var Ut=new Map;var ft=e=>Ut.has(e),Yt=e=>Ut.get(e),Ye=()=>Array.from(Ut.keys());var pt=Symbol("stroid.middleware.abort"),Xr=({name:e,payload:t,middlewares:r,reportIssue:n,warn:o})=>{if(!Array.isArray(r)||r.length===0)return t.next;let s=new WeakSet,i=D(t.next);for(let u of r){if(typeof u!="function")continue;let l,g=i;try{l=u({action:t.action,name:e,prev:t.prev,next:g,path:t.path});}catch(p){let d=`Middleware for "${e}" failed: ${p?.message??p}`;return n(d,"dev"),pt}if(l&&typeof l.then=="function"){let p=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(p,"dev"),pt}l===void 0?(R()&&!s.has(u)&&(s.add(u),o(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=g):i=l;}return i},gt=({name:e,label:t,fn:r,args:n,reportIssue:o})=>{if(typeof r=="function")try{r(...n);}catch(s){let i=`${t} for "${e}" failed: ${s?.message??s}`;o(i,"always");}};var ye=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(o?.(e),r==="critical"){n==="dev"&&f(e),T(e);return}if(n==="always"){J(e);return}f(e);};var Jr=()=>Se(Ue(ge)),Qr=()=>Jr().computedEntries,Oo=()=>Jr().computedDependents;var Zr=e=>Object.prototype.hasOwnProperty.call(Qr(),e);var en=e=>{let t=Qr(),r=Oo(),n=new Set,o=[...e];for(;o.length>0;){let p=o.shift(),d=r[p];if(d)for(let c of d)n.has(c)||(n.add(c),o.push(c));}if(n.size===0)return [];let s=p=>{let d=t[p];if(d)for(let c of d.deps)t[c]&&(n.has(c)||(n.add(c),s(c)));};Array.from(n).forEach(p=>s(p));let i=new Map,u=new Map;for(let p of n){let d=t[p];if(!d)continue;let c=0;for(let S of d.deps)n.has(S)&&(c++,u.has(S)||u.set(S,[]),u.get(S).push(p));i.set(p,c);}let l=[];for(let[p,d]of i)d===0&&l.push(p);l.sort();let g=[];for(;l.length>0;){let p=l.shift();g.push(p);let d=u.get(p)??[];for(let c of d){let S=(i.get(c)??1)-1;if(i.set(c,S),S===0){let b=l.findIndex(a=>a>c);b===-1?l.push(c):l.splice(b,0,c);}}}return g};function St(e,t){let r=ee(e);if(!yt(r)||!Ge(r))return null;let n=he(r);return n===null||typeof n!="object"?n:D(n);}var Q=e=>z(e);var Xe=e=>(e??Se()).transaction,Vo=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var E=()=>Xe().depth>0,$=(e,t)=>{let r=Xe(t);r.failed=true,r.error||(r.error=Vo(e));},ht=e=>{let t=Se();Xe(t).pending.push(()=>Yr(t,e));},mt=(e,t)=>{Xe().stagedValues.set(e,t);},Ae=e=>{let t=Xe();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var De=new Set,Je=[],Xt=false,rn=e=>{let t=w[e]?.options?.snapshot??C().defaultSnapshotMode;return t==="shallow"||t==="ref"?t:"deep"},nn=(e,t)=>t==="ref"?e:t==="shallow"?qe(e):D(e);var Gt=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},No=()=>{Je.length=0;for(let d of De)Je.push(d);De.clear();let e=C().flush,t=e.priorityStores||[],r=new Set(Je),n=t.length?new Set(t):null,o=[];if(n){for(let d of t)r.has(d)&&o.push(d);for(let d of Je)n.has(d)||o.push(d);}else o.push(...Je);let s=en(o),i=new Set(o);for(let d of s)r.has(d)&&!i.has(d)&&(o.push(d),i.add(d));let u=Number.isFinite(e.chunkSize)&&e.chunkSize>0?e.chunkSize:Number.POSITIVE_INFINITY,l=e.chunkDelayMs,g=u===Number.POSITIVE_INFINITY&&l===0;return {names:o.slice(),sliceSize:u,chunkDelayMs:l,runInline:g,prioritySet:n}},on=()=>{let{names:e,sliceSize:t,chunkDelayMs:r,runInline:n,prioritySet:o}=No(),s=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),i=()=>{Xt=false,De.size>0&&sn();};if(n){for(let c of e){let S=_[c];if(!S||S.size===0)continue;let b=w[c]?.updateCount??0,a=rn(c),m=Pe[c],k=m&&m.version===b?m.snapshot:(()=>{let y=nn(N[c],a);return Pe[c]={version:b,snapshot:y},y})(),h=s();for(let y of S)try{y(k);}catch(F){f(`Subscriber for "${c}" threw: ${F?.message??F}`);}let v=s()-h,M=w[c]?.metrics||{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0};M.notifyCount+=1,M.totalNotifyMs+=v,M.lastNotifyMs=v,w[c]&&(w[c].metrics=M),(w[c]?.updateCount??b)!==b&&De.add(c);}i();return}let u=c=>{let S=[];for(let b of e){if(c&&!c(b))continue;let a=_[b];if(!a||a.size===0)continue;let m=w[b]?.updateCount??0,k=rn(b),h=Pe[b],v=h&&h.version===m?h.snapshot:(()=>{let M=nn(N[b],k);return Pe[b]={version:m,snapshot:M},M})();S.push({name:b,subsArray:Array.from(a),index:0,snapshot:v,version:m,notified:new Set,metrics:w[b]?.metrics?{...w[b].metrics}:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},totalMs:0});}return S},l=o?u(c=>o.has(c)):[],g=u(c=>!o||!o.has(c)),p=c=>{let S=_[c.name];if(!S||S.size===0){c.subsArray=[],c.index=0;return}c.subsArray=Array.from(S),c.index=0;},d=(c,S)=>{let b=()=>{if(c.length===0){S();return}let a=c.shift();if((w[a.name]?.updateCount??a.version)!==a.version){if(De.add(a.name),c.length===0){S();return}n?b():Gt(b,r);return}if(p(a),a.subsArray.length===0){if(c.length===0){S();return}n?b():Gt(b,r);return}let k=s(),h=0;for(;a.index<a.subsArray.length&&h<t;){let x=a.subsArray[a.index++];if(!a.notified.has(x)){a.notified.add(x);try{x(a.snapshot);}catch(y){f(`Subscriber for "${a.name}" threw: ${y?.message??y}`);}h+=1;}}a.totalMs+=s()-k;let v=_[a.name],M=v?Array.from(v).some(x=>!a.notified.has(x)):false;if(a.index<a.subsArray.length||M?c.push(a):(a.metrics.notifyCount+=1,a.metrics.totalNotifyMs+=a.totalMs,a.metrics.lastNotifyMs=a.totalMs,w[a.name]&&(w[a.name].metrics=a.metrics)),c.length===0){S();return}n?b():Gt(b,r);};b();};l.length>0?d(l,()=>d(g,i)):d(g,i);},sn=()=>{Xt||(Xt=true,typeof queueMicrotask=="function"?queueMicrotask(on):Promise.resolve().then(on));},me=e=>{De.add(e),sn();};var jo=(e,t)=>(_[e]||(_[e]=new Set),_[e].add(t),()=>{_[e]?.delete(t),_[e]?.size===0&&delete _[e];});var an=jo;var $o=()=>W().computedCleanups;var cn=e=>{let t=$o(),r=t.get(e);if(!r){R()&&f(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var un=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,u=e.featureRuntimes,l=e.deletingStores,g=(a,m)=>{ye(m,{onError:s[a]?.options?.onError,severity:"warn",visibility:"dev"});},p=({name:a,prev:m,options:k,initialState:h,getMeta:v,getStoreValue:M,hasStore:x})=>({name:a,options:k,prev:m,getMeta:v,getStoreValue:M,getAllStores:()=>t,getInitialState:()=>h,hasStore:x,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:y=>{ye(y,{onError:k.onError,severity:"warn",visibility:"dev"});},warn:f,log:H,hashState:Le,deepClone:D,sanitize:fe,validate:()=>({ok:true,value:m}),isDev:R}),d=({name:a,prev:m,options:k,initialState:h,phase:v})=>{let M=p({name:a,prev:m,options:k,initialState:h,getMeta:()=>s[a],getStoreValue:()=>t[a],hasStore:()=>Fe(e,a)}),x=p({name:a,prev:m,options:k,initialState:h,getMeta:()=>{},getStoreValue:()=>m,hasStore:()=>false});Ye().forEach(y=>{let F=u.get(y);v==="before"?F?.beforeStoreDelete?.(M):F?.afterStoreDelete?.(x);});},c=a=>{if(!Fe(e,a))return;let m=t[a],k=s[a].options,h=n[a],v=r[a];l.add(a);try{v?.forEach(y=>{try{y(null);}catch(F){f(`Subscriber for "${a}" threw during delete: ${F?.message??F}`);}}),gt({name:a,label:"onDelete",fn:k.onDelete,args:[m],reportIssue:(y,F)=>{ye(y,{onError:k.onError,severity:"warn",visibility:F});}}),d({name:a,prev:m,options:k,initialState:h,phase:"before"}),delete t[a],delete r[a],delete n[a],delete o[a],delete s[a],delete i[a],Zr(a)&&cn(a);let x=e.computedDependents[a];if(x)for(let y of x)f(`[stroid] source store "${a}" was deleted. Computed store "${y}" depends on it and will return stale data. Call deleteComputed("${y}") to clean up.`);d({name:a,prev:m,options:k,initialState:h,phase:"after"}),H(`Store "${a}" deleted`);}finally{l.delete(a);}};return {deleteExistingStore:c,clearAllStores:()=>{let a=[],k=0,h=Number.POSITIVE_INFINITY;for(;k<20;){let M=Object.keys(t);if(M.length===0)break;M.forEach(y=>{Fe(e,y)&&(c(y),a.push(y));}),k+=1;let x=Object.keys(t).length;if(x===0||x>=h)break;h=x;}let v=Object.keys(t).length;return v>0?f(`clearAllStores stopped after ${k} pass${k===1?"":"es"}; ${v} store(s) still registered (likely recreated during deletion).`):f(`All stores cleared (${a.length} stores removed)`),a},clearStores:a=>{let m=Object.keys(t).filter(k=>a?a.endsWith("*")?k.startsWith(a.slice(0,-1)):k===a:true);return m.forEach(k=>c(k)),m},reportStoreError:g}};var _o=ge,Io=Ue(_o),fn=null,ln=new WeakSet,Wo=e=>{ln.has(e)||(ln.add(e),Ye().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Yt(t);r&&e.featureRuntimes.set(t,r());}}));},L=()=>{let e=Se(Io);return Wo(e),e};var W=()=>L(),pn=e=>{fn=e;},Oe=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,n)=>(e()[r]=n,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let n=Object.getOwnPropertyDescriptor(e(),r);if(n)return {...n,configurable:true}}}),zo=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)}),Ho=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)}),N=Oe(()=>L().stores),_=Oe(()=>L().subscribers),Z=Oe(()=>L().initialStates),be=Oe(()=>L().initialFactories),w=Oe(()=>L().metaEntries),Pe=Oe(()=>L().snapshotCache),te=zo(()=>L().featureRuntimes),dn=new WeakMap,Bo=e=>{let t=dn.get(e);return t||(t=un(e),dn.set(e,t)),t};Ho(()=>Bo(L()));var Sn=e=>{let t=te.get(e);if(t)return t;let r=Yt(e);if(!r)return;let n=r();return te.set(e,n),n},Lo=()=>{Ye().forEach(e=>{Sn(e);});};Lo();var z=e=>Fe(L(),e),he=e=>{if(E()){let r=Ae(e);if(r.has)return r.value}let t=Kt();return t&&Object.prototype.hasOwnProperty.call(t,e)?t[e]:N[e]},q=(e,t)=>{let n=R()?Lr(t):t;N[e]=n;},Jt=(e,t,r=Date.now())=>{q(e,t),w[e]&&(w[e].updatedAt=new Date(r).toISOString(),w[e].updatedAtMs=r,w[e].updateCount++,fn?.(e));};var yn=e=>Ur(L(),e);var Qt=new Set,Zt=e=>e?Qt.has(e):Qt.size>0,er=e=>{e&&Qt.add(e);};var hn=new Set,mn=e=>{let t=wr();return !t||e.includes("::")?e:(R()&&!hn.has(e)&&(hn.add(e),f(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},ee=e=>mn(typeof e=="string"?e:e.name),yt=e=>z(e)&&!yn(e)?true:(Tt(e,Object.keys(N)),false),bn=(e,t,r={})=>{ye(t,{...r,onError:w[e]?.options?.onError});},wn=(e,t,r={})=>{ye(e,{...r,onError:t});},Ve=(e,t,r="dev")=>{bn(e,t,{severity:"warn",visibility:r});},vn=(e,t,r="dev")=>{wn(e,t,{severity:"warn",visibility:r});},re=(e,t)=>bn(e,t,{severity:"critical",visibility:"always"}),Te=(e,t)=>wn(e,t,{severity:"critical",visibility:"always"}),Qe=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
13
+ Import "stroid/${t}" before calling createStore("${e}", ...).`;if(vn(n,r,"always"),C().strictMissingFeatures)throw new Error(n)};var xn=new WeakMap,kn=new WeakMap,qo=500,Ko="",bt=e=>{let t=xn.get(e);return t||(t=new Map,xn.set(e,t)),t},Cn=e=>{let t=kn.get(e);return t||(t=new Map,kn.set(e,t)),t},Uo=(e,t)=>{let r=Cn(e),n=r.get(t);return n||(n=new Map,r.set(t,n)),n},Rn=(e,t,r)=>{for(e.has(t)&&e.delete(t),e.set(t,r);e.size>qo;){let n=e.keys().next().value;if(!n)break;let o=e.get(n);e.delete(n),o?.node.verdicts&&(o.node.verdicts.delete(o.type),o.node.verdicts.size===0&&delete o.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=bt(W());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)=>(bt(W())[t]=r,true)});var tr=(e,t,r,n)=>{let o=w[e];if(!o)return {ok:true};let s=Me(r);if(s.length===0)return {ok:true};let i=ae(n),u=W(),l=bt(u),g=Uo(u,e),p=s.join(Ko),d=l.get(e);d||(d={children:new Map},l.set(e,d));let c=d;for(let h of s){let v=c.children.get(h);v||(v={children:new Map},c.children.set(h,v)),c=v;}let S=c.verdicts?.get(i);if(S){let h=`${p}|${i}`;return Rn(g,h,{node:c,type:i}),S}let b=o.options?.pathCreate===true,a=t,m={ok:true};for(let h=0;h<s.length;h++){let v=s[h],M=h===s.length-1;if(a==null){let y=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,h).join(".")||"root"}" is ${a===null?"null":"undefined"}.`;T(y),m={ok:false,reason:y};break}if(typeof a!="object"){let y=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,h).join(".")||"root"}" is not an object.`;T(y),m={ok:false,reason:y};break}if(Array.isArray(a)){let y=Number(v);if(!Number.isInteger(y)||y<0){let j=`Path "${s.join(".")}" targets non-numeric index "${v}" on an array in "${e}".`;T(j),m={ok:false,reason:j};break}let F=a;if(y>=F.length){let j=`Path "${s.join(".")}" is invalid for "${e}" - index ${y} is out of bounds (length ${F.length}).`;T(j),m={ok:false,reason:j};break}if(M){let j=F[y];if(j!=null){let Ie=ae(j);if(Ie!==i){let st=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${Ie}, received ${i}.`;T(st),m={ok:false,reason:st};break}}m={ok:true};break}a=F[y];continue}if(!Object.prototype.hasOwnProperty.call(a,v)){if(b&&M){m={ok:true};break}let y=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${v}" at "${s.slice(0,h).join(".")||"root"}".`;T(y),m={ok:false,reason:y};break}if(M){let y=a[v];if(y!=null){let F=ae(y);if(F!==i){let j=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${F}, received ${i}.`;T(j),m={ok:false,reason:j};break}}m={ok:true};break}a=a[v];}c.verdicts||(c.verdicts=new Map);let k=c.verdicts.has(i);if(c.verdicts.set(i,m),!k){let h=`${p}|${i}`;Rn(g,h,{node:c,type:i});}return m},we=(e,t,r,n)=>{try{return n?.reuseInput&&$t(t)?{ok:!0,value:t}:{ok:!0,value:fe(t)}}catch(o){let s=`Sanitize failed for "${e}": ${o?.message??o}`;return w[e]?.options?.onError?.(s),r?.(s),f(s),{ok:false}}},Go=(e,t)=>{let r=new Set,n=w[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},wt=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let o=Go(e,n),s=(u,l)=>{o.forEach(g=>g(u)),l==="critical"?T(u):f(u);};if(typeof r=="function")try{let u=r(t);return u===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:u===!0?t:u}}catch(u){return s(`Validation for "${e}" failed: ${u?.message??u}`,"critical"),{ok:false}}let i=jt(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Ze=(e,t,r,n,o)=>{let s=we(e,t,n,o);if(!s.ok)return {ok:false};let i=wt(e,s.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},Y=e=>{let t=W();bt(t).delete(e),Cn(t).delete(e);};pn(Y);var Ge=e=>{if((E()?Ae(e):{has:false}).has||N[e]!==void 0)return true;let r=be[e];if(!r)return true;try{let n=r(),o=we(e,n,w[e]?.options?.onError);if(!o.ok)return !1;let s=w[e]?.options?.validate,i=Ze(e,o.value,s,w[e]?.options?.onError);if(!i.ok)return !1;if(E()){let u=i.value;mt(e,u),ht(()=>{q(e,u),Z[e]=D(u),delete be[e],Y(e);});}else q(e,i.value),Z[e]=D(i.value),delete be[e],Y(e);return !0}catch(n){return re(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var Mn=new WeakMap,Xo=e=>{let t=Mn.get(e);return t||(t=new Map,Mn.set(e,t)),t};var rr=e=>{let t=W(),r=Xo(t),n=r.get(e);if(n)return n;let o=w[e];if(!o)return f(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:o.options,getMeta:()=>w[e],getStoreValue:()=>N[e],getAllStores:()=>N,getInitialState:()=>Z[e],hasStore:()=>z(e),setStoreValue:i=>{q(e,i);},applyFeatureState:(i,u)=>{Jt(e,i,u),Y(e);},notify:()=>{},reportStoreError:i=>{re(e,i);},warn:f,log:H,hashState:Le,deepClone:D,sanitize:fe,validate:i=>wt(e,i,w[e]?.options?.validate),isDev:R};return r.set(e,s),s},nr=(e,t)=>{let r=rr(e);r&&(r.notify=()=>t(e),te.forEach(n=>{n.onStoreCreate?.(r);}));},vt=(e,t,r,n,o)=>{let s=rr(e);if(!s)return;s.notify=()=>o(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:n});te.forEach(u=>{u.onStoreWrite?.(i);});};var or=(e,t)=>Xr({name:e,payload:t,middlewares:(()=>{let r=w[e]?.options?.middleware||[],n=C().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{Ve(e,r,n);},warn:f}),et=(e,t,r,n)=>gt({name:e,label:t,fn:r,args:n,reportIssue:(o,s)=>{Ve(e,o,s);}}),sr=(e,t)=>{let r={...t};return r.persist&&!ft("persist")&&(r.explicitPersist&&Qe(e,"persist",r.onError),r.persist=null),r.sync&&!ft("sync")&&(r.explicitSync&&Qe(e,"sync",r.onError),r.sync=false),ft("devtools")||(r.explicitDevtools&&Qe(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var rs=32,En=new Set,ns=(e,t)=>{R()&&(t<rs||En.has(e)||(En.add(e),f(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},ir=(e,t,r={})=>{if(E()){let a=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;Te(a,r.onError),$(a);return}if(!_t(e)){Te(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Be(t)){Te(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&R()&&f(`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.`),Hr(r).forEach(a=>{f(a);});let o=sr(e,Br(r,e));if(o.scope==="temp"&&r.persist){let a=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;o.onError?.(a),R()||J(a),O(a);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,u=s&&i==="production",l=o.allowSSRGlobalStore??false;if(u&&!l){let a=`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.`;Te(a,r.onError);return}if(z(e)){let a=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return Ve(e,a),{name:e}}s&&!l&&!Zt(e)&&R()&&(er(e),f(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let g=we(e,t,o.onError);if(!g.ok)return;let p=g.value,d=o.lazy===true&&typeof t=="function",c=(_[e]?.size??0)>0;if(d)N[e]=void 0,be[e]=t;else {let a=Ze(e,p,o.validate,o.onError);if(!a.ok)return;q(e,a.value),Z[e]=D(a.value);}let S=Date.now(),b=new Date(S).toISOString();return w[e]={createdAt:b,updatedAt:b,updatedAtMs:S,updateCount:0,version:o.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0},options:o},Y(e),nr(e,me),et(e,"onCreate",w[e].options.onCreate,[p]),c&&me(e),H(`Store "${e}" created -> ${JSON.stringify(p)}`),{name:e}};function xt(e,t,r){let n=ee(e);if(!Ge(n))return {ok:false,reason:"validate"};if(!z(n)){let c=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return re(n,c),E()&&$(c),{ok:false,reason:"not-found"}}let o,s=E()?Ae(n):{has:false,value:void 0},i=s.has?s.value:he(n),u=typeof t=="function"&&r===void 0;if(u){let c=R()?Date.now():0;try{let S=C().mutatorProduce,b=!1,a,m=h=>{let v=t(h);return v!==void 0&&(b=!0,a=v),v},k=S?S(i,m):(()=>{let h=D(i);return m(h),h})();if(b&&C().strictMutatorReturns){let h=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return re(n,h),E()&&$(h),{ok:!1,reason:"validate"}}b&&R()&&!C().strictMutatorReturns&&f(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),o=b&&!C().strictMutatorReturns?a:k;}catch(S){return re(n,`Mutator for "${n}" failed: ${S?.message??S}`),E()&&$(S),{ok:false,reason:"validate"}}finally{c&&ns(n,Date.now()-c);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!Be(t))return E()&&$(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof i!="object"||i===null||Array.isArray(i))return O(`setStore("${n}", data) only merges into object stores.
15
+ Use setStore("${n}", "path", value) or recreate the store with an object shape.`),E()&&$(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let c=we(n,t);if(!c.ok)return E()&&$(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};o={...i,...c.value};}else if(typeof t=="string"||Array.isArray(t)){if(!Ke(t))return E()&&$(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let c=we(n,r);if(!c.ok)return E()&&$(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let S=c.value,b=tr(n,i,t,S);if(!b.ok)return w[n]?.options?.onError?.(b.reason??`Invalid path for "${n}".`),E()&&$(b.reason),{ok:false,reason:"path"};o=zt(i,t,S);}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 O(c),w[n]?.options?.onError?.(c),E()&&$(c),{ok:false,reason:"invalid-args"}}if(!Be(o))return E()&&$(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let l=w[n]?.options?.validate,g=or(n,{action:"set",prev:i,next:o,path:t});if(g===pt)return E()&&$(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let d=Ze(n,g,l,void 0,u&&g===o?{reuseInput:true}:void 0);if(!d.ok)return E()&&$(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};if(E()){let c=d.value,S=i;mt(n,c),ht(()=>{q(n,c),Y(n);let b=Date.now();w[n].updatedAt=new Date(b).toISOString(),w[n].updatedAtMs=b,w[n].updateCount++,vt(n,"set",S,c,me),et(n,"onSet",w[n].options.onSet,[S,c]),me(n),H(`Store "${n}" updated`);});}else {q(n,d.value),Y(n);let c=Date.now();w[n].updatedAt=new Date(c).toISOString(),w[n].updatedAtMs=c,w[n].updateCount++,vt(n,"set",i,d.value,me),et(n,"onSet",w[n].options.onSet,[i,d.value]),me(n);}return E()||H(`Store "${n}" updated`),{ok:true}}var Fn=100,ar=100,os=1e3,V=()=>W().async,oe=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,n)=>(e()[r]=n,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let n=Object.getOwnPropertyDescriptor(e(),r);if(n)return {...n,configurable:true}}}),je=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),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}}}),le=oe(()=>V().fetchRegistry),ue=oe(()=>V().inflight),ne=oe(()=>V().requestVersion),K=oe(()=>V().cacheMeta),tt=oe(()=>V().rateWindowStart),Ne=oe(()=>V().rateCount);je(()=>V().ratePruneState);var kt=oe(()=>V().cleanupSubs),ve=oe(()=>V().storeCleanupFns),Rt=oe(()=>V().revalidateHandlers),Ct=je(()=>V().noSignalWarned),Mt=je(()=>V().shapeWarned),Et=je(()=>V().autoCreateWarned),Ft=je(()=>V().revalidateKeys),I=je(()=>V().asyncMetrics),At=(e,t)=>{if(e.has(t)||(e.add(t),e.size<=os))return;let r=e.values().next().value;r!==void 0&&e.delete(r);},An=()=>{Bt(V());},Pn=(e,t)=>{if(!t)return false;let r=K[e];return r?r.expiresAt!==null&&r.expiresAt<=Date.now()?(delete K[e],false):Date.now()-r.timestamp<t:false},ss=e=>{delete le[e],Ct.delete(e),Mt.delete(e),Et.delete(e);let t=r=>r===e||r.startsWith(`${e}:`);Object.keys(ue).forEach(r=>{t(r)&&delete ue[r];}),Object.keys(ne).forEach(r=>{t(r)&&delete ne[r];}),Object.keys(K).forEach(r=>{t(r)&&delete K[r];}),Object.keys(tt).forEach(r=>{t(r)&&delete tt[r];}),Object.keys(Ne).forEach(r=>{t(r)&&delete Ne[r];});},Dn=e=>{let t=`${e}:`,r=Object.entries(K).filter(([o,s])=>o!==e&&!o.startsWith(t)?false:s.expiresAt!==null&&s.expiresAt<=Date.now()?(delete K[o],false):true).sort((o,s)=>o[1].timestamp-s[1].timestamp);if(r.length<=Fn)return;let n=r.length-Fn;r.slice(0,n).forEach(([o])=>{delete K[o],delete ne[o];});},On=e=>{let t=`${e}:`,r=0;return Object.keys(ue).forEach(n=>{(n===e||n.startsWith(t))&&(r+=1);}),r},cr=(e,t)=>{ve[e]||(ve[e]=new Set),ve[e].add(t),lr(e);},ur=(e,t)=>{let r=ve[e];r&&(r.delete(t),r.size===0&&delete ve[e]);},lr=e=>{kt[e]||(kt[e]=an(e,t=>{if(t!==null)return;let r=ve[e];r&&(r.forEach(n=>{try{n();}catch{}}),delete ve[e]),kt[e]?.(),delete kt[e],ss(e);}));};var Vn=10,is=10,dr=3e4,as=8,Nn=(e,t)=>new Promise(r=>{if(t?.aborted){r();return}let n=setTimeout(()=>{t?.removeEventListener("abort",o),r();},e),o=()=>{clearTimeout(n),t?.removeEventListener("abort",o),r();};t?.addEventListener("abort",o,{once:true});}),Tn=(e,t,r,n)=>Number.isFinite(r)?r:(f(`fetchStore("${e}") received non-finite ${t}; using ${n}.`),n),jn=(e,t,r,n)=>{let o=Number.isFinite(t)?t:t>0?Vn:0,s=Math.min(Vn,Math.max(0,Math.trunc(o)));Number.isFinite(t)||f(`fetchStore("${e}") received non-finite retry; using ${s}.`);let i=Math.min(dr,Math.max(is,Tn(e,"retryDelay",r,400))),u=Math.min(as,Math.max(1,Tn(e,"retryBackoff",n,1.7)));return s!==t&&f(`fetchStore("${e}") clamped retry attempts to ${s}.`),i!==r&&f(`fetchStore("${e}") clamped retryDelay to ${i}ms.`),u!==n&&f(`fetchStore("${e}") clamped retryBackoff to ${u}.`),{retry:s,retryDelay:i,retryBackoff:u}};var $n=(e,t)=>!t||t==="none"||e===null||typeof e!="object"?e:t==="shallow"?qe(e):D(e);var rt=(e,t,r,n)=>{if(typeof r=="function")try{r(n);}catch(o){f(`fetchStore("${e}") ${t} callback failed: ${o?.message??o}`);}},U=(e,t,r)=>(rt(e,"onError",r,t),R()?(O(t),null):(T(t),null));var Pt=(e,t)=>(ne[e]??0)===t,_n=e=>{let t=(ne[e]??0)+1;return ne[e]=t,t},In=(e,t)=>{ne[e]===t&&delete ne[e];},Wn=(e,t)=>{ue[e]=t;},zn=e=>{delete ue[e];},Hn=e=>!!ue[e],Bn=(e,t,r,n)=>{let o=ue[t];if(o)return I.dedupes+=1,r&&o.transform&&o.transform!==r?(U(e,`fetchStore("${e}") cannot dedupe callers that use different transform functions for cacheSlot "${t}".`,n),null):!r||o.transform===r?o.promise:o.raw.then(s=>r(s))};var $e=1e3,fr=100,Ln=(e,t)=>{t-e.ratePruneState.lastAt<$e||(e.ratePruneState.lastAt=t,Object.keys(e.rateWindowStart).forEach(r=>{t-(e.rateWindowStart[r]??0)>$e&&(delete e.rateWindowStart[r],delete e.rateCount[r]);}));},qn=e=>{Ln(V(),e);},Kn=(e=$e)=>{let t=V();t.ratePruneTimer||typeof setTimeout=="function"&&(t.ratePruneTimer=setTimeout(()=>{t.ratePruneTimer=null,Ln(t,Date.now());},e));},Un=(e,t)=>{let r=tt[e],n=Ne[e]??0;return r!==void 0&&t-r<$e?n>=fr?true:(Ne[e]=n+1,false):(tt[e]=t,Ne[e]=1,false)};var Yn=e=>{let t={};return e.method&&(t.method=e.method.toUpperCase()),e.headers?t.headers=e.headers:t.headers={"Content-Type":"application/json"},e.body&&(t.body=typeof e.body=="string"?e.body:JSON.stringify(e.body)),e.signal&&(t.signal=e.signal),t},Gn=async(e,t)=>{let r=t??"auto";if(r==="json")return e.json();if(r==="text")return e.text();if(r==="arrayBuffer")return e.arrayBuffer();if(r==="blob")return e.blob();if(r==="formData")return e.formData();let n=e.headers.get("content-type")||"";return n.includes("application/json")||n.includes("+json")?e.json():n.startsWith("text/")||n.includes("xml")||n.includes("html")?e.text():n.includes("form-data")?e.formData():e.arrayBuffer()};var nt=[],cs=e=>{if(!e||typeof e!="object")return false;let t=e;return "data"in t&&"loading"in t&&"error"in t&&"status"in t},us=(e,t,r,n)=>{if(Q(e)){if(n.stateAdapter){try{let o=St({name:e}),s=i=>{xt(t,i);};n.stateAdapter({name:e,prev:o,next:r,set:s});}catch(o){f(`fetchStore("${e}") stateAdapter failed: ${o?.message??o}`);}return}xt(t,r);}},_e=(e,t,r,n)=>(f(`fetchStore("${e}") aborted`),Pt(t,r)&&Q(e)&&n({loading:false,error:"aborted",status:"aborted",revalidating:false}),null);async function ot(e,t,r={}){let n=ee(e);if(!n||typeof n!="string"){O("fetchStore requires a store name as first argument");return}let o={name:n};if(!t){O(`fetchStore("${n}") requires a URL, Promise, or Promise factory as second argument`);return}let{transform:s,onSuccess:i,onError:u,stateAdapter:l,method:g,headers:p,body:d,ttl:c,staleWhileRevalidate:S=false,dedupe:b=true,retry:a=0,retryDelay:m=400,retryBackoff:k=1.7,signal:h,cacheKey:v,responseType:M="auto"}=r;!h&&R()&&!Ct.has(n)&&(At(Ct,n),f(`fetchStore("${n}") called without an AbortSignal. Provide "signal" to enable cancellation (recommended).`));let x=v?`${n}:${v}`:n,y=P=>us(n,o,P,r),F=typeof t!="string"&&typeof t!="function"&&typeof t?.then=="function",j=jn(n,a,m,k),Ie=false,st=F&&a>0,Jn=typeof window>"u"&&(typeof process<"u"?process.env?.NODE_ENV:void 0)==="production",Qn=r.autoCreate??C().asyncAutoCreate,Zn=r.cloneResult??C().asyncCloneResult;if(l&&!Q(n))return U(n,`fetchStore("${n}") with stateAdapter requires an existing backing store.
21
+ Call createStore("${n}", ...) first or omit stateAdapter to use the default AsyncState shape.`,u);if(!Q(n)&&Jn)return U(n,`fetchStore("${n}") cannot create a backing store on the server in production.
22
+ Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,u);if(!Q(n)){if(!Qn)return U(n,`fetchStore("${n}") requires an existing backing store when autoCreate is disabled.
23
+ Call createStore("${n}", ...) first or enable autoCreate.`,u);if(R()&&!Et.has(n)){At(Et,n);let P=`fetchStore("${n}") auto-created its backing store.
24
+ Call createStore("${n}", ...) first to avoid typos creating phantom stores.`;u?.(P),f(P);}if(ir(n,{data:null,loading:false,error:null,status:"idle"}),!Q(n))return U(n,`fetchStore("${n}") could not initialize its backing store.
25
+ On the server in production, use createStoreForRequest(...) inside the request scope or create the store with { allowSSRGlobalStore: true } before calling fetchStore.`,u)}if(!l){let P=St({name:n});if(P&&!cs(P))return Mt.has(n)||At(Mt,n),U(n,`fetchStore("${n}") cannot write AsyncState into an existing non-async store. Provide a stateAdapter or create the store with the async shape to avoid overwriting fields.`,u)}lr(n);let Dt=null,xe=false,Ot=()=>K[x]?.data??null;if(Pn(x,c)){if(I.cacheHits+=1,Dt=Ot(),y({data:Dt,loading:S,error:null,status:"success",cached:true,revalidating:S}),!S)return Dt;xe=true;}else I.cacheMisses+=1;if(b){let P=Bn(n,x,s,u);if(P!==void 0)return P}let pr=Date.now();if(qn(pr),Kn(),Un(x,pr))return U(n,`fetchStore("${n}") rate limited: ${fr} requests per ${$e}ms window for cacheSlot "${x}".`,u);if(!Hn(x)&&On(n)>=ar)return U(n,`fetchStore("${n}") exceeded ${ar} concurrent request slots. Reuse cacheKey values, wait for pending requests, or delete the store to clear async state.`,u);let G=_n(x);xe||y({loading:true,error:null,status:"loading",cached:false,revalidating:false}),I.requests+=1;let eo=Date.now(),it=!h&&typeof AbortController<"u"?new AbortController:null,de=h||it?.signal,at=it?()=>{it.signal.aborted||it.abort();}:null;at&&cr(n,at);let to=async()=>{let P=0,X=j.retryDelay;for(;;){if(de?.aborted)return _e(n,x,G,y);let ke=typeof t=="function"?t():t,yr=F||typeof ke!="string"&&typeof ke?.then=="function",hr=yr?{...j,retry:0}:j;yr&&(a>0||st)&&!Ie&&(f(`fetchStore("${n}") ignores retry settings for direct Promise inputs; pass a URL string or factory to use retries.`),Ie=true);try{let se;if(typeof ke=="string"){let oo=Yn({method:g,headers:p,body:d,signal:de,...r}),ut=await fetch(ke,oo);if(!ut.ok)throw new Error(`HTTP ${ut.status}: ${ut.statusText}`);se=await Gn(ut,M);}else if(typeof ke.then=="function")se=await ke;else return O(`fetchStore("${n}") - second argument must be a URL string, Promise, or Promise factory.
26
+ Examples:
27
+ fetchStore("users", "https://api.example.com/users")
28
+ fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(de?.aborted)return _e(n,x,G,y);let ct=s?s(se):se;if(ct&&typeof ct.then=="function")return U(n,`fetchStore("${n}") transform must be synchronous. Return the transformed value directly instead of a Promise.`,u);let ie=$n(ct,Zn);if(de?.aborted)return _e(n,x,G,y);if(!Pt(x,G))return null;K[x]={timestamp:Date.now(),expiresAt:c?Date.now()+c:null,data:ie},Dn(n),y({data:ie,loading:!1,error:null,status:"success",cached:!1,revalidating:!1}),rt(n,"onSuccess",i,ie);let mr=Date.now()-eo;return I.lastMs=mr,I.avgMs=(I.avgMs*(I.requests-1)+mr)/I.requests,{raw:se,transformed:ie}}catch(se){if(P+=1,se?.name==="AbortError")return _e(n,x,G,y);if(P<=hr.retry){if(de?.aborted||(await Nn(X,de),de?.aborted))return _e(n,x,G,y);X=Math.min(dr,X*hr.retryBackoff);continue}if(!Pt(x,G))return null;let ie=se?.message||"Something went wrong";return y({data:xe?Ot():null,loading:false,error:ie,status:"error",cached:xe,revalidating:false}),rt(n,"onError",u,ie),I.failures+=1,f(`fetchStore("${n}") failed: ${ie}`),null}}},We=null,ro=new Promise((P,X)=>{h||(We=setTimeout(()=>{We=null,X(new Error("Timeout: async request hung for 60 seconds without an AbortSignal"));},6e4));}),gr=Promise.race([to().finally(()=>{We&&(clearTimeout(We),We=null);}),ro]).catch(P=>{let X=P?.message||"Request timed out";return y({data:xe?Ot():null,loading:false,error:X,status:"error",cached:xe,revalidating:false}),rt(n,"onError",u,X),I.failures+=1,f(`fetchStore("${n}") failed: ${X}`),null}),Sr=gr.then(P=>P?.transformed??null).finally(()=>{zn(x),In(x,G),at&&ur(n,at);}),no=gr.then(P=>P?.raw);return Wn(x,{promise:Sr,raw:no,transform:s}),typeof t=="function"?le[n]={kind:"factory",factory:t,options:{...r,cacheKey:v}}:typeof t=="string"?le[n]={kind:"url",url:t,options:{...r,cacheKey:v}}:delete le[n],Sr}async function Xn(e){let t=ee(e);if(!Q(t))return;let r=le[t];if(!r){let o=`${t}:`,s=Object.entries(K).filter(([i])=>i===t||i.startsWith(o));if(s.length>0){let[,i]=s.reduce((u,l)=>l[1].timestamp>=u[1].timestamp?l:u);return i.data}R()&&f(`refetchStore("${t}") - no previous fetch found.
29
+ Call fetchStore("${t}", url) first.`);return}let n={name:t};return r.kind==="factory"?ot(n,r.factory,r.options):ot(n,r.url,r.options)}function ls(e,t){if(typeof window>"u"||typeof window.addEventListener!="function")return ()=>{};let n=(e==="*"?"*":e?ee(e):void 0)??"*";if(Ft.has(n))return Rt[n]??(()=>{});let o=C().revalidateOnFocus,s=Math.max(0,t?.debounceMs??o.debounceMs),i=Math.max(1,t?.maxConcurrent??o.maxConcurrent),u=Math.max(0,t?.staggerMs??o.staggerMs),l=null,g=()=>{let c=n==="*"?Object.keys(le):[n];if(t?.priority==="high"&&n!=="*"&&(c=[n,...c.filter(a=>a!==n)]),c.length===0)return;let S=0,b=()=>{let a=c.slice(S,S+i);if(a.forEach((m,k)=>{let h=()=>{let v=le[m];if(!v){Xn({name:m});return}v.kind==="factory"?ot({name:m},v.factory,v.options):ot({name:m},v.url,v.options);};u>0?setTimeout(h,k*u):h();}),S+=a.length,S<c.length){let m=u>0?u*Math.max(1,a.length):0;setTimeout(b,m);}};b();},p=()=>{if(s===0){g();return}l!==null&&clearTimeout(l),l=setTimeout(g,s);};window.addEventListener("focus",p),window.addEventListener("online",p),Ft.add(n);let d=()=>{if(window.removeEventListener("focus",p),window.removeEventListener("online",p),l!==null&&(clearTimeout(l),l=null),Ft.delete(n),delete Rt[n],n!=="*")ur(n,d);else {let c=nt.indexOf(d);c!==-1&&nt.splice(c,1);}};return Rt[n]=d,n!=="*"?cr(n,d):nt.push(d),d}var ds=()=>({...I}),fs=()=>{ps(),An();},ps=()=>{nt.forEach(e=>e()),nt.length=0;};export{fs as _resetAsyncStateForTests,ls as enableRevalidateOnFocus,ot as fetchStore,ds as getAsyncMetrics,Xn as refetchStore};
@@ -0,0 +1,17 @@
1
+ import { S as StoreName, a as StoreDefinition, b as StoreValue, c as StoreKey, d as StateFor } from './types-grvlY4BX.cjs';
2
+
3
+ type ComputedOptions = {
4
+ autoDispose?: boolean;
5
+ onError?: (err: unknown) => void;
6
+ };
7
+ type DepHandle = StoreDefinition<string, StoreValue> | StoreKey<string, StoreValue>;
8
+ type DepValue<T> = T extends StoreDefinition<string, infer S> ? Readonly<S> | null : T extends StoreKey<string, infer S> ? Readonly<S> | null : T extends StoreName ? Readonly<StateFor<T>> | null : StoreValue | null;
9
+ declare function createComputed<TResult, Deps extends readonly (StoreName | DepHandle)[]>(name: string, deps: Deps, compute: (...args: {
10
+ [K in keyof Deps]: DepValue<Deps[K]>;
11
+ }) => TResult, options?: ComputedOptions): StoreDefinition<string, TResult> | undefined;
12
+ declare const invalidateComputed: (name: string) => void;
13
+ declare const deleteComputed: (name: string) => void;
14
+ declare const isComputedStore: (name: string) => boolean;
15
+ declare const _resetComputedForTests: () => void;
16
+
17
+ export { _resetComputedForTests as _, isComputedStore as a, createComputed as c, deleteComputed as d, invalidateComputed as i };
@@ -0,0 +1,17 @@
1
+ import { S as StoreName, a as StoreDefinition, b as StoreValue, c as StoreKey, d as StateFor } from './types-grvlY4BX.js';
2
+
3
+ type ComputedOptions = {
4
+ autoDispose?: boolean;
5
+ onError?: (err: unknown) => void;
6
+ };
7
+ type DepHandle = StoreDefinition<string, StoreValue> | StoreKey<string, StoreValue>;
8
+ type DepValue<T> = T extends StoreDefinition<string, infer S> ? Readonly<S> | null : T extends StoreKey<string, infer S> ? Readonly<S> | null : T extends StoreName ? Readonly<StateFor<T>> | null : StoreValue | null;
9
+ declare function createComputed<TResult, Deps extends readonly (StoreName | DepHandle)[]>(name: string, deps: Deps, compute: (...args: {
10
+ [K in keyof Deps]: DepValue<Deps[K]>;
11
+ }) => TResult, options?: ComputedOptions): StoreDefinition<string, TResult> | undefined;
12
+ declare const invalidateComputed: (name: string) => void;
13
+ declare const deleteComputed: (name: string) => void;
14
+ declare const isComputedStore: (name: string) => boolean;
15
+ declare const _resetComputedForTests: () => void;
16
+
17
+ export { _resetComputedForTests as _, isComputedStore as a, createComputed as c, deleteComputed as d, invalidateComputed as i };