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/server.js
CHANGED
|
@@ -1,13 +1,2 @@
|
|
|
1
|
-
import {
|
|
2
|
-
Store data only - handle functions outside the store.`,Pr=()=>`Map/Set detected. stroid converts these to plain objects.
|
|
3
|
-
Use arrays or plain objects for best results.`,Vr=()=>`Date object detected. stroid stores it as ISO string.
|
|
4
|
-
Use new Date(value) to convert back when reading.`,Ar=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Nr=()=>"Map detected; converting to plain object.",Dr=()=>"Set detected; converting to array.",_r=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Wr=e=>`Store name "${e}" contains spaces.
|
|
5
|
-
Use camelCase or kebab-case: "userName" or "user-name"`,Hr=e=>`Store name "${e}" is not allowed.
|
|
6
|
-
Reserved names: "__proto__", "constructor", "prototype".`,hn=128,bn=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=hn,Rn=(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]},Vt=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||bn(n,s)&&Rn(n,s)<=2});if(r){y(`Store "${e}" not found. Did you mean "${r}"?`);return}L(`Store "${e}" not found.
|
|
7
|
-
Available stores: [${t.join(", ")}]
|
|
8
|
-
Call createStore("${e}", data) first.`);};var te=new Set(["__proto__","constructor","prototype"]),Nt=(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 De=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,Lr=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},Dt=e=>{let t=De(e);return t==="function"?(L(Or()),false):t==="map"||t==="set"?(y(Pr()),true):(t==="date"&&y(Vr()),true)},At=(e,t)=>{let r=Lr(e);if(r)throw new Error(`${r} values are not supported`);let o=De(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&&!At(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||te.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!At(i.value,t))return false}return true}return true},jt=e=>At(e,new WeakSet),Ne=(e,t)=>{let r=Lr(e);if(r)throw new Error(`${r} values are not supported`);let o=De(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 v()&&y(Ar()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),v()&&y(Nr());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)]=Ne(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),v()&&y(Dr()),Array.from(e,n=>Ne(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,c]of Object.entries(s))if(c.enumerable&&!te.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=Ne(c.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=>Ne(n,t))}return e},ue=e=>Ne(e,new WeakSet),je=e=>typeof e!="string"||e.trim()===""?(L(_r(e)),false):te.has(e)?(L(Hr(e)),false):e.includes(" ")?(L(Wr(e)),false):true;var It=null,wn=()=>{if(It)return It;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 It=t,t},Br=e=>{let t=wn(),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},vn=2166136261,xn=2654435761,Cn=1e5,re=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},le=(e,t)=>{re(e,t.length);for(let r=0;r<t.length;r++)re(e,t.charCodeAt(r));},F=(e,t)=>{le(e,t);},qr=(e,t)=>{if(Number.isNaN(t)){F(e,"NaN");return}if(!Number.isFinite(t)){F(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){F(e,"-0");return}let r=t|0;if(t===r){F(e,"int"),re(e,r);return}F(e,"num"),le(e,String(t));},he=(e,t)=>{if(e.nodes++>Cn){F(e,"[max]");return}if(t===null){F(e,"null");return}let r=typeof t;if(r==="string"){F(e,"string"),le(e,t);return}if(r==="number"){F(e,"number"),qr(e,t);return}if(r==="boolean"){F(e,t?"true":"false");return}if(r==="undefined"){F(e,"undefined");return}if(r==="bigint"){F(e,"bigint"),le(e,t.toString());return}if(r==="symbol"){F(e,"symbol");let u=t;le(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){F(e,"function"),le(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){F(e,"ref"),re(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){F(e,"array"),re(e,o.length);for(let u=0;u<o.length;u++)Object.prototype.hasOwnProperty.call(o,u)?he(e,o[u]):F(e,"hole");return}if(o instanceof Date){F(e,"date"),qr(e,o.getTime());return}if(o instanceof Map){F(e,"map"),re(e,o.size),o.forEach((u,a)=>{he(e,a),he(e,u);});return}if(o instanceof Set){F(e,"set"),re(e,o.size),o.forEach(u=>{he(e,u);});return}F(e,"object");let i=Object.getOwnPropertyDescriptors(o),c=[];Object.entries(i).forEach(([u,a])=>{a?.enumerable&&(te.has(u)||"get"in a||"set"in a||c.push([u,a]));}),re(e,c.length);for(let[u,a]of c)le(e,u),he(e,a.value);},Ie=e=>{if(typeof e=="string")return Br(JSON.stringify(e));let t={h1:vn,h2:xn,seen:new WeakMap,nextId:1,nodes:0};he(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 kn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",$e=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&&(te.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},$t=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},Mn=e=>$t(e)===null,En=e=>{let t=$t(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},de=(e,t=new WeakMap)=>{if(En(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(de(i,t),de(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(de(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=de(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||te.has(n)||"get"in s||"set"in s||(r[n]=de(s.value,t));}),r},k=e=>{if(kn)try{return structuredClone(e)}catch(t){if(!Mn(e)){let r=$t(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return y(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),de(e)}return de(e)};var zt=(e,t)=>{try{let r=k(e);return t(r),r}catch(r){throw new Error(`produceClone failed (possible circular reference or unserializable data): ${r?.message??r}`)}};var Fn=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},be=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?Fn(e):[String(e)];var Gr=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")},Ht=e=>(Gr(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Kr=e=>{if(!Gr(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 et=Symbol("stroid.middleware.abort"),Yr=({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=k(t.next);for(let c of r){if(typeof c!="function")continue;let u,a=i;try{u=c({action:t.action,name:e,prev:t.prev,next:a,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(l){let p=`Middleware for "${e}" failed: ${l?.message??l}`;return o(p,"dev"),et}if(u&&typeof u.then=="function"){let l=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(l,"dev"),et}u===void 0?(v()&&!s.has(c)&&(s.add(c),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=a):i=u;}return i},tt=({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 pe=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;T(`${t} callback threw: ${String(n)}`);}},fe=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(pe(n,"onError",e),r==="critical"){o==="dev"&&y(e),ce(e);return}if(o==="always"){T(e);return}y(e);};var rt=null,Jr=e=>{rt=e;},Xr=e=>rt?rt(e):[];R("computed.order-resolver",()=>{rt=null;},105);var Qr=()=>X(me(Se));var Lt=()=>Qr().computedEntries,Zr=()=>Qr().computedDependents;var eo=e=>Object.prototype.hasOwnProperty.call(Lt(),e);var qt=e=>{let t=Lt(),r=Zr(),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,c=new Map;for(let l of o){let p=t[l];if(!p)continue;let m=0;for(let g of p.deps)o.has(g)&&(m++,c.has(g)||c.set(g,[]),c.get(g).push(l));i.set(l,m);}let u=[];for(let[l,p]of i)p===0&&u.push(l);u.sort();let a=[];for(;u.length>0;){let l=u.shift();a.push(l);let p=c.get(l)??[];for(let m of p){let g=(i.get(m)??1)-1;if(i.set(m,g),g===0){let h=u.findIndex(d=>d>m);h===-1?u.push(m):u.splice(h,0,m);}}}return a};Jr(qt);var Bt=e=>{let t=Lt()[e];if(!t)return null;let r=Zr()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Gt=new Set,On=()=>{Gt.clear();};R("options.legacy-warnings",On,30);var ot=(()=>{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"}})(),Ut=e=>{try{return typeof window>"u"?ot:e==="session"||e==="sessionStorage"?window.sessionStorage??ot:window.localStorage??ot}catch{return ot}},ze=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Re=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),ro=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}},Pn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",to=e=>{try{e[Pn]=!0;}catch{}return e},Vn={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"},An=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:to(p=>p),decrypt:to(p=>p),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Ut("localStorage"),...r};if(typeof e=="string")return {driver:Ut(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,u=e.allowPlaintext===true,a=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(c&&ro(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||Ut("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:c,maxSize:a,checksum:l,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},oo=e=>{if(!ze(e))return [];let t=[];return Object.entries(Vn).forEach(([r,o])=>{Re(e,r)&&(Gt.has(r)||(Gt.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},no=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=ze(e.lifecycle)?e.lifecycle:void 0,c=ze(e.persist)?e.persist:void 0,u=ze(e.devtools)?e.devtools:void 0,a=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=ze(e.features)?{...e.features}:void 0,g=Re(e,"persist"),h=Re(e,"sync"),d=Re(e,"devtools")||Re(e,"historyLimit")||Re(e,"redactor"),x=o==="global"?true:e.allowSSRGlobalStore??false,{persist:w=false,devtools:O=false,onError:j,sync:I}=e;if(c?.sensitiveData===true){let V=c.encrypt,b=c.encryptAsync;if((!V||ro(V))&&!b)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"&&!g?null:An(w,t),devtools:o==="temp"&&!d?false:typeof O=="boolean"?O: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:j,validate:a,migrations:c?.migrations??e.migrations??{},version:c?.version??e.version??1,redactor:o==="temp"&&!d?void 0:u?.redactor??e.redactor,historyLimit:o==="temp"&&!d?0:u?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!h?false:I??false,features:m,allowSSRGlobalStore:x,snapshot:l,snapshotSafety:p,explicitPersist:g,explicitSync:h,explicitDevtools:d}};var nt=new Set,io=e=>e?nt.has(e):nt.size>0,ao=e=>{e&&nt.add(e);},Nn=()=>{nt.clear();};R("ssr.warnings",Nn,60);var so=new Set,Dn=e=>{let t=Tr();return !t||e.includes("::")?e:(v()&&!so.has(e)&&(so.add(e),y(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},st=e=>Dn(typeof e=="string"?e:e.name),it=e=>U(e)&&!lo(e)?true:(Vt(e,Object.keys(He)),false),co=(e,t,r={})=>{fe(t,{...r,onError:P[e]?.options?.onError});},uo=(e,t,r={})=>{fe(e,{...r,onError:t});},Q=(e,t,r="dev")=>{co(e,t,{severity:"warn",visibility:r});},jn=(e,t,r="dev")=>{uo(e,t,{severity:"warn",visibility:r});},_e=(e,t)=>co(e,t,{severity:"critical",visibility:"always"}),We=(e,t)=>uo(e,t,{severity:"critical",visibility:"always"}),at=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
9
|
-
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(jn(o,r,"always"),C().strictMissingFeatures)throw new Error(o)};var po=new WeakMap,fo=new WeakMap;var ct=e=>{let t=po.get(e);return t||(t=new Map,po.set(e,t)),t},go=e=>{let t=fo.get(e);return t||(t=new Map,fo.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=ct(M());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)=>(ct(M())[t]=r,true)});var we=(e,t,r,o)=>{try{return o?.reuseInput&&jt(t)?{ok:!0,value:t}:{ok:!0,value:ue(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return pe(P[e]?.options?.onError,`onError(${e})`,s),pe(r,`onError(${e})`,s),y(s),{ok:false}}},In=(e,t)=>{let r=new Set,o=P[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Kt=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=In(e,o),s=(c,u)=>{n.forEach(a=>pe(a,`onError(${e})`,c)),u==="critical"?ce(c):y(c);};if(typeof r=="function")try{let c=r(t);return c===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:c===!0?t:c}}catch(c){return s(`Validation for "${e}" failed: ${c?.message??c}`,"critical"),{ok:false}}let i=Nt(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Le=(e,t,r,o,n)=>{let s=we(e,t,o,n);if(!s.ok)return {ok:false};let i=Kt(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},Z=e=>{let t=M();ct(t).delete(e),go(t).delete(e);},$n=()=>{let e=M();ct(e).clear(),go(e).clear();};R("validation.path-cache",$n,50);So(Z);var yo=(e,t=M())=>{if((z()?ve(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=we(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,c=Le(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!c.ok)return !1;if(z()){let u=c.value;lt(e,u),ut(()=>{G(e,u,t),t.initialStates[e]=k(u),delete t.initialFactories[e],Z(e);});}else G(e,c.value,t),t.initialStates[e]=k(c.value),delete t.initialFactories[e],Z(e);return !0}catch(n){return _e(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var mo=new WeakMap,ho=e=>{let t=mo.get(e);return t||(t=new Map,mo.set(e,t)),t},zn=()=>{ho(M()).clear();};R("features.contexts",zn,100);var bo=e=>{let t=M(),r=ho(t),o=r.get(e);if(o)return o;let n=P[e];if(!n)return y(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>P[e],getStoreValue:()=>He[e],getAllStores:()=>He,getInitialState:()=>ko[e],hasStore:()=>U(e),setStoreValue:i=>{G(e,i);},applyFeatureState:(i,c)=>{Mo(e,i,c),Z(e);},notify:()=>{},reportStoreError:i=>{_e(e,i);},warn:y,warnAlways:T,log:_,hashState:Ie,deepClone:k,sanitize:ue,validate:i=>Kt(e,i,P[e]?.options?.validate),isDev:v};return r.set(e,s),s},Ro=(e,t)=>{let r=C();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(_e(e,n),r.assertRuntime)throw new Error(n)},wo=(e,t)=>{pt();let r=bo(e);r&&(r.notify=()=>t(e),Ro(e,r),B.forEach((o,n)=>{try{o.onStoreCreate?.(r);}catch(s){Q(e,`Feature "${String(n)}" onStoreCreate for "${e}" failed: ${s?.message??s}`,"always");}}));},vo=(e,t,r,o,n)=>{pt();let s=bo(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});Ro(e,i),B.forEach((c,u)=>{try{c.onStoreWrite?.(i);}catch(a){Q(e,`Feature "${String(u)}" onStoreWrite for "${e}" failed: ${a?.message??a}`,"always");}});};var xo=(e,t)=>Yr({name:e,payload:t,middlewares:(()=>{let r=P[e]?.options?.middleware||[],o=C().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{Q(e,r,o);},warn:y}),dt=(e,t,r,o)=>tt({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{Q(e,n,s);}}),Co=(e,t)=>{let r={...t};return r.persist&&!Je("persist")&&(r.explicitPersist&&at(e,"persist",r.onError),r.persist=null),r.sync&&!Je("sync")&&(r.explicitSync&&at(e,"sync",r.onError),r.sync=false),Je("devtools")||(r.explicitDevtools&&at(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var ft=null,Eo=e=>(ft=e,()=>{ft===e&&(ft=null);}),xe=e=>{ft?.(e);};var gt=new Set,_n=e=>{gt.clear();};R("store-create.ssr-global-warned",()=>_n(),65);function To(e,t,r={}){if(z()){let b=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;We(b,r.onError),Ce(b);return}if(!je(e)){We(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Dt(t)){We(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&v()&&y(`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.`),oo(r).forEach(b=>{y(b);});let n=Co(e,no(r,e,C().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let b=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;pe(n.onError,`onError(${e})`,b),v()||T(b),L(b);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=s&&i==="production",u=n.allowSSRGlobalStore??false,a=M(),l=a.stores,p=a.subscribers,m=a.initialStates,g=a.initialFactories,h=a.metaEntries,d=a.scope==="request";if(c&&!u&&!d){let b=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
|
|
10
|
-
Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;We(b,r.onError);return}if(c&&u&&!d&&!gt.has(e)&&(gt.add(e),T(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
|
|
11
|
-
This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),U(e,a)){let b=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return Q(e,b),{name:e}}s&&!u&&!d&&!io(e)&&v()&&(ao(e),y(`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 x=we(e,t,n.onError);if(!x.ok)return;let w=x.value,O=n.lazy===true&&typeof t=="function",j=(p[e]?.size??0)>0;if(O)l[e]=void 0,g[e]=t;else {let b=Le(e,w,n.validate,n.onError);if(!b.ok)return;G(e,b.value,a),m[e]=k(b.value);}let I=Date.now(),V=new Date(I).toISOString();return h[e]={createdAt:V,updatedAt:V,updatedAtMs:I,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},Z(e),wo(e,xe),dt(e,"onCreate",h[e].options.onCreate,[w]),Fo(a,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),j&&xe(e),_(`Store "${e}" created -> ${JSON.stringify(w)}`),{name:e}}var Wn=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Oo=(e,t)=>t==="ref"?e:t==="shallow"?$e(e):k(e);function Yt(e,t){let r=st(e);if(!it(r))return null;let o=M();if(!yo(r,o))return null;Jt(r,o);let n=qe(r,o),s=Wn(o.metaEntries[r],C().defaultSnapshotMode);return n===null||typeof n!="object"?n:Oo(n,s);}var Be=0,Hn=(e,t)=>(Be>=Number.MAX_SAFE_INTEGER&&(Be=0),Be+=1,`${e}:${t}:${Be}`),Ln=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},qn=e=>({...e,path:[...e.path],meta:{...e.meta,causedBy:e.meta.causedBy?[...e.meta.causedBy]:void 0}}),Bn=e=>e?Array.isArray(e)?e.map(t=>typeof t=="number"?t:String(t)):be(e):[],Un=e=>{let t=e.timestamp??Date.now();return {id:Hn(e.source,t),store:e.store,path:Bn(e.path),op:e.op,...e.value!==void 0?{value:e.value}:{},meta:{timestamp:t,source:e.source,causedBy:Ln(e.context),...e.isUnsafe===true?{isUnsafe:true}:{},...e.asyncBoundary===true?{asyncBoundary:true}:{}}}},Ue=e=>Un({store:e.store,op:"set",path:[],value:e.value,source:e.source,context:e.context});var yt=(e,t=M())=>{t.lastRuntimePatches=e.map(qn);};R("runtime-patch.sequence",()=>{Be=0;},126);var Ge=null,oe=null,Po=e=>{if(!e){oe=null;return}if(oe&&oe!==e){T("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}oe=e;},Gn=()=>{Ge=null,oe=null;};R("write-context.runner",Gn,121);var St=()=>oe?.get()??Ge,Xt=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(oe)return oe.run(e,t);let r=Ge;Ge=e;try{return t()}finally{Ge=r;}};var Kn=new Set;R("store-write.slow-mutator-warned",()=>Kn.clear(),65);var Yn=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var Ao=e=>St(),Jn=(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);},Vo=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:c,metricsUpdate:u})=>{let a=e.metaEntries;G(t,o,e),Z(t);let l=Date.now();a[t].updatedAt=new Date(l).toISOString(),a[t].updatedAtMs=l;let p=c??St();p&&(p.correlationId||p.traceContext)?(a[t].lastCorrelationId=p.correlationId??null,a[t].lastCorrelationAt=new Date(l).toISOString(),a[t].lastCorrelationAtMs=l,a[t].lastTraceContext=p.traceContext??null):(a[t].lastCorrelationId=null,a[t].lastCorrelationAt=null,a[t].lastCorrelationAtMs=null,a[t].lastTraceContext=null),Yn(a[t]),Jn(a[t],u),vo(t,n,r,o,xe),dt(t,s,a[t].options[s],[r,o]),xe(t),_(i);},No=(e,t)=>{let r=t.context??St();if(z()){lt(t.name,t.next),Do(t.runtimePatches??[]),ut(()=>Vo(e,{...t,context:r}));return}Vo(e,{...t,context:r}),t.runtimePatches&&t.runtimePatches.length>0&&yt(t.runtimePatches,e);};function jo(e,t){let r=st(e);if(!r)return {ok:false,reason:"invalid-args"};let o=M(),n=Qt(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 Qt=(e,t,r,o="hydrate",n)=>{let s=(h,d)=>(z()&&Ce(d??h),{ok:false,reason:h});if(!it(t))return s("not-found",`replaceStore("${t}") called before createStore().`);let i=z()?ve(t):{has:false,value:void 0},c=i.has?i.value:qe(t,e),u=we(t,r);if(!u.ok)return s("sanitize",`replaceStore("${t}") failed sanitize`);let a=u.value;if(a===void 0){let h=`Whole-store undefined replacement is blocked for "${t}". Use null for intentional empty state.`;return Q(t,h),s("undefined",h)}let l=e.metaEntries[t]?.options?.validate,p=Ao(),m=xo(t,{action:o,prev:c,next:a,path:null,correlationId:p?.correlationId,traceContext:p?.traceContext});if(m===et)return s("middleware",`replaceStore("${t}") aborted by middleware`);let g=Le(t,m,l);return g.ok?(No(e,{name:t,prev:c,next:g.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:p,runtimePatches:[Ue({store:t,value:g.value,source:o==="hydrate"?"hydrateStores":"replaceStore",context:p})]}),{ok:true}):s("validate",`replaceStore("${t}") failed validation`)};var Xn=()=>M().computedCleanups,Io=new WeakMap;var Qn=e=>{let t=Io.get(e);return t||(t=new Map,Io.set(e,t)),t};var $o=e=>{let t=Xn(),r=t.get(e);if(!r){v()&&y(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var zo=(e,t=M())=>Qn(t).get(e)?.autoDispose===true;var _o=new Map;var Zt=e=>{let t=_o.get(e);return !!t&&t.size>0},Ke=(e,t,r)=>{let o=_o.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 Wo=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,u=e.deletingStores,a=(d,x)=>{fe(x,{onError:s[d]?.options?.onError,severity:"warn",visibility:"dev"});},l=({name:d,prev:x,options:w,initialState:O,getMeta:j,getStoreValue:I,hasStore:V})=>({name:d,options:w,prev:x,getMeta:j,getStoreValue:I,getAllStores:()=>t,getInitialState:()=>O,hasStore:V,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:b=>{fe(b,{onError:w.onError,severity:"warn",visibility:"dev"});},warn:y,warnAlways:T,log:_,hashState:Ie,deepClone:k,sanitize:ue,validate:()=>({ok:true,value:x}),isDev:v}),p=({name:d,prev:x,options:w,initialState:O,phase:j})=>{let I=l({name:d,prev:x,options:w,initialState:O,getMeta:()=>s[d],getStoreValue:()=>t[d],hasStore:()=>ae(e,d)}),V=l({name:d,prev:x,options:w,initialState:O,getMeta:()=>{},getStoreValue:()=>x,hasStore:()=>false});ye().forEach(b=>{let $=c.get(b);j==="before"?$?.beforeStoreDelete?.(I):$?.afterStoreDelete?.(V);});},m=d=>{if(!ae(e,d))return;let x=t[d],w=s[d].options,O=o[d],j=r[d];u.add(d);try{j?.forEach(b=>{try{b(null);}catch($){y(`Subscriber for "${d}" threw during delete: ${$?.message??$}`);}}),tt({name:d,label:"onDelete",fn:w.onDelete,args:[x],reportIssue:(b,$)=>{fe(b,{onError:w.onError,severity:"warn",visibility:$});}}),p({name:d,prev:x,options:w,initialState:O,phase:"before"}),delete t[d],delete r[d],delete o[d],delete n[d],delete s[d],delete i[d],eo(d)&&$o(d);let V=e.computedDependents[d];if(V)for(let b of [...V]){let $=Bt(b);if($&&zo(b,e)&&$.deps.every(Ee=>!ae(e,Ee))){m(b);continue}y(`[stroid] source store "${d}" was deleted. Computed store "${b}" depends on it and will return stale data. Call deleteComputed("${b}") to clean up.`);}p({name:d,prev:x,options:w,initialState:O,phase:"after"}),Ke("afterStoreDelete",d,{type:"afterStoreDelete",prev:x}),Qe(e,{type:"deleted",name:d}),_(`Store "${d}" deleted`);}finally{u.delete(d);}};return {deleteExistingStore:m,clearAllStores:()=>{let d=[],w=0,O=Number.POSITIVE_INFINITY;for(;w<20;){let I=Object.keys(t);if(I.length===0)break;I.forEach(b=>{ae(e,b)&&(m(b),d.push(b));}),w+=1;let V=Object.keys(t).length;if(V===0||V>=O)break;O=V;}let j=Object.keys(t).length;return j>0?y(`clearAllStores stopped after ${w} pass${w===1?"":"es"}; ${j} store(s) still registered (likely recreated during deletion).`):_(`All stores cleared (${d.length} stores removed)`),d},clearStores:d=>{let x=Object.keys(t).filter(w=>d?d.endsWith("*")?w.startsWith(d.slice(0,-1)):w===d:true);return x.forEach(w=>m(w)),x},reportStoreError:a}};var er=Se,Lo=me(er),qo=null,N=()=>{let e=X(Lo);return kt(e),e};var M=()=>N();var Fo=(e,t)=>{Qe(e,t);};function So(e){qo=e;}var ke=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}}}),Zn=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)}),es=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)}),He=ke(()=>N().stores);ke(()=>N().subscribers);var ko=ke(()=>N().initialStates);ke(()=>N().initialFactories);var P=ke(()=>N().metaEntries);ke(()=>N().snapshotCache);var B=Zn(()=>N().featureRuntimes),Ho=new WeakMap,ts=e=>{let t=Ho.get(e);return t||(t=Wo(e),Ho.set(e,t)),t};es(()=>ts(N()));var rs=e=>{let t=B.get(e);if(t)return t;let r=Xe(e);if(!r)return;let o=r();return B.set(e,o),o},pt=()=>{ye().forEach(e=>{rs(e);});};pt();var U=(e,t)=>ae(t??N(),e),qe=(e,t=N())=>{if(z()){let r=ve(e);if(r.has)return r.value}return Bo(e,t)},Bo=(e,t=N())=>{let r=Ve();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},G=(e,t,r=N())=>{let o=Ve();o?(o[e]=t,Object.prototype.hasOwnProperty.call(r.stores,e)||(r.stores[e]=void 0)):r.stores[e]=t;},Mo=(e,t,r=Date.now())=>{G(e,t),P[e]&&(P[e].updatedAt=new Date(r).toISOString(),P[e].updatedAtMs=r,P[e].lastCorrelationId=null,P[e].lastCorrelationAt=null,P[e].lastCorrelationAtMs=null,P[e].lastTraceContext=null,P[e].updateCount>=Number.MAX_SAFE_INTEGER?P[e].updateCount=0:P[e].updateCount+=1,qo?.(e));},Jt=(e,t=N())=>{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();},os=()=>{wr(N());},ns=()=>{B.forEach(e=>{try{e.resetAll?.();}catch{}}),B.clear();};R("features.reset",ns,10);R("registries.clear",os,20);R("registry.default",()=>{er=Se,Lo=me(er);},115);var lo=e=>Rr(N(),e);var ne=null,Uo=e=>{if(!e){ne=null;return}if(ne&&ne!==e){T("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;},ss=()=>{ne=null;};R("transaction.runner",ss,120);var Me=e=>{let t=ne?.get();return t||(e??X()).transaction},is=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 z=()=>ne?(ne.get()?.depth??0)>0:Me().depth>0,Ce=(e,t)=>{let r=Me(t);r.failed=true,r.error||(r.error=is(e));},ut=e=>{let t=X();Me(t).pending.push(()=>Ze(t,e));},lt=(e,t)=>{let r=Me();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},Do=e=>{if(e.length===0)return;Me().runtimePatches.push(...e);},ve=e=>{let t=Me();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Go=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},tr=(e,t)=>{if(t==="ref"){if(!v())return e;try{return Ht(e)}catch{return e}}if(t==="shallow"){let o=$e(e);if(!v())return o;try{return Ht(o)}catch{return o}}let r=k(e);if(!v())return r;try{return Kr(r)}catch{return r}};var Ko=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:o}=e,n=C().flush,s=n.priorityStores||[],i=s.length?new Set(s):null;o.length=0,r.length=0;let c=new Set;if(i){for(let h of t)r.push(h),c.add(h);for(let h of s)c.has(h)&&o.push(h);for(let h of r)i.has(h)||o.push(h);}else for(let h of t)r.push(h),c.add(h),o.push(h);t.clear();let u=Xr(o),a=new Set(o);for(let h of u)a.has(h)||(o.push(h),a.add(h));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 rr=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}),or=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),nr=(e,t)=>{e&&(e.metrics=t);};var Ye=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},Yo=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>Ze(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var Jo=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)},Xo=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:c,runInline:u,prioritySet:a}=t,l=Ve(),p=e.stores,m=e.subscribers,g=e.metaEntries,h=e.snapshotCache,d=C().defaultSnapshotMode,x=S=>Go(g[S],d),w=S=>l&&Object.prototype.hasOwnProperty.call(l,S)?l[S]:p[S],O=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),j=Zt("beforeFlush"),I=Zt("afterFlush"),V=S=>{j&&Ke("beforeFlush",S,{type:"beforeFlush"});},b=(S,A)=>{I&&Ke("afterFlush",S,{type:"afterFlush",elapsedMs:A});},$=S=>{let A=g[S];if(!A)return null;let E=A.lastCorrelationId??void 0,f=A.lastTraceContext??void 0;return !E&&!f?null:{correlationId:E,traceContext:f}},Ee=()=>{o();};if(u){for(let S of s){let A=m[S];if(!A||A.size===0)continue;let E=g[S]?.updateCount??0,f=x(S),ge=w(S),W=h[S],H=W&&W.source===ge&&W.mode===f?W.snapshot:(()=>{let D=tr(ge,f);return h[S]={version:r,snapshot:D,source:ge,mode:f},D})(),K=rr(g[S]?.metrics);V(S);let se=O(),ee=Array.from(A),Te=$(S),Fe=()=>{for(let D of ee)try{D(H);}catch(ie){let Y=g[S]?.options?.snapshotSafety??"warn";if(v()&&(f==="ref"||f==="shallow")&&Jo(ie)){if(Y==="throw")throw ie;if(Y==="auto-clone")try{let Pe=k(H);y(`Snapshot mutation detected for "${S}". Delivered a cloned snapshot to the subscriber.`);try{D(Pe);}catch(vt){y(`Subscriber for "${S}" threw on cloned snapshot: ${vt?.message??vt}`);}continue}catch{}y(`Snapshot mutation detected for "${S}": ${ie?.message??ie}`);continue}y(`Subscriber for "${S}" threw: ${ie?.message??ie}`);}};Te?Xt(Te,Fe):Fe();let Oe=O()-se;b(S,Oe),or(K,Oe),nr(g[S],K),(g[S]?.updateCount??E)!==E&&n.pendingNotifications.add(S);}Ee();return}let cr=S=>{let A=[];for(let E of s){if(S&&!S(E))continue;let f=m[E];if(!f||f.size===0)continue;let ge=g[E]?.updateCount??0,W=x(E),H=w(E),K=h[E],se=K&&K.source===H&&K.mode===W?K.snapshot:(()=>{let ee=tr(H,W);return h[E]={version:r,snapshot:ee,source:H,mode:W},ee})();A.push({name:E,snapshot:se,version:ge,subscribers:Array.from(f),subscriberSet:new Set(f),notified:new Set,metrics:rr(g[E]?.metrics),totalMs:0,beforeHooked:false});}return A},ur=a?cr(S=>a.has(S)):[],lr=cr(S=>!a||!a.has(S)),Rt=(S,A)=>{let E=()=>{if(S.length===0){A();return}let f=S.shift();if((g[f.name]?.updateCount??f.version)!==f.version){if(n.pendingNotifications.add(f.name),S.length===0){A();return}Ye(E,c);return}let W=()=>{let q=m[f.name];if(!(!q||q.size===0))for(let D of q)f.subscriberSet.has(D)||(f.subscriberSet.add(D),f.subscribers.push(D));};W();let H=f.subscribers;if(H.length===0){if(S.length===0){A();return}Ye(E,c);return}f.beforeHooked||(f.beforeHooked=true,V(f.name));let K=O(),se=0,ee=false,Te=$(f.name),Fe=()=>{for(let q=0;q<H.length&&se<i;q+=1){let D=H[q];if(f.notified.has(D))continue;f.notified.add(D);try{D(f.snapshot);}catch(Y){let wt=g[f.name]?.options?.snapshotSafety??"warn",Pe=x(f.name);if(v()&&(Pe==="ref"||Pe==="shallow")&&Jo(Y)){if(wt==="throw")throw Y;if(wt==="auto-clone")try{let dr=k(f.snapshot);y(`Snapshot mutation detected for "${f.name}". Delivered a cloned snapshot to the subscriber.`);try{D(dr);}catch(pr){y(`Subscriber for "${f.name}" threw on cloned snapshot: ${pr?.message??pr}`);}if(f.notified.add(D),se+=1,(g[f.name]?.updateCount??f.version)!==f.version){ee=!0,n.pendingNotifications.add(f.name);break}continue}catch{}y(`Snapshot mutation detected for "${f.name}": ${Y?.message??Y}`);continue}y(`Subscriber for "${f.name}" threw: ${Y?.message??Y}`);}if(se+=1,(g[f.name]?.updateCount??f.version)!==f.version){ee=true,n.pendingNotifications.add(f.name);break}}};if(Te?Xt(Te,Fe):Fe(),f.totalMs+=O()-K,ee){if(S.length===0){A();return}Ye(E,c);return}W();let Oe=false;for(let q of H)if(!f.notified.has(q)){Oe=true;break}if(Oe?S.push(f):(or(f.metrics,f.totalMs),nr(g[f.name],f.metrics),b(f.name,f.totalMs)),S.length===0){A();return}Ye(E,c);};E();};ur.length>0?Rt(ur,()=>Rt(lr,Ee)):Rt(lr,Ee);};var as=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=Ko(t);Xo(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&sr(e);});},sr=e=>{Yo(e,as);};var cs=e=>{let t=M(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&sr(t);};Eo(cs);var us=()=>{let e=M().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};R("notify.reset",us,40);var mt=(e,t={},r)=>{if(z()){let a="hydrateStores(...) cannot be called inside setStoreBatch.";return y(a),Ce(a),{hydrated:[],created:[],failed:[],blocked:{reason:"transaction"}}}let o={hydrated:[],created:[],failed:[]};if(!e||typeof e!="object")return o;let n=M(),s=[],i=r??{};if(!(i.allowTrusted===true||i.allowHydration===true||i.allowUntrusted===true||C().allowUntrustedHydration===true))return T("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 a=false;try{a=!!i.validate(e);}catch(l){let p=`hydrateStores() trust.validate threw: ${l?.message??l}`;if(v())throw new Error(`hydrateStores() trust.validate threw an error. Fix your validator before this becomes a silent production failure.
|
|
12
|
-
Original error: ${l?.message??l}`);let m=t?.default?.onError;if(typeof m=="function")try{m(p);}catch(g){T(`hydrateStores(...) onError threw: ${g?.message??g}`);}if(T(p),typeof i.onValidationError=="function")try{if(!!i.onValidationError(l,e))a=!0;else return o.blocked={reason:"validation-error",cause:l},o}catch(g){return T(`hydrateStores(...) onValidationError threw: ${g?.message??g}`),o.blocked={reason:"validation-error",cause:g},o}else return o.blocked={reason:"validation-error",cause:l},o}if(!a)return T("hydrateStores(...) rejected by trust validation."),o.blocked={reason:"validation-failed"},o}let u=[];return Object.entries(e).forEach(([a,l])=>{if(!je(a)){o.failed.push({name:a,reason:"invalid-name"});return}if(U(a,n)){let p=Qt(n,a,l,"hydrate");p.ok?(o.hydrated.push(a),u.push(a),s.push(Ue({store:a,value:n.stores[a],source:"hydrateStores"}))):o.failed.push({name:a,reason:"merge-failed",cause:p.reason,received:l});}else {let p=t;To(a,l,p[a]||p.default||{})?(o.created.push(a),u.push(a),s.push(Ue({store:a,value:n.stores[a],source:"hydrateStores"}))):o.failed.push({name:a,reason:"create-failed",received:l});}}),u.length>0&&qt(u).forEach(l=>{let p=n.computedEntries[l];if(!p)return;let m=p.deps.map(g=>Yt(g));try{let g=p.compute(...m);if(g&&typeof g.then=="function"){y(`hydrateStores recompute for "${l}" returned a Promise; skipping.`);return}let h=Yt(l);if(Object.is(g,h))return;jo(l,g);}catch(g){y(`hydrateStores recompute for "${l}" failed: ${g?.message??g}`);}}),s.length>0&&yt(s,n),o};var ar=new AsyncLocalStorage,ht=new AsyncLocalStorage,ir=new AsyncLocalStorage,Qo=new AsyncLocalStorage;xr({run:(e,t)=>ar.run(e,t),get:()=>ar.getStore()||null});kr({run:(e,t)=>ht.run(e,t),get:()=>ht.getStore()||null,enterWith:e=>ht.enterWith(e)});Uo({run:(e,t)=>ir.run(e,t),get:()=>ir.getStore()||null,enterWith:e=>ir.enterWith(e)});Po({run:(e,t)=>Qo.run(e,t),get:()=>Qo.getStore()||null});var Jc=e=>{let t=Et("request"),r={},o={},n=i=>Object.prototype.hasOwnProperty.call(r,i);return typeof e=="function"&&e({create:(i,c,u={})=>(r[i]=k(c),o[i]={...u},r[i]),set:(i,c)=>{if(!n(i))throw new Error(`createStoreForRequest.set("${i}") requires create("${i}", initialState) first.`);return r[i]=typeof c=="function"?zt(r[i],c):c,r[i]},get:i=>n(i)?k(r[i]):void 0}),{registry:t,snapshot:()=>k(r),hydrate:(i,c={})=>{let u={...c,default:c.default};return Object.keys(r).forEach(a=>{let l=a,p={...c.default||{},...c[l]||{},...o[a]||{}};u[l]=p;}),ht.run(t,()=>ar.run(k(r),()=>(mt(r,u,{allowTrusted:true}),i())))}}};export{Jc as createStoreForRequest};//# sourceMappingURL=server.js.map
|
|
1
|
+
import {h,i as i$1,ia,R,e,v,x,qa}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';import {AsyncLocalStorage}from'async_hooks';var i=new AsyncLocalStorage,u=new AsyncLocalStorage,c=new AsyncLocalStorage,O=new AsyncLocalStorage;h({run:(t,o)=>i.run(t,o),get:()=>i.getStore()||null});i$1({run:(t,o)=>u.run(t,o),get:()=>u.getStore()||null,enterWith:t=>u.enterWith(t)});ia({run:(t,o)=>c.run(t,o),get:()=>c.getStore()||null,enterWith:t=>c.enterWith(t)});R({run:(t,o)=>O.run(t,o),get:()=>O.getStore()||null});var C=t=>t!==null&&(typeof t=="object"||typeof t=="function")&&typeof t.then=="function",P=t=>{let o=e("request"),r={},f={},M=e=>Object.prototype.hasOwnProperty.call(r,e),R=e=>{Object.keys(r).forEach(a=>{delete r[a];}),Object.keys(o.metaEntries).forEach(a=>{let S=Object.prototype.hasOwnProperty.call(e,a)?e[a]:o.stores[a];r[a]=v(S);});};return typeof t=="function"&&t({create:(e,a,S={})=>(r[e]=v(a),f[e]={...S},r[e]),set:(e,a)=>{if(!M(e))throw new Error(`createStoreForRequest.set("${e}") requires create("${e}", initialState) first.`);return r[e]=typeof a=="function"?x(r[e],a):v(a),r[e]},get:e=>M(e)?v(r[e]):void 0,snapshot:()=>v(r)}),{registry:o,snapshot:()=>v(r),hydrate:(e,a={})=>{let S={...a,default:a.default};return Object.keys(r).forEach(p=>{let s=p,x={...a.default||{},...a[s]||{},...f[p]||{}};S[s]=x;}),u.run(o,()=>i.run(v(r),()=>{qa(r,S,{allowTrusted:true});let p=i.getStore();if(!p)return e();try{let s=e();return C(s)?Promise.resolve(s).finally(()=>{R(p);}):(R(p),s)}catch(s){throw R(p),s}}))}}};export{P as createStoreForRequest};//# sourceMappingURL=server.js.map
|
|
13
2
|
//# sourceMappingURL=server.js.map
|
package/dist/store-registry.d.ts
CHANGED
package/dist/sync.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var Pe=new Map,St=null,bt=(e,t)=>{Pe.set(e,t),St?.(e,t);};var Ee=e=>Pe.get(e),ce=()=>Array.from(Pe.keys()),wt=e=>{St=e;};var kt=({value:e,sanitize:t,validate:r,onSanitizeError:o})=>{let s;if(t)try{s=t(e);}catch(a){return o?.(a),{ok:false}}else s=e;let i=r(s);return i.ok?{ok:true,value:i.value??s}:{ok:false}},Fe=({value:e,fallbackMs:t=Date.now(),onInvalid:r})=>{if(typeof e=="number")return Number.isFinite(e)?e:(r?.(),t);if(typeof e=="string"){let o=Date.parse(e);return Number.isFinite(o)?o:(r?.(),t)}return r?.(),t};var vr=new Map,V=(e,t,r=0)=>{!e||typeof t!="function"||vr.set(e,{name:e,order:r,fn:t});};var Ct=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),Rt=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,warnedOnce:Ct(),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}}),vt=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.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(),Ct().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 _e=new Map,xt=new WeakSet,ze=e=>{xt.has(e)||(xt.add(e),ce().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Ee(t);r&&e.featureRuntimes.set(t,r());}}));},xr=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,Mt,We=e=>(Mt||xr||e).replace(/\.ts(\?|$)/,".js$1"),ue=We("stroid:default-registry");var Mr=()=>{Mt=void 0,_e.clear();};V("registry.scope-override",Mr,110);var Er=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Fr=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},Tr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,runtimePatches:[],failed:false,error:void 0}),jr=(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:Tr(),async:Rt(),notify:Er(),lifecycleListener:null};return ze(t),t},le=e=>{let t=We(e),r=_e.get(t);if(r)return r;let o=jr();return _e.set(t,o),o},oe=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var Et=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,Fr(e.notify),vt(e.async),e.lifecycleListener=null;};var He=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var Y=[],Tt={run:(e,t)=>{Y.push(e);try{return t()}finally{Y.pop();}},get:()=>Y.length>0?Y[Y.length-1]:null,enterWith:e=>{if(Y.length>0){Y[Y.length-1]=e;return}Y.push(e);}};var de=e=>(Tt).get()||e||le(ue);var Ar={log:(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},warn:(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},critical:(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));}},Vt={logSink:Ar,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",autoCorrelationIds:false,acknowledgeLooseTypes:false,pathCacheSize:500,defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0,selectorCloneFrozen:true},Be=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}),Le=new WeakMap,At=Be(Vt),Dr=e=>{let t=Le.get(e);return t||(t=Be(At),Le.set(e,t)),t};var I=()=>Dr(de());var Ir=()=>{Le=new WeakMap,At=Be(Vt);};V("config.reset",Ir,90);var Pr=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,_r=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,Dt=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,zr="production",Wr=Pr??_r??zr,je=typeof Dt=="boolean"?Dt:Wr!=="production",A=()=>je,$t=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Hr=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},Lr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},ke=(e,t)=>{if((I().logSink.critical??Hr)(e,t),I().assertRuntime)throw new Error(e)},w=(e,t)=>{if(!je)return;if((I().logSink.warn??$t)(e,t),I().assertRuntime)throw new Error(e)},q=(e,t)=>{if((I().logSink.warn??$t)(e,t),I().assertRuntime)throw new Error(e)};var ee=(e,t)=>{if(!je)return;(I().logSink.log??Lr)(e,t);};var Ot=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Nt=()=>"Map detected; converting to plain object.",It=()=>"Set detected; converting to array.";var fe=new Set(["__proto__","constructor","prototype"]),Ue=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let s=r.error,i=s?.details?.[0]?.message||s?.message||r.message||e.errors;if(i)return {ok:!1,error:i};if(s)return {ok:!1,error:s}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var qe=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,Ur=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null};var Ce=(e,t)=>{let r=Ur(e);if(r)throw new Error(`${r} values are not supported`);let o=qe(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 A()&&w(Ot()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),A()&&w(Nt());let s={};for(let[i,a]of e){if(typeof i!="string")throw new Error("Map keys must be strings to remain JSON-safe");s[String(i)]=Ce(a,t);}return s}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),A()&&w(It()),Array.from(e,s=>Ce(s,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s={},i=Object.getOwnPropertyDescriptors(e);for(let[a,f]of Object.entries(i))if(f.enumerable&&!fe.has(a)){if("get"in f||"set"in f)throw new Error(`Accessor properties are not supported during sanitize ("${a}")`);s[a]=Ce(f.value,t);}return s}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(s=>Ce(s,t))}return e},pe=e=>Ce(e,new WeakSet);var Ge=null,qr=()=>{if(Ge)return Ge;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 Ge=t,t},_t=e=>{let t=qr(),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},Gr=2166136261,Kr=2654435761,Yr=1e5,te=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},ne=(e,t)=>{te(e,t.length);for(let r=0;r<t.length;r++)te(e,t.charCodeAt(r));},T=(e,t)=>{ne(e,t);},Pt=(e,t)=>{if(Number.isNaN(t)){T(e,"NaN");return}if(!Number.isFinite(t)){T(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){T(e,"-0");return}let r=t|0;if(t===r){T(e,"int"),te(e,r);return}T(e,"num"),ne(e,String(t));},ge=(e,t)=>{if(e.nodes++>Yr){T(e,"[max]");return}if(t===null){T(e,"null");return}let r=typeof t;if(r==="string"){T(e,"string"),ne(e,t);return}if(r==="number"){T(e,"number"),Pt(e,t);return}if(r==="boolean"){T(e,t?"true":"false");return}if(r==="undefined"){T(e,"undefined");return}if(r==="bigint"){T(e,"bigint"),ne(e,t.toString());return}if(r==="symbol"){T(e,"symbol");let p=t;ne(e,Symbol.keyFor(p)??p.description??String(p));return}if(r==="function"){T(e,"function"),ne(e,t.name||"anonymous");return}let o=t,s=e.seen.get(o);if(s!==void 0){T(e,"ref"),te(e,s);return}let i=e.nextId++;if(e.seen.set(o,i),Array.isArray(o)){T(e,"array"),te(e,o.length);for(let p=0;p<o.length;p++)Object.prototype.hasOwnProperty.call(o,p)?ge(e,o[p]):T(e,"hole");return}if(o instanceof Date){T(e,"date"),Pt(e,o.getTime());return}if(o instanceof Map){T(e,"map"),te(e,o.size),o.forEach((p,S)=>{ge(e,S),ge(e,p);});return}if(o instanceof Set){T(e,"set"),te(e,o.size),o.forEach(p=>{ge(e,p);});return}T(e,"object");let a=Object.getOwnPropertyDescriptors(o),f=[];Object.entries(a).forEach(([p,S])=>{S?.enumerable&&(fe.has(p)||"get"in S||"set"in S||f.push([p,S]));}),te(e,f.length);for(let[p,S]of f)ne(e,p),ge(e,S.value);},Re=e=>{if(typeof e=="string")return _t(JSON.stringify(e));let t={h1:Gr,h2:Kr,seen:new WeakMap,nextId:1,nodes:0};ge(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 Jr=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Ye=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,s]of t)if(typeof s=="function"&&e instanceof s)return o;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},Xr=e=>Ye(e)===null,Qr=e=>{let t=Ye(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},se=(e,t=new WeakMap)=>{if(Qr(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 s=new Map;return t.set(e,s),e.forEach((i,a)=>{s.set(se(a,t),se(i,t));}),s}if(e instanceof Set){let s=new Set;return t.set(e,s),e.forEach(i=>{s.add(se(i,t));}),s}if(Array.isArray(e)){let s=[];return t.set(e,s),e.forEach((i,a)=>{s[a]=se(i,t);}),s}let r={};t.set(e,r);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch(s){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${s?.message??s}`)}return Object.entries(o).forEach(([s,i])=>{!i.enumerable||fe.has(s)||"get"in i||"set"in i||(r[s]=se(i.value,t));}),r},B=e=>{if(Jr)try{return structuredClone(e)}catch(t){if(!Xr(e)){let r=Ye(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return w(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),se(e)}return se(e)};var Je=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let s=o?.message??o;q(`${t} callback threw: ${String(s)}`);}},ye=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:s}=t;if(Je(s,"onError",e),r==="critical"){o==="dev"&&w(e),ke(e);return}if(o==="always"){q(e);return}w(e);};var zt=({name:e,label:t,fn:r,args:o,reportIssue:s})=>{if(typeof r=="function")try{r(...o);}catch(i){let a=`${t} for "${e}" failed: ${i?.message??i}`;s(a,"always");}};V("computed.order-resolver",()=>{},105);var Lt=()=>de(le(ue));var Xe=()=>Lt().computedEntries,Bt=()=>Lt().computedDependents;var Ut=e=>Object.prototype.hasOwnProperty.call(Xe(),e);var Qe=e=>{let t=Xe()[e];if(!t)return null;let r=Bt()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var to=new Set;var ro=()=>{to.clear();};V("ssr.warnings",ro,60);var qt=(e,t,r={})=>{ye(t,{...r,onError:$[e]?.options?.onError});};var Gt=(e,t,r="dev")=>{qt(e,t,{severity:"warn",visibility:r});};var Ze=(e,t)=>qt(e,t,{severity:"critical",visibility:"always"});var Kt=new WeakMap,Yt=new WeakMap;var $e=e=>{let t=Kt.get(e);return t||(t=new Map,Kt.set(e,t)),t},Jt=e=>{let t=Yt.get(e);return t||(t=new Map,Yt.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=$e(P());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)=>($e(P())[t]=r,true)});var oo=(e,t)=>{let r=new Set,o=$[e]?.options?.onError;return typeof o=="function"&&r.add(o),r},Xt=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let s=oo(e),i=(f,p)=>{s.forEach(S=>Je(S,`onError(${e})`,f)),p==="critical"?ke(f):w(f);};if(typeof r=="function")try{let f=r(t);return f===!1?(i(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:f===!0?t:f}}catch(f){return i(`Validation for "${e}" failed: ${f?.message??f}`,"critical"),{ok:false}}let a=Ue(r,t);return a.ok?{ok:true,value:a.data??t}:(i(`Validation failed for "${e}": ${a.error}`,"critical"),{ok:false})};var et=e=>{let t=P();$e(t).delete(e),Jt(t).delete(e);},no=()=>{let e=P();$e(e).clear(),Jt(e).clear();};V("validation.path-cache",no,50);Qt(et);var sr=new Map;var xe=(e,t,r)=>{let o=sr.get(e);!o||o.size===0||o.forEach(s=>{try{s(t,r);}catch(i){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,i);}});};var so=()=>{};V("write-context.runner",so,121);var co=()=>{let e=P().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};V("notify.reset",co,40);var uo=()=>P().computedCleanups,cr=new WeakMap;var lo=e=>{let t=cr.get(e);return t||(t=new Map,cr.set(e,t)),t};var ur=e=>{let t=uo(),r=t.get(e);if(!r){A()&&w(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var lr=(e,t=P())=>lo(t).get(e)?.autoDispose===true;var dr=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,s=e.initialFactories,i=e.metaEntries,a=e.snapshotCache,f=e.featureRuntimes,p=e.deletingStores,S=(l,v)=>{ye(v,{onError:i[l]?.options?.onError,severity:"warn",visibility:"dev"});},m=({name:l,prev:v,options:C,initialState:D,getMeta:k,getStoreValue:R,hasStore:x})=>({name:l,options:C,prev:v,getMeta:k,getStoreValue:R,getAllStores:()=>t,getInitialState:()=>D,hasStore:x,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:b=>{ye(b,{onError:C.onError,severity:"warn",visibility:"dev"});},warn:w,warnAlways:q,log:ee,hashState:Re,deepClone:B,sanitize:pe,validate:()=>({ok:true,value:v}),isDev:A}),n=({name:l,prev:v,options:C,initialState:D,phase:k})=>{let R=m({name:l,prev:v,options:C,initialState:D,getMeta:()=>i[l],getStoreValue:()=>t[l],hasStore:()=>oe(e,l)}),x=m({name:l,prev:v,options:C,initialState:D,getMeta:()=>{},getStoreValue:()=>v,hasStore:()=>false});ce().forEach(b=>{let O=f.get(b);k==="before"?O?.beforeStoreDelete?.(R):O?.afterStoreDelete?.(x);});},c=l=>{if(!oe(e,l))return;let v=t[l],C=i[l].options,D=o[l],k=r[l];p.add(l);try{k?.forEach(b=>{try{b(null);}catch(O){w(`Subscriber for "${l}" threw during delete: ${O?.message??O}`);}}),zt({name:l,label:"onDelete",fn:C.onDelete,args:[v],reportIssue:(b,O)=>{ye(b,{onError:C.onError,severity:"warn",visibility:O});}}),n({name:l,prev:v,options:C,initialState:D,phase:"before"}),delete t[l],delete r[l],delete o[l],delete s[l],delete i[l],delete a[l],Ut(l)&&ur(l);let x=e.computedDependents[l];if(x)for(let b of [...x]){let O=Qe(b);if(O&&lr(b,e)&&O.deps.every(X=>!oe(e,X))){c(b);continue}w(`[stroid] source store "${l}" was deleted. Computed store "${b}" depends on it and will return stale data. Call deleteComputed("${b}") to clean up.`);}n({name:l,prev:v,options:C,initialState:D,phase:"after"}),xe("afterStoreDelete",l,{type:"afterStoreDelete",prev:v}),He(e,{type:"deleted",name:l}),ee(`Store "${l}" deleted`);}finally{p.delete(l);}};return {deleteExistingStore:c,clearAllStores:()=>{let l=[],C=0,D=Number.POSITIVE_INFINITY;for(;C<20;){let R=Object.keys(t);if(R.length===0)break;R.forEach(b=>{oe(e,b)&&(c(b),l.push(b));}),C+=1;let x=Object.keys(t).length;if(x===0||x>=D)break;D=x;}let k=Object.keys(t).length;return k>0?w(`clearAllStores stopped after ${C} pass${C===1?"":"es"}; ${k} store(s) still registered (likely recreated during deletion).`):ee(`All stores cleared (${l.length} stores removed)`),l},clearStores:l=>{let v=Object.keys(t).filter(C=>l?l.endsWith("*")?C.startsWith(l.slice(0,-1)):C===l:true);return v.forEach(C=>c(C)),v},reportStoreError:S}};var dt=ue,pr=le(dt),gr=null,H=()=>{let e=de(pr);return ze(e),e};var P=()=>H();function Qt(e){gr=e;}var he=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}}}),fo=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 s=o[r];return typeof s=="function"?s.bind(o):s},set:(t,r,o)=>(e()[r]=o,true)}),po=e=>new Proxy({},{get:(t,r)=>{let o=e(),s=o[r];return typeof s=="function"?s.bind(o):s},set:(t,r,o)=>(e()[r]=o,true)}),Ae=he(()=>H().stores);he(()=>H().subscribers);var yr=he(()=>H().initialStates);he(()=>H().initialFactories);var $=he(()=>H().metaEntries);he(()=>H().snapshotCache);var J=fo(()=>H().featureRuntimes),fr=new WeakMap,go=e=>{let t=fr.get(e);return t||(t=dr(e),fr.set(e,t)),t};po(()=>go(H()));var yo=e=>{let t=J.get(e);if(t)return t;let r=Ee(e);if(!r)return;let o=r();return J.set(e,o),o},ft=()=>{ce().forEach(e=>{yo(e);});};wt((e,t)=>{J.get(e)||J.set(e,t());});ft();var De=(e,t)=>oe(H(),e);var Oe=(e,t,r=H())=>{r.stores[e]=t;},hr=(e,t,r=Date.now())=>{Oe(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,gr?.(e));};var ho=()=>{Et(H());},mo=()=>{J.forEach(e=>{try{e.resetAll?.();}catch{}}),J.clear();};V("features.reset",mo,10);V("registries.clear",ho,20);V("registry.default",()=>{dt=ue,pr=le(dt);},115);var mr=new WeakMap,Sr=e=>{let t=mr.get(e);return t||(t=new Map,mr.set(e,t)),t},So=()=>{Sr(P()).clear();};V("features.contexts",So,100);var bo=e=>{let t=P(),r=Sr(t),o=r.get(e);if(o)return o;let s=$[e];if(!s)return w(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let i={name:e,options:s.options,getMeta:()=>$[e],getStoreValue:()=>Ae[e],getAllStores:()=>Ae,getInitialState:()=>yr[e],hasStore:()=>De(e),setStoreValue:a=>{Oe(e,a);},applyFeatureState:(a,f)=>{hr(e,a,f),et(e);},notify:()=>{},reportStoreError:a=>{Ze(e,a);},warn:w,warnAlways:q,log:ee,hashState:Re,deepClone:B,sanitize:pe,validate:a=>Xt(e,a,$[e]?.options?.validate),isDev:A};return r.set(e,i),i},wo=(e,t)=>{let r=I();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 s=`Feature hook context missing fields for "${e}": ${o.join(", ")}.`;if(Ze(e,s),r.assertRuntime)throw new Error(s)};var pt=(e,t,r,o,s,i)=>{ft();let a=bo(e);if(!a)return;a.notify=()=>s(e);let f=Object.assign(Object.create(a),{action:t,prev:r,next:o});wo(e,f);let p=new Set(i);J.forEach((S,m)=>{if(!p.has(m))try{S.onStoreWrite?.(f);}catch(n){Gt(e,`Feature "${String(m)}" onStoreWrite for "${e}" failed: ${n?.message??n}`,"always");}});};var br=false,me=1,ko=e=>typeof e?.v=="number"?e.v:typeof e?.protocol=="number"?e.protocol:void 0,gt=new Set,yt=new Set,Ie=100,Cr=e=>{if(!e)return null;if(e===true)return Ie;if(typeof e!="object")return null;let t=e.loopGuard;if(t===false)return null;if(t===true||t===void 0)return Ie;if(typeof t=="object"){let r=t.windowMs;return typeof r=="number"&&Number.isFinite(r)&&r>0?r:Ie}return Ie},Co=e=>typeof TextEncoder<"u"?new TextEncoder().encode(e).length:typeof Buffer<"u"?Buffer.byteLength(e):e.length,Ro=({incoming:e,accepted:t})=>{let r=t?.clock??0,o=typeof e.clock=="number"?e.clock:0;if(o!==r)return o-r;let s=e.source??"",i=t?.source??"";return s===i?0:s.localeCompare(i,"en",{sensitivity:"variant"})},vo=e=>e?.updatedAtMs??Fe({value:e?.updatedAt,fallbackMs:0}),xo=e=>{if(typeof e!="object"||e===null)return false;let t=e;return (typeof t.v=="number"||typeof t.protocol=="number")&&typeof t.type=="string"&&typeof t.name=="string"&&typeof t.clock=="number"&&typeof t.source=="string"},wr=({name:e,syncChannels:t,instanceId:r,authToken:o,reportStoreError:s})=>{let i=t[e];if(i)try{let a={v:me,protocol:me,type:"sync-request",source:r,name:e,clock:0,requestedAt:Date.now()};o&&(a.token=o),i.postMessage(a);}catch(a){s(e,`Failed to request sync snapshot for "${e}": ${a?.message??a}`);}},Mo=(e,t)=>(t[e]=(t[e]??0)+1,t[e]),Eo=(e,t,r)=>(r[e]=Math.max(r[e]??0,t)+1,r[e]),Fo=({name:e,syncChannels:t,syncWindowCleanup:r,syncClocks:o,syncVersions:s})=>{t[e]?.close(),delete t[e],r[e]?.(),delete r[e],delete o[e],delete s[e];},To=({syncChannels:e,syncWindowCleanup:t})=>{Object.values(t).forEach(r=>{try{r();}catch{}}),Object.values(e).forEach(r=>{try{r.close();}catch{}});},jo=({name:e,syncOption:t,syncChannels:r,syncClocks:o,syncVersions:s,syncWindowCleanup:i,instanceId:a,getMeta:f,getAcceptedSyncVersion:p,getStoreValue:S,hasStoreEntry:m,notify:n,validate:c,reportStoreError:g,warn:y,setStoreValue:l,normalizeIncomingState:v,acceptIncomingSyncVersion:C,resolveSyncVersion:D,broadcastSync:k,markLoopGuard:R,hashState:x})=>{if(!t)return;if(typeof window>"u"||typeof BroadcastChannel>"u"){g(e,`Sync enabled for "${e}" but BroadcastChannel not available in this environment.`);return}let b=typeof t=="object"?t.policy:void 0,O=b==="insecure"||b!=="strict"&&typeof t=="object"&&t.insecure===true,X=typeof t=="object"&&typeof t.authToken=="string"&&t.authToken.length>0,ie=typeof t=="object"&&typeof t.verify=="function",Me=typeof t=="object"&&typeof t.sign=="function",Se=b==="strict"||!A()&&b!=="insecure";if(Se&&!O&&!X&&!ie){g(e,`Sync for "${e}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`);return}!Se&&!O&&!X&&!ie&&!gt.has(e)&&(gt.add(e),q(`Sync for "${e}" is unauthenticated. Any same-origin tab can forge sync messages. Provide sync.authToken or sync.verify to enforce authentication.`)),Me&&!ie&&!yt.has(e)&&(yt.add(e),y(`Sync for "${e}" is configured with "sign" but no "verify". "sign" has no effect unless incoming messages are verified.`));let Q=typeof t=="object"?t.authToken:void 0,d=Cr(t),F=false,M=typeof t=="object"&&t.channel?t.channel:`stroid_sync_${e}`;try{let u=new BroadcastChannel(M);if(r[e]=u,u.onmessage=_=>{let h=_.data;if(!h||h.source===a||h.name!==e||r[e]!==u||!m(e)||!f(e))return;if(!xo(h)){g(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(Q&&h.token!==Q){F||(g(e,`Sync message for "${e}" failed auth token verification; ignoring.`),F=!0);return}let N=ko(h);if(N!==me){g(e,`Sync protocol mismatch for "${e}". Expected v${me} but received ${String(N??"unknown")}. Ignoring message.`);return}let W=h.type==="sync-state";if(W&&(typeof h.data>"u"||typeof h.clock!="number")){g(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(typeof t=="object"&&typeof t.verify=="function"){let j=!1;try{j=!!t.verify(h);}catch(E){g(e,`Sync message verification failed for "${e}": ${E?.message??E}`);return}if(!j){g(e,`Sync message for "${e}" failed verification; ignoring.`);return}}let G=typeof t=="object"&&t.checksum==="none"?"none":"hash";if(W&&G!=="none"){let j=x(h.data);if(h.checksum!==j){g(e,`Sync checksum mismatch for "${e}". Expected ${String(j)}, got ${String(h.checksum)}. Ignoring message.`);return}}if(h.type==="sync-request"){k(e);return}let L=typeof t=="object"?t.conflictResolver:null;if(Ro({incoming:{clock:h.clock,source:h.source},accepted:p(e)})<=0){let j=vo(f(e)),E=typeof h.updatedAt=="number"?h.updatedAt:Date.now();if(L){let U=L({local:S(e),incoming:h.data,localUpdated:j,incomingUpdated:E});if(U!==void 0){let z=v(e,U);if(z===null)return;let be=S(e);l(e,z);let Z=typeof t=="object"?t.resolveUpdatedAt:null,we=Z?Z({localUpdated:j,incomingUpdated:E,now:Date.now()}):Math.max(Date.now(),j,E);D(e,we,typeof h.clock=="number"?h.clock:0),pt(e,"sync",be,z,()=>n(e),["sync"]),d&&R(e,d),n(e),k(e);}}return}let K=v(e,h.data);if(K===null)return;let re=S(e);l(e,K),C(e,typeof h.updatedAt=="number"?h.updatedAt:Date.now(),typeof h.clock=="number"?h.clock:0,typeof h.source=="string"?h.source:""),pt(e,"sync",re,K,()=>n(e),["sync"]),d&&R(e,d),n(e);},typeof window<"u"&&typeof window.addEventListener=="function"){i[e]?.();let _=window,h=()=>{wr({name:e,syncChannels:r,instanceId:a,authToken:Q,reportStoreError:g});};_.addEventListener("focus",h),_.addEventListener("online",h),i[e]=()=>{_.removeEventListener("focus",h),_.removeEventListener("online",h);};}queueMicrotask(()=>{wr({name:e,syncChannels:r,instanceId:a,authToken:Q,reportStoreError:g});});}catch(u){y(`Failed to setup sync for "${e}": ${u?.message||u}`);}},kr=({name:e,syncOption:t,syncChannels:r,syncClocks:o,instanceId:s,updatedAt:i,data:a,hashState:f,reportStoreError:p})=>{let S=r[e];if(S)try{let m=typeof t=="object"&&t.checksum==="none"?"none":"hash",n={v:me,protocol:me,type:"sync-state",source:s,name:e,clock:o[e]??0,updatedAt:Fe({value:i,fallbackMs:Date.now()}),data:a,checksum:m==="hash"?f(a):null};if(typeof t=="object"&&t.authToken&&(n.token=t.authToken),typeof t=="object"&&typeof t.sign=="function")try{let y=t.sign(n);if(y&&typeof y.then=="function"){p(e,`Sync signer for "${e}" returned a Promise. "sign" must be synchronous.`);return}y!==void 0&&(n.auth=y);}catch(y){p(e,`Failed to sign sync payload for "${e}": ${y?.message??y}`);return}let c=typeof t=="object"&&typeof t.maxPayloadBytes=="number"?t.maxPayloadBytes:64*1024,g=Co(JSON.stringify(n));if(g>c){p(e,`Sync payload for "${e}" exceeds ${c} bytes (${g} bytes). Skipping BroadcastChannel sync.`);return}try{S.postMessage(n);}catch(y){if(y&&typeof y=="object"&&y.name==="DataCloneError"){p(e,`Sync payload for "${e}" could not be cloned (DataCloneError). Remove non-serializable values or provide a custom serializer. Payload size ~${g} bytes.`);return}throw y}}catch(m){p(e,`Failed to broadcast sync for "${e}": ${m?.message??m}`);}},Vo=()=>{let e=Object.create(null),t=Object.create(null),r=Object.create(null),o=Object.create(null),s=Object.create(null),i=new Set,a=`stroid_${Math.random().toString(16).slice(2)}`,f=(n,c)=>{r[n]={clock:t[n]??0,updatedAt:Fe({value:c,fallbackMs:Date.now()}),source:a};},p=(n,c)=>{Mo(n,t),f(n,c);},S=(n,c)=>{!c||!Number.isFinite(c)||(s[n]=Date.now()+c);},m=(n,c)=>{if(!c)return false;let g=s[n];return g?Date.now()>=g?(delete s[n],false):true:false};return {onStoreCreate(n){if(!n.options.sync)return;let c=n.options.sync,g=n.notify,y=typeof c=="object"?c.policy:void 0,l=y==="insecure"||y!=="strict"&&typeof c=="object"&&c.insecure===true,v=typeof c=="object"&&typeof c.authToken=="string"&&c.authToken.length>0,C=typeof c=="object"&&typeof c.verify=="function";if((y==="strict"||!n.isDev()&&y!=="insecure")&&c&&!l&&!v&&!C){n.reportStoreError(`Sync for "${n.name}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`),n.options.sync=false;return}if(jo({name:n.name,syncOption:c,syncChannels:e,syncClocks:t,syncVersions:r,syncWindowCleanup:o,instanceId:a,getMeta:n.getMeta,getAcceptedSyncVersion:k=>r[k],getStoreValue:k=>n.getStoreValue(),hasStoreEntry:()=>n.hasStore(),notify:()=>g(),validate:(k,R)=>n.validate(R),reportStoreError:(k,R)=>n.reportStoreError(R),warn:n.warn,setStoreValue:(k,R)=>n.setStoreValue(R),normalizeIncomingState:(k,R)=>{let x=kt({value:R,sanitize:n.sanitize,validate:n.validate,onSanitizeError:b=>{n.reportStoreError(`Sanitize failed for incoming sync "${k}": ${b?.message??b}`);}});return x.ok?x.value:null},acceptIncomingSyncVersion:(k,R,x,b)=>{n.applyFeatureState(n.getStoreValue(),R),t[n.name]=Math.max(t[n.name]??0,x),r[n.name]={clock:x,updatedAt:R,source:b};},resolveSyncVersion:(k,R,x)=>{n.applyFeatureState(n.getStoreValue(),R);let b=Eo(n.name,x,t);return r[n.name]={clock:b,updatedAt:R,source:a},b},broadcastSync:()=>{let k=n.getMeta();k&&kr({name:n.name,syncOption:n.options.sync,syncChannels:e,syncClocks:t,instanceId:a,updatedAt:k.updatedAtMs??k.updatedAt,data:n.getStoreValue(),hashState:n.hashState,reportStoreError:(R,x)=>n.reportStoreError(x)});},markLoopGuard:S,hashState:n.hashState}),e[n.name]){let k=n.getMeta();f(n.name,k?.updatedAtMs??k?.updatedAt??new Date().toISOString());}},onStoreWrite(n){if(!n.options.sync)return;let c=n.getMeta();if(!c)return;let g=Cr(n.options.sync);if(m(n.name,g)){p(n.name,c.updatedAtMs??c.updatedAt),i.has(n.name)||(i.add(n.name),n.warn(`Sync broadcast for "${n.name}" suppressed by loopGuard to prevent feedback loops.`));return}p(n.name,c.updatedAtMs??c.updatedAt),kr({name:n.name,syncOption:n.options.sync,syncChannels:e,syncClocks:t,instanceId:a,updatedAt:c.updatedAtMs??c.updatedAt,data:n.next,hashState:n.hashState,reportStoreError:(y,l)=>n.reportStoreError(l)});},beforeStoreDelete(n){Fo({name:n.name,syncChannels:e,syncWindowCleanup:o,syncClocks:t,syncVersions:r}),delete s[n.name],i.delete(n.name);},resetAll(){To({syncChannels:e,syncWindowCleanup:o}),Object.keys(e).forEach(n=>delete e[n]),Object.keys(t).forEach(n=>delete t[n]),Object.keys(r).forEach(n=>delete r[n]),Object.keys(o).forEach(n=>delete o[n]),Object.keys(s).forEach(n=>delete s[n]),gt.clear(),yt.clear(),i.clear();}}},Rr=()=>{br||(br=true,bt("sync",Vo));};var Ao=()=>{Rr();};export{Ao as installSync};//# sourceMappingURL=sync.js.map
|
|
1
|
+
export{b as installSync}from'./chunk-PVATWAY4.js';import'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';//# sourceMappingURL=sync.js.map
|
|
2
2
|
//# sourceMappingURL=sync.js.map
|
package/dist/testing.js
CHANGED
|
@@ -1,23 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
Store data only - handle functions outside the store.`,Er=()=>`Map/Set detected. stroid converts these to plain objects.
|
|
3
|
-
Use arrays or plain objects for best results.`,Fr=()=>`Date object detected. stroid stores it as ISO string.
|
|
4
|
-
Use new Date(value) to convert back when reading.`,Ar=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Pr=()=>"Map detected; converting to plain object.",Or=()=>"Set detected; converting to array.",Nr=(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]}", ...)`,Dr=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
|
|
8
|
-
Consider splitting into separate stores for better readability.`;var Vr=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Ir=e=>`Store name "${e}" contains spaces.
|
|
9
|
-
Use camelCase or kebab-case: "userName" or "user-name"`,jr=e=>`Store name "${e}" is not allowed.
|
|
10
|
-
Reserved names: "__proto__", "constructor", "prototype".`,So=128,ho=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=So,bo=(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]},Pt=(e,t)=>{let r=t.find(n=>{let o=n.toLowerCase(),s=e.toLowerCase();return o.includes(s)||s.includes(o)||ho(o,s)&&bo(o,s)<=2});if(r){p(`Store "${e}" not found. Did you mean "${r}"?`);return}L(`Store "${e}" not found.
|
|
11
|
-
Available stores: [${t.join(", ")}]
|
|
12
|
-
Call createStore("${e}", data) first.`);};var Y=new Set(["__proto__","constructor","prototype"]),Nt=(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 ce=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,$r=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},Ce=e=>{let t=ce(e);return t==="function"?(L(Tr()),false):t==="map"||t==="set"?(p(Er()),true):(t==="date"&&p(Fr()),true)},Ot=(e,t)=>{let r=$r(e);if(r)throw new Error(`${r} values are not supported`);let n=ce(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&&!Ot(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||Y.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Ot(i.value,t))return false}return true}return true},Dt=e=>Ot(e,new WeakSet),_e=(e,t)=>{let r=$r(e);if(r)throw new Error(`${r} values are not supported`);let n=ce(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date")return M()&&p(Ar()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),M()&&p(Pr());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)]=_e(i,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),M()&&p(Or()),Array.from(e,o=>_e(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&&!Y.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);o[i]=_e(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=>_e(o,t))}return e},ge=e=>_e(e,new WeakSet),Vt=e=>typeof e!="string"||e.trim()===""?(L(Vr(e)),false):Y.has(e)?(L(jr(e)),false):e.includes(" ")?(L(Ir(e)),false):true;var It=null,wo=()=>{if(It)return It;let e,t=[];for(let r=0;r<256;r++){e=r;for(let n=0;n<8;n++)e=e&1?3988292384^e>>>1:e>>>1;t[r]=e>>>0;}return It=t,t},zr=e=>{let t=wo(),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},vo=2166136261,Ro=2654435761,xo=1e5,ue=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},ye=(e,t)=>{ue(e,t.length);for(let r=0;r<t.length;r++)ue(e,t.charCodeAt(r));},D=(e,t)=>{ye(e,t);},_r=(e,t)=>{if(Number.isNaN(t)){D(e,"NaN");return}if(!Number.isFinite(t)){D(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){D(e,"-0");return}let r=t|0;if(t===r){D(e,"int"),ue(e,r);return}D(e,"num"),ye(e,String(t));},ke=(e,t)=>{if(e.nodes++>xo){D(e,"[max]");return}if(t===null){D(e,"null");return}let r=typeof t;if(r==="string"){D(e,"string"),ye(e,t);return}if(r==="number"){D(e,"number"),_r(e,t);return}if(r==="boolean"){D(e,t?"true":"false");return}if(r==="undefined"){D(e,"undefined");return}if(r==="bigint"){D(e,"bigint"),ye(e,t.toString());return}if(r==="symbol"){D(e,"symbol");let u=t;ye(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){D(e,"function"),ye(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){D(e,"ref"),ue(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){D(e,"array"),ue(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?ke(e,n[u]):D(e,"hole");return}if(n instanceof Date){D(e,"date"),_r(e,n.getTime());return}if(n instanceof Map){D(e,"map"),ue(e,n.size),n.forEach((u,c)=>{ke(e,c),ke(e,u);});return}if(n instanceof Set){D(e,"set"),ue(e,n.size),n.forEach(u=>{ke(e,u);});return}D(e,"object");let i=Object.getOwnPropertyDescriptors(n),a=[];Object.entries(i).forEach(([u,c])=>{c?.enumerable&&(Y.has(u)||"get"in c||"set"in c||a.push([u,c]));}),ue(e,a.length);for(let[u,c]of a)ye(e,u),ke(e,c.value);},ze=e=>{if(typeof e=="string")return zr(JSON.stringify(e));let t={h1:vo,h2:Ro,seen:new WeakMap,nextId:1,nodes:0};ke(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 Co=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",jt=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&&(Y.has(n)||"get"in o||"set"in o||(t[n]=o.value));}),t},$t=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},ko=e=>$t(e)===null,Mo=e=>{let t=$t(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},me=(e,t=new WeakMap)=>{if(Mo(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(me(i,t),me(s,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(s=>{o.add(me(s,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((s,i)=>{o[i]=me(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||Y.has(o)||"get"in s||"set"in s||(r[o]=me(s.value,t));}),r},V=e=>{if(Co)try{return structuredClone(e)}catch(t){if(!ko(e)){let r=$t(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return p(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),me(e)}return me(e)},_t=(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 Wr=10,To=5,Eo=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},Se=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?Eo(e):[String(e)],zt=e=>{let t=Se(e),r=t.length;return r>Wr?(L(Nr(r,Wr,t)),false):(r>To&&p(Dr(r,t)),true)};var Wt=(e,t,r)=>{let n=Se(t);if(n.length===0)return e;for(let s of n)if(Y.has(s))return z(`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(Y.has(a))return z(`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 h=l,w=Number(a);return h[w]=o(void 0,i+1),h}return l[a]=o(void 0,i+1),l}return u?r:s};return o(e,0)};var Lt=new Set,Fo=()=>{Lt.clear();};T("options.legacy-warnings",Fo,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"}})(),Ht=e=>{try{return typeof window>"u"?tt:e==="session"||e==="sessionStorage"?window.sessionStorage??tt:window.localStorage??tt}catch{return tt}},We=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Me=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Lr=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}},Ao=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Hr=e=>{try{e[Ao]=!0;}catch{}return e},Po={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"},Oo=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Hr(h=>h),decrypt:Hr(h=>h),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Ht("localStorage"),...r};if(typeof e=="string")return {driver:Ht(e),...r};let n=e.encrypt||r.encrypt,o=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,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&&Lr(n)&&!s)throw new Error(`[stroid/persist] Store "${t}" is marked sensitiveData but is configured to persist in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`);return {driver:e.driver||e.storage||Ht("localStorage"),key:e.key||r.key,serialize:e.serialize||r.serialize,deserialize:e.deserialize||r.deserialize,encrypt:n,decrypt:o,encryptAsync:s,decryptAsync:i,allowPlaintext:u,sensitiveData:a,maxSize:c,checksum:l,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Br=e=>{if(!We(e))return [];let t=[];return Object.entries(Po).forEach(([r,n])=>{Me(e,r)&&(Lt.has(r)||(Lt.add(r),t.push(`createStore option "${r}" is deprecated. Use "${n}" instead.`)));}),t},qr=(e={},t,r="deep")=>{let n=e.scope??"request",o=e.lazy===true,s=e.pathCreate===true,i=We(e.lifecycle)?e.lifecycle:void 0,a=We(e.persist)?e.persist:void 0,u=We(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",h=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,w=We(e.features)?{...e.features}:void 0,g=Me(e,"persist"),v=Me(e,"sync"),d=Me(e,"devtools")||Me(e,"historyLimit")||Me(e,"redactor"),m=n==="global"?true:e.allowSSRGlobalStore??false,{persist:S=false,devtools:R=false,onError:x,sync:k}=e;if(a?.sensitiveData===true){let A=a.encrypt,b=a.encryptAsync;if((!A||Lr(A))&&!b)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:Oo(S,t),devtools:n==="temp"&&!d?false:typeof R=="boolean"?R: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:x,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"&&!v?false:k??false,features:w,allowSSRGlobalStore:m,snapshot:l,snapshotSafety:h,explicitPersist:g,explicitSync:v,explicitDevtools:d}};var rt=Symbol("stroid.middleware.abort"),Ur=({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=V(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 h=`Middleware for "${e}" failed: ${l?.message??l}`;return n(h,"dev"),rt}if(u&&typeof u.then=="function"){let l=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return n(l,"dev"),rt}u===void 0?(M()&&!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},nt=({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 J=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(n){let o=n?.message??n;G(`${t} callback threw: ${String(o)}`);}},he=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(J(o,"onError",e),r==="critical"){n==="dev"&&p(e),z(e);return}if(n==="always"){G(e);return}p(e);};var ot=null,Kr=e=>{ot=e;},Gr=e=>ot?ot(e):[];T("computed.order-resolver",()=>{ot=null;},105);var Yr=()=>K(xe(Re));var Bt=()=>Yr().computedEntries,Xr=()=>Yr().computedDependents;var Jr=e=>Object.prototype.hasOwnProperty.call(Bt(),e);var No=e=>{let t=Bt(),r=Xr(),n=new Set,o=[...e];for(;o.length>0;){let l=o.shift(),h=r[l];if(h)for(let w of h)n.has(w)||(n.add(w),o.push(w));}if(n.size===0)return [];let s=l=>{let h=t[l];if(h)for(let w of h.deps)t[w]&&(n.has(w)||(n.add(w),s(w)));};Array.from(n).forEach(l=>s(l));let i=new Map,a=new Map;for(let l of n){let h=t[l];if(!h)continue;let w=0;for(let g of h.deps)n.has(g)&&(w++,a.has(g)||a.set(g,[]),a.get(g).push(l));i.set(l,w);}let u=[];for(let[l,h]of i)h===0&&u.push(l);u.sort();let c=[];for(;u.length>0;){let l=u.shift();c.push(l);let h=a.get(l)??[];for(let w of h){let g=(i.get(w)??1)-1;if(i.set(w,g),g===0){let v=u.findIndex(d=>d>w);v===-1?u.push(w):u.splice(v,0,w);}}}return c};Kr(No);var qt=e=>{let t=Bt()[e];if(!t)return null;let r=Xr()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Qr=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")},Ut=e=>(Qr(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Zr=e=>{if(!Qr(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 He=0,Do=(e,t)=>(He>=Number.MAX_SAFE_INTEGER&&(He=0),He+=1,`${e}:${t}:${He}`),Vo=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},Io=e=>({...e,path:[...e.path],meta:{...e.meta,causedBy:e.meta.causedBy?[...e.meta.causedBy]:void 0}}),jo=e=>e?Array.isArray(e)?e.map(t=>typeof t=="number"?t:String(t)):Se(e):[],Kt=e=>{let t=e.timestamp??Date.now();return {id:Do(e.source,t),store:e.store,path:jo(e.path),op:e.op,...e.value!==void 0?{value:e.value}:{},meta:{timestamp:t,source:e.source,causedBy:Vo(e.context),...e.isUnsafe===true?{isUnsafe:true}:{},...e.asyncBoundary===true?{asyncBoundary:true}:{}}}},Gt=e=>Kt({store:e.store,op:"set",path:[],value:e.value,source:e.source,context:e.context}),en=e=>e.intent.kind==="root"||!e.preserveIntent?[Gt({store:e.store,value:e.committedValue,source:"setStore",context:e.context})]:e.intent.kind==="merge"?[Kt({store:e.store,op:"merge",path:[],value:e.intent.value,source:"setStore",context:e.context})]:[Kt({store:e.store,op:"set",path:e.intent.path,value:e.intent.value,source:"setStore",context:e.context})],tn=(e,t=P())=>{t.lastRuntimePatches=e.map(Io);};T("runtime-patch.sequence",()=>{He=0;},126);var st=null;var $o=()=>{st=null;};T("transaction.runner",$o,120);var Te=e=>{let t=st?.get();return t||(e??K()).transaction},_o=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 F=()=>st?(st.get()?.depth??0)>0:Te().depth>0,$=(e,t)=>{let r=Te(t);r.failed=true,r.error||(r.error=_o(e));},it=e=>{let t=K();Te(t).pending.push(()=>et(t,e));},at=(e,t)=>{let r=Te();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},rn=e=>{if(e.length===0)return;Te().runtimePatches.push(...e);},le=e=>{let t=Te();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"},Yt=(e,t)=>{if(t==="ref"){if(!M())return e;try{return Ut(e)}catch{return e}}if(t==="shallow"){let n=jt(e);if(!M())return n;try{return Ut(n)}catch{return n}}let r=V(e);if(!M())return r;try{return Zr(r)}catch{return r}};var on=e=>{let{pendingNotifications:t,pendingBuffer:r,orderedNames:n}=e,o=E().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 v of t)r.push(v),a.add(v);for(let v of s)a.has(v)&&n.push(v);for(let v of r)i.has(v)||n.push(v);}else for(let v of t)r.push(v),a.add(v),n.push(v);t.clear();let u=Gr(n),c=new Set(n);for(let v of u)c.has(v)||(n.push(v),c.add(v));let l=Number.isFinite(o.chunkSize)&&o.chunkSize>0?o.chunkSize:Number.POSITIVE_INFINITY,h=o.chunkDelayMs,w=l===Number.POSITIVE_INFINITY&&h===0;return {names:n,sliceSize:l,chunkDelayMs:h,runInline:w,prioritySet:i}};var Xt=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}),Jt=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),Qt=(e,t)=>{e&&(e.metrics=t);};var Le=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},sn=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let n=()=>et(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(n):Promise.resolve().then(n);};var an=new Map;var Zt=e=>{let t=an.get(e);return !!t&&t.size>0},Be=(e,t,r)=>{let n=an.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 qe=null,ct=null;var zo=()=>{qe=null,ct=null;};T("write-context.runner",zo,121);var ut=()=>ct?.get()??qe,er=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(ct)return ct.run(e,t);let r=qe;qe=e;try{return t()}finally{qe=r;}};var cn=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)},un=(e,t,r,n)=>{let o=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:u,prioritySet:c}=t,h=e.stores,w=e.subscribers,g=e.metaEntries,v=e.snapshotCache,d=E().defaultSnapshotMode,m=y=>nn(g[y],d),S=y=>h[y],R=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),x=Zt("beforeFlush"),k=Zt("afterFlush"),A=y=>{x&&Be("beforeFlush",y,{type:"beforeFlush"});},b=(y,_)=>{k&&Be("afterFlush",y,{type:"afterFlush",elapsedMs:_});},C=y=>{let _=g[y];if(!_)return null;let N=_.lastCorrelationId??void 0,f=_.lastTraceContext??void 0;return !N&&!f?null:{correlationId:N,traceContext:f}},O=()=>{n();};if(u){for(let y of s){let _=w[y];if(!_||_.size===0)continue;let N=g[y]?.updateCount??0,f=m(y),we=S(y),q=v[y],U=q&&q.source===we&&q.mode===f?q.snapshot:(()=>{let W=Yt(we,f);return v[y]={version:r,snapshot:W,source:we,mode:f},W})(),re=Xt(g[y]?.metrics);A(y);let de=R(),ae=Array.from(_),Ne=C(y),De=()=>{for(let W of ae)try{W(U);}catch(fe){let ne=g[y]?.options?.snapshotSafety??"warn";if(M()&&(f==="ref"||f==="shallow")&&cn(fe)){if(ne==="throw")throw fe;if(ne==="auto-clone")try{let Ie=V(U);p(`Snapshot mutation detected for "${y}". Delivered a cloned snapshot to the subscriber.`);try{W(Ie);}catch(xt){p(`Subscriber for "${y}" threw on cloned snapshot: ${xt?.message??xt}`);}continue}catch{}p(`Snapshot mutation detected for "${y}": ${fe?.message??fe}`);continue}p(`Subscriber for "${y}" threw: ${fe?.message??fe}`);}};Ne?er(Ne,De):De();let Ve=R()-de;b(y,Ve),Jt(re,Ve),Qt(g[y],re),(g[y]?.updateCount??N)!==N&&o.pendingNotifications.add(y);}O();return}let j=y=>{let _=[];for(let N of s){if(y&&!y(N))continue;let f=w[N];if(!f||f.size===0)continue;let we=g[N]?.updateCount??0,q=m(N),U=S(N),re=v[N],de=re&&re.source===U&&re.mode===q?re.snapshot:(()=>{let ae=Yt(U,q);return v[N]={version:r,snapshot:ae,source:U,mode:q},ae})();_.push({name:N,snapshot:de,version:we,subscribers:Array.from(f),subscriberSet:new Set(f),notified:new Set,metrics:Xt(g[N]?.metrics),totalMs:0,beforeHooked:false});}return _},Pe=c?j(y=>c.has(y)):[],Oe=j(y=>!c||!c.has(y)),vt=(y,_)=>{let N=()=>{if(y.length===0){_();return}let f=y.shift();if((g[f.name]?.updateCount??f.version)!==f.version){if(o.pendingNotifications.add(f.name),y.length===0){_();return}Le(N,a);return}let q=()=>{let X=w[f.name];if(!(!X||X.size===0))for(let W of X)f.subscriberSet.has(W)||(f.subscriberSet.add(W),f.subscribers.push(W));};q();let U=f.subscribers;if(U.length===0){if(y.length===0){_();return}Le(N,a);return}f.beforeHooked||(f.beforeHooked=true,A(f.name));let re=R(),de=0,ae=false,Ne=C(f.name),De=()=>{for(let X=0;X<U.length&&de<i;X+=1){let W=U[X];if(f.notified.has(W))continue;f.notified.add(W);try{W(f.snapshot);}catch(ne){let Rt=g[f.name]?.options?.snapshotSafety??"warn",Ie=m(f.name);if(M()&&(Ie==="ref"||Ie==="shallow")&&cn(ne)){if(Rt==="throw")throw ne;if(Rt==="auto-clone")try{let ur=V(f.snapshot);p(`Snapshot mutation detected for "${f.name}". Delivered a cloned snapshot to the subscriber.`);try{W(ur);}catch(lr){p(`Subscriber for "${f.name}" threw on cloned snapshot: ${lr?.message??lr}`);}if(f.notified.add(W),de+=1,(g[f.name]?.updateCount??f.version)!==f.version){ae=!0,o.pendingNotifications.add(f.name);break}continue}catch{}p(`Snapshot mutation detected for "${f.name}": ${ne?.message??ne}`);continue}p(`Subscriber for "${f.name}" threw: ${ne?.message??ne}`);}if(de+=1,(g[f.name]?.updateCount??f.version)!==f.version){ae=true,o.pendingNotifications.add(f.name);break}}};if(Ne?er(Ne,De):De(),f.totalMs+=R()-re,ae){if(y.length===0){_();return}Le(N,a);return}q();let Ve=false;for(let X of U)if(!f.notified.has(X)){Ve=true;break}if(Ve?y.push(f):(Jt(f.metrics,f.totalMs),Qt(g[f.name],f.metrics),b(f.name,f.totalMs)),y.length===0){_();return}Le(N,a);};N();};Pe.length>0?vt(Pe,()=>vt(Oe,O)):vt(Oe,O);};var Wo=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,n=on(t);un(e,n,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&tr(e);});},tr=e=>{sn(e,Wo);};var lt=null,ln=e=>(lt=e,()=>{lt===e&&(lt=null);}),Ee=e=>{lt?.(e);};var Ho=e=>{let t=P(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&tr(t);};ln(Ho);var Lo=()=>{let e=P().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};T("notify.reset",Lo,40);var dt=new Set,pn=e=>e?dt.has(e):dt.size>0,gn=e=>{e&&dt.add(e);},Bo=()=>{dt.clear();};T("ssr.warnings",Bo,60);var fn=new Set,qo=e=>{let t=kr();return !t||e.includes("::")?e:(M()&&!fn.has(e)&&(fn.add(e),p(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},ft=e=>qo(typeof e=="string"?e:e.name),yn=e=>se(e)&&!hn(e)?true:(Pt(e,Object.keys(Ke)),false),mn=(e,t,r={})=>{he(t,{...r,onError:I[e]?.options?.onError});},Sn=(e,t,r={})=>{he(e,{...r,onError:t});},Q=(e,t,r="dev")=>{mn(e,t,{severity:"warn",visibility:r});},Uo=(e,t,r="dev")=>{Sn(e,t,{severity:"warn",visibility:r});},ie=(e,t)=>mn(e,t,{severity:"critical",visibility:"always"}),Ue=(e,t)=>Sn(e,t,{severity:"critical",visibility:"always"}),pt=(e,t,r)=>{let n=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
13
|
-
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Uo(n,r,"always"),E().strictMissingFeatures)throw new Error(n)};var bn=new WeakMap,wn=new WeakMap,Ko=500,Go="",Ge=e=>{let t=bn.get(e);return t||(t=new Map,bn.set(e,t)),t},nr=e=>{let t=wn.get(e);return t||(t=new Map,wn.set(e,t)),t},Yo=(e,t)=>{let r=nr(e),n=r.get(t);return n||(n=new Map,r.set(t,n)),n},Xo=()=>{let e=E().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?Ko:Math.max(0,Math.floor(e))},vn=(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=Ge(P());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let n=r[t];return typeof n=="function"?n.bind(r):n},set:(e,t,r)=>(Ge(P())[t]=r,true)});var Rn=(e,t,r,n)=>{let o=I[e];if(!o)return {ok:true};let s=Se(r);if(s.length===0)return {ok:true};let i=ce(n),a=Xo(),u=P(),c=Ge(u),l=Yo(u,e),h=s.join(Go),w=c.get(e);w||(w={children:new Map},c.set(e,w));let g=w;for(let x of s){let k=g.children.get(x);k||(k={children:new Map},g.children.set(x,k)),g=k;}let v=g.verdicts?.get(i);if(v){let x=`${h}|${i}`;return vn(l,x,{node:g,type:i},a),v}let d=o.options?.pathCreate===true,m=t,S={ok:true};for(let x=0;x<s.length;x++){let k=s[x],A=x===s.length-1;if(m==null){let C=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,x).join(".")||"root"}" is ${m===null?"null":"undefined"}.`;z(C),S={ok:false,reason:C};break}if(typeof m!="object"){let C=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,x).join(".")||"root"}" is not an object.`;z(C),S={ok:false,reason:C};break}if(Array.isArray(m)){let C=Number(k);if(!Number.isInteger(C)||C<0){let j=`Path "${s.join(".")}" targets non-numeric index "${k}" on an array in "${e}".`;z(j),S={ok:false,reason:j};break}let O=m;if(C>=O.length){let j=`Path "${s.join(".")}" is invalid for "${e}" - index ${C} is out of bounds (length ${O.length}).`;z(j),S={ok:false,reason:j};break}if(A){let j=O[C];if(j!=null){let Pe=ce(j);if(Pe!==i){let Oe=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${Pe}, received ${i}.`;z(Oe),S={ok:false,reason:Oe};break}}S={ok:true};break}m=O[C];continue}if(!Object.prototype.hasOwnProperty.call(m,k)){if(d&&A){S={ok:true};break}let C=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${k}" at "${s.slice(0,x).join(".")||"root"}".`;z(C),S={ok:false,reason:C};break}if(A){let C=m[k];if(C!=null){let O=ce(C);if(O!==i){let j=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${O}, received ${i}.`;z(j),S={ok:false,reason:j};break}}S={ok:true};break}m=m[k];}g.verdicts||(g.verdicts=new Map);let R=g.verdicts.has(i);if(g.verdicts.set(i,S),!R){let x=`${h}|${i}`;vn(l,x,{node:g,type:i},a);}return S},be=(e,t,r,n)=>{try{return n?.reuseInput&&Dt(t)?{ok:!0,value:t}:{ok:!0,value:ge(t)}}catch(o){let s=`Sanitize failed for "${e}": ${o?.message??o}`;return J(I[e]?.options?.onError,`onError(${e})`,s),J(r,`onError(${e})`,s),p(s),{ok:false}}},Jo=(e,t)=>{let r=new Set,n=I[e]?.options?.onError;return typeof n=="function"&&r.add(n),typeof t=="function"&&r.add(t),r},or=(e,t,r,n)=>{if(!r)return {ok:true,value:t};let o=Jo(e,n),s=(a,u)=>{o.forEach(c=>J(c,`onError(${e})`,a)),u==="critical"?z(a):p(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=Nt(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Ye=(e,t,r,n,o)=>{let s=be(e,t,n,o);if(!s.ok)return {ok:false};let i=or(e,s.value,r,n);return i.ok?{ok:true,value:i.value}:{ok:false}},ee=e=>{let t=P();Ge(t).delete(e),nr(t).delete(e);},Qo=()=>{let e=P();Ge(e).clear(),nr(e).clear();};T("validation.path-cache",Qo,50);xn(ee);var gt=(e,t=P())=>{if((F()?le(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=be(e,o,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=Ye(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(F()){let u=a.value;at(e,u),it(()=>{te(e,u,t),t.initialStates[e]=V(u),delete t.initialFactories[e],ee(e);});}else te(e,a.value,t),t.initialStates[e]=V(a.value),delete t.initialFactories[e],ee(e);return !0}catch(o){return ie(e,`Lazy initializer for "${e}" failed: ${o?.message??o}`),false}};var Cn=new WeakMap,kn=e=>{let t=Cn.get(e);return t||(t=new Map,Cn.set(e,t)),t},Zo=()=>{kn(P()).clear();};T("features.contexts",Zo,100);var Mn=e=>{let t=P(),r=kn(t),n=r.get(e);if(n)return n;let o=I[e];if(!o)return p(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:o.options,getMeta:()=>I[e],getStoreValue:()=>Ke[e],getAllStores:()=>Ke,getInitialState:()=>On[e],hasStore:()=>se(e),setStoreValue:i=>{te(e,i);},applyFeatureState:(i,a)=>{Nn(e,i,a),ee(e);},notify:()=>{},reportStoreError:i=>{ie(e,i);},warn:p,warnAlways:G,log:B,hashState:ze,deepClone:V,sanitize:ge,validate:i=>or(e,i,I[e]?.options?.validate),isDev:M};return r.set(e,s),s},Tn=(e,t)=>{let r=E();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(ie(e,o),r.assertRuntime)throw new Error(o)},En=(e,t)=>{mt();let r=Mn(e);r&&(r.notify=()=>t(e),Tn(e,r),Z.forEach((n,o)=>{try{n.onStoreCreate?.(r);}catch(s){Q(e,`Feature "${String(o)}" onStoreCreate for "${e}" failed: ${s?.message??s}`,"always");}}));},Fn=(e,t,r,n,o)=>{mt();let s=Mn(e);if(!s)return;s.notify=()=>o(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:n});Tn(e,i),Z.forEach((a,u)=>{try{a.onStoreWrite?.(i);}catch(c){Q(e,`Feature "${String(u)}" onStoreWrite for "${e}" failed: ${c?.message??c}`,"always");}});};var An=(e,t)=>Ur({name:e,payload:t,middlewares:(()=>{let r=I[e]?.options?.middleware||[],n=E().middleware||[];return r.length===0?n:n.length===0?r:[...r,...n]})(),reportIssue:(r,n)=>{Q(e,r,n);},warn:p}),yt=(e,t,r,n)=>nt({name:e,label:t,fn:r,args:n,reportIssue:(o,s)=>{Q(e,o,s);}}),Pn=(e,t)=>{let r={...t};return r.persist&&!Xe("persist")&&(r.explicitPersist&&pt(e,"persist",r.onError),r.persist=null),r.sync&&!Xe("sync")&&(r.explicitSync&&pt(e,"sync",r.onError),r.sync=false),Xe("devtools")||(r.explicitDevtools&&pt(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var es=32,sr=new Set;T("store-write.slow-mutator-warned",()=>sr.clear(),65);var ts=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var Vn=(e,t)=>{M()&&(t<es||sr.has(e)||(sr.add(e),p(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},In=e=>ut(),rs=(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);},Dn=(e,{name:t,prev:r,next:n,action:o,hookLabel:s,logMessage:i,context:a,metricsUpdate:u})=>{let c=e.metaEntries;te(t,n,e),ee(t);let l=Date.now();c[t].updatedAt=new Date(l).toISOString(),c[t].updatedAtMs=l;let h=a??ut();h&&(h.correlationId||h.traceContext)?(c[t].lastCorrelationId=h.correlationId??null,c[t].lastCorrelationAt=new Date(l).toISOString(),c[t].lastCorrelationAtMs=l,c[t].lastTraceContext=h.traceContext??null):(c[t].lastCorrelationId=null,c[t].lastCorrelationAt=null,c[t].lastCorrelationAtMs=null,c[t].lastTraceContext=null),ts(c[t]),rs(c[t],u),Fn(t,o,r,n,Ee),yt(t,s,c[t].options[s],[r,n]),Ee(t),B(i);},St=(e,t)=>{let r=t.context??ut();if(F()){at(t.name,t.next),rn(t.runtimePatches??[]),it(()=>Dn(e,{...t,context:r}));return}Dn(e,{...t,context:r}),t.runtimePatches&&t.runtimePatches.length>0&&tn(t.runtimePatches,e);};function Fe(e,t,r){return ns(e,t,r)}var ns=(e,t,r,n)=>{let o=ft(e),s=P(),i=s.metaEntries;if(!gt(o,s))return {ok:false,reason:"validate"};if(!se(o,s)){let R=`setStore("${o}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return ie(o,R),F()&&$(R),{ok:false,reason:"not-found"}}let a,u={kind:"root"},c=F()?le(o):{has:false,value:void 0},l=c.has?c.value:rr(o,s);if(typeof t=="function"&&r===void 0){let R=M()?Date.now():0;try{let x=E().mutatorProduce,k=!1,A,b=O=>{let j=t(O);return j!==void 0&&(k=!0,A=j),j},C=x?x(l,b):(()=>{let O=V(l);return b(O),O})();if(k&&E().strictMutatorReturns){let O=`setStore("${o}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return ie(o,O),F()&&$(O),{ok:!1,reason:"validate"}}k&&M()&&!E().strictMutatorReturns&&p(`setStore("${o}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=k&&!E().strictMutatorReturns?A:C,u={kind:"root"};}catch(x){return ie(o,`Mutator for "${o}" failed: ${x?.message??x}`),F()&&$(x),{ok:false,reason:"validate"}}finally{R&&Vn(o,Date.now()-R);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!Ce(t))return F()&&$(`setStore("${o}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof l!="object"||l===null||Array.isArray(l))return L(`setStore("${o}", data) only merges into object stores.
|
|
14
|
-
Use setStore("${o}", "path", value) or recreate the store with an object shape.`),F()&&$(`setStore("${o}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let R=be(o,t);if(!R.ok)return F()&&$(`setStore("${o}") failed sanitize`),{ok:false,reason:"validate"};a={...l,...R.value},u={kind:"merge",value:R.value};}else if(typeof t=="string"||Array.isArray(t)){if(!zt(t))return F()&&$(`setStore("${o}") received invalid path`),{ok:false,reason:"invalid-args"};let R=be(o,r);if(!R.ok)return F()&&$(`setStore("${o}") failed sanitize`),{ok:false,reason:"validate"};let x=R.value,k=Rn(o,l,t,x);if(!k.ok)return J(i[o]?.options?.onError,`onError(${o})`,k.reason??`Invalid path for "${o}".`),F()&&$(k.reason),{ok:false,reason:"path"};a=Wt(l,t,x),u={kind:"path",path:t,value:x};}else {let R=`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 L(R),J(i[o]?.options?.onError,`onError(${o})`,R),F()&&$(R),{ok:false,reason:"invalid-args"}}if(!Ce(a))return F()&&$(`setStore("${o}") produced invalid data`),{ok:false,reason:"validate"};let w=i[o]?.options?.validate,g=In(),v=An(o,{action:"set",prev:l,next:a,path:t,correlationId:g?.correlationId,traceContext:g?.traceContext});if(v===rt)return F()&&$(`setStore("${o}") aborted by middleware`),{ok:false,reason:"middleware"};let d=Object.is(v,a),m=Ye(o,v,w,void 0,d?{reuseInput:true}:void 0);if(!m.ok)return F()&&$(`setStore("${o}") failed validation`),{ok:false,reason:"validate"};let S=en({store:o,intent:u,committedValue:m.value,preserveIntent:u.kind!=="root"&&Object.is(v,a)&&Object.is(m.value,v),context:g});try{if(_t(l,m.value))return {ok:!0}}catch{}return St(s,{name:o,prev:l,next:m.value,action:"set",hookLabel:"onSet",logMessage:`Store "${o}" updated`,context:g,runtimePatches:S}),{ok:true}};function ht(e){let t=ft(e);if(!yn(t))return {ok:false,reason:"not-found"};let r=P();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 Q(t,c),F()&&$(c),{ok:false,reason:"lazy-uninitialized"}}if(!gt(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 Q(t,c),F()&&$(c),{ok:false,reason:"not-found"}}let o=F()?le(t):{has:false,value:void 0},s=o.has?o.value:r.stores[t],i=typeof performance<"u"&&performance.now?performance.now():Date.now(),a=V(r.initialStates[t]),u=(typeof performance<"u"&&performance.now?performance.now():Date.now())-i;return St(r,{name:t,prev:s,next:a,action:"reset",hookLabel:"onReset",logMessage:`Store "${t}" reset to initial state/value`,metricsUpdate:{resetElapsedMs:u},runtimePatches:[Gt({store:t,value:a,source:"resetStore"})]}),{ok:true}}var bt=()=>{fr();};var jn=e=>({name:e});var as=()=>P().computedCleanups,$n=new WeakMap;var cs=e=>{let t=$n.get(e);return t||(t=new Map,$n.set(e,t)),t};var _n=e=>{let t=as(),r=t.get(e);if(!r){M()&&p(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var zn=(e,t=P())=>cs(t).get(e)?.autoDispose===true;var Wn=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,m)=>{he(m,{onError:s[d]?.options?.onError,severity:"warn",visibility:"dev"});},l=({name:d,prev:m,options:S,initialState:R,getMeta:x,getStoreValue:k,hasStore:A})=>({name:d,options:S,prev:m,getMeta:x,getStoreValue:k,getAllStores:()=>t,getInitialState:()=>R,hasStore:A,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:b=>{he(b,{onError:S.onError,severity:"warn",visibility:"dev"});},warn:p,warnAlways:G,log:B,hashState:ze,deepClone:V,sanitize:ge,validate:()=>({ok:true,value:m}),isDev:M}),h=({name:d,prev:m,options:S,initialState:R,phase:x})=>{let k=l({name:d,prev:m,options:S,initialState:R,getMeta:()=>s[d],getStoreValue:()=>t[d],hasStore:()=>pe(e,d)}),A=l({name:d,prev:m,options:S,initialState:R,getMeta:()=>{},getStoreValue:()=>m,hasStore:()=>false});ve().forEach(b=>{let C=a.get(b);x==="before"?C?.beforeStoreDelete?.(k):C?.afterStoreDelete?.(A);});},w=d=>{if(!pe(e,d))return;let m=t[d],S=s[d].options,R=n[d],x=r[d];u.add(d);try{x?.forEach(b=>{try{b(null);}catch(C){p(`Subscriber for "${d}" threw during delete: ${C?.message??C}`);}}),nt({name:d,label:"onDelete",fn:S.onDelete,args:[m],reportIssue:(b,C)=>{he(b,{onError:S.onError,severity:"warn",visibility:C});}}),h({name:d,prev:m,options:S,initialState:R,phase:"before"}),delete t[d],delete r[d],delete n[d],delete o[d],delete s[d],delete i[d],Jr(d)&&_n(d);let A=e.computedDependents[d];if(A)for(let b of [...A]){let C=qt(b);if(C&&zn(b,e)&&C.deps.every(O=>!pe(e,O))){w(b);continue}p(`[stroid] source store "${d}" was deleted. Computed store "${b}" depends on it and will return stale data. Call deleteComputed("${b}") to clean up.`);}h({name:d,prev:m,options:S,initialState:R,phase:"after"}),Be("afterStoreDelete",d,{type:"afterStoreDelete",prev:m}),Ze(e,{type:"deleted",name:d}),B(`Store "${d}" deleted`);}finally{u.delete(d);}};return {deleteExistingStore:w,clearAllStores:()=>{let d=[],S=0,R=Number.POSITIVE_INFINITY;for(;S<20;){let k=Object.keys(t);if(k.length===0)break;k.forEach(b=>{pe(e,b)&&(w(b),d.push(b));}),S+=1;let A=Object.keys(t).length;if(A===0||A>=R)break;R=A;}let x=Object.keys(t).length;return x>0?p(`clearAllStores stopped after ${S} pass${S===1?"":"es"}; ${x} store(s) still registered (likely recreated during deletion).`):B(`All stores cleared (${d.length} stores removed)`),d},clearStores:d=>{let m=Object.keys(t).filter(S=>d?d.endsWith("*")?S.startsWith(d.slice(0,-1)):S===d:true);return m.forEach(S=>w(S)),m},reportStoreError:c}};var ir=Re,Ln=xe(ir),Bn=null,H=()=>{let e=K(Ln);return Mt(e),e};var P=()=>H();var qn=(e,t)=>{Ze(e,t);};function xn(e){Bn=e;}var Ae=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}}}),us=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)}),ls=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)}),Ke=Ae(()=>H().stores);Ae(()=>H().subscribers);var On=Ae(()=>H().initialStates);Ae(()=>H().initialFactories);var I=Ae(()=>H().metaEntries);Ae(()=>H().snapshotCache);var Z=us(()=>H().featureRuntimes),Hn=new WeakMap,ds=e=>{let t=Hn.get(e);return t||(t=Wn(e),Hn.set(e,t)),t};ls(()=>ds(H()));var fs=e=>{let t=Z.get(e);if(t)return t;let r=Je(e);if(!r)return;let n=r();return Z.set(e,n),n},mt=()=>{ve().forEach(e=>{fs(e);});};mt();var se=(e,t)=>pe(t??H(),e),rr=(e,t=H())=>{if(F()){let r=le(e);if(r.has)return r.value}return dn(e,t)},dn=(e,t=H())=>{let r=je();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},te=(e,t,r=H())=>{r.stores[e]=t;},Nn=(e,t,r=Date.now())=>{te(e,t),I[e]&&(I[e].updatedAt=new Date(r).toISOString(),I[e].updatedAtMs=r,I[e].lastCorrelationId=null,I[e].lastCorrelationAt=null,I[e].lastCorrelationAtMs=null,I[e].lastTraceContext=null,I[e].updateCount>=Number.MAX_SAFE_INTEGER?I[e].updateCount=0:I[e].updateCount+=1,Bn?.(e));};var ps=()=>{wr(H());},gs=()=>{Z.forEach(e=>{try{e.resetAll?.();}catch{}}),Z.clear();};T("features.reset",gs,10);T("registries.clear",ps,20);T("registry.default",()=>{ir=Re,Ln=xe(ir);},115);var hn=e=>br(H(),e);var wt=new Set,ys=e=>{wt.clear();};T("store-create.ssr-global-warned",()=>ys(),65);function Un(e,t,r={}){if(F()){let b=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;Ue(b,r.onError),$(b);return}if(!Vt(e)){Ue(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Ce(t)){Ue(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&M()&&p(`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.`),Br(r).forEach(b=>{p(b);});let o=Pn(e,qr(r,e,E().defaultSnapshotMode));if(o.scope==="temp"&&r.persist){let b=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;J(o.onError,`onError(${e})`,b),M()||G(b),L(b);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",u=o.allowSSRGlobalStore??false,c=P(),l=c.stores,h=c.subscribers,w=c.initialStates,g=c.initialFactories,v=c.metaEntries,d=c.scope==="request";if(a&&!u&&!d){let b=`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.`;Ue(b,r.onError);return}if(a&&u&&!d&&!wt.has(e)&&(wt.add(e),G(`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.`)),se(e,c)){let b=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return Q(e,b),{name:e}}s&&!u&&!d&&!pn(e)&&M()&&(gn(e),p(`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 m=be(e,t,o.onError);if(!m.ok)return;let S=m.value,R=o.lazy===true&&typeof t=="function",x=(h[e]?.size??0)>0;if(R)l[e]=void 0,g[e]=t;else {let b=Ye(e,S,o.validate,o.onError);if(!b.ok)return;te(e,b.value,c),w[e]=V(b.value);}let k=Date.now(),A=new Date(k).toISOString();return v[e]={createdAt:A,updatedAt:A,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},ee(e),En(e,Ee),yt(e,"onCreate",v[e].options.onCreate,[S]),qn(c,{type:"created",name:e,isGlobal:o.scope==="global",isTemp:o.scope==="temp"}),x&&Ee(e),B(`Store "${e}" created -> ${JSON.stringify(S)}`),{name:e}}var ar=()=>K().async;var Gn=()=>ar().storeCleanups;var Kn=e=>{e&&Array.from(e).forEach(t=>{try{t();}catch{}});};var ms=(e,t)=>{Object.keys(t).length===0&&delete Gn()[e];},Ss=(e,t)=>{{Kn(e[t]),delete e[t];return}};var Yn=e=>{let t=Gn();Object.entries(t).forEach(([r,n])=>{n[e]&&(Ss(n,e),ms(r,n));});};var Xn=()=>{Qe(ar());};var cr=()=>{hs(),Xn();},hs=()=>{Yn("revalidate");};var $u=(e="mock",t={})=>{let r=jn(e);return Un(e,t),{set:n=>typeof n=="function"?Fe(r,n):Fe(r,n),reset:()=>ht(r),use:()=>r}},_u=(e,t)=>{let r=Date.now;Object.defineProperty(Date,"now",{value:()=>e,configurable:true});try{return t()}finally{Object.defineProperty(Date,"now",{value:r,configurable:true});}},zu=()=>{bt(),cr();},Wu=(e,t=1e3,r=n=>({value:n}))=>{let n=typeof performance<"u"&&performance.now?performance.now():Date.now();for(let i=0;i<t;i++)Fe(e,r(i));let s=(typeof performance<"u"&&performance.now?performance.now():Date.now())-n;return {iterations:t,totalMs:s,avgMs:s/t}};export{Wu as benchmarkStoreSet,$u as createMockStore,zu as resetAllStoresForTest,_u as withMockedTime};//# sourceMappingURL=testing.js.map
|
|
1
|
+
import'./chunk-YU5GMPCC.js';import {e}from'./chunk-BW32TJGE.js';import'./chunk-6ELWGQ4Q.js';import {P,K,sa,U,ta}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';var D=(o="mock",t={})=>{let e=P(o);return K(o,t),{set:r=>typeof r=="function"?U(e,r):U(e,r),reset:()=>sa(e),use:()=>e}},N=(o,t)=>{let e=Date.now;Object.defineProperty(Date,"now",{value:()=>o,configurable:true});try{return t()}finally{Object.defineProperty(Date,"now",{value:e,configurable:true});}},g=()=>{ta(),e();},x=(o,t=1e3,e=r=>({value:r}))=>{let r=typeof performance<"u"&&performance.now?performance.now():Date.now();for(let a=0;a<t;a++)U(o,e(a));let s=(typeof performance<"u"&&performance.now?performance.now():Date.now())-r;return {iterations:t,totalMs:s,avgMs:s/t}};export{x as benchmarkStoreSet,D as createMockStore,g as resetAllStoresForTest,N as withMockedTime};//# sourceMappingURL=testing.js.map
|
|
23
2
|
//# sourceMappingURL=testing.js.map
|