stroid 0.1.4-beta.0 → 0.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +313 -288
- package/README.md +1017 -117
- package/dist/async.js +1 -33
- package/dist/chunk-645IESIU.js +2 -0
- package/dist/chunk-6ELWGQ4Q.js +2 -0
- package/dist/chunk-BW32TJGE.js +13 -0
- package/dist/chunk-FOQKGHPS.js +26 -0
- package/dist/chunk-KQCSFGHJ.js +2 -0
- package/dist/chunk-M2NJVI36.js +2 -0
- package/dist/chunk-PVATWAY4.js +2 -0
- package/dist/chunk-X3JR32JD.js +2 -0
- package/dist/chunk-YU5GMPCC.js +2 -0
- package/dist/computed.js +1 -12
- package/dist/core.js +1 -22
- package/dist/devtools.js +1 -1
- package/dist/feature.js +1 -1
- package/dist/helpers.js +1 -22
- package/dist/index.js +1 -35
- package/dist/install.js +1 -1
- package/dist/options.d.ts +1 -1
- package/dist/persist.js +1 -1
- package/dist/psr.d.ts +14 -4
- package/dist/psr.js +1 -18
- package/dist/react/index.js +5 -36
- package/dist/registry.d.ts +1 -0
- package/dist/runtime-admin.js +1 -1
- package/dist/runtime-tools.js +1 -3
- package/dist/selectors.js +1 -1
- package/dist/server.d.ts +1 -0
- package/dist/server.js +1 -12
- package/dist/store-registry.d.ts +2 -0
- package/dist/sync.js +1 -1
- package/dist/testing.js +1 -22
- package/dist/types/adapters/options.d.ts +335 -0
- package/dist/types/async/cache.d.ts +40 -0
- package/dist/types/async/clone.d.ts +10 -0
- package/dist/types/async/errors.d.ts +3 -0
- package/dist/types/async/fetch.d.ts +37 -0
- package/dist/types/async/inflight.d.ts +30 -0
- package/dist/types/async/rate.d.ts +5 -0
- package/dist/types/async/registry.d.ts +117 -0
- package/dist/types/async/request.d.ts +11 -0
- package/dist/types/async/retry.d.ts +10 -0
- package/dist/types/async.d.ts +10 -0
- package/dist/types/computed/computed-graph.d.ts +33 -0
- package/dist/types/computed/index.d.ts +21 -0
- package/dist/types/computed/types.d.ts +40 -0
- package/dist/types/config.d.ts +10 -0
- package/dist/types/core/index.d.ts +11 -0
- package/dist/types/core/lifecycle-hooks.d.ts +16 -0
- package/dist/types/core/runtime-patch.d.ts +67 -0
- package/dist/types/core/store-admin-impl.d.ts +9 -0
- package/dist/types/core/store-admin.d.ts +9 -0
- package/dist/types/core/store-core.d.ts +13 -0
- package/dist/types/core/store-create.d.ts +16 -0
- package/dist/types/core/store-hydrate-impl.d.ts +35 -0
- package/dist/types/core/store-hydrate.d.ts +9 -0
- package/dist/types/core/store-lifecycle/hooks.d.ts +20 -0
- package/dist/types/core/store-lifecycle/identity.d.ts +23 -0
- package/dist/types/core/store-lifecycle/registry.d.ts +54 -0
- package/dist/types/core/store-lifecycle/types.d.ts +67 -0
- package/dist/types/core/store-lifecycle/validation.d.ts +53 -0
- package/dist/types/core/store-name.d.ts +28 -0
- package/dist/types/core/store-notify.d.ts +13 -0
- package/dist/types/core/store-read.d.ts +18 -0
- package/dist/types/core/store-registry.d.ts +115 -0
- package/dist/types/core/store-replace-impl.d.ts +11 -0
- package/dist/types/core/store-replace.d.ts +9 -0
- package/dist/types/core/store-set-impl.d.ts +13 -0
- package/dist/types/core/store-set.d.ts +9 -0
- package/dist/types/core/store-shared/core.d.ts +13 -0
- package/dist/types/core/store-shared/notify.d.ts +12 -0
- package/dist/types/core/store-transaction.d.ts +28 -0
- package/dist/types/core/store-write-shared.d.ts +25 -0
- package/dist/types/core/store-write.d.ts +13 -0
- package/dist/types/features/feature-registry.d.ts +91 -0
- package/dist/types/features/lifecycle.d.ts +40 -0
- package/dist/types/index.d.ts +17 -0
- package/dist/types/integrations/query.d.ts +8 -0
- package/dist/types/internals/computed-order.d.ts +3 -0
- package/dist/types/internals/config.d.ts +116 -0
- package/dist/types/internals/diagnostics.d.ts +21 -0
- package/dist/types/internals/reporting.d.ts +9 -0
- package/dist/types/internals/store-admin.d.ts +7 -0
- package/dist/types/internals/store-ops.d.ts +13 -0
- package/dist/types/internals/test-reset.d.ts +2 -0
- package/dist/types/internals/write-context.d.ts +20 -0
- package/dist/types/notification/delivery.d.ts +3 -0
- package/dist/types/notification/index.d.ts +10 -0
- package/dist/types/notification/metrics.d.ts +12 -0
- package/dist/types/notification/priority.d.ts +9 -0
- package/dist/types/notification/scheduler.d.ts +11 -0
- package/dist/types/notification/snapshot.d.ts +8 -0
- package/dist/types/runtime-admin/index.d.ts +2 -0
- package/dist/types/runtime-tools/index.d.ts +63 -0
- package/dist/types/store.d.ts +16 -0
- package/dist/types/types/utility.d.ts +17 -0
- package/dist/types/utils/clone.d.ts +4 -0
- package/dist/types/utils/devfreeze.d.ts +2 -0
- package/dist/types/utils/hash.d.ts +8 -0
- package/dist/types/utils/path.d.ts +5 -0
- package/dist/types/utils/validation.d.ts +14 -0
- package/dist/types/utils.d.ts +13 -0
- package/dist/types.d.ts +1 -1
- package/package.json +50 -37
- package/dist/tsdoc-metadata.json +0 -11
package/dist/async.js
CHANGED
|
@@ -1,34 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
Store data only - handle functions outside the store.`,rn=()=>`Map/Set detected. stroid converts these to plain objects.
|
|
3
|
-
Use arrays or plain objects for best results.`,nn=()=>`Date object detected. stroid stores it as ISO string.
|
|
4
|
-
Use new Date(value) to convert back when reading.`,on=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",sn=()=>"Map detected; converting to plain object.",an=()=>"Set detected; converting to array.",cn=(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]}", ...)`,un=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
|
|
8
|
-
Consider splitting into separate stores for better readability.`,fn=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,pn=e=>`Store name "${e}" contains spaces.
|
|
9
|
-
Use camelCase or kebab-case: "userName" or "user-name"`,gn=e=>`Store name "${e}" is not allowed.
|
|
10
|
-
Reserved names: "__proto__", "constructor", "prototype".`,xs=128,Cs=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=xs,ks=(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]},nr=(e,t)=>{let r=t.find(n=>{let o=n.toLowerCase(),s=e.toLowerCase();return o.includes(s)||s.includes(o)||Cs(o,s)&&ks(o,s)<=2});if(r){f(`Store "${e}" not found. Did you mean "${r}"?`);return}j(`Store "${e}" not found.
|
|
11
|
-
Available stores: [${t.join(", ")}]
|
|
12
|
-
Call createStore("${e}", data) first.`);};var ie=new Set(["__proto__","constructor","prototype"]),sr=(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 xe=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,yn=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},Le=e=>{let t=xe(e);return t==="function"?(j(tn()),false):t==="map"||t==="set"?(f(rn()),true):(t==="date"&&f(nn()),true)},or=(e,t)=>{let r=yn(e);if(r)throw new Error(`${r} values are not supported`);let n=xe(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&&!or(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||ie.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!or(i.value,t))return false}return true}return true},ir=e=>or(e,new WeakSet),at=(e,t)=>{let r=yn(e);if(r)throw new Error(`${r} values are not supported`);let n=xe(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 E()&&f(on()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),E()&&f(sn());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)]=at(i,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),E()&&f(an()),Array.from(e,o=>at(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,a]of Object.entries(s))if(a.enumerable&&!ie.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);o[i]=at(a.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=>at(o,t))}return e},Ae=e=>at(e,new WeakSet),ar=e=>typeof e!="string"||e.trim()===""?(j(fn(e)),false):ie.has(e)?(j(gn(e)),false):e.includes(" ")?(j(pn(e)),false):true;var cr=null,Ms=()=>{if(cr)return cr;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 cr=t,t},Sn=e=>{let t=Ms(),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},Es=2166136261,Ts=2654435761,Fs=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));},$=(e,t)=>{Pe(e,t);},mn=(e,t)=>{if(Number.isNaN(t)){$(e,"NaN");return}if(!Number.isFinite(t)){$(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){$(e,"-0");return}let r=t|0;if(t===r){$(e,"int"),Ce(e,r);return}$(e,"num"),Pe(e,String(t));},Be=(e,t)=>{if(e.nodes++>Fs){$(e,"[max]");return}if(t===null){$(e,"null");return}let r=typeof t;if(r==="string"){$(e,"string"),Pe(e,t);return}if(r==="number"){$(e,"number"),mn(e,t);return}if(r==="boolean"){$(e,t?"true":"false");return}if(r==="undefined"){$(e,"undefined");return}if(r==="bigint"){$(e,"bigint"),Pe(e,t.toString());return}if(r==="symbol"){$(e,"symbol");let u=t;Pe(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){$(e,"function"),Pe(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){$(e,"ref"),Ce(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){$(e,"array"),Ce(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?Be(e,n[u]):$(e,"hole");return}if(n instanceof Date){$(e,"date"),mn(e,n.getTime());return}if(n instanceof Map){$(e,"map"),Ce(e,n.size),n.forEach((u,c)=>{Be(e,c),Be(e,u);});return}if(n instanceof Set){$(e,"set"),Ce(e,n.size),n.forEach(u=>{Be(e,u);});return}$(e,"object");let i=Object.getOwnPropertyDescriptors(n),a=[];Object.entries(i).forEach(([u,c])=>{c?.enumerable&&(ie.has(u)||"get"in c||"set"in c||a.push([u,c]));}),Ce(e,a.length);for(let[u,c]of a)Pe(e,u),Be(e,c.value);},ct=e=>{if(typeof e=="string")return Sn(JSON.stringify(e));let t={h1:Es,h2:Ts,seen:new WeakMap,nextId:1,nodes:0};Be(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 As=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",De=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&&(ie.has(n)||"get"in o||"set"in o||(t[n]=o.value));}),t},ur=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=[["WeakMap",globalThis.WeakMap],["WeakSet",globalThis.WeakSet],["WeakRef",globalThis.WeakRef],["Promise",globalThis.Promise],["ReadableStream",globalThis.ReadableStream],["WritableStream",globalThis.WritableStream],["TransformStream",globalThis.TransformStream],["EventTarget",globalThis.EventTarget]];for(let[n,o]of t)if(typeof o=="function"&&e instanceof o)return n;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},Ps=e=>ur(e)===null,Os=e=>{let t=ur(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},Oe=(e,t=new WeakMap)=>{if(Os(e),e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let o=new Map;return t.set(e,o),e.forEach((s,i)=>{o.set(Oe(i,t),Oe(s,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(s=>{o.add(Oe(s,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((s,i)=>{o[i]=Oe(s,t);}),o}let r={};t.set(e,r);let n;try{n=Object.getOwnPropertyDescriptors(e);}catch(o){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${o?.message??o}`)}return Object.entries(n).forEach(([o,s])=>{!s.enumerable||ie.has(o)||"get"in s||"set"in s||(r[o]=Oe(s.value,t));}),r},I=e=>{if(As)try{return structuredClone(e)}catch(t){if(!Ps(e)){let r=ur(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return f(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),Oe(e)}return Oe(e)},lr=(e,t)=>{if(Object.is(e,t))return true;if(!e||!t||typeof e!="object"||typeof t!="object")return false;let r=e,n=t,o=Object.keys(r),s=Object.keys(n);if(o.length!==s.length)return false;for(let i of o)if(!Object.prototype.hasOwnProperty.call(n,i)||!Object.is(r[i],n[i]))return false;return true};var hn=10,Ds=5,Ns=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},ke=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?Ns(e):[String(e)],ut=e=>{let t=ke(e),r=t.length;return r>hn?(j(cn(r,hn,t)),false):(r>Ds&&f(un(r,t)),true)},fr=(e,t,r)=>{let n=ke(t);if(n.length===0)return e;for(let s of n)if(ie.has(s))return L(`Blocked forbidden path segment "${String(s)}" in setStore path "${n.join(".")}".`),e;let o=(s,i)=>{let a=n[i],u=i===n.length-1;if(Array.isArray(s)){let c=Number(a);if(!Number.isInteger(c))return s;let l=[...s];return u?(l[c]=r,l):(l[c]=o(l[c],i+1),l)}if(s&&typeof s=="object"){if(ie.has(a))return L(`Blocked unsafe path segment "${String(a)}" while setting "${n.join(".")}".`),s;let c={...s};return u?(c[a]=r,c):(c[a]=o(c[a],i+1),c)}if(s==null&&!u){let c=Number.isInteger(Number(a)),l=c?[]:{};if(c){let R=l,b=Number(a);return R[b]=o(void 0,i+1),R}return l[a]=o(void 0,i+1),l}return u?r:s};return o(e,0)};var gr=new Set,Vs=()=>{gr.clear();};A("options.legacy-warnings",Vs,30);var Dt=(()=>{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"}})(),pr=e=>{try{return typeof window>"u"?Dt:e==="session"||e==="sessionStorage"?window.sessionStorage??Dt:window.localStorage??Dt}catch{return Dt}},lt=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),qe=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),wn=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}},Is=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",bn=e=>{try{e[Is]=!0;}catch{}return e},js={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"},$s=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:bn(R=>R),decrypt:bn(R=>R),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:pr("localStorage"),...r};if(typeof e=="string")return {driver:pr(e),...r};let n=e.encrypt||r.encrypt,o=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,a=e.sensitiveData===true,u=e.allowPlaintext===true,c=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,l=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(a&&wn(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||pr("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:u,sensitiveData:a,maxSize:c,checksum:l,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Rn=e=>{if(!lt(e))return [];let t=[];return Object.entries(js).forEach(([r,n])=>{qe(e,r)&&(gr.has(r)||(gr.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},vn=(e={},t,r="deep")=>{let n=e.scope??"request",o=e.lazy===true,s=e.pathCreate===true,i=lt(e.lifecycle)?e.lifecycle:void 0,a=lt(e.persist)?e.persist:void 0,u=lt(e.devtools)?e.devtools:void 0,c=e.validate??e.validator??e.schema,l=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",R=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,b=lt(e.features)?{...e.features}:void 0,g=qe(e,"persist"),C=qe(e,"sync"),d=qe(e,"devtools")||qe(e,"historyLimit")||qe(e,"redactor"),S=n==="global"?true:e.allowSSRGlobalStore??false,{persist:w=false,devtools:h=false,onError:m,sync:k}=e;if(a?.sensitiveData===true){let F=a.encrypt,v=a.encryptAsync;if((!F||wn(F))&&!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:n,lazy:o,pathCreate:s,persist:n==="temp"&&!g?null:$s(w,t),devtools:n==="temp"&&!d?false:typeof h=="boolean"?h:u?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:m,validate:c,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:n==="temp"&&!d?void 0:u?.redactor??e.redactor,historyLimit:n==="temp"&&!d?0:u?.historyLimit??e.historyLimit??50,sync:n==="temp"&&!C?false:k??false,features:b,allowSSRGlobalStore:S,snapshot:l,snapshotSafety:R,explicitPersist:g,explicitSync:C,explicitDevtools:d}};var Nt=Symbol("stroid.middleware.abort"),xn=({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=I(t.next);for(let a of r){if(typeof a!="function")continue;let u,c=i;try{u=a({action:t.action,name:e,prev:t.prev,next:c,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(l){let R=`Middleware for "${e}" failed: ${l?.message??l}`;return n(R,"dev"),Nt}if(u&&typeof u.then=="function"){let l=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(l,"dev"),Nt}u===void 0?(E()&&!s.has(a)&&(s.add(a),o(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=c):i=u;}return i},Vt=({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 re=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(n){let o=n?.message??n;se(`${t} callback threw: ${String(o)}`);}},Ne=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(re(o,"onError",e),r==="critical"){n==="dev"&&f(e),L(e);return}if(n==="always"){se(e);return}f(e);};var It=null,Cn=e=>{It=e;},kn=e=>It?It(e):[];A("computed.order-resolver",()=>{It=null;},105);var Mn=()=>oe(He(We));var yr=()=>Mn().computedEntries,En=()=>Mn().computedDependents;var Tn=e=>Object.prototype.hasOwnProperty.call(yr(),e);var _s=e=>{let t=yr(),r=En(),n=new Set,o=[...e];for(;o.length>0;){let l=o.shift(),R=r[l];if(R)for(let b of R)n.has(b)||(n.add(b),o.push(b));}if(n.size===0)return [];let s=l=>{let R=t[l];if(R)for(let b of R.deps)t[b]&&(n.has(b)||(n.add(b),s(b)));};Array.from(n).forEach(l=>s(l));let i=new Map,a=new Map;for(let l of n){let R=t[l];if(!R)continue;let b=0;for(let g of R.deps)n.has(g)&&(b++,a.has(g)||a.set(g,[]),a.get(g).push(l));i.set(l,b);}let u=[];for(let[l,R]of i)R===0&&u.push(l);u.sort();let c=[];for(;u.length>0;){let l=u.shift();c.push(l);let R=a.get(l)??[];for(let b of R){let g=(i.get(b)??1)-1;if(i.set(b,g),g===0){let C=u.findIndex(d=>d>b);C===-1?u.push(b):u.splice(C,0,b);}}}return c};Cn(_s);var mr=e=>{let t=yr()[e];if(!t)return null;let r=En()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Fn=e=>{if(typeof e!="object"||e===null)return false;let t=e;if(t.$$typeof||typeof window<"u"&&e instanceof Element)return false;let r=t.constructor?.name;return !(r&&r!=="Object"&&r!=="Array")},Sr=e=>(Fn(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),An=e=>{if(!Fn(e))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 dt=0,zs=(e,t)=>(dt>=Number.MAX_SAFE_INTEGER&&(dt=0),dt+=1,`${e}:${t}:${dt}`),Ws=e=>{let t=[e?.correlationId,e?.traceContext?.traceId,e?.traceContext?.spanId].filter(r=>typeof r=="string"&&r.length>0);return t.length>0?t:void 0},Hs=e=>({...e,path:[...e.path],meta:{...e.meta,causedBy:e.meta.causedBy?[...e.meta.causedBy]:void 0}}),Ls=e=>e?Array.isArray(e)?e.map(t=>typeof t=="number"?t:String(t)):ke(e):[],hr=e=>{let t=e.timestamp??Date.now();return {id:zs(e.source,t),store:e.store,path:Ls(e.path),op:e.op,...e.value!==void 0?{value:e.value}:{},meta:{timestamp:t,source:e.source,causedBy:Ws(e.context),...e.isUnsafe===true?{isUnsafe:true}:{},...e.asyncBoundary===true?{asyncBoundary:true}:{}}}},Bs=e=>hr({store:e.store,op:"set",path:[],value:e.value,source:e.source,context:e.context}),Pn=e=>e.intent.kind==="root"||!e.preserveIntent?[Bs({store:e.store,value:e.committedValue,source:"setStore",context:e.context})]:e.intent.kind==="merge"?[hr({store:e.store,op:"merge",path:[],value:e.intent.value,source:"setStore",context:e.context})]:[hr({store:e.store,op:"set",path:e.intent.path,value:e.intent.value,source:"setStore",context:e.context})],On=(e,t=D())=>{t.lastRuntimePatches=e.map(Hs);};A("runtime-patch.sequence",()=>{dt=0;},126);var jt=null;var qs=()=>{jt=null;};A("transaction.runner",qs,120);var Ue=e=>{let t=jt?.get();return t||(e??oe()).transaction},Us=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 N=()=>jt?(jt.get()?.depth??0)>0:Ue().depth>0,K=(e,t)=>{let r=Ue(t);r.failed=true,r.error||(r.error=Us(e));},$t=e=>{let t=oe();Ue(t).pending.push(()=>Ot(t,e));},_t=(e,t)=>{let r=Ue();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},Dn=e=>{if(e.length===0)return;Ue().runtimePatches.push(...e);},Ke=e=>{let t=Ue();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Nn=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},br=(e,t)=>{if(t==="ref"){if(!E())return e;try{return Sr(e)}catch{return e}}if(t==="shallow"){let n=De(e);if(!E())return n;try{return Sr(n)}catch{return n}}let r=I(e);if(!E())return r;try{return An(r)}catch{return r}};var Vn=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:n}=e,o=T().flush,s=o.priorityStores||[],i=s.length?new Set(s):null;n.length=0,r.length=0;let a=new Set;if(i){for(let C of t)r.push(C),a.add(C);for(let C of s)a.has(C)&&n.push(C);for(let C of r)i.has(C)||n.push(C);}else for(let C of t)r.push(C),a.add(C),n.push(C);t.clear();let u=kn(n),c=new Set(n);for(let C of u)c.has(C)||(n.push(C),c.add(C));let l=Number.isFinite(o.chunkSize)&&o.chunkSize>0?o.chunkSize:Number.POSITIVE_INFINITY,R=o.chunkDelayMs,b=l===Number.POSITIVE_INFINITY&&R===0;return {names:n,sliceSize:l,chunkDelayMs:R,runInline:b,prioritySet:i}};var wr=e=>({notifyCount:e?.notifyCount??0,totalNotifyMs:e?.totalNotifyMs??0,lastNotifyMs:e?.lastNotifyMs??0,resetCount:e?.resetCount??0,totalResetMs:e?.totalResetMs??0,lastResetMs:e?.lastResetMs??0}),Rr=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),vr=(e,t)=>{e&&(e.metrics=t);};var ft=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},In=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let n=()=>Ot(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(n):Promise.resolve().then(n);};var Ge=new Map,jn=(e,t)=>{let r=Ge.get(e);return r||(r=new Set,Ge.set(e,r)),r.add(t),()=>{let n=Ge.get(e);n&&(n.delete(t),n.size===0&&Ge.delete(e));}},xr=e=>{let t=Ge.get(e);return !!t&&t.size>0},pt=(e,t,r)=>{let n=Ge.get(e);!n||n.size===0||n.forEach(o=>{try{o(t,r);}catch(s){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,s);}});};var gt=null,zt=null;var Ks=()=>{gt=null,zt=null;};A("write-context.runner",Ks,121);var Wt=()=>zt?.get()??gt,Ye=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(zt)return zt.run(e,t);let r=gt;gt=e;try{return t()}finally{gt=r;}};var $n=e=>{if(!(e instanceof TypeError))return false;let t=e?.message??String(e);return /read only|readonly|cannot assign|cannot add property|cannot delete property/i.test(t)},_n=(e,t,r,n)=>{let o=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:u,prioritySet:c}=t,R=e.stores,b=e.subscribers,g=e.metaEntries,C=e.snapshotCache,d=T().defaultSnapshotMode,S=x=>Nn(g[x],d),w=x=>R[x],h=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),m=xr("beforeFlush"),k=xr("afterFlush"),F=x=>{m&&pt("beforeFlush",x,{type:"beforeFlush"});},v=(x,z)=>{k&&pt("afterFlush",x,{type:"afterFlush",elapsedMs:z});},y=x=>{let z=g[x];if(!z)return null;let V=z.lastCorrelationId??void 0,p=z.lastTraceContext??void 0;return !V&&!p?null:{correlationId:V,traceContext:p}},O=()=>{n();};if(u){for(let x of s){let z=b[x];if(!z||z.size===0)continue;let V=g[x]?.updateCount??0,p=S(x),pe=w(x),Y=C[x],W=Y&&Y.source===pe&&Y.mode===p?Y.snapshot:(()=>{let q=br(pe,p);return C[x]={version:r,snapshot:q,source:pe,mode:p},q})(),J=wr(g[x]?.metrics);F(x);let ue=h(),H=Array.from(z),Te=y(x),le=()=>{for(let q of H)try{q(W);}catch(ee){let ne=g[x]?.options?.snapshotSafety??"warn";if(E()&&(p==="ref"||p==="shallow")&&$n(ee)){if(ne==="throw")throw ee;if(ne==="auto-clone")try{let we=I(W);f(`Snapshot mutation detected for "${x}". Delivered a cloned snapshot to the subscriber.`);try{q(we);}catch(ot){f(`Subscriber for "${x}" threw on cloned snapshot: ${ot?.message??ot}`);}continue}catch{}f(`Snapshot mutation detected for "${x}": ${ee?.message??ee}`);continue}f(`Subscriber for "${x}" threw: ${ee?.message??ee}`);}};Te?Ye(Te,le):le();let Z=h()-ue;v(x,Z),Rr(J,Z),vr(g[x],J),(g[x]?.updateCount??V)!==V&&o.pendingNotifications.add(x);}O();return}let M=x=>{let z=[];for(let V of s){if(x&&!x(V))continue;let p=b[V];if(!p||p.size===0)continue;let pe=g[V]?.updateCount??0,Y=S(V),W=w(V),J=C[V],ue=J&&J.source===W&&J.mode===Y?J.snapshot:(()=>{let H=br(W,Y);return C[V]={version:r,snapshot:H,source:W,mode:Y},H})();z.push({name:V,snapshot:ue,version:pe,subscribers:Array.from(p),subscriberSet:new Set(p),notified:new Set,metrics:wr(g[V]?.metrics),totalMs:0,beforeHooked:false});}return z},B=c?M(x=>c.has(x)):[],be=M(x=>!c||!c.has(x)),Ee=(x,z)=>{let V=()=>{if(x.length===0){z();return}let p=x.shift();if((g[p.name]?.updateCount??p.version)!==p.version){if(o.pendingNotifications.add(p.name),x.length===0){z();return}ft(V,a);return}let Y=()=>{let X=b[p.name];if(!(!X||X.size===0))for(let q of X)p.subscriberSet.has(q)||(p.subscriberSet.add(q),p.subscribers.push(q));};Y();let W=p.subscribers;if(W.length===0){if(x.length===0){z();return}ft(V,a);return}p.beforeHooked||(p.beforeHooked=true,F(p.name));let J=h(),ue=0,H=false,Te=y(p.name),le=()=>{for(let X=0;X<W.length&&ue<i;X+=1){let q=W[X];if(p.notified.has(q))continue;p.notified.add(q);try{q(p.snapshot);}catch(ne){let $e=g[p.name]?.options?.snapshotSafety??"warn",we=S(p.name);if(E()&&(we==="ref"||we==="shallow")&&$n(ne)){if($e==="throw")throw ne;if($e==="auto-clone")try{let P=I(p.snapshot);f(`Snapshot mutation detected for "${p.name}". Delivered a cloned snapshot to the subscriber.`);try{q(P);}catch(ge){f(`Subscriber for "${p.name}" threw on cloned snapshot: ${ge?.message??ge}`);}if(p.notified.add(q),ue+=1,(g[p.name]?.updateCount??p.version)!==p.version){H=!0,o.pendingNotifications.add(p.name);break}continue}catch{}f(`Snapshot mutation detected for "${p.name}": ${ne?.message??ne}`);continue}f(`Subscriber for "${p.name}" threw: ${ne?.message??ne}`);}if(ue+=1,(g[p.name]?.updateCount??p.version)!==p.version){H=true,o.pendingNotifications.add(p.name);break}}};if(Te?Ye(Te,le):le(),p.totalMs+=h()-J,H){if(x.length===0){z();return}ft(V,a);return}Y();let Z=false;for(let X of W)if(!p.notified.has(X)){Z=true;break}if(Z?x.push(p):(Rr(p.metrics,p.totalMs),vr(g[p.name],p.metrics),v(p.name,p.totalMs)),x.length===0){z();return}ft(V,a);};V();};B.length>0?Ee(B,()=>Ee(be,O)):Ee(be,O);};var Gs=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,n=Vn(t);_n(e,n,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&Cr(e);});},Cr=e=>{In(e,Gs);};var Ht=null,zn=e=>(Ht=e,()=>{Ht===e&&(Ht=null);}),Xe=e=>{Ht?.(e);};var Ys=e=>{let t=D(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&Cr(t);};zn(Ys);var Xs=()=>{let e=D().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};A("notify.reset",Xs,40);var Lt=new Set,Ln=e=>e?Lt.has(e):Lt.size>0,Bn=e=>{e&&Lt.add(e);},Js=()=>{Lt.clear();};A("ssr.warnings",Js,60);var Hn=new Set,Qs=e=>{let t=Zr();return !t||e.includes("::")?e:(E()&&!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}`)},Me=e=>Qs(typeof e=="string"?e:e.name),qn=e=>ae(e)&&!Gn(e)?true:(nr(e,Object.keys(St)),false),Un=(e,t,r={})=>{Ne(t,{...r,onError:_[e]?.options?.onError});},Kn=(e,t,r={})=>{Ne(e,{...r,onError:t});},Ve=(e,t,r="dev")=>{Un(e,t,{severity:"warn",visibility:r});},Zs=(e,t,r="dev")=>{Kn(e,t,{severity:"warn",visibility:r});},me=(e,t)=>Un(e,t,{severity:"critical",visibility:"always"}),mt=(e,t)=>Kn(e,t,{severity:"critical",visibility:"always"}),Bt=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
13
|
-
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Zs(n,r,"always"),T().strictMissingFeatures)throw new Error(n)};var Yn=new WeakMap,Xn=new WeakMap,ei=500,ti="",ht=e=>{let t=Yn.get(e);return t||(t=new Map,Yn.set(e,t)),t},Mr=e=>{let t=Xn.get(e);return t||(t=new Map,Xn.set(e,t)),t},ri=(e,t)=>{let r=Mr(e),n=r.get(t);return n||(n=new Map,r.set(t,n)),n},ni=()=>{let e=T().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?ei:Math.max(0,Math.floor(e))},Jn=(e,t,r,n)=>{if(n<=0){e.has(t)&&e.delete(t);return}for(e.has(t)&&e.delete(t),e.set(t,r);e.size>n;){let o=e.keys().next().value;if(!o)break;let s=e.get(o);e.delete(o),s?.node.verdicts&&(s.node.verdicts.delete(s.type),s.node.verdicts.size===0&&delete s.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=ht(D());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)=>(ht(D())[t]=r,true)});var Qn=(e,t,r,n)=>{let o=_[e];if(!o)return {ok:true};let s=ke(r);if(s.length===0)return {ok:true};let i=xe(n),a=ni(),u=D(),c=ht(u),l=ri(u,e),R=s.join(ti),b=c.get(e);b||(b={children:new Map},c.set(e,b));let g=b;for(let m of s){let k=g.children.get(m);k||(k={children:new Map},g.children.set(m,k)),g=k;}let C=g.verdicts?.get(i);if(C){let m=`${R}|${i}`;return Jn(l,m,{node:g,type:i},a),C}let d=o.options?.pathCreate===true,S=t,w={ok:true};for(let m=0;m<s.length;m++){let k=s[m],F=m===s.length-1;if(S==null){let y=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,m).join(".")||"root"}" is ${S===null?"null":"undefined"}.`;L(y),w={ok:false,reason:y};break}if(typeof S!="object"){let y=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,m).join(".")||"root"}" is not an object.`;L(y),w={ok:false,reason:y};break}if(Array.isArray(S)){let y=Number(k);if(!Number.isInteger(y)||y<0){let M=`Path "${s.join(".")}" targets non-numeric index "${k}" on an array in "${e}".`;L(M),w={ok:false,reason:M};break}let O=S;if(y>=O.length){let M=`Path "${s.join(".")}" is invalid for "${e}" - index ${y} is out of bounds (length ${O.length}).`;L(M),w={ok:false,reason:M};break}if(F){let M=O[y];if(M!=null){let B=xe(M);if(B!==i){let be=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${B}, received ${i}.`;L(be),w={ok:false,reason:be};break}}w={ok:true};break}S=O[y];continue}if(!Object.prototype.hasOwnProperty.call(S,k)){if(d&&F){w={ok:true};break}let y=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${k}" at "${s.slice(0,m).join(".")||"root"}".`;L(y),w={ok:false,reason:y};break}if(F){let y=S[k];if(y!=null){let O=xe(y);if(O!==i){let M=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${O}, received ${i}.`;L(M),w={ok:false,reason:M};break}}w={ok:true};break}S=S[k];}g.verdicts||(g.verdicts=new Map);let h=g.verdicts.has(i);if(g.verdicts.set(i,w),!h){let m=`${R}|${i}`;Jn(l,m,{node:g,type:i},a);}return w},Ie=(e,t,r,n)=>{try{return n?.reuseInput&&ir(t)?{ok:!0,value:t}:{ok:!0,value:Ae(t)}}catch(o){let s=`Sanitize failed for "${e}": ${o?.message??o}`;return re(_[e]?.options?.onError,`onError(${e})`,s),re(r,`onError(${e})`,s),f(s),{ok:false}}},oi=(e,t)=>{let r=new Set,n=_[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},Er=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let o=oi(e,n),s=(a,u)=>{o.forEach(c=>re(c,`onError(${e})`,a)),u==="critical"?L(a):f(a);};if(typeof r=="function")try{let a=r(t);return a===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:a===!0?t:a}}catch(a){return s(`Validation for "${e}" failed: ${a?.message??a}`,"critical"),{ok:false}}let i=sr(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},bt=(e,t,r,n,o)=>{let s=Ie(e,t,n,o);if(!s.ok)return {ok:false};let i=Er(e,s.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},Se=e=>{let t=D();ht(t).delete(e),Mr(t).delete(e);},si=()=>{let e=D();ht(e).clear(),Mr(e).clear();};A("validation.path-cache",si,50);Zn(Se);var qt=(e,t=D())=>{if((N()?Ke(e):{has:false}).has||t.stores[e]!==void 0)return true;let n=t.initialFactories[e];if(!n)return true;try{let o=n(),s=Ie(e,o,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=bt(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(N()){let u=a.value;_t(e,u),$t(()=>{fe(e,u,t),t.initialStates[e]=I(u),delete t.initialFactories[e],Se(e);});}else fe(e,a.value,t),t.initialStates[e]=I(a.value),delete t.initialFactories[e],Se(e);return !0}catch(o){return me(e,`Lazy initializer for "${e}" failed: ${o?.message??o}`),false}};var eo=new WeakMap,to=e=>{let t=eo.get(e);return t||(t=new Map,eo.set(e,t)),t},ii=()=>{to(D()).clear();};A("features.contexts",ii,100);var ro=e=>{let t=D(),r=to(t),n=r.get(e);if(n)return n;let o=_[e];if(!o)return f(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:o.options,getMeta:()=>_[e],getStoreValue:()=>St[e],getAllStores:()=>St,getInitialState:()=>co[e],hasStore:()=>ae(e),setStoreValue:i=>{fe(e,i);},applyFeatureState:(i,a)=>{uo(e,i,a),Se(e);},notify:()=>{},reportStoreError:i=>{me(e,i);},warn:f,warnAlways:se,log:te,hashState:ct,deepClone:I,sanitize:Ae,validate:i=>Er(e,i,_[e]?.options?.validate),isDev:E};return r.set(e,s),s},no=(e,t)=>{let r=T();if(!r.strictMissingFeatures&&!r.assertRuntime)return;let n=[];if(typeof t.getMeta!="function"&&n.push("getMeta"),typeof t.getStoreValue!="function"&&n.push("getStoreValue"),typeof t.getAllStores!="function"&&n.push("getAllStores"),typeof t.getInitialState!="function"&&n.push("getInitialState"),typeof t.hasStore!="function"&&n.push("hasStore"),typeof t.setStoreValue!="function"&&n.push("setStoreValue"),typeof t.applyFeatureState!="function"&&n.push("applyFeatureState"),typeof t.notify!="function"&&n.push("notify"),typeof t.reportStoreError!="function"&&n.push("reportStoreError"),typeof t.warn!="function"&&n.push("warn"),typeof t.warnAlways!="function"&&n.push("warnAlways"),typeof t.log!="function"&&n.push("log"),typeof t.hashState!="function"&&n.push("hashState"),typeof t.deepClone!="function"&&n.push("deepClone"),typeof t.sanitize!="function"&&n.push("sanitize"),typeof t.validate!="function"&&n.push("validate"),typeof t.isDev!="function"&&n.push("isDev"),n.length===0)return;let o=`Feature hook context missing fields for "${e}": ${n.join(", ")}.`;if(me(e,o),r.assertRuntime)throw new Error(o)},oo=(e,t)=>{Kt();let r=ro(e);r&&(r.notify=()=>t(e),no(e,r),de.forEach((n,o)=>{try{n.onStoreCreate?.(r);}catch(s){Ve(e,`Feature "${String(o)}" onStoreCreate for "${e}" failed: ${s?.message??s}`,"always");}}));},so=(e,t,r,n,o)=>{Kt();let s=ro(e);if(!s)return;s.notify=()=>o(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:n});no(e,i),de.forEach((a,u)=>{try{a.onStoreWrite?.(i);}catch(c){Ve(e,`Feature "${String(u)}" onStoreWrite for "${e}" failed: ${c?.message??c}`,"always");}});};var io=(e,t)=>xn({name:e,payload:t,middlewares:(()=>{let r=_[e]?.options?.middleware||[],n=T().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{Ve(e,r,n);},warn:f}),Ut=(e,t,r,n)=>Vt({name:e,label:t,fn:r,args:n,reportIssue:(o,s)=>{Ve(e,o,s);}}),ao=(e,t)=>{let r={...t};return r.persist&&!Tt("persist")&&(r.explicitPersist&&Bt(e,"persist",r.onError),r.persist=null),r.sync&&!Tt("sync")&&(r.explicitSync&&Bt(e,"sync",r.onError),r.sync=false),Tt("devtools")||(r.explicitDevtools&&Bt(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var ai=32,Tr=new Set;A("store-write.slow-mutator-warned",()=>Tr.clear(),65);var ci=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var fo=(e,t)=>{E()&&(t<ai||Tr.has(e)||(Tr.add(e),f(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},po=e=>e??Wt(),ui=(e,t)=>{if(!e||!t)return;let r=t.resetElapsedMs;typeof r=="number"&&(e.metrics.resetCount=(e.metrics.resetCount??0)+1,e.metrics.totalResetMs=(e.metrics.totalResetMs??0)+r,e.metrics.lastResetMs=r);},lo=(e,{name:t,prev:r,next:n,action:o,hookLabel:s,logMessage:i,context:a,metricsUpdate:u})=>{let c=e.metaEntries;fe(t,n,e),Se(t);let l=Date.now();c[t].updatedAt=new Date(l).toISOString(),c[t].updatedAtMs=l;let R=a??Wt();R&&(R.correlationId||R.traceContext)?(c[t].lastCorrelationId=R.correlationId??null,c[t].lastCorrelationAt=new Date(l).toISOString(),c[t].lastCorrelationAtMs=l,c[t].lastTraceContext=R.traceContext??null):(c[t].lastCorrelationId=null,c[t].lastCorrelationAt=null,c[t].lastCorrelationAtMs=null,c[t].lastTraceContext=null),ci(c[t]),ui(c[t],u),so(t,o,r,n,Xe),Ut(t,s,c[t].options[s],[r,n]),Xe(t),te(i);},go=(e,t)=>{let r=t.context??Wt();if(N()){_t(t.name,t.next),Dn(t.runtimePatches??[]),$t(()=>lo(e,{...t,context:r}));return}lo(e,{...t,context:r}),t.runtimePatches&&t.runtimePatches.length>0&&On(t.runtimePatches,e);};var li=(e,t,r,n)=>{let o=Me(e),s=D(),i=s.metaEntries;if(!qt(o,s))return {ok:false,reason:"validate"};if(!ae(o,s)){let h=`setStore("${o}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return me(o,h),N()&&K(h),{ok:false,reason:"not-found"}}let a,u={kind:"root"},c=N()?Ke(o):{has:false,value:void 0},l=c.has?c.value:yt(o,s);if(typeof t=="function"&&r===void 0){let h=E()?Date.now():0;try{let m=T().mutatorProduce,k=!1,F,v=O=>{let M=t(O);return M!==void 0&&(k=!0,F=M),M},y=m?m(l,v):(()=>{let O=I(l);return v(O),O})();if(k&&T().strictMutatorReturns){let O=`setStore("${o}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return me(o,O),N()&&K(O),{ok:!1,reason:"validate"}}k&&E()&&!T().strictMutatorReturns&&f(`setStore("${o}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=k&&!T().strictMutatorReturns?F:y,u={kind:"root"};}catch(m){return me(o,`Mutator for "${o}" failed: ${m?.message??m}`),N()&&K(m),{ok:false,reason:"validate"}}finally{h&&fo(o,Date.now()-h);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!Le(t))return N()&&K(`setStore("${o}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof l!="object"||l===null||Array.isArray(l))return j(`setStore("${o}", data) only merges into object stores.
|
|
14
|
-
Use setStore("${o}", "path", value) or recreate the store with an object shape.`),N()&&K(`setStore("${o}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let h=Ie(o,t);if(!h.ok)return N()&&K(`setStore("${o}") failed sanitize`),{ok:false,reason:"validate"};a={...l,...h.value},u={kind:"merge",value:h.value};}else if(typeof t=="string"||Array.isArray(t)){if(!ut(t))return N()&&K(`setStore("${o}") received invalid path`),{ok:false,reason:"invalid-args"};let h=Ie(o,r);if(!h.ok)return N()&&K(`setStore("${o}") failed sanitize`),{ok:false,reason:"validate"};let m=h.value,k=Qn(o,l,t,m);if(!k.ok)return re(i[o]?.options?.onError,`onError(${o})`,k.reason??`Invalid path for "${o}".`),N()&&K(k.reason),{ok:false,reason:"path"};a=fr(l,t,m),u={kind:"path",path:t,value:m};}else {let h=`setStore("${o}") - invalid arguments.
|
|
15
|
-
Usage:
|
|
16
|
-
setStore("${o}", "field", value)
|
|
17
|
-
setStore("${o}", "nested.field", value)
|
|
18
|
-
setStore("${o}", { field: value })
|
|
19
|
-
setStore(storeDef, draft => { draft.field = value })
|
|
20
|
-
replaceStore("${o}", value) // full-store replace`;return j(h),re(i[o]?.options?.onError,`onError(${o})`,h),N()&&K(h),{ok:false,reason:"invalid-args"}}if(!Le(a))return N()&&K(`setStore("${o}") produced invalid data`),{ok:false,reason:"validate"};let b=i[o]?.options?.validate,g=po(n),C=io(o,{action:"set",prev:l,next:a,path:t,correlationId:g?.correlationId,traceContext:g?.traceContext});if(C===Nt)return N()&&K(`setStore("${o}") aborted by middleware`),{ok:false,reason:"middleware"};let d=Object.is(C,a),S=bt(o,C,b,void 0,d?{reuseInput:true}:void 0);if(!S.ok)return N()&&K(`setStore("${o}") failed validation`),{ok:false,reason:"validate"};let w=Pn({store:o,intent:u,committedValue:S.value,preserveIntent:u.kind!=="root"&&Object.is(C,a)&&Object.is(S.value,C),context:g});try{if(lr(l,S.value))return {ok:!0}}catch{}return go(s,{name:o,prev:l,next:S.value,action:"set",hookLabel:"onSet",logMessage:`Store "${o}" updated`,context:g,runtimePatches:w}),{ok:true}},wt=(e,t,r,n)=>li(e,t,r,n);var fi=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},yo=(e,t)=>t==="ref"?e:t==="shallow"?De(e):I(e);function Gt(e,t){let r=Me(e);if(!qn(r))return null;let n=D();if(!qt(r,n))return null;kr(r,n);let o=yt(r,n),s=fi(n.metaEntries[r],T().defaultSnapshotMode);return o===null||typeof o!="object"?o:yo(o,s);}var he=e=>ae(e);var pi=()=>D().computedCleanups,mo=new WeakMap;var gi=e=>{let t=mo.get(e);return t||(t=new Map,mo.set(e,t)),t};var So=e=>{let t=pi(),r=t.get(e);if(!r){E()&&f(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var ho=(e,t=D())=>gi(t).get(e)?.autoDispose===true;var bo=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,a=e.featureRuntimes,u=e.deletingStores,c=(d,S)=>{Ne(S,{onError:s[d]?.options?.onError,severity:"warn",visibility:"dev"});},l=({name:d,prev:S,options:w,initialState:h,getMeta:m,getStoreValue:k,hasStore:F})=>({name:d,options:w,prev:S,getMeta:m,getStoreValue:k,getAllStores:()=>t,getInitialState:()=>h,hasStore:F,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:v=>{Ne(v,{onError:w.onError,severity:"warn",visibility:"dev"});},warn:f,warnAlways:se,log:te,hashState:ct,deepClone:I,sanitize:Ae,validate:()=>({ok:true,value:S}),isDev:E}),R=({name:d,prev:S,options:w,initialState:h,phase:m})=>{let k=l({name:d,prev:S,options:w,initialState:h,getMeta:()=>s[d],getStoreValue:()=>t[d],hasStore:()=>Fe(e,d)}),F=l({name:d,prev:S,options:w,initialState:h,getMeta:()=>{},getStoreValue:()=>S,hasStore:()=>false});ze().forEach(v=>{let y=a.get(v);m==="before"?y?.beforeStoreDelete?.(k):y?.afterStoreDelete?.(F);});},b=d=>{if(!Fe(e,d))return;let S=t[d],w=s[d].options,h=n[d],m=r[d];u.add(d);try{m?.forEach(v=>{try{v(null);}catch(y){f(`Subscriber for "${d}" threw during delete: ${y?.message??y}`);}}),Vt({name:d,label:"onDelete",fn:w.onDelete,args:[S],reportIssue:(v,y)=>{Ne(v,{onError:w.onError,severity:"warn",visibility:y});}}),R({name:d,prev:S,options:w,initialState:h,phase:"before"}),delete t[d],delete r[d],delete n[d],delete o[d],delete s[d],delete i[d],Tn(d)&&So(d);let F=e.computedDependents[d];if(F)for(let v of [...F]){let y=mr(v);if(y&&ho(v,e)&&y.deps.every(O=>!Fe(e,O))){b(v);continue}f(`[stroid] source store "${d}" was deleted. Computed store "${v}" depends on it and will return stale data. Call deleteComputed("${v}") to clean up.`);}R({name:d,prev:S,options:w,initialState:h,phase:"after"}),pt("afterStoreDelete",d,{type:"afterStoreDelete",prev:S}),Pt(e,{type:"deleted",name:d}),te(`Store "${d}" deleted`);}finally{u.delete(d);}};return {deleteExistingStore:b,clearAllStores:()=>{let d=[],w=0,h=Number.POSITIVE_INFINITY;for(;w<20;){let k=Object.keys(t);if(k.length===0)break;k.forEach(v=>{Fe(e,v)&&(b(v),d.push(v));}),w+=1;let F=Object.keys(t).length;if(F===0||F>=h)break;h=F;}let m=Object.keys(t).length;return m>0?f(`clearAllStores stopped after ${w} pass${w===1?"":"es"}; ${m} store(s) still registered (likely recreated during deletion).`):te(`All stores cleared (${d.length} stores removed)`),d},clearStores:d=>{let S=Object.keys(t).filter(w=>d?d.endsWith("*")?w.startsWith(d.slice(0,-1)):w===d:true);return S.forEach(w=>b(w)),S},reportStoreError:c}};var Fr=We,Ro=He(Fr),vo=null,G=()=>{let e=oe(Ro);return Qt(e),e};var D=()=>G();var xo=(e,t)=>{Pt(e,t);};function Zn(e){vo=e;}var Je=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}}}),yi=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)}),mi=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)}),St=Je(()=>G().stores);Je(()=>G().subscribers);var co=Je(()=>G().initialStates);Je(()=>G().initialFactories);var _=Je(()=>G().metaEntries);Je(()=>G().snapshotCache);var de=yi(()=>G().featureRuntimes),wo=new WeakMap,Si=e=>{let t=wo.get(e);return t||(t=bo(e),wo.set(e,t)),t};mi(()=>Si(G()));var hi=e=>{let t=de.get(e);if(t)return t;let r=Ft(e);if(!r)return;let n=r();return de.set(e,n),n},Kt=()=>{ze().forEach(e=>{hi(e);});};Kt();var ae=(e,t)=>Fe(t??G(),e),yt=(e,t=G())=>{if(N()){let r=Ke(e);if(r.has)return r.value}return Wn(e,t)},Wn=(e,t=G())=>{let r=st();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},fe=(e,t,r=G())=>{r.stores[e]=t;},uo=(e,t,r=Date.now())=>{fe(e,t),_[e]&&(_[e].updatedAt=new Date(r).toISOString(),_[e].updatedAtMs=r,_[e].lastCorrelationId=null,_[e].lastCorrelationAt=null,_[e].lastCorrelationAtMs=null,_[e].lastTraceContext=null,_[e].updateCount>=Number.MAX_SAFE_INTEGER?_[e].updateCount=0:_[e].updateCount+=1,vo?.(e));},kr=(e,t=G())=>{let r=t.metaEntries[e];if(!r)return;r.readCount=(r.readCount??0)+1;let n=Date.now();r.lastReadAtMs=n,r.lastReadAt=new Date(n).toISOString();},bi=()=>{Gr(G());},wi=()=>{de.forEach(e=>{try{e.resetAll?.();}catch{}}),de.clear();};A("features.reset",wi,10);A("registries.clear",bi,20);A("registry.default",()=>{Fr=We,Ro=He(Fr);},115);var Gn=e=>Kr(G(),e);var Yt=new Set,Ri=e=>{Yt.clear();};A("store-create.ssr-global-warned",()=>Ri(),65);function Ar(e,t,r={}){if(N()){let v=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;mt(v,r.onError),K(v);return}if(!ar(e)){mt(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Le(t)){mt(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&E()&&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.`),Rn(r).forEach(v=>{f(v);});let o=ao(e,vn(r,e,T().defaultSnapshotMode));if(o.scope==="temp"&&r.persist){let v=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;re(o.onError,`onError(${e})`,v),E()||se(v),j(v);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",u=o.allowSSRGlobalStore??false,c=D(),l=c.stores,R=c.subscribers,b=c.initialStates,g=c.initialFactories,C=c.metaEntries,d=c.scope==="request";if(a&&!u&&!d){let v=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
|
|
21
|
-
Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;mt(v,r.onError);return}if(a&&u&&!d&&!Yt.has(e)&&(Yt.add(e),se(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
|
|
22
|
-
This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),ae(e,c)){let v=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return Ve(e,v),{name:e}}s&&!u&&!d&&!Ln(e)&&E()&&(Bn(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 S=Ie(e,t,o.onError);if(!S.ok)return;let w=S.value,h=o.lazy===true&&typeof t=="function",m=(R[e]?.size??0)>0;if(h)l[e]=void 0,g[e]=t;else {let v=bt(e,w,o.validate,o.onError);if(!v.ok)return;fe(e,v.value,c),b[e]=I(v.value);}let k=Date.now(),F=new Date(k).toISOString();return C[e]={createdAt:F,updatedAt:F,updatedAtMs:k,updateCount:0,version:o.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0,resetCount:0,totalResetMs:0,lastResetMs:0},options:o,readCount:0,lastReadAt:null,lastReadAtMs:null,lastCorrelationId:null,lastCorrelationAt:null,lastCorrelationAtMs:null,lastTraceContext:null},Se(e),oo(e,Xe),Ut(e,"onCreate",C[e].options.onCreate,[w]),xo(c,{type:"created",name:e,isGlobal:o.scope==="global",isTemp:o.scope==="temp"}),m&&Xe(e),te(`Store "${e}" created -> ${JSON.stringify(w)}`),{name:e}}var U=()=>oe().async;var Co=100,Pr=100,xi=1e3,Qe=()=>U().fetchRegistry,je=()=>U().inflight,Ze=()=>U().requestVersion,et=()=>U().cacheMeta,Or=()=>U().rateWindowStart,Dr=()=>U().rateCount;var Eo=()=>U().revalidateHandlers,Rt=()=>U().storeCleanups,To=()=>U().warnedOnce,Fo=()=>U().revalidateKeys,vt=()=>U().asyncMetrics,Ci=e=>{let t=To(),r=t.get(e);return r||(r=new Set,t.set(e,r)),r},ki=(e,t)=>{if(e.has(t)||(e.add(t),e.size<=xi))return;let r=e.values().next().value;r!==void 0&&e.delete(r);},xt=(e,t,r)=>{let n=Ci(e);n.has(t)||(ki(n,t),r());},ko=null,Mo=e=>{e&&Array.from(e).forEach(t=>{try{t();}catch{}});},Mi=e=>{let t=Rt(),r=t[e];return r||(r=Object.create(null),t[e]=r),r},Ao=(e,t)=>{Object.keys(t).length===0&&delete Rt()[e];},Po=(e,t)=>{if(t){Mo(e[t]),delete e[t];return}Object.keys(e).forEach(r=>{Mo(e[r]),delete e[r];});},Ei=e=>{let t=Rt(),r=t[e];r&&(Po(r),delete t[e]);},Oo=e=>{let t=Rt();Object.entries(t).forEach(([r,n])=>{n[e]&&(Po(n,e),Ao(r,n));});},Do=()=>{ko||(ko=jn("afterStoreDelete",e=>{Ei(e),Ti(e);}));},No=()=>{At(U());},Vo=(e,t)=>{if(!t)return false;let r=et(),n=r[e];return n?n.expiresAt!==null&&n.expiresAt<=Date.now()?(delete r[e],false):Date.now()-n.timestamp<t:false},Ti=e=>{let t=Qe(),r=et(),n=je(),o=Ze(),s=Or(),i=Dr(),a=To();delete t[e],a.get("noSignal")?.delete(e),a.get("shape")?.delete(e),a.get("autoCreate")?.delete(e),a.get("mutableResult")?.delete(e);let u=c=>c===e||c.startsWith(`${e}:`);Object.keys(n).forEach(c=>{u(c)&&delete n[c];}),Object.keys(o).forEach(c=>{u(c)&&delete o[c];}),Object.keys(r).forEach(c=>{u(c)&&delete r[c];}),Object.keys(s).forEach(c=>{u(c)&&delete s[c];}),Object.keys(i).forEach(c=>{u(c)&&delete i[c];});},Io=e=>{let t=`${e}:`,r=et(),n=Ze(),o=Object.entries(r).filter(([i,a])=>i!==e&&!i.startsWith(t)?false:a.expiresAt!==null&&a.expiresAt<=Date.now()?(delete r[i],false):true).sort((i,a)=>i[1].timestamp-a[1].timestamp);if(o.length<=Co)return;let s=o.length-Co;o.slice(0,s).forEach(([i])=>{delete r[i],delete n[i];});},jo=e=>{let t=`${e}:`,r=je(),n=0;return Object.keys(r).forEach(o=>{(o===e||o.startsWith(t))&&(n+=1);}),n},Nr=(e,t,r="store")=>{Do();let n=Mi(e),o=n[r];o||(o=new Set,n[r]=o),o.add(t);},Vr=(e,t,r)=>{let o=Rt()[e];if(!o)return;let s=i=>{let a=o[i];a&&(a.delete(t),a.size===0&&delete o[i]);};r?s(r):Object.keys(o).forEach(s),Ao(e,o);},$o=e=>{Do();};var _o=10,Fi=10,Ir=3e4,Ai=8,Wo=(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});}),zo=(e,t,r,n)=>Number.isFinite(r)?r:(f(`fetchStore("${e}") received non-finite ${t}; using ${n}.`),n),Ho=(e,t,r,n)=>{let o=Number.isFinite(t)?t:t>0?_o:0,s=Math.min(_o,Math.max(0,Math.trunc(o)));Number.isFinite(t)||f(`fetchStore("${e}") received non-finite retry; using ${s}.`);let i=Math.min(Ir,Math.max(Fi,zo(e,"retryDelay",r,400))),a=Math.min(Ai,Math.max(1,zo(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.`),a!==n&&f(`fetchStore("${e}") clamped retryBackoff to ${a}.`),{retry:s,retryDelay:i,retryBackoff:a}};var Lo=(e,t)=>!t||t==="none"||e===null||typeof e!="object"?e:t==="shallow"?De(e):I(e);var tt=(e,t,r,n)=>{if(typeof r=="function")try{r(n);}catch(o){f(`fetchStore("${e}") ${t} callback failed: ${o?.message??o}`);}},ce=(e,t,r)=>T().strictAsyncUsageErrors?Pi(e,t,r):(tt(e,"onError",r,t),E()?(j(t),null):(L(t),null)),Pi=(e,t,r)=>{throw tt(e,"onError",r,t),E()?j(t):L(t),new Error(t)};var Ct=(e,t)=>(Ze()[e]??0)===t,Bo=e=>{let t=Ze(),r=(t[e]??0)+1;return t[e]=r,r},qo=(e,t)=>{let r=Ze();r[e]===t&&delete r[e];},Uo=(e,t)=>{let r=je();r[e]=t;},Ko=e=>{let t=je();delete t[e];},Go=e=>!!je()[e],Yo=(e,t,r,n)=>{let o=je()[t];if(o)return vt().dedupes+=1,r&&o.transform&&o.transform!==r?(ce(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 rt=1e3,jr=100,Xo=(e,t)=>{t-e.ratePruneState.lastAt<rt||(e.ratePruneState.lastAt=t,Object.keys(e.rateWindowStart).forEach(r=>{t-(e.rateWindowStart[r]??0)>rt&&(delete e.rateWindowStart[r],delete e.rateCount[r]);}));},Jo=e=>{Xo(U(),e);},Qo=(e=rt)=>{let t=U();t.ratePruneTimer||typeof setTimeout=="function"&&(t.ratePruneTimer=setTimeout(()=>{t.ratePruneTimer=null,Xo(t,Date.now());},e));},Zo=(e,t)=>{let r=Or(),n=Dr(),o=r[e],s=n[e]??0;return o!==void 0&&t-o<rt?s>=jr?true:(n[e]=s+1,false):(r[e]=t,n[e]=1,false)};var es=e=>{let t={},r=(e.method??"GET").toUpperCase(),n=e.body!==void 0&&e.body!==null;return e.method&&(t.method=r),e.headers?t.headers=e.headers:(n||!["GET","HEAD","DELETE"].includes(r))&&(t.headers={"Content-Type":"application/json"}),n&&(t.body=typeof e.body=="string"?e.body:JSON.stringify(e.body)),e.signal&&(t.signal=e.signal),t},ts=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 Oi=e=>{if(!e||typeof e!="object")return false;let t=e;return "data"in t&&"loading"in t&&"error"in t&&"status"in t},Di=(e,t,r,n,o)=>{if(!he(e))return;let s=n.stateAdapter;if(s){try{let i=Gt({name:e}),a=u=>{wt(t,u,void 0,o);};Ye(o,()=>{s({name:e,prev:i,next:r,set:a});});}catch(i){f(`fetchStore("${e}") stateAdapter failed: ${i?.message??i}`);}return}Ye(o,()=>{wt(t,r,void 0,o);});},nt=(e,t,r,n)=>(f(`fetchStore("${e}") aborted`),Ct(t,r)&&he(e)&&n({loading:false,error:"aborted",status:"aborted",revalidating:false}),null);async function kt(e,t,r={}){let n=Me(e);if(!n||typeof n!="string"){j("fetchStore requires a store name as first argument");return}let o={name:n};if(!t){j(`fetchStore("${n}") requires a URL, Promise, or Promise factory as second argument`);return}let{transform:s,onSuccess:i,onError:a,stateAdapter:u,method:c,headers:l,body:R,ttl:b,staleWhileRevalidate:g=false,dedupe:C=true,retry:d=0,retryDelay:S=400,retryBackoff:w=1.7,signal:h,cacheKey:m,responseType:k="auto"}=r,F=et(),v=Qe(),y=vt(),O=(()=>{let P=r.correlationId,Q=r.traceContext;return P||Q?{correlationId:P,traceContext:Q}:T().autoCorrelationIds?{correlationId:`stroid-${n}-${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,traceContext:Q}:null})();!h&&E()&&xt("noSignal",n,()=>{f(`fetchStore("${n}") called without an AbortSignal. Provide "signal" to enable cancellation (recommended).`);});let M=m?`${n}:${m}`:n,B=P=>Di(n,o,O?{...P,correlationId:O.correlationId,traceContext:O.traceContext}:P,r,O),be=typeof t!="string"&&typeof t!="function"&&typeof t?.then=="function",Ee=Ho(n,d,S,w),x=false,z=be&&d>0,V=typeof window>"u"&&(typeof process<"u"?process.env?.NODE_ENV:void 0)==="production",p=r.autoCreate??T().asyncAutoCreate,pe=r.cloneResult??T().asyncCloneResult;if(u&&!he(n))return ce(n,`fetchStore("${n}") with stateAdapter requires an existing backing store.
|
|
23
|
-
Call createStore("${n}", ...) first or omit stateAdapter to use the default AsyncState shape.`,a);if(!he(n)&&V)return ce(n,`fetchStore("${n}") cannot create a backing store on the server in production.
|
|
24
|
-
Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,a);if(!he(n)){if(!p)return ce(n,`fetchStore("${n}") requires an existing backing store when autoCreate is disabled.
|
|
25
|
-
Call createStore("${n}", ...) first or enable autoCreate.`,a);if(E()&&xt("autoCreate",n,()=>{let P=`fetchStore("${n}") auto-created its backing store.
|
|
26
|
-
Call createStore("${n}", ...) first to avoid typos creating phantom stores.`;re(a,`fetchStore.onError(${n})`,P),f(P);}),Ar(n,{data:null,loading:false,error:null,status:"idle"}),!he(n))return ce(n,`fetchStore("${n}") could not initialize its backing store.
|
|
27
|
-
On the server in production, use createStoreForRequest(...) inside the request scope or create the store with { allowSSRGlobalStore: true } before calling fetchStore.`,a)}if(!u){let P=Gt({name:n});if(P&&!Oi(P))return xt("shape",n,()=>{}),ce(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.`,a)}$o();let Y=null,W=false,J=()=>F[M]?.data??null;if(Vo(M,b)){if(y.cacheHits+=1,Y=J(),B({data:Y,loading:g,error:null,status:"success",cached:true,revalidating:g}),!g)return Y;W=true;}else y.cacheMisses+=1;if(C){let P=Yo(n,M,s,a);if(P!==void 0)return P}let ue=Date.now();if(Jo(ue),Qo(),Zo(M,ue))return ce(n,`fetchStore("${n}") rate limited: ${jr} requests per ${rt}ms window for store "${n}".`,a);if(!Go(M)&&jo(n)>=Pr)return ce(n,`fetchStore("${n}") exceeded ${Pr} concurrent request slots. Reuse cacheKey values, wait for pending requests, or delete the store to clear async state.`,a);let H=Bo(M);W||B({loading:true,error:null,status:"loading",cached:false,revalidating:false}),y.requests+=1;let Te=Date.now(),le=!h&&typeof AbortController<"u"?new AbortController:null,Z=h||le?.signal,X=le?()=>{le.signal.aborted||le.abort();}:null;X&&Nr(n,X);let q=async()=>{let P=0,Q=Ee.retryDelay;for(;;){if(Z?.aborted)return nt(n,M,H,B);let ge=typeof t=="function"?t():t,$r=be||typeof ge!="string"&&typeof ge?.then=="function",_r=$r?{...Ee,retry:0}:Ee;$r&&(d>0||z)&&!x&&(f(`fetchStore("${n}") ignores retry settings for direct Promise inputs; pass a URL string or factory to use retries.`),x=true);try{let Re;if(typeof ge=="string"){let Mt=es({method:c,headers:l,body:R,signal:Z,...r}),Et=await fetch(ge,Mt);if(!Et.ok)throw new Error(`HTTP ${Et.status}: ${Et.statusText}`);Re=await ts(Et,k);}else if(typeof ge.then=="function")Re=await ge;else return j(`fetchStore("${n}") - second argument must be a URL string, Promise, or Promise factory.
|
|
28
|
-
Examples:
|
|
29
|
-
fetchStore("users", "https://api.example.com/users")
|
|
30
|
-
fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(Z?.aborted)return nt(n,M,H,B);let _e=s?s(Re):Re;if(_e&&typeof _e.then=="function"){let Mt=`fetchStore("${n}") transform must be synchronous. Return the transformed value directly instead of a Promise.`;return Ct(M,H)&&B({data:W?J():null,loading:!1,error:Mt,status:"error",cached:W,revalidating:!1}),ce(n,Mt,a)}pe==="none"&&E()&&_e&&typeof _e=="object"&&xt("mutableResult",n,()=>{f(`fetchStore("${n}") received a mutable object while asyncCloneResult is "none".
|
|
31
|
-
Async data is stored by reference; mutations will affect cache and subscribers.
|
|
32
|
-
Set cloneResult: "deep" (per call) or configureStroid({ asyncCloneResult: "deep" }).`);});let ve=Lo(_e,pe);if(Z?.aborted)return nt(n,M,H,B);if(!Ct(M,H))return null;F[M]={timestamp:Date.now(),expiresAt:b?Date.now()+b:null,data:ve},Io(n),B({data:ve,loading:!1,error:null,status:"success",cached:!1,revalidating:!1}),tt(n,"onSuccess",i,ve);let zr=Date.now()-Te;return y.lastMs=zr,y.avgMs=(y.avgMs*(y.requests-1)+zr)/y.requests,{raw:Re,transformed:ve}}catch(Re){if(P+=1,Re?.name==="AbortError")return nt(n,M,H,B);if(P<=_r.retry){if(Z?.aborted||(await Wo(Q,Z),Z?.aborted))return nt(n,M,H,B);Q=Math.min(Ir,Q*_r.retryBackoff);continue}if(!Ct(M,H))return null;let ve=Re?.message||"Something went wrong";return B({data:W?J():null,loading:false,error:ve,status:"error",cached:W,revalidating:false}),tt(n,"onError",a,ve),y.failures+=1,f(`fetchStore("${n}") failed: ${ve}`),null}}},ee=null,ne=new Promise((P,Q)=>{h||(ee=setTimeout(()=>{ee=null,Q(new Error("Timeout: async request hung for 60 seconds without an AbortSignal"));},6e4));}),$e=Promise.race([q().finally(()=>{ee&&(clearTimeout(ee),ee=null);}),ne]).catch(P=>{let Q=P?.message||"Request timed out";return B({data:W?J():null,loading:false,error:Q,status:"error",cached:W,revalidating:false}),tt(n,"onError",a,Q),y.failures+=1,f(`fetchStore("${n}") failed: ${Q}`),null}),we=$e.then(P=>P?.transformed??null).finally(()=>{Ko(M),qo(M,H),X&&Vr(n,X);}),ot=$e.then(P=>P?.raw);return Uo(M,{promise:we,raw:ot,transform:s}),typeof t=="function"?v[n]={kind:"factory",factory:t,options:{...r,cacheKey:m}}:typeof t=="string"?v[n]={kind:"url",url:t,options:{...r,cacheKey:m}}:delete v[n],we}async function rs(e){let t=Me(e);if(!he(t))return;let n=Qe()[t];if(!n){let s=`${t}:`,i=et(),a=Object.entries(i).filter(([u])=>u===t||u.startsWith(s));if(a.length>0){let[,u]=a.reduce((c,l)=>l[1].timestamp>=c[1].timestamp?l:c);return u.data}E()&&f(`refetchStore("${t}") - no previous fetch found.
|
|
33
|
-
Call fetchStore("${t}", url) first.`);return}let o={name:t};return n.kind==="factory"?kt(o,n.factory,n.options):kt(o,n.url,n.options)}function Ni(e,t){if(typeof window>"u"||typeof window.addEventListener!="function")return ()=>{};let r=Fo(),n=Eo(),s=(e==="*"?"*":e?Me(e):void 0)??"*";if(r.has(s))return n[s]??(()=>{});let i=T().revalidateOnFocus,a=Math.max(0,t?.debounceMs??i.debounceMs),u=Math.max(1,t?.maxConcurrent??i.maxConcurrent),c=Math.max(0,t?.staggerMs??i.staggerMs),l=null,R=()=>{let C=Qe(),d=s==="*"?Object.keys(C):[s];if(t?.priority==="high"&&s!=="*"&&(d=[s,...d.filter(h=>h!==s)]),d.length===0)return;let S=0,w=()=>{let h=d.slice(S,S+u);if(h.forEach((m,k)=>{let F=()=>{let y=Qe()[m];if(!y){rs({name:m});return}y.kind==="factory"?kt({name:m},y.factory,y.options):kt({name:m},y.url,y.options);};c>0?setTimeout(F,k*c):F();}),S+=h.length,S<d.length){let m=c>0?c*Math.max(1,h.length):0;setTimeout(w,m);}};w();},b=()=>{if(a===0){R();return}l!==null&&clearTimeout(l),l=setTimeout(R,a);};window.addEventListener("focus",b),window.addEventListener("online",b),r.add(s);let g=()=>{window.removeEventListener("focus",b),window.removeEventListener("online",b),l!==null&&(clearTimeout(l),l=null),r.delete(s),delete n[s],Vr(s,g,"revalidate");};return n[s]=g,Nr(s,g,"revalidate"),g}var Vi=()=>({...vt()}),Ii=()=>{ji(),No();},ji=()=>{Oo("revalidate");};export{Ii as _resetAsyncStateForTests,Ni as enableRevalidateOnFocus,kt as fetchStore,Vi as getAsyncMetrics,rs as refetchStore};//# sourceMappingURL=async.js.map
|
|
1
|
+
import'./chunk-YU5GMPCC.js';export{e as _resetAsyncStateForTests,c as enableRevalidateOnFocus,a as fetchStore,d as getAsyncMetrics,b as refetchStore}from'./chunk-BW32TJGE.js';import'./chunk-6ELWGQ4Q.js';import'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';//# sourceMappingURL=async.js.map
|
|
34
2
|
//# sourceMappingURL=async.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {k as k$1,b as b$1,aa}from'./chunk-FOQKGHPS.js';var c=()=>k$1().async;var R=100,L=100,E=1e3,j=()=>c().fetchRegistry,C=()=>c().inflight,h=()=>c().requestVersion,x=()=>c().requestSequence,y=()=>c().cacheMeta,w=()=>c().rateWindowStart,q=()=>c().rateCount;var X=()=>c().revalidateHandlers,g=()=>c().storeCleanups,m=()=>c().warnedOnce,$=()=>c().revalidateKeys,z=()=>c().asyncMetrics,W=e=>{let r=m(),t=r.get(e);return t||(t=new Set,r.set(e,t)),t},K=(e,r)=>{if(e.has(r)||(e.add(r),e.size<=E))return;let t=e.values().next().value;t!==void 0&&e.delete(t);},k=(e,r,t)=>{let n=W(e);n.has(r)||(K(n,r),t());},A=null,v=e=>{e&&Array.from(e).forEach(r=>{try{r();}catch{}});},M=e=>{let r=g(),t=r[e];return t||(t=Object.create(null),r[e]=t),t},O=(e,r)=>{Object.keys(r).length===0&&delete g()[e];},T=(e,r)=>{if(r){v(e[r]),delete e[r];return}Object.keys(e).forEach(t=>{v(e[t]),delete e[t];});},_=e=>{let r=g(),t=r[e];t&&(T(t),delete r[e]);},G=e=>{let r=g();Object.entries(r).forEach(([t,n])=>{n[e]&&(T(n,e),O(t,n));});},b=()=>{A||(A=aa("afterStoreDelete",e=>{_(e),B(e);}));},U=()=>{b$1(c());},J=(e,r)=>{if(!r)return false;let t=y(),n=t[e];return n?n.expiresAt!==null&&n.expiresAt<=Date.now()?(delete t[e],false):Date.now()-n.timestamp<r:false},B=e=>{let r=j(),t=y(),n=C(),o=h(),a=x(),p=w(),i=q(),u=m();delete r[e],u.get("noSignal")?.delete(e),u.get("shape")?.delete(e),u.get("autoCreate")?.delete(e),u.get("mutableResult")?.delete(e);let l=s=>s===e||s.startsWith(`${e}:`);Object.keys(n).forEach(s=>{l(s)&&delete n[s];}),Object.keys(o).forEach(s=>{l(s)&&delete o[s];}),Object.keys(a).forEach(s=>{l(s)&&delete a[s];}),Object.keys(t).forEach(s=>{l(s)&&delete t[s];}),Object.keys(p).forEach(s=>{l(s)&&delete p[s];}),Object.keys(i).forEach(s=>{l(s)&&delete i[s];});},Q=e=>{let r=`${e}:`,t=y(),n=h(),o=x(),a=Object.entries(t).filter(([i,u])=>i!==e&&!i.startsWith(r)?false:u.expiresAt!==null&&u.expiresAt<=Date.now()?(delete t[i],false):true).sort((i,u)=>i[1].timestamp-u[1].timestamp);if(a.length<=R)return;let p=a.length-R;a.slice(0,p).forEach(([i])=>{delete t[i],delete n[i],delete o[i];});},Y=e=>{let r=`${e}:`,t=C(),n=0;return Object.keys(t).forEach(o=>{(o===e||o.startsWith(r))&&(n+=1);}),n},Z=(e,r,t="store")=>{b();let n=M(e),o=n[t];o||(o=new Set,n[t]=o),o.add(r);},ee=(e,r,t)=>{let o=g()[e];if(!o)return;let a=p=>{let i=o[p];i&&(i.delete(r),i.size===0&&delete o[p]);};t?a(t):Object.keys(o).forEach(a),O(e,o);},te=e=>{b();};export{c as a,L as b,j as c,C as d,h as e,x as f,y as g,w as h,q as i,X as j,$ as k,z as l,k as m,G as n,U as o,J as p,Q as q,Y as r,Z as s,ee as t,te as u};//# sourceMappingURL=chunk-6ELWGQ4Q.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-6ELWGQ4Q.js.map
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import {g,c,l,m,u,p as p$1,r as r$1,b,s,t,k,j,o,n as n$1,q,d,a,h,i,f,e}from'./chunk-6ELWGQ4Q.js';import {G,r,l as l$1,n,p,N,A,K as K$1,M,o as o$1,V,S as S$1,u as u$1,v,w}from'./chunk-FOQKGHPS.js';var Ue=10,ht=10,Se=3e4,yt=8,Ve=(e,t)=>new Promise(n=>{if(t?.aborted){n();return}let r=setTimeout(()=>{t?.removeEventListener("abort",s),n();},e),s=()=>{clearTimeout(r),t?.removeEventListener("abort",s),n();};t?.addEventListener("abort",s,{once:true});}),He=(e,t,n,r)=>Number.isFinite(n)?n:(p(`fetchStore("${e}") received non-finite ${t}; using ${r}.`),r),Ye=(e,t,n,r)=>{let s=Number.isFinite(t)?t:t>0?Ue:0,o=Math.min(Ue,Math.max(0,Math.trunc(s)));Number.isFinite(t)||p(`fetchStore("${e}") received non-finite retry; using ${o}.`);let l=Math.min(Se,Math.max(ht,He(e,"retryDelay",n,400))),i=Math.min(yt,Math.max(1,He(e,"retryBackoff",r,1.7)));return o!==t&&p(`fetchStore("${e}") clamped retry attempts to ${o}.`),l!==n&&p(`fetchStore("${e}") clamped retryDelay to ${l}ms.`),i!==r&&p(`fetchStore("${e}") clamped retryBackoff to ${i}.`),{retry:o,retryDelay:l,retryBackoff:i}};var Ge=(e,t)=>!t||t==="none"||e===null||typeof e!="object"?e:t==="shallow"?u$1(e):v(e);var K=(e,t,n,r)=>{if(typeof n=="function")try{n(r);}catch(s){p(`fetchStore("${e}") ${t} callback failed: ${s?.message??s}`);}},S=(e,t,n$1)=>l$1().strictAsyncUsageErrors?gt(e,t,n$1):(K(e,"onError",n$1,t),n()?(r(t),null):(o$1(t),null)),gt=(e,t,n$1)=>{throw K(e,"onError",n$1,t),n()?r(t):o$1(t),new Error(t)};var Xe=(e,t)=>Object.is(e,t)?true:!e||!t||typeof e!="object"||typeof t!="object"?false:w(e,t),St=(e,t)=>{if(!e||!t)return true;if(e.requestKind!==t.requestKind)return false;if(e.requestKind==="url"){if(e.url!==t.url)return false}else if(!Object.is(e.requestRef,t.requestRef))return false;return e.method===t.method&&e.responseType===t.responseType&&e.stateAdapter===t.stateAdapter&&Xe(e.headers,t.headers)&&Xe(e.body,t.body)},Q=(e$1,t)=>(e()[e$1]??0)===t,ze=e$1=>{let t=f(),n=e(),r=(t[e$1]??0)+1;return t[e$1]=r,n[e$1]=r,r},Je=(e$1,t)=>{let n=e();n[e$1]===t&&delete n[e$1];},Qe=(e,t)=>{let n=d();n[e]=t;},Ze=e=>{let t=d();delete t[e];},et=e=>!!d()[e],tt=(e,t,n,r)=>{let s=d()[t];if(s)return l().dedupes+=1,St(s.contract,n.contract)?s.transform!==n.transform||s.cloneResult!==n.cloneResult?(S(e,`fetchStore("${e}") cannot dedupe callers that use different result contracts for cacheSlot "${t}".`,r),null):s.promise:(S(e,`fetchStore("${e}") cannot dedupe callers that use different request or state contracts for cacheSlot "${t}".`,r),null)};var B=1e3,be=100,rt=(e,t)=>{t-e.ratePruneState.lastAt<B||(e.ratePruneState.lastAt=t,Object.keys(e.rateWindowStart).forEach(n=>{t-(e.rateWindowStart[n]??0)>B&&(delete e.rateWindowStart[n],delete e.rateCount[n]);}));},nt=e=>{rt(a(),e);},ot=(e=B)=>{let t=a();t.ratePruneTimer||typeof setTimeout=="function"&&(t.ratePruneTimer=setTimeout(()=>{t.ratePruneTimer=null,rt(t,Date.now());},e));},st=(e,t)=>{let n=h(),r=i(),s=n[e],o=r[e]??0;return s!==void 0&&t-s<B?o>=be?true:(r[e]=o+1,false):(n[e]=t,r[e]=1,false)};var it=e=>{let t={},n=(e.method??"GET").toUpperCase(),r=e.body!==void 0&&e.body!==null;return e.method&&(t.method=n),e.headers?t.headers=e.headers:(r||!["GET","HEAD","DELETE"].includes(n))&&(t.headers={"Content-Type":"application/json"}),r&&(t.body=typeof e.body=="string"?e.body:JSON.stringify(e.body)),e.signal&&(t.signal=e.signal),t},at=async(e,t)=>{let n=t??"auto";if(n==="json")return e.json();if(n==="text")return e.text();if(n==="arrayBuffer")return e.arrayBuffer();if(n==="blob")return e.blob();if(n==="formData")return e.formData();let r=e.headers.get("content-type")||"";return r.includes("application/json")||r.includes("+json")?e.json():r.startsWith("text/")||r.includes("xml")||r.includes("html")?e.text():r.includes("form-data")?e.formData():e.arrayBuffer()};var bt=e=>{if(!e||typeof e!="object")return false;let t=e;return "data"in t&&"loading"in t&&"error"in t&&"status"in t},Rt=(e,t,n,r,s)=>{if(!N(e))return;let o=r.stateAdapter;if(o){try{let l=M({name:e}),i=d=>{V(t,d,void 0,s);};S$1(s,()=>{o({name:e,prev:l,next:n,set:i});});}catch(l){p(`fetchStore("${e}") stateAdapter failed: ${l?.message??l}`);}return}S$1(s,()=>{V(t,n,void 0,s);});},U=(e,t,n,r)=>(p(`fetchStore("${e}") aborted`),Q(t,n)&&N(e)&&r({loading:false,error:"aborted",status:"aborted",revalidating:false}),null);async function ie(e,t$1,n$1={}){let r$2=G(e);if(!r$2||typeof r$2!="string"){r("fetchStore requires a store name as first argument");return}let s$1={name:r$2};if(!t$1){r(`fetchStore("${r$2}") requires a URL, Promise, or Promise factory as second argument`);return}let{transform:o,onSuccess:l$2,onError:i,stateAdapter:d,method:b$1,headers:R,body:w,ttl:A$1,staleWhileRevalidate:I=false,dedupe:H=true,retry:O=0,retryDelay:N$1=400,retryBackoff:_=1.7,signal:m$1,cacheKey:y,responseType:g$1="auto"}=n$1,V=g(),v=c(),f=l(),j=(()=>{let a=n$1.correlationId,h=n$1.traceContext;return a||h?{correlationId:a,traceContext:h}:l$1().autoCorrelationIds?{correlationId:`stroid-${r$2}-${Date.now().toString(36)}-${Math.random().toString(36).slice(2,8)}`,traceContext:h}:null})();!m$1&&n()&&m("noSignal",r$2,()=>{p(`fetchStore("${r$2}") called without an AbortSignal. Provide "signal" to enable cancellation (recommended).`);});let c$1=y?`${r$2}:${y}`:r$2,p$2=a=>Rt(r$2,s$1,j?{...a,correlationId:j.correlationId,traceContext:j.traceContext}:a,n$1,j),C=typeof t$1!="string"&&typeof t$1!="function"&&typeof t$1?.then=="function",ae=Ye(r$2,O,N$1,_),Re=false,ct=C&&O>0,we=typeof t$1=="string"?{requestKind:"url",url:t$1,method:(b$1??"GET").toUpperCase(),headers:R,body:w,responseType:g$1,stateAdapter:d}:typeof t$1=="function"?{requestKind:"factory",requestRef:t$1,method:(b$1??"GET").toUpperCase(),headers:R,body:w,responseType:g$1,stateAdapter:d}:{requestKind:"promise",requestRef:t$1,stateAdapter:d},ut=typeof window>"u"&&(typeof process<"u"?process.env?.NODE_ENV:void 0)==="production",ft=n$1.autoCreate??l$1().asyncAutoCreate,Z=n$1.cloneResult??l$1().asyncCloneResult;if(d&&!N(r$2))return S(r$2,`fetchStore("${r$2}") with stateAdapter requires an existing backing store.
|
|
2
|
+
Call createStore("${r$2}", ...) first or omit stateAdapter to use the default AsyncState shape.`,i);if(!N(r$2)&&ut)return S(r$2,`fetchStore("${r$2}") cannot create a backing store on the server in production.
|
|
3
|
+
Use createStoreForRequest(...) inside the request scope or create the store ahead of time with { allowSSRGlobalStore: true }.`,i);if(!N(r$2)){if(!ft)return S(r$2,`fetchStore("${r$2}") requires an existing backing store when autoCreate is disabled.
|
|
4
|
+
Call createStore("${r$2}", ...) first or enable autoCreate.`,i);if(n()&&m("autoCreate",r$2,()=>{let a=`fetchStore("${r$2}") auto-created its backing store.
|
|
5
|
+
Call createStore("${r$2}", ...) first to avoid typos creating phantom stores.`;A(i,`fetchStore.onError(${r$2})`,a),p(a);}),K$1(r$2,{data:null,loading:false,error:null,status:"idle"}),!N(r$2))return S(r$2,`fetchStore("${r$2}") could not initialize its backing store.
|
|
6
|
+
On the server in production, use createStoreForRequest(...) inside the request scope or create the store with { allowSSRGlobalStore: true } before calling fetchStore.`,i)}if(!d){let a=M({name:r$2});if(a&&!bt(a))return m("shape",r$2,()=>{}),S(r$2,`fetchStore("${r$2}") cannot write AsyncState into an existing non-async store. Provide a stateAdapter or create the store with the async shape to avoid overwriting fields.`,i)}u(r$2);let ce=null,E=false,ee=()=>V[c$1]?.data??null;if(p$1(c$1,A$1)){if(f.cacheHits+=1,ce=ee(),p$2({data:ce,loading:I,error:null,status:"success",cached:true,revalidating:I}),!I)return ce;E=true;}else f.cacheMisses+=1;if(H){let a=tt(r$2,c$1,{contract:we,transform:o,cloneResult:Z},i);if(a!==void 0)return a}let xe=Date.now();if(nt(xe),ot(),st(c$1,xe))return S(r$2,`fetchStore("${r$2}") rate limited: ${be} requests per ${B}ms window for store "${r$2}".`,i);if(!et(c$1)&&r$1(r$2)>=b)return S(r$2,`fetchStore("${r$2}") exceeded ${b} concurrent request slots. Reuse cacheKey values, wait for pending requests, or delete the store to clear async state.`,i);let x=ze(c$1);E||p$2({loading:true,error:null,status:"loading",cached:false,revalidating:false}),f.requests+=1;let lt=Date.now(),D=!m$1&&typeof AbortController<"u"?new AbortController:null,P=m$1||D?.signal,te=D?()=>{D.signal.aborted||D.abort();}:null;te&&s(r$2,te);let dt=async()=>{let a=0,h=ae.retryDelay;for(;;){if(P?.aborted)return U(r$2,c$1,x,p$2);let W=typeof t$1=="function"?t$1():t$1,Ce=C||typeof W!="string"&&typeof W?.then=="function",Ee=Ce?{...ae,retry:0}:ae;Ce&&(O>0||ct)&&!Re&&(p(`fetchStore("${r$2}") ignores retry settings for direct Promise inputs; pass a URL string or factory to use retries.`),Re=true);try{let k;if(typeof W=="string"){let re=it({method:b$1,headers:R,body:w,signal:P,...n$1}),ne=await fetch(W,re);if(!ne.ok)throw new Error(`HTTP ${ne.status}: ${ne.statusText}`);k=await at(ne,g$1);}else if(typeof W.then=="function")k=await W;else return r(`fetchStore("${r$2}") - second argument must be a URL string, Promise, or Promise factory.
|
|
7
|
+
Examples:
|
|
8
|
+
fetchStore("users", "https://api.example.com/users")
|
|
9
|
+
fetchStore("users", () => fetch("https://api.example.com/users"))`),null;if(P?.aborted)return U(r$2,c$1,x,p$2);let L=o?o(k):k;if(L&&typeof L.then=="function"){let re=`fetchStore("${r$2}") transform must be synchronous. Return the transformed value directly instead of a Promise.`;return Q(c$1,x)&&p$2({data:E?ee():null,loading:!1,error:re,status:"error",cached:E,revalidating:!1}),S(r$2,re,i)}Z==="none"&&n()&&L&&typeof L=="object"&&m("mutableResult",r$2,()=>{p(`fetchStore("${r$2}") received a mutable object while asyncCloneResult is "none".
|
|
10
|
+
Async data is stored by reference; mutations will affect cache and subscribers.
|
|
11
|
+
Set cloneResult: "deep" (per call) or configureStroid({ asyncCloneResult: "deep" }).`);});let M=Ge(L,Z);if(P?.aborted)return U(r$2,c$1,x,p$2);if(!Q(c$1,x))return null;V[c$1]={timestamp:Date.now(),expiresAt:A$1?Date.now()+A$1:null,data:M},q(r$2),p$2({data:M,loading:!1,error:null,status:"success",cached:!1,revalidating:!1}),K(r$2,"onSuccess",l$2,M);let ke=Date.now()-lt;return f.lastMs=ke,f.avgMs=(f.avgMs*(f.requests-1)+ke)/f.requests,{raw:k,transformed:M}}catch(k){if(a+=1,k?.name==="AbortError")return U(r$2,c$1,x,p$2);if(a<=Ee.retry){if(P?.aborted||(await Ve(h,P),P?.aborted))return U(r$2,c$1,x,p$2);h=Math.min(Se,h*Ee.retryBackoff);continue}if(!Q(c$1,x))return null;let M=k?.message||"Something went wrong";return p$2({data:E?ee():null,loading:false,error:M,status:"error",cached:E,revalidating:false}),K(r$2,"onError",i,M),f.failures+=1,p(`fetchStore("${r$2}") failed: ${M}`),null}}},Y=null,mt=new Promise((a,h)=>{m$1||(Y=setTimeout(()=>{Y=null,D&&!D.signal.aborted&&D.abort(),h(new Error("Timeout: async request hung for 60 seconds without an AbortSignal"));},6e4));}),Ae=Promise.race([dt().finally(()=>{Y&&(clearTimeout(Y),Y=null);}),mt]).catch(a=>{let h=a?.message||"Request timed out";return p$2({data:E?ee():null,loading:false,error:h,status:"error",cached:E,revalidating:false}),K(r$2,"onError",i,h),f.failures+=1,p(`fetchStore("${r$2}") failed: ${h}`),null}),ve=Ae.then(a=>a?.transformed??null).finally(()=>{Ze(c$1),Je(c$1,x),te&&t(r$2,te);}),pt=Ae.then(a=>a?.raw);return Qe(c$1,{promise:ve,raw:pt,transform:o,cloneResult:Z,contract:we}),typeof t$1=="function"?v[r$2]={kind:"factory",factory:t$1,options:{...n$1,cacheKey:y}}:typeof t$1=="string"?v[r$2]={kind:"url",url:t$1,options:{...n$1,cacheKey:y}}:delete v[r$2],ve}async function wt(e){let t=G(e);if(!N(t))return;let r=c()[t];if(!r){let o=`${t}:`,l=g(),i=Object.entries(l).filter(([d])=>d===t||d.startsWith(o));if(i.length>0){let[,d]=i.reduce((b,R)=>R[1].timestamp>=b[1].timestamp?R:b);return d.data}n()&&p(`refetchStore("${t}") - no previous fetch found.
|
|
12
|
+
Call fetchStore("${t}", url) first.`);return}let s={name:t};return r.kind==="factory"?ie(s,r.factory,r.options):ie(s,r.url,r.options)}function Jt(e,t$1){if(typeof window>"u"||typeof window.addEventListener!="function")return ()=>{};let n=k(),r=j(),o=(e==="*"?"*":e?G(e):void 0)??"*";if(n.has(o))return r[o]??(()=>{});let l=l$1().revalidateOnFocus,i=Math.max(0,t$1?.debounceMs??l.debounceMs),d=Math.max(1,t$1?.maxConcurrent??l.maxConcurrent),b=Math.max(0,t$1?.staggerMs??l.staggerMs),R=null,w=false,A=new Set,I=m=>{m!==null&&(clearTimeout(m),A.delete(m));},H=(m,y)=>{let g=setTimeout(()=>{A.delete(g),!w&&m();},y);return A.add(g),g},O=()=>{if(w)return;let m=c(),y=o==="*"?Object.keys(m):[o];if(t$1?.priority==="high"&&o!=="*"&&(y=[o,...y.filter(v=>v!==o)]),y.length===0)return;let g=0,V=()=>{if(w)return;let v=y.slice(g,g+d);if(v.forEach((f,j)=>{let c$1=()=>{if(w)return;let C=c()[f];if(!C){wt({name:f});return}C.kind==="factory"?ie({name:f},C.factory,C.options):ie({name:f},C.url,C.options);};b>0?H(c$1,j*b):c$1();}),g+=v.length,g<y.length){let f=b>0?b*Math.max(1,v.length):0;H(V,f);}};V();},N=()=>{if(!w){if(i===0){O();return}I(R),R=H(O,i);}};window.addEventListener("focus",N),window.addEventListener("online",N),n.add(o);let _=()=>{w=true,window.removeEventListener("focus",N),window.removeEventListener("online",N),I(R),R=null,A.forEach(m=>clearTimeout(m)),A.clear(),n.delete(o),delete r[o],t(o,_,"revalidate");};return r[o]=_,s(o,_,"revalidate"),_}var Qt=()=>({...l()}),Zt=()=>{xt(),o();},xt=()=>{n$1("revalidate");};export{ie as a,wt as b,Jt as c,Qt as d,Zt as e};//# sourceMappingURL=chunk-BW32TJGE.js.map
|
|
13
|
+
//# sourceMappingURL=chunk-BW32TJGE.js.map
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import {f,e,d,c}from'./chunk-KQCSFGHJ.js';var Hr=new Map,O=(e,t,r=0)=>{!e||typeof t!="function"||Hr.set(e,{name:e,order:r,fn:t});},Lr=()=>{Array.from(Hr.values()).sort((t,r)=>t.order!==r.order?t.order-r.order:t.name.localeCompare(r.name,"en")).forEach(t=>t.fn());};var Br=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),Ur=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),requestSequence:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,warnedOnce:Br(),storeCleanups:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}}),qr=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(o=>{try{o();}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.requestSequence).forEach(t=>delete e.requestSequence[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.storeCleanups).forEach(t=>delete e.storeCleanups[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),Br().forEach((t,r)=>{e.warnedOnce.set(r,t);}),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var er=new Map,Gr=new WeakSet,tr=e$1=>{Gr.has(e$1)||(Gr.add(e$1),e().forEach(t=>{if(!e$1.featureRuntimes.get(t)){let r=d(t);r&&e$1.featureRuntimes.set(t,r());}}));},Hn=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,Kr,rr=e=>(Kr||Hn||e).replace(/\.ts(\?|$)/,".js$1"),Te=rr("stroid:default-registry"),Yr=()=>Ee(Te);var Ln=()=>{Kr=void 0,er.clear();};O("registry.scope-override",Ln,110);var Bn=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Un=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},or=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,runtimePatches:[],failed:false,error:void 0}),qn=(e="default")=>{let t={scope:e,stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,lastRuntimePatches:[],transaction:or(),async:Ur(),notify:Bn(),lifecycleListener:null};return tr(t),t},Ee=e=>{let t=rr(e),r=er.get(t);if(r)return r;let o=qn();return er.set(t,o),o},Pe=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t),Jr=(e,t)=>e.deletingStores.has(t),Xr=e=>{e.computedCleanups.forEach(t=>{try{t();}catch{}}),e.computedCleanups.clear(),[e.stores,e.subscribers,e.initialStates,e.initialFactories,e.metaEntries,e.snapshotCache,e.computedEntries,e.computedDependents].forEach(t=>{Object.keys(t).forEach(r=>{delete t[r];});}),e.deletingStores.clear(),e.transaction.depth=0,e.transaction.pending=[],e.transaction.stagedValues.clear(),e.transaction.snapshotCache.clear(),e.transaction.runtimePatches.length=0,e.transaction.failed=false,e.transaction.error=void 0,e.lastRuntimePatches.length=0,Un(e.notify),qr(e.async),e.lifecycleListener=null;};var xt=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var Qr=null,mi=e=>{Qr=e;},Oe=()=>Qr?.get()||null,nr=null,de=[],Zr={run:(e,t)=>{de.push(e);try{return t()}finally{de.pop();}},get:()=>de.length>0?de[de.length-1]:null,enterWith:e=>{if(de.length>0){de[de.length-1]=e;return}de.push(e);}},yi=e=>{nr=e;},We=(e,t)=>(nr??Zr).run(e,t),X=e=>(nr??Zr).get()||e||Ee(Te);var Gn={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}`));}},eo={logSink:Gn,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",autoCorrelationIds:false,acknowledgeLooseTypes:false,pathCacheSize:500,defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0,selectorCloneFrozen:true},Mt=e=>({logSink:{...e.logSink},flush:{...e.flush},revalidateOnFocus:{...e.revalidateOnFocus},namespace:e.namespace,strictMissingFeatures:e.strictMissingFeatures,assertRuntime:e.assertRuntime,strictMutatorReturns:e.strictMutatorReturns,asyncAutoCreate:e.asyncAutoCreate,asyncCloneResult:e.asyncCloneResult,autoCorrelationIds:e.autoCorrelationIds,acknowledgeLooseTypes:e.acknowledgeLooseTypes,pathCacheSize:e.pathCacheSize,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce,selectorCloneFrozen:e.selectorCloneFrozen}),Ct=new WeakMap,ir=Mt(eo),to=e=>{let t=Ct.get(e);return t||(t=Mt(ir),Ct.set(e,t)),t},ro,sr=false,Yn=()=>ro,M=()=>to(X());var vi=e=>{if(!e)return;let t=X(),r=to(t);if(e.logSink&&(r={...r,logSink:{log:e.logSink.log??r.logSink.log,warn:e.logSink.warn??r.logSink.warn,critical:e.logSink.critical??r.logSink.critical}}),e.flush&&(r={...r,flush:{chunkSize:Number.isFinite(e.flush.chunkSize??r.flush.chunkSize)?e.flush.chunkSize:r.flush.chunkSize,chunkDelayMs:Number.isFinite(e.flush.chunkDelayMs??r.flush.chunkDelayMs)?e.flush.chunkDelayMs:r.flush.chunkDelayMs,priorityStores:Array.isArray(e.flush.priorityStores)?e.flush.priorityStores:r.flush.priorityStores}}),e.revalidateOnFocus&&(r={...r,revalidateOnFocus:{debounceMs:Number.isFinite(e.revalidateOnFocus.debounceMs??r.revalidateOnFocus.debounceMs)?e.revalidateOnFocus.debounceMs:r.revalidateOnFocus.debounceMs,maxConcurrent:Number.isFinite(e.revalidateOnFocus.maxConcurrent??r.revalidateOnFocus.maxConcurrent)?Math.max(1,e.revalidateOnFocus.maxConcurrent):r.revalidateOnFocus.maxConcurrent,staggerMs:Number.isFinite(e.revalidateOnFocus.staggerMs??r.revalidateOnFocus.staggerMs)?Math.max(0,e.revalidateOnFocus.staggerMs):r.revalidateOnFocus.staggerMs}}),typeof e.namespace=="string"&&(r={...r,namespace:e.namespace.trim()}),typeof e.strictMissingFeatures=="boolean"&&(r={...r,strictMissingFeatures:e.strictMissingFeatures}),typeof e.strictFeatures=="boolean"&&(r={...r,strictMissingFeatures:e.strictFeatures}),typeof e.assertRuntime=="boolean"&&(r={...r,assertRuntime:e.assertRuntime}),typeof e.strictMutatorReturns=="boolean"&&(r={...r,strictMutatorReturns:e.strictMutatorReturns}),typeof e.asyncAutoCreate=="boolean"&&(r={...r,asyncAutoCreate:e.asyncAutoCreate}),typeof e.strictAsyncUsageErrors=="boolean"&&(r={...r,strictAsyncUsageErrors:e.strictAsyncUsageErrors}),typeof e.autoCorrelationIds=="boolean"&&(r={...r,autoCorrelationIds:e.autoCorrelationIds}),(e.asyncCloneResult==="none"||e.asyncCloneResult==="shallow"||e.asyncCloneResult==="deep")&&(r={...r,asyncCloneResult:e.asyncCloneResult}),typeof e.acknowledgeLooseTypes=="boolean"&&(r={...r,acknowledgeLooseTypes:e.acknowledgeLooseTypes}),typeof e.pathCacheSize=="number"&&Number.isFinite(e.pathCacheSize)&&(r={...r,pathCacheSize:Math.max(0,Math.floor(e.pathCacheSize))}),(e.snapshotStrategy==="shallow"||e.snapshotStrategy==="ref"||e.snapshotStrategy==="deep")&&(r={...r,defaultSnapshotMode:e.snapshotStrategy}),(e.defaultSnapshotMode==="shallow"||e.defaultSnapshotMode==="ref"||e.defaultSnapshotMode==="deep")&&(r={...r,defaultSnapshotMode:e.defaultSnapshotMode}),Array.isArray(e.middleware)&&(r={...r,middleware:e.middleware}),typeof e.allowUntrustedHydration=="boolean"&&(r={...r,allowUntrustedHydration:e.allowUntrustedHydration}),typeof e.allowHydration=="boolean"&&(r={...r,allowUntrustedHydration:e.allowHydration}),typeof e.allowTrustedHydration=="boolean"&&(r={...r,allowUntrustedHydration:e.allowTrustedHydration}),typeof e.mutatorProduce=="function")r={...r,mutatorProduce:e.mutatorProduce};else if(e.mutatorProduce==="immer"){let o=Yn();o?r={...r,mutatorProduce:o}:sr||(sr=true,V(`configureStroid({ mutatorProduce: "immer" }) requires Immer's produce function.
|
|
2
|
+
Call registerMutatorProduce(produce) or pass mutatorProduce: produce directly.`));}typeof e.selectorCloneFrozen=="boolean"&&(r={...r,selectorCloneFrozen:e.selectorCloneFrozen}),Ct.set(t,r),t===Yr()&&(ir=Mt(r));},Jn=()=>{Ct=new WeakMap,ir=Mt(eo),ro=void 0,sr=false;};O("config.reset",Jn,90);var oo=()=>M().namespace;var Xn=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Qn=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,no=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,Zn="production",es=Xn??Qn??Zn,ot=typeof no=="boolean"?no:es!=="production",T=()=>ot,ar=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},ts=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},rs=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},H=(e,t)=>{if((M().logSink.critical??ts)(e,t),M().assertRuntime)throw new Error(e)},g=(e,t)=>{if(!ot)return;if((M().logSink.warn??ar)(e,t),M().assertRuntime)throw new Error(e)},V=(e,t)=>{if((M().logSink.warn??ar)(e,t),M().assertRuntime)throw new Error(e)},L=(e,t)=>{if(ot&&(M().logSink.warn??ar)(e,t),H(e,t),M().assertRuntime)throw new Error(e)},J=(e,t)=>{if(!ot)return;(M().logSink.log??rs)(e,t);},so=()=>`Functions cannot be stored in stroid.
|
|
3
|
+
Store data only - handle functions outside the store.`,io=()=>`Map/Set detected. stroid converts these to plain objects.
|
|
4
|
+
Use arrays or plain objects for best results.`,ao=()=>`Date object detected. stroid stores it as ISO string.
|
|
5
|
+
Use new Date(value) to convert back when reading.`,co=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",uo=()=>"Map detected; converting to plain object.",lo=()=>"Set detected; converting to array.",po=(e,t,r)=>`Path depth of ${e} exceeded maximum of ${t}.
|
|
6
|
+
"${r.join(".")}"
|
|
7
|
+
This is a data design issue. Split into separate stores:
|
|
8
|
+
createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,fo=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
|
|
9
|
+
Consider splitting into separate stores for better readability.`,go=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,So=e=>`Cannot go deeper at "${e}" - value is not an object`,mo=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,yo=e=>`Store name "${e}" contains spaces.
|
|
10
|
+
Use camelCase or kebab-case: "userName" or "user-name"`,ho=e=>`Store name "${e}" is not allowed.
|
|
11
|
+
Reserved names: "__proto__", "constructor", "prototype".`,os=128,ns=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=os,ss=(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},(n,s)=>s),o=new Array(e.length+1);for(let n=1;n<=t.length;n++){o[0]=n;for(let s=1;s<=e.length;s++)o[s]=t[n-1]===e[s-1]?r[s-1]:Math.min(r[s-1],o[s-1],r[s])+1;[r,o]=[o,r];}return r[e.length]},cr=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||ns(n,s)&&ss(n,s)<=2});if(r){g(`Store "${e}" not found. Did you mean "${r}"?`);return}L(`Store "${e}" not found.
|
|
12
|
+
Available stores: [${t.join(", ")}]
|
|
13
|
+
Call createStore("${e}", data) first.`);};var oe=new Set(["__proto__","constructor","prototype"]),lr=(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 n=r.error,s=n?.details?.[0]?.message||n?.message||r.message||e.errors;if(s)return {ok:!1,error:s};if(n)return {ok:!1,error:n}}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 me=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,bo=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},He=e=>{let t=me(e);return t==="function"?(L(so()),false):t==="map"||t==="set"?(g(io()),true):(t==="date"&&g(ao()),true)},ur=(e,t)=>{let r=bo(e);if(r)throw new Error(`${r} values are not supported`);let o=me(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return true}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date"||o==="map"||o==="set")return false;if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n=Object.keys(e);for(let s of n){let i=Number(s);if(!Number.isInteger(i))return false}for(let s=0;s<e.length;s+=1)if(s in e&&!ur(e[s],t))return false;return true}if(o==="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 n=Object.getOwnPropertyDescriptors(e);for(let[s,i]of Object.entries(n)){if(!i.enumerable||oe.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!ur(i.value,t))return false}return true}return true},dr=e=>ur(e,new WeakSet),nt=(e,t)=>{let r=bo(e);if(r)throw new Error(`${r} values are not supported`);let o=me(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date")return T()&&g(co()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),T()&&g(uo());let n={};for(let[s,i]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");n[String(s)]=nt(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),T()&&g(lo()),Array.from(e,n=>nt(n,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n={},s=Object.getOwnPropertyDescriptors(e);for(let[i,a]of Object.entries(s))if(a.enumerable&&!oe.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=nt(a.value,t);}return n}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(n=>nt(n,t))}return e},Fe=e=>nt(e,new WeakSet),st=e=>typeof e!="string"||e.trim()===""?(L(mo(e)),false):oe.has(e)?(L(ho(e)),false):e.includes(" ")?(L(yo(e)),false):true;var pr=null,is=()=>{if(pr)return pr;let e,t=[];for(let r=0;r<256;r++){e=r;for(let o=0;o<8;o++)e=e&1?3988292384^e>>>1:e>>>1;t[r]=e>>>0;}return pr=t,t},Ro=e=>{let t=is(),r=-1;for(let o=0;o<e.length;o++)r=r>>>0,r=r>>>8^t[(r^e.charCodeAt(o))&255];return (r^-1)>>>0},as=2166136261,cs=2654435761,us=1e5,ye=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},Ve=(e,t)=>{ye(e,t.length);for(let r=0;r<t.length;r++)ye(e,t.charCodeAt(r));},I=(e,t)=>{Ve(e,t);},wo=(e,t)=>{if(Number.isNaN(t)){I(e,"NaN");return}if(!Number.isFinite(t)){I(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){I(e,"-0");return}let r=t|0;if(t===r){I(e,"int"),ye(e,r);return}I(e,"num"),Ve(e,String(t));},Le=(e,t)=>{if(e.nodes++>us){I(e,"[max]");return}if(t===null){I(e,"null");return}let r=typeof t;if(r==="string"){I(e,"string"),Ve(e,t);return}if(r==="number"){I(e,"number"),wo(e,t);return}if(r==="boolean"){I(e,t?"true":"false");return}if(r==="undefined"){I(e,"undefined");return}if(r==="bigint"){I(e,"bigint"),Ve(e,t.toString());return}if(r==="symbol"){I(e,"symbol");let u=t;Ve(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){I(e,"function"),Ve(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){I(e,"ref"),ye(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){I(e,"array"),ye(e,o.length);for(let u=0;u<o.length;u++)Object.prototype.hasOwnProperty.call(o,u)?Le(e,o[u]):I(e,"hole");return}if(o instanceof Date){I(e,"date"),wo(e,o.getTime());return}if(o instanceof Map){I(e,"map"),ye(e,o.size),o.forEach((u,c)=>{Le(e,c),Le(e,u);});return}if(o instanceof Set){I(e,"set"),ye(e,o.size),o.forEach(u=>{Le(e,u);});return}I(e,"object");let i=Object.getOwnPropertyDescriptors(o),a=[];Object.entries(i).forEach(([u,c])=>{c?.enumerable&&(oe.has(u)||"get"in c||"set"in c||a.push([u,c]));}),ye(e,a.length);for(let[u,c]of a)Ve(e,u),Le(e,c.value);},it=e=>{if(typeof e=="string")return Ro(JSON.stringify(e));let t={h1:as,h2:cs,seen:new WeakMap,nextId:1,nodes:0};Le(t,e);let r=t.h1>>>0,o=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,o^=o>>>16,o=Math.imul(o,668265261),o^=o>>>15,o=Math.imul(o,374761393),o^=o>>>16,(r&2097151)*4294967296+(o>>>0)};var ls=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",at=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(([o,n])=>{n.enumerable&&(oe.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},fr=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=[["WeakMap",globalThis.WeakMap],["WeakSet",globalThis.WeakSet],["WeakRef",globalThis.WeakRef],["Promise",globalThis.Promise],["ReadableStream",globalThis.ReadableStream],["WritableStream",globalThis.WritableStream],["TransformStream",globalThis.TransformStream],["EventTarget",globalThis.EventTarget]];for(let[o,n]of t)if(typeof n=="function"&&e instanceof n)return o;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},ds=e=>fr(e)===null,ps=e=>{let t=fr(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},Ae=(e,t=new WeakMap)=>{if(ps(e),e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let n=new Map;return t.set(e,n),e.forEach((s,i)=>{n.set(Ae(i,t),Ae(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(Ae(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=Ae(s,t);}),n}let r={};t.set(e,r);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch(n){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${n?.message??n}`)}return Object.entries(o).forEach(([n,s])=>{!s.enumerable||oe.has(n)||"get"in s||"set"in s||(r[n]=Ae(s.value,t));}),r},D=e=>{if(ls)try{return structuredClone(e)}catch(t){if(!ds(e)){let r=fr(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return g(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),Ae(e)}return Ae(e)},gr=(e,t)=>{if(Object.is(e,t))return true;if(!e||!t||typeof e!="object"||typeof t!="object")return false;let r=e,o=t,n=Object.keys(r),s=Object.keys(o);if(n.length!==s.length)return false;for(let i of n)if(!Object.prototype.hasOwnProperty.call(o,i)||!Object.is(r[i],o[i]))return false;return true},fs=(e,t)=>{try{let r=D(e);return t(r),r}catch(r){throw new Error(`produceClone failed (possible circular reference or unserializable data): ${r?.message??r}`)}};var vo=10,gs=5,Ss=e=>{let t=[],r="",o=false;for(let n of e){if(o){r+=n,o=false;continue}if(n==="\\"){o=true;continue}if(n==="."){t.push(r),r="";continue}r+=n;}return o&&(r+="\\"),t.push(r),t},he=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?Ss(e):[String(e)],ct=e=>{let t=he(e),r=t.length;return r>vo?(L(po(r,vo,t)),false):(r>gs&&g(fo(r,t)),true)},Sr=(e,t)=>{let r=he(t),o=e;for(let n of r){if(o==null){g(go(r,n));return}if(typeof o!="object"){g(So(n));return}o=o[n];}return o},mr=(e,t,r)=>{let o=he(t);if(o.length===0)return e;for(let s of o)if(oe.has(s))return H(`Blocked forbidden path segment "${String(s)}" in setStore path "${o.join(".")}".`),e;let n=(s,i)=>{let a=o[i],u=i===o.length-1;if(Array.isArray(s)){let c=Number(a);if(!Number.isInteger(c))return s;let l=[...s];return u?(l[c]=r,l):(l[c]=n(l[c],i+1),l)}if(s&&typeof s=="object"){if(oe.has(a))return H(`Blocked unsafe path segment "${String(a)}" while setting "${o.join(".")}".`),s;let c={...s};return u?(c[a]=r,c):(c[a]=n(c[a],i+1),c)}if(s==null&&!u){let c=Number.isInteger(Number(a)),l=c?[]:{};if(c){let p=l,m=Number(a);return p[m]=n(void 0,i+1),p}return l[a]=n(void 0,i+1),l}return u?r:s};return n(e,0)};var hr=new Set,ms=()=>{hr.clear();};O("options.legacy-warnings",ms,30);var Tt=(()=>{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"}})(),yr=e=>{try{return typeof window>"u"?Tt:e==="session"||e==="sessionStorage"?window.sessionStorage??Tt:window.localStorage??Tt}catch{return Tt}},ut=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Be=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),xo=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}},ys=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",ko=e=>{try{e[ys]=!0;}catch{}return e},hs={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"},bs=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:ko(p=>p),decrypt:ko(p=>p),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:yr("localStorage"),...r};if(typeof e=="string")return {driver:yr(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,a=e.sensitiveData===true,u=e.allowPlaintext===true,c=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,l=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(a&&xo(o)&&!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||yr("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:o,decrypt:n,encryptAsync:s,decryptAsync:i,allowPlaintext:u,sensitiveData:a,maxSize:c,checksum:l,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Co=e=>{if(!ut(e))return [];let t=[];return Object.entries(hs).forEach(([r,o])=>{Be(e,r)&&(hr.has(r)||(hr.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},Mo=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=ut(e.lifecycle)?e.lifecycle:void 0,a=ut(e.persist)?e.persist:void 0,u=ut(e.devtools)?e.devtools:void 0,c=e.validate??e.validator??e.schema,l=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",p=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,m=ut(e.features)?{...e.features}:void 0,d=Be(e,"persist"),y=Be(e,"sync"),z=Be(e,"devtools")||Be(e,"historyLimit")||Be(e,"redactor"),f=o==="global"?true:e.allowSSRGlobalStore??false,{persist:R=false,devtools:h=false,onError:w,sync:k}=e;if(a?.sensitiveData===true){let N=a.encrypt,E=a.encryptAsync;if((!N||xo(N))&&!E)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:o,lazy:n,pathCreate:s,persist:o==="temp"&&!d?null:bs(R,t),devtools:o==="temp"&&!z?false:typeof h=="boolean"?h:u?.enabled??true,middleware:i?.middleware??e.middleware??[],onSet:i?.onSet??e.onSet,onReset:i?.onReset??e.onReset,onDelete:i?.onDelete??e.onDelete,onCreate:i?.onCreate??e.onCreate,onError:w,validate:c,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:o==="temp"&&!z?void 0:u?.redactor??e.redactor,historyLimit:o==="temp"&&!z?0:u?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!y?false:k??false,features:m,allowSSRGlobalStore:f,snapshot:l,snapshotSafety:p,explicitPersist:d,explicitSync:y,explicitDevtools:z}};var Ue=Symbol("stroid.middleware.abort"),To=({name:e,payload:t,middlewares:r,reportIssue:o,warn:n})=>{if(!Array.isArray(r)||r.length===0)return t.next;let s=new WeakSet,i=D(t.next);for(let a of r){if(typeof a!="function")continue;let u,c=i;try{u=a({action:t.action,name:e,prev:t.prev,next:c,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(l){let p=`Middleware for "${e}" failed: ${l?.message??l}`;return o(p,"dev"),Ue}if(u&&typeof u.then=="function"){let l=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(l,"dev"),Ue}u===void 0?(T()&&!s.has(a)&&(s.add(a),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=c):i=u;}return i},Et=({name:e,label:t,fn:r,args:o,reportIssue:n})=>{if(typeof r=="function")try{r(...o);}catch(s){let i=`${t} for "${e}" failed: ${s?.message??s}`;n(i,"always");}};var Q=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;V(`${t} callback threw: ${String(n)}`);}},Ne=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(Q(n,"onError",e),r==="critical"){o==="dev"&&g(e),H(e);return}if(o==="always"){V(e);return}g(e);};var Pt=null,Eo=e=>{Pt=e;},Po=e=>Pt?Pt(e):[];O("computed.order-resolver",()=>{Pt=null;},105);var Vo=()=>X(Ee(Te)),ws="opaque",B=()=>Vo().computedEntries,lt=()=>Vo().computedDependents,Rs=(e,t)=>{let r=B(),o=new Set,n=[],s=i=>{if(i===e)return true;if(o.has(i))return false;o.add(i),n.push(i);let a=r[i]?.deps??[];for(let u of a)if(s(u))return true;return n.pop(),false};for(let i of t)if(n.length=0,s(i))return [e,...n,e].join(" -> ");return null},Ao=(e,t)=>{let r=lt();for(let o of t){let n=r[o];n&&(n.delete(e),n.size===0&&delete r[o]);}},No=(e,t,r,o=ws)=>{let n=Rs(e,t);if(n)return L(`[stroid] createComputed("${e}") rejected: circular dependency detected -> ${n}
|
|
14
|
+
Define relationships without cycles.`),false;let s=B(),i=lt();s[e]&&Ao(e,s[e].deps),s[e]={deps:t,compute:r,stale:true,classification:o,hasLastOutput:false,lastOutput:void 0};for(let a of t)i[a]||(i[a]=new Set),i[a].add(e);return true},br=e=>{let t=B(),r=t[e];r&&(Ao(e,r.deps),delete t[e]);},wr=e=>{let t=B();t[e]&&(t[e].stale=true);},Ot=e=>Object.prototype.hasOwnProperty.call(B(),e),Ft=e=>B()[e],Rr=e=>e==="asyncBoundary"?"async-boundary":"computed",Do=(e,t,r=[])=>JSON.stringify([e,t,[...r]]),vs=e=>e==="leaf"||e==="computed"||e==="async-boundary",ks=e=>{try{let t=JSON.parse(e);if(!Array.isArray(t)||t.length!==3)return null;let[r,o,n]=t;return !vs(r)||typeof o!="string"||!Array.isArray(n)||n.some(s=>typeof s!="string"&&typeof s!="number")?null:{type:r,storeId:o,path:[...n]}}catch{return null}},Oo=(e,t)=>({id:Do(e,t),storeId:t,path:[],type:e}),jo=e=>{let t=B()[e];return Oo(t?Rr(t.classification):"leaf",e)},Io=e=>{let t=B();if(t[e])return e;let r=ks(e);if(!r||r.path.length!==0||r.type!=="computed"&&r.type!=="async-boundary")return null;let o=t[r.storeId];return o&&Rr(o.classification)===r.type?r.storeId:null},$o=(e,t)=>{let r=Rr(t.classification);return {id:Do(r,e),storeId:e,path:[],dependencies:t.deps.map(o=>jo(o).id),nodeType:r,classification:t.classification,...t.classification==="asyncBoundary"?{asyncBoundary:true}:{}}},xs=e=>{let t=Io(e);if(!t)return null;let r=B()[t];return r?$o(t,r):null},vr=e=>{let t=B(),r=lt(),o=new Set,n=[...e];for(;n.length>0;){let l=n.shift(),p=r[l];if(p)for(let m of p)o.has(m)||(o.add(m),n.push(m));}if(o.size===0)return [];let s=l=>{let p=t[l];if(p)for(let m of p.deps)t[m]&&(o.has(m)||(o.add(m),s(m)));};Array.from(o).forEach(l=>s(l));let i=new Map,a=new Map;for(let l of o){let p=t[l];if(!p)continue;let m=0;for(let d of p.deps)o.has(d)&&(m++,a.has(d)||a.set(d,[]),a.get(d).push(l));i.set(l,m);}let u=[];for(let[l,p]of i)p===0&&u.push(l);u.sort();let c=[];for(;u.length>0;){let l=u.shift();c.push(l);let p=a.get(l)??[];for(let m of p){let d=(i.get(m)??1)-1;if(i.set(m,d),d===0){let y=u.findIndex(z=>z>m);y===-1?u.push(m):u.splice(y,0,m);}}}return c};Eo(vr);var Cs=()=>{let e=B(),t=lt(),r=Object.keys(e),o=[];for(let[n,s]of Object.entries(e))for(let i of s.deps)o.push({from:i,to:n});return {nodes:r,edges:o,dependencies:Object.fromEntries(Object.entries(e).map(([n,s])=>[n,[...s.deps]])),dependents:Object.fromEntries(Object.entries(t).map(([n,s])=>[n,[...s]]))}},kr=e=>{let t=B()[e];if(!t)return null;let r=lt()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}},Ms=()=>{let e=B(),t=new Map,r=new Map;for(let[s,i]of Object.entries(e)){let a=$o(s,i);t.set(a.id,{id:a.id,storeId:a.storeId,path:a.path,type:a.nodeType}),i.deps.forEach((u,c)=>{let l=jo(u),p=B()[u]?"computed-input":"leaf-input";t.set(l.id,l),r.set(`${l.id}|${a.id}|${c}`,{from:l.id,to:a.id,type:p});});}let o=Array.from(t.values()).sort((s,i)=>s.id.localeCompare(i.id)),n=Array.from(r.values()).sort((s,i)=>{let a=s.from.localeCompare(i.from);if(a!==0)return a;let u=s.to.localeCompare(i.to);return u!==0?u:s.type.localeCompare(i.type)});return {granularity:"store",nodes:o,edges:n}},Ts=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Fo=(e,t)=>Ts(e,t)?e[t]:null,zo=(e,t,r)=>{if(r.memo.has(e))return r.memo.get(e);if(r.stack.has(e))throw new Error(`evaluateComputed("${e}") detected a computed cycle`);let o=B()[e];if(!o)throw new Error(`evaluateComputed("${e}") could not find a computed descriptor`);if(o.classification!=="deterministic")throw new Error(`evaluateComputed("${e}") only supports deterministic computed nodes`);r.stack.add(e);try{let n=o.deps.map(i=>{let a=B()[i];if(!a)return Fo(t,i);if(a.classification!=="deterministic")throw new Error(`evaluateComputed("${e}") cannot cross non-deterministic dependency "${i}"`);return zo(i,t,r)}),s;try{s=o.compute(...n);}catch{s=Fo(t,e);}return r.memo.set(e,s),s}finally{r.stack.delete(e);}},Es=(e,t)=>{if(!t||typeof t!="object"||Array.isArray(t))throw new Error(`evaluateComputed("${e}") requires a snapshot record`);let r=Io(e);if(!r)throw new Error(`evaluateComputed("${e}") could not find a computed descriptor`);return zo(r,t,{memo:new Map,stack:new Set})};var qe=new Map,ta=(e,t)=>{let r=qe.get(e);return r||(r=new Set,qe.set(e,r)),r.add(t),()=>{let o=qe.get(e);o&&(o.delete(t),o.size===0&&qe.delete(e));}},xr=e=>{let t=qe.get(e);return !!t&&t.size>0},dt=(e,t,r)=>{let o=qe.get(e);!o||o.size===0||o.forEach(n=>{try{n(t,r);}catch(s){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,s);}});};var Ho=e$1=>{let t=e$1.stores,r=e$1.subscribers,o=e$1.initialStates,n=e$1.initialFactories,s=e$1.metaEntries,i=e$1.snapshotCache,a=e$1.featureRuntimes,u=e$1.deletingStores,c=()=>Object.fromEntries(Object.keys(s).map(f=>[f,U(f,e$1)])),l=(f,R)=>{Ne(R,{onError:s[f]?.options?.onError,severity:"warn",visibility:"dev"});},p=({name:f,prev:R,options:h,initialState:w,getMeta:k,getStoreValue:N,getAllStores:E,hasStore:x})=>({name:f,options:h,prev:R,getMeta:k,getStoreValue:N,getAllStores:E,getInitialState:()=>w,hasStore:x,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:P=>{Ne(P,{onError:h.onError,severity:"warn",visibility:"dev"});},warn:g,warnAlways:V,log:J,hashState:it,deepClone:D,sanitize:Fe,validate:()=>({ok:true,value:R}),isDev:T}),m=({name:f,prev:R,options:h,initialState:w,phase:k})=>{let N=p({name:f,prev:R,options:h,initialState:w,getMeta:()=>s[f],getStoreValue:()=>U(f,e$1),getAllStores:c,hasStore:()=>Pe(e$1,f)}),E=p({name:f,prev:R,options:h,initialState:w,getMeta:()=>{},getStoreValue:()=>R,getAllStores:c,hasStore:()=>false});e().forEach(x=>{let P=a.get(x);k==="before"?P?.beforeStoreDelete?.(N):P?.afterStoreDelete?.(E);});},d=f=>{if(!Pe(e$1,f))return;let R=U(f,e$1),h=s[f].options,w=o[f],k=r[f];u.add(f);try{k?.forEach(P=>{try{P(null);}catch(F){g(`Subscriber for "${f}" threw during delete: ${F?.message??F}`);}}),Et({name:f,label:"onDelete",fn:h.onDelete,args:[R],reportIssue:(P,F)=>{Ne(P,{onError:h.onError,severity:"warn",visibility:F});}}),m({name:f,prev:R,options:h,initialState:w,phase:"before"});let N=Oe();N&&delete N[f],delete t[f],delete r[f],delete o[f],delete n[f],delete s[f],delete i[f],Ot(f)&&_o(f);let x=e$1.computedDependents[f];if(x)for(let P of [...x]){let F=kr(P);if(F&&Wo(P,e$1)&&F.deps.every(xe=>!Pe(e$1,xe))){d(P);continue}g(`[stroid] source store "${f}" was deleted. Computed store "${P}" depends on it and will return stale data. Call deleteComputed("${P}") to clean up.`);}m({name:f,prev:R,options:h,initialState:w,phase:"after"}),dt("afterStoreDelete",f,{type:"afterStoreDelete",prev:R}),xt(e$1,{type:"deleted",name:f}),J(`Store "${f}" deleted`);}finally{u.delete(f);}};return {deleteExistingStore:d,clearAllStores:()=>{let f=[],h=0,w=Number.POSITIVE_INFINITY;for(;h<20;){let N=Object.keys(t);if(N.length===0)break;N.forEach(x=>{Pe(e$1,x)&&(d(x),f.push(x));}),h+=1;let E=Object.keys(t).length;if(E===0||E>=w)break;w=E;}let k=Object.keys(t).length;return k>0?g(`clearAllStores stopped after ${h} pass${h===1?"":"es"}; ${k} store(s) still registered (likely recreated during deletion).`):J(`All stores cleared (${f.length} stores removed)`),f},clearStores:f=>{let R=Object.keys(t).filter(h=>f?f.endsWith("*")?h.startsWith(f.slice(0,-1)):h===f:true);return R.forEach(h=>d(h)),R},reportStoreError:l}};var pt=0,Ps=(e,t)=>(pt>=Number.MAX_SAFE_INTEGER&&(pt=0),pt+=1,`${e}:${t}:${pt}`),Os=e=>{let t=[e?.correlationId,e?.traceContext?.traceId,e?.traceContext?.spanId].filter(r=>typeof r=="string"&&r.length>0);return t.length>0?t:void 0},Lo=e=>({...e,path:[...e.path],meta:{...e.meta,causedBy:e.meta.causedBy?[...e.meta.causedBy]:void 0}}),Fs=e=>e?Array.isArray(e)?e.map(t=>typeof t=="number"?t:String(t)):he(e):[],Cr=e=>{let t=e.timestamp??Date.now();return {id:Ps(e.source,t),store:e.store,path:Fs(e.path),op:e.op,...e.value!==void 0?{value:e.value}:{},meta:{timestamp:t,source:e.source,causedBy:Os(e.context),...e.isUnsafe===true?{isUnsafe:true}:{},...e.asyncBoundary===true?{asyncBoundary:true}:{}}}},be=e=>Cr({store:e.store,op:"set",path:[],value:e.value,source:e.source,context:e.context}),Bo=e=>e.intent.kind==="root"||!e.preserveIntent?[be({store:e.store,value:e.committedValue,source:"setStore",context:e.context})]:e.intent.kind==="merge"?[Cr({store:e.store,op:"merge",path:[],value:e.intent.value,source:"setStore",context:e.context})]:[Cr({store:e.store,op:"set",path:e.intent.path,value:e.intent.value,source:"setStore",context:e.context})],De=(e,t=v())=>{t.lastRuntimePatches=e.map(Lo);},Uo=(e=v())=>e.lastRuntimePatches.map(Lo);O("runtime-patch.sequence",()=>{pt=0;},126);var ne=null,ka=e=>{if(!e){ne=null;return}if(ne&&ne!==e){V("injectTransactionRunner(...) was called more than once. The existing runner will be kept to avoid cross-request transaction leaks. If you need to replace it in tests, call injectTransactionRunner(null) first.");return}ne=e;},Vs=()=>{ne=null;};O("transaction.runner",Vs,120);var we=e=>{let t=ne?.get();return t||(e??X()).transaction},Go=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted"),As=e=>({notifyCount:e.notifyCount,totalNotifyMs:e.totalNotifyMs,lastNotifyMs:e.lastNotifyMs,resetCount:e.resetCount,totalResetMs:e.totalResetMs,lastResetMs:e.lastResetMs}),Ns=e=>({updatedAt:e.updatedAt,updatedAtMs:e.updatedAtMs,updateCount:e.updateCount,lastCorrelationId:e.lastCorrelationId,lastCorrelationAt:e.lastCorrelationAt,lastCorrelationAtMs:e.lastCorrelationAtMs,lastTraceContext:e.lastTraceContext,metrics:As(e.metrics)}),Ds=e=>{let t=new Map;Object.keys(e.stores).forEach(o=>{t.set(o,U(o,e));});let r=new Map;return Object.entries(e.metaEntries).forEach(([o,n])=>{r.set(o,Ns(n));}),{stores:t,meta:r,pendingNotifications:[...e.notify.pendingNotifications],lastRuntimePatches:Uo(e)}},qo=(e,t)=>{let r=new Set(Object.keys(e.stores));t.stores.forEach((o,n)=>{Z(n,o,e),r.delete(n);}),r.forEach(o=>{delete e.stores[o];}),t.meta.forEach((o,n)=>{let s=e.metaEntries[n];s&&(s.updatedAt=o.updatedAt,s.updatedAtMs=o.updatedAtMs,s.updateCount=o.updateCount,s.lastCorrelationId=o.lastCorrelationId,s.lastCorrelationAt=o.lastCorrelationAt,s.lastCorrelationAtMs=o.lastCorrelationAtMs,s.lastTraceContext=o.lastTraceContext,s.metrics.notifyCount=o.metrics.notifyCount,s.metrics.totalNotifyMs=o.metrics.totalNotifyMs,s.metrics.lastNotifyMs=o.metrics.lastNotifyMs,s.metrics.resetCount=o.metrics.resetCount,s.metrics.totalResetMs=o.metrics.totalResetMs,s.metrics.lastResetMs=o.metrics.lastResetMs);}),e.notify.pendingNotifications.clear(),t.pendingNotifications.forEach(o=>{e.notify.pendingNotifications.add(o);}),De(t.lastRuntimePatches,e);},Ko=e=>{let t=e??X(),r=ne?.get();return !r&&ne?.enterWith&&(r=or(),ne.enterWith(r)),r||(r=we(t)),r.depth+=1,r.depth===1&&(r.pending=[],r.stagedValues.clear(),r.snapshotCache.clear(),r.runtimePatches.length=0,r.failed=false,r.error=void 0),t},C=()=>ne?(ne.get()?.depth??0)>0:we().depth>0,A=(e,t)=>{let r=we(t);r.failed=true,r.error||(r.error=Go(e));},Vt=e=>{let t=X();we(t).pending.push(()=>We(t,e));},At=(e,t)=>{let r=we();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},Yo=e=>{if(e.length===0)return;we().runtimePatches.push(...e);},ae=e=>{let t=we();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}},Jo=(e,t)=>{let r=we(t),o=t??X();if(r.depth===0||(e&&A(e,t),r.depth=Math.max(0,r.depth-1),r.depth>0))return null;let n=r.failed?r.error??new Error("setStoreBatch aborted"):null;if(!n){let s=Ds(o);for(let i of r.pending)try{if(i(),r.failed){n=r.error??new Error("setStoreBatch aborted"),qo(o,s);break}}catch(a){A(a,t),n||(n=r.error??Go(a)),qo(o,s);break}!n&&r.failed&&(n=r.error??new Error("setStoreBatch aborted"));}return !n&&r.runtimePatches.length>0&&De(r.runtimePatches,o),r.pending=[],r.stagedValues.clear(),r.snapshotCache.clear(),r.runtimePatches.length=0,r.failed=false,r.error=void 0,n};var Mr=Te,Qo=Ee(Mr),Zo=null,W=()=>{let e=X(Qo);return tr(e),e};var v=()=>W();var en=(e,t)=>{xt(e,t);};function tn(e){Zo=e;}var Ge=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,o)=>(e()[r]=o,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let o=Object.getOwnPropertyDescriptor(e(),r);if(o)return {...o,configurable:true}}}),js=e=>new Proxy(new Map,{get:(t,r)=>{let o=e();if(r==="size")return o.size;if(r===Symbol.iterator)return o[Symbol.iterator].bind(o);let n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),Is=e=>new Proxy({},{get:(t,r)=>{let o=e(),n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),rn=Ge(()=>W().stores),Va=Ge(()=>W().subscribers),on=Ge(()=>W().initialStates);Ge(()=>W().initialFactories);var $=Ge(()=>W().metaEntries);Ge(()=>W().snapshotCache);var ee=js(()=>W().featureRuntimes),Xo=new WeakMap,nn=e=>{let t=Xo.get(e);return t||(t=Ho(e),Xo.set(e,t)),t};Is(()=>nn(W()));var sn=()=>nn(W()),$s=e=>{let t=ee.get(e);if(t)return t;let r=d(e);if(!r)return;let o=r();return ee.set(e,o),o},ft=()=>{e().forEach(e=>{$s(e);});};f((e,t)=>{ee.get(e)||ee.set(e,t());});ft();var G=(e,t)=>Pe(t??W(),e),K=(e,t=W())=>{if(C()){let r=ae(e);if(r.has)return r.value}return U(e,t)},U=(e,t=W())=>{let r=Oe();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},Z=(e,t,r=W())=>{let o=Oe();o?(o[e]=t,Object.prototype.hasOwnProperty.call(r.stores,e)||(r.stores[e]=void 0)):r.stores[e]=t;},an=(e,t,r=Date.now())=>{Z(e,t),$[e]&&($[e].updatedAt=new Date(r).toISOString(),$[e].updatedAtMs=r,$[e].lastCorrelationId=null,$[e].lastCorrelationAt=null,$[e].lastCorrelationAtMs=null,$[e].lastTraceContext=null,$[e].updateCount>=Number.MAX_SAFE_INTEGER?$[e].updateCount=0:$[e].updateCount+=1,Zo?.(e));},Nt=(e,t=W())=>{let r=t.metaEntries[e];if(!r)return;r.readCount=(r.readCount??0)+1;let o=Date.now();r.lastReadAtMs=o,r.lastReadAt=new Date(o).toISOString();},zs=()=>{Xr(W());},_s=()=>{ee.forEach(e=>{try{e.resetAll?.();}catch{}}),ee.clear();};O("features.reset",_s,10);O("registries.clear",zs,20);O("registry.default",()=>{Mr=Te,Qo=Ee(Mr);},115);var cn=e=>Jr(W(),e);var Dt=new Set,ln=e=>e?Dt.has(e):Dt.size>0,dn=e=>{e&&Dt.add(e);},Ws=()=>{Dt.clear();};O("ssr.warnings",Ws,60);var un=new Set,Hs=e=>{let t=oo();return !t||e.includes("::")?e:(T()&&!un.has(e)&&(un.add(e),g(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},pe=e=>Hs(typeof e=="string"?e:e.name),je=e=>G(e)&&!cn(e)?true:(cr(e,Object.keys(rn)),false),pn=(e,t,r={})=>{Ne(t,{...r,onError:$[e]?.options?.onError});},fn=(e,t,r={})=>{Ne(e,{...r,onError:t});},Y=(e,t,r="dev")=>{pn(e,t,{severity:"warn",visibility:r});},Ls=(e,t,r="dev")=>{fn(e,t,{severity:"warn",visibility:r});},fe=(e,t)=>pn(e,t,{severity:"critical",visibility:"always"}),gt=(e,t)=>fn(e,t,{severity:"critical",visibility:"always"}),jt=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
15
|
+
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Ls(o,r,"always"),M().strictMissingFeatures)throw new Error(o)},Bs=e=>ee.get(e)?.api;var gn=new WeakMap,Sn=new WeakMap,Us=500,qs="",St=e=>{let t=gn.get(e);return t||(t=new Map,gn.set(e,t)),t},Tr=e=>{let t=Sn.get(e);return t||(t=new Map,Sn.set(e,t)),t},Gs=(e,t)=>{let r=Tr(e),o=r.get(t);return o||(o=new Map,r.set(t,o)),o},Ks=()=>{let e=M().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?Us:Math.max(0,Math.floor(e))},mn=(e,t,r,o)=>{if(o<=0){e.has(t)&&e.delete(t);return}for(e.has(t)&&e.delete(t),e.set(t,r);e.size>o;){let n=e.keys().next().value;if(!n)break;let s=e.get(n);e.delete(n),s?.node.verdicts&&(s.node.verdicts.delete(s.type),s.node.verdicts.size===0&&delete s.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=St(v());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let o=r[t];return typeof o=="function"?o.bind(r):o},set:(e,t,r)=>(St(v())[t]=r,true)});var yn=(e,t,r,o)=>{let n=$[e];if(!n)return {ok:true};let s=he(r);if(s.length===0)return {ok:true};let i=me(o),a=Ks(),u=v(),c=St(u),l=Gs(u,e),p=s.join(qs),m=c.get(e);m||(m={children:new Map},c.set(e,m));let d=m;for(let w of s){let k=d.children.get(w);k||(k={children:new Map},d.children.set(w,k)),d=k;}let y=d.verdicts?.get(i);if(y){let w=`${p}|${i}`;return mn(l,w,{node:d,type:i},a),y}let z=n.options?.pathCreate===true,f=t,R={ok:true};for(let w=0;w<s.length;w++){let k=s[w],N=w===s.length-1;if(f==null){let x=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,w).join(".")||"root"}" is ${f===null?"null":"undefined"}.`;H(x),R={ok:false,reason:x};break}if(typeof f!="object"){let x=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,w).join(".")||"root"}" is not an object.`;H(x),R={ok:false,reason:x};break}if(Array.isArray(f)){let x=Number(k);if(!Number.isInteger(x)||x<0){let F=`Path "${s.join(".")}" targets non-numeric index "${k}" on an array in "${e}".`;H(F),R={ok:false,reason:F};break}let P=f;if(x>=P.length){let F=`Path "${s.join(".")}" is invalid for "${e}" - index ${x} is out of bounds (length ${P.length}).`;H(F),R={ok:false,reason:F};break}if(N){let F=P[x];if(F!=null){let xe=me(F);if(xe!==i){let Qe=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${xe}, received ${i}.`;H(Qe),R={ok:false,reason:Qe};break}}R={ok:true};break}f=P[x];continue}if(!Object.prototype.hasOwnProperty.call(f,k)){if(z&&N){R={ok:true};break}let x=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${k}" at "${s.slice(0,w).join(".")||"root"}".`;H(x),R={ok:false,reason:x};break}if(N){let x=f[k];if(x!=null){let P=me(x);if(P!==i){let F=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${P}, received ${i}.`;H(F),R={ok:false,reason:F};break}}R={ok:true};break}f=f[k];}d.verdicts||(d.verdicts=new Map);let h=d.verdicts.has(i);if(d.verdicts.set(i,R),!h){let w=`${p}|${i}`;mn(l,w,{node:d,type:i},a);}return R},ge=(e,t,r,o)=>{try{return o?.reuseInput&&dr(t)?{ok:!0,value:t}:{ok:!0,value:Fe(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return Q($[e]?.options?.onError,`onError(${e})`,s),Q(r,`onError(${e})`,s),g(s),{ok:false}}},Ys=(e,t)=>{let r=new Set,o=$[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Er=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=Ys(e,o),s=(a,u)=>{n.forEach(c=>Q(c,`onError(${e})`,a)),u==="critical"?H(a):g(a);};if(typeof r=="function")try{let a=r(t);return a===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:a===!0?t:a}}catch(a){return s(`Validation for "${e}" failed: ${a?.message??a}`,"critical"),{ok:false}}let i=lr(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Ie=(e,t,r,o,n)=>{let s=ge(e,t,o,n);if(!s.ok)return {ok:false};let i=Er(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},se=e=>{let t=v();St(t).delete(e),Tr(t).delete(e);},Js=()=>{let e=v();St(e).clear(),Tr(e).clear();};O("validation.path-cache",Js,50);tn(se);var $e=(e,t=v())=>{if((C()?ae(e):{has:false}).has||t.stores[e]!==void 0)return true;let o=t.initialFactories[e];if(!o)return true;try{let n=o(),s=ge(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=Ie(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(C()){let u=a.value;At(e,u),Vt(()=>{Z(e,u,t),t.initialStates[e]=D(u),delete t.initialFactories[e],se(e);});}else Z(e,a.value,t),t.initialStates[e]=D(a.value),delete t.initialFactories[e],se(e);return !0}catch(n){return fe(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var hn=new WeakMap,bn=e=>{let t=hn.get(e);return t||(t=new Map,hn.set(e,t)),t},Xs=()=>{bn(v()).clear();};O("features.contexts",Xs,100);var Pr=e=>{let t=v(),r=bn(t),o=r.get(e);if(o)return o;let n=$[e];if(!n)return g(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s=()=>Object.fromEntries(Object.keys(t.metaEntries).map(a=>[a,U(a,t)])),i={name:e,options:n.options,getMeta:()=>$[e],getStoreValue:()=>U(e,t),getAllStores:s,getInitialState:()=>on[e],hasStore:()=>G(e),setStoreValue:a=>{Z(e,a);},applyFeatureState:(a,u)=>{an(e,a,u),se(e);},notify:()=>{},reportStoreError:a=>{fe(e,a);},warn:g,warnAlways:V,log:J,hashState:it,deepClone:D,sanitize:Fe,validate:a=>Er(e,a,$[e]?.options?.validate),isDev:T};return r.set(e,i),i},Or=(e,t)=>{let r=M();if(!r.strictMissingFeatures&&!r.assertRuntime)return;let o=[];if(typeof t.getMeta!="function"&&o.push("getMeta"),typeof t.getStoreValue!="function"&&o.push("getStoreValue"),typeof t.getAllStores!="function"&&o.push("getAllStores"),typeof t.getInitialState!="function"&&o.push("getInitialState"),typeof t.hasStore!="function"&&o.push("hasStore"),typeof t.setStoreValue!="function"&&o.push("setStoreValue"),typeof t.applyFeatureState!="function"&&o.push("applyFeatureState"),typeof t.notify!="function"&&o.push("notify"),typeof t.reportStoreError!="function"&&o.push("reportStoreError"),typeof t.warn!="function"&&o.push("warn"),typeof t.warnAlways!="function"&&o.push("warnAlways"),typeof t.log!="function"&&o.push("log"),typeof t.hashState!="function"&&o.push("hashState"),typeof t.deepClone!="function"&&o.push("deepClone"),typeof t.sanitize!="function"&&o.push("sanitize"),typeof t.validate!="function"&&o.push("validate"),typeof t.isDev!="function"&&o.push("isDev"),o.length===0)return;let n=`Feature hook context missing fields for "${e}": ${o.join(", ")}.`;if(fe(e,n),r.assertRuntime)throw new Error(n)},wn=(e,t)=>{ft();let r=Pr(e);r&&(r.notify=()=>t(e),Or(e,r),ee.forEach((o,n)=>{try{o.onStoreCreate?.(r);}catch(s){Y(e,`Feature "${String(n)}" onStoreCreate for "${e}" failed: ${s?.message??s}`,"always");}}));},Rn=(e,t,r,o,n)=>{ft();let s=Pr(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});Or(e,i),ee.forEach((a,u)=>{try{a.onStoreWrite?.(i);}catch(c){Y(e,`Feature "${String(u)}" onStoreWrite for "${e}" failed: ${c?.message??c}`,"always");}});},pc=(e,t,r,o,n,s)=>{ft();let i=Pr(e);if(!i)return;i.notify=()=>n(e);let a=Object.assign(Object.create(i),{action:t,prev:r,next:o});Or(e,a);let u=new Set(s);ee.forEach((c,l)=>{if(!u.has(l))try{c.onStoreWrite?.(a);}catch(p){Y(e,`Feature "${String(l)}" onStoreWrite for "${e}" failed: ${p?.message??p}`,"always");}});};var It=(e,t)=>To({name:e,payload:t,middlewares:(()=>{let r=$[e]?.options?.middleware||[],o=M().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{Y(e,r,o);},warn:g}),$t=(e,t,r,o)=>Et({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{Y(e,n,s);}}),vn=(e,t)=>{let r={...t};return r.persist&&!c("persist")&&(r.explicitPersist&&jt(e,"persist",r.onError),r.persist=null),r.sync&&!c("sync")&&(r.explicitSync&&jt(e,"sync",r.onError),r.sync=false),c("devtools")||(r.explicitDevtools&&jt(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var zt=null,kn=e=>(zt=e,()=>{zt===e&&(zt=null);}),Ke=e=>{zt?.(e);};var _t=new Set,Fr=e=>{if(e){_t.delete(e);return}_t.clear();};O("store-create.ssr-global-warned",()=>Fr(),65);function ce(e,t,r={}){if(C()){let E=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;gt(E,r.onError),A(E);return}if(!st(e)){gt(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!He(t)){gt(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&T()&&g(`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.`),Co(r).forEach(E=>{g(E);});let n=vn(e,Mo(r,e,M().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let E=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;Q(n.onError,`onError(${e})`,E),T()||V(E),L(E);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",u=n.allowSSRGlobalStore??false,c=v(),l=c.stores,p=c.subscribers,m=c.initialStates,d=c.initialFactories,y=c.metaEntries,z=c.scope==="request";if(a&&!u&&!z){let E=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
|
|
16
|
+
Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;gt(E,r.onError);return}if(a&&u&&!z&&!_t.has(e)&&(_t.add(e),V(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
|
|
17
|
+
This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),G(e,c)){let E=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return Y(e,E),{name:e}}s&&!u&&!z&&!ln(e)&&T()&&(dn(e),g(`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 f=ge(e,t,n.onError);if(!f.ok)return;let R=f.value,h=n.lazy===true&&typeof t=="function",w=(p[e]?.size??0)>0;if(h)l[e]=void 0,d[e]=t;else {let E=Ie(e,R,n.validate,n.onError);if(!E.ok)return;Z(e,E.value,c),m[e]=D(E.value);}let k=Date.now(),N=new Date(k).toISOString();return y[e]={createdAt:N,updatedAt:N,updatedAtMs:k,updateCount:0,version:n.version,metrics:{notifyCount:0,totalNotifyMs:0,lastNotifyMs:0,resetCount:0,totalResetMs:0,lastResetMs:0},options:n,readCount:0,lastReadAt:null,lastReadAtMs:null,lastCorrelationId:null,lastCorrelationAt:null,lastCorrelationAtMs:null,lastTraceContext:null},se(e),wn(e,Ke),$t(e,"onCreate",y[e].options.onCreate,[R]),en(c,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),w&&Ke(e),J(`Store "${e}" created -> ${JSON.stringify(R)}`),{name:e}}function xn(e,t,r={}){let o=(r.lazy===true,ce(e,t,r));if(o)return o;throw new Error(`createStoreStrict("${String(e)}") failed. See earlier warnings/errors or onError callbacks for the cause.`)}var Cn=e=>{if(typeof e!="object"||e===null)return false;let t=e;if(t.$$typeof||typeof window<"u"&&e instanceof Element)return false;let r=t.constructor?.name;return !(r&&r!=="Object"&&r!=="Array")},mt=e=>(Cn(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Wt=e=>{if(!Cn(e))return e;let t=[e],r=new WeakSet;for(;t.length>0;){let o=t.pop();if(!r.has(o)){r.add(o),Object.isFrozen(o)||Object.freeze(o);for(let n of Object.keys(o)){let s=o[n];typeof s=="object"&&s!==null&&!r.has(s)&&t.push(s);}}}return e};var Ht=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Ye=(e,t)=>{if(t==="ref"){if(!T())return e;try{return mt(e)}catch{return e}}if(t==="shallow"){let o=at(e);if(!T())return o;try{return mt(o)}catch{return o}}let r=D(e);if(!T())return r;try{return Wt(r)}catch{return r}};var Mn=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:o}=e,n=M().flush,s=n.priorityStores||[],i=s.length?new Set(s):null;o.length=0,r.length=0;let a=new Set;if(i){for(let y of t)r.push(y),a.add(y);for(let y of s)a.has(y)&&o.push(y);for(let y of r)i.has(y)||o.push(y);}else for(let y of t)r.push(y),a.add(y),o.push(y);t.clear();let u=Po(o),c=new Set(o);for(let y of u)c.has(y)||(o.push(y),c.add(y));let l=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,p=n.chunkDelayMs,m=l===Number.POSITIVE_INFINITY&&p===0;return {names:o,sliceSize:l,chunkDelayMs:p,runInline:m,prioritySet:i}};var Vr=e=>({notifyCount:e?.notifyCount??0,totalNotifyMs:e?.totalNotifyMs??0,lastNotifyMs:e?.lastNotifyMs??0,resetCount:e?.resetCount??0,totalResetMs:e?.totalResetMs??0,lastResetMs:e?.lastResetMs??0}),Ar=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),Nr=(e,t)=>{e&&(e.metrics=t);};var yt=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Tn=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>We(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var ht=null,Re=null,zc=e=>{if(!e){Re=null;return}if(Re&&Re!==e){V("injectWriteContextRunner(...) was called more than once. The existing runner will be kept to avoid cross-request write-context leaks. If you need to replace it in tests, call injectWriteContextRunner(null) first.");return}Re=e;},Qs=()=>{ht=null,Re=null;};O("write-context.runner",Qs,121);var Lt=()=>Re?.get()??ht,Dr=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(Re)return Re.run(e,t);let r=ht;ht=e;try{return t()}finally{ht=r;}};var En=e=>{if(!(e instanceof TypeError))return false;let t=e?.message??String(e);return /read only|readonly|cannot assign|cannot add property|cannot delete property/i.test(t)},Pn=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:u,prioritySet:c}=t,l=Oe(),p=e.stores,m=e.subscribers,d=e.metaEntries,y=e.snapshotCache,z=M().defaultSnapshotMode,f=b=>Ht(d[b],z),R=b=>l&&Object.prototype.hasOwnProperty.call(l,b)?l[b]:p[b],h=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),w=xr("beforeFlush"),k=xr("afterFlush"),N=b=>{w&&dt("beforeFlush",b,{type:"beforeFlush"});},E=(b,_)=>{k&&dt("afterFlush",b,{type:"afterFlush",elapsedMs:_});},x=b=>{let _=d[b];if(!_)return null;let j=_.lastCorrelationId??void 0,S=_.lastTraceContext??void 0;return !j&&!S?null:{correlationId:j,traceContext:S}},P=()=>{o();};if(u){for(let b of s){let _=m[b];if(!_||_.size===0)continue;let j=d[b]?.updateCount??0,S=f(b),ze=R(b),te=y[b],re=te&&te.source===ze&&te.mode===S?te.snapshot:(()=>{let q=Ye(ze,S);return y[b]={version:r,snapshot:q,source:ze,mode:S},q})(),ue=Vr(d[b]?.metrics);N(b);let Ce=h(),Se=Array.from(_),Ze=x(b),et=()=>{for(let q of Se)try{q(re);}catch(Me){let le=d[b]?.options?.snapshotSafety??"warn";if(T()&&(S==="ref"||S==="shallow")&&En(Me)){if(le==="throw")throw Me;if(le==="auto-clone")try{let rt=D(re);g(`Snapshot mutation detected for "${b}". Delivered a cloned snapshot to the subscriber.`);try{q(rt);}catch(Zt){g(`Subscriber for "${b}" threw on cloned snapshot: ${Zt?.message??Zt}`);}continue}catch{}g(`Snapshot mutation detected for "${b}": ${Me?.message??Me}`);continue}g(`Subscriber for "${b}" threw: ${Me?.message??Me}`);}};Ze?Dr(Ze,et):et();let tt=h()-Ce;E(b,tt),Ar(ue,tt),Nr(d[b],ue),(d[b]?.updateCount??j)!==j&&n.pendingNotifications.add(b);}P();return}let F=b=>{let _=[];for(let j of s){if(b&&!b(j))continue;let S=m[j];if(!S||S.size===0)continue;let ze=d[j]?.updateCount??0,te=f(j),re=R(j),ue=y[j],Ce=ue&&ue.source===re&&ue.mode===te?ue.snapshot:(()=>{let Se=Ye(re,te);return y[j]={version:r,snapshot:Se,source:re,mode:te},Se})();_.push({name:j,snapshot:Ce,version:ze,subscribers:Array.from(S),subscriberSet:new Set(S),notified:new Set,metrics:Vr(d[j]?.metrics),totalMs:0,beforeHooked:false});}return _},xe=c?F(b=>c.has(b)):[],Qe=F(b=>!c||!c.has(b)),Xt=(b,_)=>{let j=()=>{if(b.length===0){_();return}let S=b.shift();if((d[S.name]?.updateCount??S.version)!==S.version){if(n.pendingNotifications.add(S.name),b.length===0){_();return}yt(j,a);return}let te=()=>{let ie=m[S.name];if(!(!ie||ie.size===0))for(let q of ie)S.subscriberSet.has(q)||(S.subscriberSet.add(q),S.subscribers.push(q));};te();let re=S.subscribers;if(re.length===0){if(b.length===0){_();return}yt(j,a);return}S.beforeHooked||(S.beforeHooked=true,N(S.name));let ue=h(),Ce=0,Se=false,Ze=x(S.name),et=()=>{for(let ie=0;ie<re.length&&Ce<i;ie+=1){let q=re[ie];if(S.notified.has(q))continue;S.notified.add(q);try{q(S.snapshot);}catch(le){let Qt=d[S.name]?.options?.snapshotSafety??"warn",rt=f(S.name);if(T()&&(rt==="ref"||rt==="shallow")&&En(le)){if(Qt==="throw")throw le;if(Qt==="auto-clone")try{let zr=D(S.snapshot);g(`Snapshot mutation detected for "${S.name}". Delivered a cloned snapshot to the subscriber.`);try{q(zr);}catch(_r){g(`Subscriber for "${S.name}" threw on cloned snapshot: ${_r?.message??_r}`);}if(S.notified.add(q),Ce+=1,(d[S.name]?.updateCount??S.version)!==S.version){Se=!0,n.pendingNotifications.add(S.name);break}continue}catch{}g(`Snapshot mutation detected for "${S.name}": ${le?.message??le}`);continue}g(`Subscriber for "${S.name}" threw: ${le?.message??le}`);}if(Ce+=1,(d[S.name]?.updateCount??S.version)!==S.version){Se=true,n.pendingNotifications.add(S.name);break}}};if(Ze?Dr(Ze,et):et(),S.totalMs+=h()-ue,Se){if(b.length===0){_();return}yt(j,a);return}te();let tt=false;for(let ie of re)if(!S.notified.has(ie)){tt=true;break}if(tt?b.push(S):(Ar(S.metrics,S.totalMs),Nr(d[S.name],S.metrics),E(S.name,S.totalMs)),b.length===0){_();return}yt(j,a);};j();};xe.length>0?Xt(xe,()=>Xt(Qe,P)):Xt(Qe,P);};var Zs=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=Mn(t);Pn(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&Bt(e);});},Bt=e=>{Tn(e,Zs);};var Ut=(e,t)=>{if(!(!e||typeof e!="object")){if(t==="ref"||t==="shallow"){mt(e);return}t==="deep"&&Wt(e);}},ei=e=>{let t=v(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&Bt(t);};kn(ei);var lu=e=>{if(typeof e!="function"){g("setStoreBatch requires a synchronous function callback.");return}let t=Object.prototype.toString.call(e);if(t==="[object AsyncFunction]"||t==="[object AsyncGeneratorFunction]"){V("setStoreBatch does not support async functions. Move async work outside and batch only synchronous mutations.");return}if(t==="[object GeneratorFunction]"){V("setStoreBatch does not support generator functions. Move generator logic outside and batch only synchronous mutations.");return}let r=v(),o=typeof window>"u",n=typeof process<"u"?process.env?.NODE_ENV:void 0;if(o&&n==="production"&&r.scope!=="request")throw new Error("setStoreBatch() called in a global SSR context. Use createStoreForRequest() to ensure transaction isolation.");let s=r.notify;s.batchDepth=Math.max(0,s.batchDepth+1),Ko(r);let i;try{let a=We(r,e);a&&typeof a.then=="function"&&(i=new Error("setStoreBatch does not support promise-returning callbacks. Move async work outside and batch only synchronous mutations."));}catch(a){i=a;}finally{let a=Jo(i,r);s.batchDepth=Math.max(0,s.batchDepth-1),s.batchDepth===0&&s.pendingNotifications.size>0&&Bt(r),a&&!i&&(i=a);}if(i){let a=i instanceof Error?i.message:String(i);V(`setStoreBatch failed: ${a}`);}},jr=(e,t)=>{let o=v().subscribers;return o[e]||(o[e]=new Set),o[e].add(t),()=>{o[e]?.delete(t),o[e]?.size===0&&delete o[e];}};var On=(e,t)=>{if(!G(e))return null;let r=v();t.trackRead&&Nt(e,r);let o=Ht(r.metaEntries[e],M().defaultSnapshotMode);if(!t.committedOnly&&C()){let u=r.transaction.snapshotCache,c=K(e);if(c===void 0)return null;let l=u.get(e);if(l&&l.source===c&&l.mode===o){let m=l.snapshot;return Ut(m,o),m}let p=Ye(c,o);return u.set(e,{source:c,snapshot:p,mode:o}),Ut(p,o),p}let n=r.notify.flushId,s=t.committedOnly?U(e,r):K(e,r),i=r.snapshotCache[e];if(i&&i.source===s&&i.mode===o){let u=i.snapshot;return Ut(u,o),u}let a=Ye(s,o);return Ut(a,o),r.snapshotCache[e]={version:n,snapshot:a,source:s,mode:o},a},du=e=>On(e,{trackRead:true,committedOnly:false}),pu=e=>On(e,{trackRead:false,committedOnly:true});var ti=()=>{let e=v().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};O("notify.reset",ti,40);var ri=32,qt=new Set;O("store-write.slow-mutator-warned",()=>qt.clear(),65);var oi=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var Vn=e=>{qt.delete(e);},An=(e,t)=>{T()&&(t<ri||qt.has(e)||(qt.add(e),g(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},Gt=e=>e??Lt(),ni=(e,t)=>{if(!e||!t)return;let r=t.resetElapsedMs;typeof r=="number"&&(e.metrics.resetCount=(e.metrics.resetCount??0)+1,e.metrics.totalResetMs=(e.metrics.totalResetMs??0)+r,e.metrics.lastResetMs=r);},Fn=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:a,metricsUpdate:u})=>{let c=e.metaEntries;Z(t,o,e),se(t);let l=Date.now();c[t].updatedAt=new Date(l).toISOString(),c[t].updatedAtMs=l;let p=a??Lt();p&&(p.correlationId||p.traceContext)?(c[t].lastCorrelationId=p.correlationId??null,c[t].lastCorrelationAt=new Date(l).toISOString(),c[t].lastCorrelationAtMs=l,c[t].lastTraceContext=p.traceContext??null):(c[t].lastCorrelationId=null,c[t].lastCorrelationAt=null,c[t].lastCorrelationAtMs=null,c[t].lastTraceContext=null),oi(c[t]),ni(c[t],u),Rn(t,n,r,o,Ke),$t(t,s,c[t].options[s],[r,o]),Ke(t),J(i);},Je=(e,t)=>{let r=t.context??Lt();if(C()){At(t.name,t.next),Yo(t.runtimePatches??[]),Vt(()=>Fn(e,{...t,context:r}));return}Fn(e,{...t,context:r}),t.runtimePatches&&t.runtimePatches.length>0&&De(t.runtimePatches,e);};function bt(e,t,r){return Nn(e,t,r)}var Nn=(e,t,r,o)=>{let n=pe(e),s=v(),i=s.metaEntries;if(!$e(n,s))return {ok:false,reason:"validate"};if(!G(n,s)){let h=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return fe(n,h),C()&&A(h),{ok:false,reason:"not-found"}}let a,u={kind:"root"},c=C()?ae(n):{has:false,value:void 0},l=c.has?c.value:K(n,s);if(typeof t=="function"&&r===void 0){let h=T()?Date.now():0;try{let w=M().mutatorProduce,k=!1,N,E=P=>{let F=t(P);return F!==void 0&&(k=!0,N=F),F},x=w?w(l,E):(()=>{let P=D(l);return E(P),P})();if(k&&M().strictMutatorReturns){let P=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return fe(n,P),C()&&A(P),{ok:!1,reason:"validate"}}k&&T()&&!M().strictMutatorReturns&&g(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=k&&!M().strictMutatorReturns?N:x,u={kind:"root"};}catch(w){return fe(n,`Mutator for "${n}" failed: ${w?.message??w}`),C()&&A(w),{ok:false,reason:"validate"}}finally{h&&An(n,Date.now()-h);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!He(t))return C()&&A(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof l!="object"||l===null||Array.isArray(l))return L(`setStore("${n}", data) only merges into object stores.
|
|
18
|
+
Use setStore("${n}", "path", value) or recreate the store with an object shape.`),C()&&A(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let h=ge(n,t);if(!h.ok)return C()&&A(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};a={...l,...h.value},u={kind:"merge",value:h.value};}else if(typeof t=="string"||Array.isArray(t)){if(!ct(t))return C()&&A(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let h=ge(n,r);if(!h.ok)return C()&&A(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let w=h.value,k=yn(n,l,t,w);if(!k.ok)return Q(i[n]?.options?.onError,`onError(${n})`,k.reason??`Invalid path for "${n}".`),C()&&A(k.reason),{ok:false,reason:"path"};a=mr(l,t,w),u={kind:"path",path:t,value:w};}else {let h=`setStore("${n}") - invalid arguments.
|
|
19
|
+
Usage:
|
|
20
|
+
setStore("${n}", "field", value)
|
|
21
|
+
setStore("${n}", "nested.field", value)
|
|
22
|
+
setStore("${n}", { field: value })
|
|
23
|
+
setStore(storeDef, draft => { draft.field = value })
|
|
24
|
+
replaceStore("${n}", value) // full-store replace`;return L(h),Q(i[n]?.options?.onError,`onError(${n})`,h),C()&&A(h),{ok:false,reason:"invalid-args"}}if(!He(a))return C()&&A(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let m=i[n]?.options?.validate,d=Gt(o),y=It(n,{action:"set",prev:l,next:a,path:t,correlationId:d?.correlationId,traceContext:d?.traceContext});if(y===Ue)return C()&&A(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let z=Object.is(y,a),f=Ie(n,y,m,void 0,z?{reuseInput:true}:void 0);if(!f.ok)return C()&&A(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};let R=Bo({store:n,intent:u,committedValue:f.value,preserveIntent:u.kind!=="root"&&Object.is(y,a)&&Object.is(f.value,y),context:d});try{if(gr(l,f.value))return {ok:!0}}catch{}return Je(s,{name:n,prev:l,next:f.value,action:"set",hookLabel:"onSet",logMessage:`Store "${n}" updated`,context:d,runtimePatches:R}),{ok:true}},Ir=(e,t,r,o)=>Nn(e,t,r,o);function ve(e,t){let r=pe(e);if(!r)return {ok:false,reason:"invalid-args"};let o=v(),n=$r(o,r,t,"replace");return n.ok?{ok:true}:n.reason==="not-found"?{ok:false,reason:"not-found"}:n.reason==="middleware"?{ok:false,reason:"middleware"}:{ok:false,reason:"validate"}}var $r=(e,t,r,o="hydrate",n)=>{let s=(y,z)=>(C()&&A(z??y),{ok:false,reason:y});if(!je(t))return s("not-found",`replaceStore("${t}") called before createStore().`);let i=C()?ae(t):{has:false,value:void 0},a=i.has?i.value:K(t,e),u=ge(t,r);if(!u.ok)return s("sanitize",`replaceStore("${t}") failed sanitize`);let c=u.value;if(c===void 0){let y=`Whole-store undefined replacement is blocked for "${t}". Use null for intentional empty state.`;return Y(t,y),s("undefined",y)}let l=e.metaEntries[t]?.options?.validate,p=Gt(n),m=It(t,{action:o,prev:a,next:c,path:null,correlationId:p?.correlationId,traceContext:p?.traceContext});if(m===Ue)return s("middleware",`replaceStore("${t}") aborted by middleware`);let d=Ie(t,m,l);return d.ok?(Je(e,{name:t,prev:a,next:d.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:p,runtimePatches:[be({store:t,value:d.value,source:o==="hydrate"?"hydrateStores":"replaceStore",context:p})]}),{ok:true}):s("validate",`replaceStore("${t}") failed validation`)};var si=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Dn=(e,t)=>t==="ref"?e:t==="shallow"?at(e):D(e);function ke(e,t){let r=pe(e);if(!je(r))return null;let o=v();if(!$e(r,o))return null;Nt(r,o);let n=K(r,o),s=si(o.metaEntries[r],M().defaultSnapshotMode);if(t===void 0)return n===null||typeof n!="object"?n:Dn(n,s);if(!ct(t))return null;let i=Sr(n,t);return i===null||typeof i!="object"?i:Dn(i,s)}var Xe=e=>G(e);var el=e=>{let r=v().metaEntries[e];return r?.metrics?{...r.metrics}:null};var jn=(e,t={},r)=>{if(C()){let c="hydrateStores(...) cannot be called inside setStoreBatch.";return g(c),A(c),{hydrated:[],created:[],failed:[],blocked:{reason:"transaction"}}}let o={hydrated:[],created:[],failed:[]};if(!e||typeof e!="object")return o;let n=v(),s=[],i=r??{};if(!(i.allowTrusted===true||i.allowHydration===true||i.allowUntrusted===true||M().allowUntrustedHydration===true))return V("hydrateStores(...) requires explicit trust. Pass { allowTrusted: true } (or { allowHydration: true }) as the third argument or configureStroid({ allowTrustedHydration: true })."),o.blocked={reason:"untrusted"},o;if(typeof i.validate=="function"){let c=false;try{c=!!i.validate(e);}catch(l){let p=`hydrateStores() trust.validate threw: ${l?.message??l}`;if(T())throw new Error(`hydrateStores() trust.validate threw an error. Fix your validator before this becomes a silent production failure.
|
|
25
|
+
Original error: ${l?.message??l}`);let m=t?.default?.onError;if(typeof m=="function")try{m(p);}catch(d){V(`hydrateStores(...) onError threw: ${d?.message??d}`);}if(V(p),typeof i.onValidationError=="function")try{if(!!i.onValidationError(l,e))c=!0;else return o.blocked={reason:"validation-error",cause:l},o}catch(d){return V(`hydrateStores(...) onValidationError threw: ${d?.message??d}`),o.blocked={reason:"validation-error",cause:d},o}else return o.blocked={reason:"validation-error",cause:l},o}if(!c)return V("hydrateStores(...) rejected by trust validation."),o.blocked={reason:"validation-failed"},o}let u=[];return Object.entries(e).forEach(([c,l])=>{if(!st(c)){o.failed.push({name:c,reason:"invalid-name"});return}if(G(c,n)){let p=$r(n,c,l,"hydrate");p.ok?(o.hydrated.push(c),u.push(c),s.push(be({store:c,value:U(c,n),source:"hydrateStores"}))):o.failed.push({name:c,reason:"merge-failed",cause:p.reason,received:l});}else {let p=t;ce(c,l,p[c]||p.default||{})?(o.created.push(c),u.push(c),s.push(be({store:c,value:U(c,n),source:"hydrateStores"}))):o.failed.push({name:c,reason:"create-failed",received:l});}}),u.length>0&&vr(u).forEach(l=>{let p=n.computedEntries[l];if(!p)return;let m=p.deps.map(d=>ke(d));try{let d=p.compute(...m);if(d&&typeof d.then=="function"){g(`hydrateStores recompute for "${l}" returned a Promise; skipping.`);return}let y=U(l,n);if(p.hasLastOutput&&Object.is(d,p.lastOutput)||Object.is(d,y))return;p.lastOutput=d,p.hasLastOutput=!0,ve(l,d);}catch(d){g(`hydrateStores recompute for "${l}" failed: ${d?.message??d}`);}}),s.length>0&&De(s,n),o};function Kt(e){let t=pe(e);if(!je(t))return;let r=v();if(!$e(t,r))return;if(C()){let n=`deleteStore("${t}") cannot be called inside setStoreBatch. Move deleteStore outside the batch to preserve transaction semantics.`;Y(t,n),A(n);return}sn().deleteExistingStore(t),se(t),Vn(t),Fr(t);}function Yt(e){let t=pe(e);if(!je(t))return {ok:false,reason:"not-found"};let r=v();if(r.metaEntries[t]?.options?.lazy===true&&!!r.initialFactories[t]){let c=`resetStore("${t}") cannot run on a lazy store before it is initialized. Read the store once (getStore) to materialize it before resetting.`;return Y(t,c),C()&&A(c),{ok:false,reason:"lazy-uninitialized"}}if(!$e(t,r))return {ok:false,reason:"validate"};if(!Object.prototype.hasOwnProperty.call(r.initialStates,t)){let c=`resetStore("${t}") has no initial state to reset to. If this is a lazy store, ensure it has been initialized before calling resetStore.`;return Y(t,c),C()&&A(c),{ok:false,reason:"not-found"}}let n=C()?ae(t):{has:false,value:void 0},s=n.has?n.value:K(t,r),i=typeof performance<"u"&&performance.now?performance.now():Date.now(),a=D(r.initialStates[t]),u=(typeof performance<"u"&&performance.now?performance.now():Date.now())-i;return Je(r,{name:t,prev:s,next:a,action:"reset",hookLabel:"onReset",logMessage:`Store "${t}" reset to initial state/value`,metricsUpdate:{resetElapsedMs:u},runtimePatches:[be({store:t,value:a,source:"resetStore"})]}),{ok:true}}var In=()=>{Lr();};var wt=e=>({name:e}),jl=e=>{let t=`${e}::`,r=n=>n.includes("::")?n:`${t}${n}`,o=n=>typeof n=="string"?wt(r(n)):{...n,name:r(n.name)};return {store:n=>({name:r(n)}),create:(n,s,i)=>ce(r(n),s,i),createStrict:(n,s,i)=>xn(r(n),s,i),set:(n,...s)=>{let i=s;return bt(o(n),...i)},get:(n,...s)=>{let i=s;return ke(o(n),...i)},delete:n=>Kt(o(n)),reset:n=>Yt(o(n))}};var ai=()=>typeof window>"u"&&typeof process<"u"&&process.env?.NODE_ENV==="production",ci=(e,t)=>!ai()||t.scope==="request"?false:e.length>0&&e.every(r=>t.metaEntries[r]?.options.allowSSRGlobalStore===true),Jt=()=>v().computedCleanups,$n=new WeakMap,zn=new WeakMap,Rt=e=>{let t=$n.get(e);return t||(t=new Map,$n.set(e,t)),t},ui=e=>{let t=zn.get(e);return t||(t=new Map,zn.set(e,t)),t};function Xl(e,t,r,o={}){if(!e||typeof e!="string"){g("createComputed requires a store name as first argument");return}if(!Array.isArray(t)||t.length===0){g(`createComputed("${e}") requires at least one dependency`);return}if(typeof r!="function"){g(`createComputed("${e}") requires a compute function as third argument`);return}let n=Jt(),s=n.get(e);s&&(s(),n.delete(e));let i=t.map(d=>typeof d=="string"?d:d?.name);if(i.some(d=>!d||typeof d!="string")){g(`createComputed("${e}") dependencies must be store names or store handles.`);return}if(T()){let d=i.filter(y=>!Xe(y));d.length>0&&g(`createComputed("${e}") dependencies not found at registration: ${d.join(", ")}. Computed values will receive null until those stores are created.`);}if(!No(e,i,r,o.classification??"opaque"))return;let u=v();Rt(u).set(e,{...o});let c=_n(e,t,r,o.onError),l=Ft(e);l&&(l.lastOutput=c,l.hasLastOutput=true);let p=wt(e);if(Xe(e))ve(p,c);else if(!(ci(i,u)?ce(e,c,{scope:"global"}):ce(e,c))&&!Xe(e)){br(e),Rt(u).delete(e);return}let m=[];for(let d of i){let y=jr(d,()=>{Wn(e,i,r,o.onError);});m.push(y);}return Jt().set(e,()=>{m.forEach(d=>d()),br(e),Rt(v()).delete(e);}),T()&&J(`computed store "${e}" created, deps: [${i.join(", ")}]`),p}var _n=(e,t,r,o)=>{let n=t.map(s=>typeof s=="string"?ke(wt(s)):ke(s));try{return r(...n)}catch(s){return g(`createComputed("${e}") compute function threw: ${s?.message??s}`),Q(o,`computed.onError(${e})`,s),Xe(e)?K(e,v()):null}},Wn=(e,t,r,o)=>{let n=Ft(e);if(!n)return;let s=v();if(s.notify.isFlushing){let l=s.notify.flushId,p=ui(s);if(p.get(e)===l)return;p.set(e,l);}let i=_n(e,t,r,o),a=wt(e),u=K(e,s);n.hasLastOutput&&Object.is(i,n.lastOutput)||Object.is(i,u)||(n.lastOutput=i,n.hasLastOutput=true,ve(a,i),wr(e));},Ql=e=>{let t=Ft(e);if(!t){g(`invalidateComputed("${e}") -- "${e}" is not a computed store`);return}wr(e),Wn(e,t.deps,t.compute);},_o=e=>{let t=Jt(),r=t.get(e);if(!r){T()&&g(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);},Zl=e=>Ot(e),Wo=(e,t=v())=>Rt(t).get(e)?.autoDispose===true,ed=()=>{let e=Jt();e.forEach(t=>t()),e.clear(),Rt(v()).clear();};export{ed as $,Q as A,xs as B,Cs as C,kr as D,Ms as E,Es as F,pe as G,Bs as H,Js as I,pc as J,ce as K,xn as L,ke as M,Xe as N,el as O,wt as P,jl as Q,zc as R,Dr as S,ve as T,bt as U,Ir as V,Xl as W,Ql as X,_o as Y,Zl as Z,Wo as _,O as a,ta as aa,qr as b,v as ba,Te as c,Va as ca,Yr as d,$ as da,qn as e,sn as ea,Ee as f,G as fa,Pe as g,K as ga,mi as h,U as ha,yi as i,ka as ia,We as j,Ko as ja,X as k,Jo as ka,M as l,Bt as la,vi as m,lu as ma,T as n,jr as na,H as o,du as oa,g as p,pu as pa,V as q,jn as qa,L as r,Kt as ra,cr as s,Yt as sa,it as t,In as ta,at as u,D as v,gr as w,fs as x,ct as y,Sr as z};//# sourceMappingURL=chunk-FOQKGHPS.js.map
|
|
26
|
+
//# sourceMappingURL=chunk-FOQKGHPS.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var n=Object.defineProperty;var u=(e,t)=>{for(var o in t)n(e,o,{get:t[o],enumerable:true});};var r=new Map,a=null,i=(e,t)=>{r.set(e,t),a?.(e,t);},l=e=>r.has(e),x=e=>r.get(e),F=()=>Array.from(r.keys()),p=e=>{a=e;};export{u as a,i as b,l as c,x as d,F as e,p as f};//# sourceMappingURL=chunk-KQCSFGHJ.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-KQCSFGHJ.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {d}from'./chunk-BW32TJGE.js';import {r}from'./chunk-6ELWGQ4Q.js';import {ca,u,v,H as H$1,C,E as E$1,D,B as B$1,F as F$1,k as k$1,f,c,g,s}from'./chunk-FOQKGHPS.js';var i=()=>k$1(f(c)),a=t=>{let r=i();return g(r,t)?true:(s(t,Object.keys(r.stores)),false)},F=(t,r)=>{if(!r)return true;if(r.endsWith("*")){let o=r.slice(0,-1);return t.startsWith(o)}return t===r},A=t=>{let r=i();return Object.keys(r.stores).filter(o=>F(o,t))},I=t=>{if(!a(t))return null;let r=i().metaEntries[t],o=u(r);o.metrics=u(r.metrics);let s=u(r.options),e=s;return e.persist&&typeof e.persist=="object"&&(e.persist=u(e.persist)),e.sync&&typeof e.sync=="object"&&(e.sync=u(e.sync)),e.devtools&&typeof e.devtools=="object"&&(e.devtools=u(e.devtools)),e.lifecycle&&typeof e.lifecycle=="object"&&(e.lifecycle=u(e.lifecycle)),o.options=s,o},B=()=>v(i().initialStates),G=t=>{let r=i().metaEntries[t];return r?.metrics?{...r.metrics}:null},E=t=>a(t)?ca[t]?.size??0:0,j=t=>a(t)?r(t):0,k=(t={})=>{let r=t.unreadThresholdMs??6e4,o=Date.now();return A().map(s=>{let e=i().metaEntries[s],l=e?.createdAt?new Date(e.createdAt).getTime():o,c=e?.lastReadAtMs??null,w=Math.max(0,o-l),u;return (e?.readCount??0)===0&&(e?.updateCount??0)===0?u="cold":(e?.readCount??0)===0?u="write-only":c&&o-c>r?u="stale":u="active",{name:s,createdAt:e?.createdAt??new Date(l).toISOString(),lastReadAt:e?.lastReadAt??null,updateCount:e?.updateCount??0,readCount:e?.readCount??0,subscriberCount:E(s),ageMs:w,verdict:u}}).filter(s=>s.verdict==="cold"||s.verdict==="stale"||t.includeWriteOnly&&s.verdict==="write-only")},T=t=>{if(t){if(!a(t))return null;let o=I(t);return {name:t,meta:o,metrics:G(t),async:{inflight:j(t),lastCorrelationId:o?.lastCorrelationId??null,traceContext:o?.lastTraceContext??null},persist:{queueDepth:H(t)}}}let r=A().map(o=>T(o));return {stores:r,async:d(),registry:{totalStores:r.length,coldStores:k({})}}},H=t=>{if(!a(t))return 0;let r=H$1("persist");return r?.getPersistQueueDepth?r.getPersistQueueDepth(t)??0:0},_=()=>C(),J=()=>E$1(),K=t=>D(t),L=t=>B$1(t),U=(t,r)=>F$1(t,r);export{A as a,I as b,B as c,G as d,E as e,j as f,k as g,T as h,H as i,_ as j,J as k,K as l,L as m,U as n};//# sourceMappingURL=chunk-M2NJVI36.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-M2NJVI36.js.map
|