stroid 0.1.4-beta.0 → 0.1.5
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 +427 -288
- package/README.md +1125 -118
- package/dist/async-internal.d.ts +30 -0
- package/dist/async.d.ts +7 -12
- package/dist/async.js +1 -33
- package/dist/chunk-4C666HHU.js +2 -0
- package/dist/chunk-4D6OA3DD.js +2 -0
- package/dist/chunk-6IBJ7CIK.js +14 -0
- package/dist/chunk-BWNLQKTY.js +2 -0
- package/dist/chunk-E33L4MII.js +2 -0
- package/dist/chunk-FSNVSMAV.js +2 -0
- package/dist/chunk-GZQGU64H.js +2 -0
- package/dist/chunk-LWUT37FW.js +13 -0
- package/dist/chunk-NFT6AZXY.js +2 -0
- package/dist/chunk-PHE2BCFG.js +2 -0
- package/dist/chunk-SF6EP56S.js +2 -0
- package/dist/chunk-WE3ZR6OG.js +2 -0
- package/dist/chunk-WXJ3IREA.js +2 -0
- package/dist/chunk-X2MKRN7O.js +14 -0
- package/dist/chunk-Y54SMROI.js +2 -0
- package/dist/chunk-YU5GMPCC.js +2 -0
- package/dist/computed.d.ts +6 -5
- package/dist/computed.js +1 -12
- package/dist/core-internal.d.ts +23 -0
- package/dist/core.d.ts +3 -2
- package/dist/core.js +1 -22
- package/dist/devtools-internal.d.ts +26 -0
- package/dist/devtools.d.ts +4 -25
- package/dist/devtools.js +1 -1
- package/dist/feature.d.ts +9 -2
- package/dist/feature.js +1 -1
- package/dist/fetch-4RH6MPY3.js +2 -0
- package/dist/graph-D28.d.ts +20 -0
- package/dist/helpers.d.ts +2 -1
- package/dist/helpers.js +1 -22
- package/dist/index-internal.d.ts +19 -19
- package/dist/index.d.cts +40 -22
- package/dist/index.d.ts +40 -22
- package/dist/index.js +1 -35
- package/dist/install.d.ts +16 -4
- package/dist/install.js +1 -1
- package/dist/metrics.d.ts +13 -0
- package/dist/persist.d.ts +3 -1
- package/dist/persist.js +1 -1
- package/dist/psr.d.ts +20 -11
- package/dist/psr.js +1 -18
- package/dist/query.d.ts +17 -0
- package/dist/query.js +2 -0
- package/dist/react/index.d.ts +10 -3
- package/dist/react/index.js +5 -36
- package/dist/registry.d.ts +23 -14
- package/dist/runtime-admin.js +1 -1
- package/dist/runtime-tools.d.ts +38 -65
- package/dist/runtime-tools.js +1 -3
- package/dist/selectors.d.ts +1 -1
- package/dist/selectors.js +1 -1
- package/dist/server/portable.d.ts +27 -0
- package/dist/server/portable.js +2 -0
- package/dist/server.d.ts +9 -19
- package/dist/server.js +1 -12
- package/dist/shared.d.ts +36 -0
- package/dist/store-registry.d.ts +5 -1
- package/dist/sync.d.ts +10 -1
- package/dist/sync.js +1 -1
- package/dist/testing.d.ts +1 -0
- package/dist/testing.js +1 -22
- package/dist/tsdoc-metadata.json +1 -1
- package/dist/types-internal-2.d.ts +168 -0
- package/dist/{computed-types.d.ts → types-internal-3.d.ts} +1 -1
- package/dist/{options.d.ts → types-internal.d.ts} +26 -10
- package/dist/types.d.ts +12 -2
- package/package.json +111 -44
- package/dist/computed-types.js +0 -2
package/dist/selectors.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var lt=new Map;var Se=e=>lt.get(e),Q=()=>Array.from(lt.keys());var ft=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),pt=()=>({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:ft(),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}}),gt=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(n=>{try{n();}catch{}});});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.storeCleanups).forEach(t=>delete e.storeCleanups[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),ft().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 ur=new Map,M=(e,t,r=0)=>{!e||typeof t!="function"||ur.set(e,{name:e,order:r,fn:t});};var Ae=new Map,yt=new WeakSet,Ie=e=>{yt.has(e)||(yt.add(e),Q().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Se(t);r&&e.featureRuntimes.set(t,r());}}));},lr=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,mt,Pe=e=>(mt||lr||e).replace(/\.ts(\?|$)/,".js$1"),Z=Pe("stroid:default-registry");var dr=()=>{mt=void 0,Ae.clear();};M("registry.scope-override",dr,110);var fr=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),pr=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;},ht=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,runtimePatches:[],failed:false,error:void 0}),gr=(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:ht(),async:pt(),notify:fr(),lifecycleListener:null};return Ie(t),t},ee=e=>{let t=Pe(e),r=Ae.get(t);if(r)return r;let n=gr();return Ae.set(t,n),n},K=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var St=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,pr(e.notify),gt(e.async),e.lifecycleListener=null;};var Ve=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var be=()=>null,H=[],Rt={run:(e,t)=>{H.push(e);try{return t()}finally{H.pop();}},get:()=>H.length>0?H[H.length-1]:null,enterWith:e=>{if(H.length>0){H[H.length-1]=e;return}H.push(e);}};var B=e=>(Rt).get()||e||ee(Z);var mr={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}`));}},wt={logSink:mr,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},We=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}),$e=new WeakMap,Ct=We(wt),hr=e=>{let t=$e.get(e);return t||(t=We(Ct),$e.set(e,t)),t};var T=()=>hr(B());var wr=()=>{$e=new WeakMap,Ct=We(wt);};M("config.reset",wr,90);var Cr=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,kr=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,kt=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,xr="production",Mr=Cr??kr??xr,Re=typeof kt=="boolean"?kt:Mr!=="production",v=()=>Re,xt=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Tr=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},vr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},we=(e,t)=>{if((T().logSink.critical??Tr)(e,t),T().assertRuntime)throw new Error(e)},m=(e,t)=>{if(!Re)return;if((T().logSink.warn??xt)(e,t),T().assertRuntime)throw new Error(e)},te=(e,t)=>{if((T().logSink.warn??xt)(e,t),T().assertRuntime)throw new Error(e)};var re=(e,t)=>{if(!Re)return;(T().logSink.log??vr)(e,t);};var Mt=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Tt=()=>"Map detected; converting to plain object.",vt=()=>"Set detected; converting to array.";var Et=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,Ft=e=>`Cannot go deeper at "${e}" - value is not an object`;var ne=new Set(["__proto__","constructor","prototype"]);var Ot=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,Er=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 pe=(e,t)=>{let r=Er(e);if(r)throw new Error(`${r} values are not supported`);let n=Ot(e);if(n==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(n==="bigint")throw new Error("BigInt values are not supported");if(n==="symbol")throw new Error("Symbol values are not supported");if(n==="date")return v()&&m(Mt()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),v()&&m(Tt());let o={};for(let[s,p]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");o[String(s)]=pe(p,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),v()&&m(vt()),Array.from(e,o=>pe(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[p,g]of Object.entries(s))if(g.enumerable&&!ne.has(p)){if("get"in g||"set"in g)throw new Error(`Accessor properties are not supported during sanitize ("${p}")`);o[p]=pe(g.value,t);}return o}if(n==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(o=>pe(o,t))}return e},ze=e=>pe(e,new WeakSet);var He=null,Fr=()=>{if(He)return He;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 He=t,t},Nt=e=>{let t=Fr(),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},jr=2166136261,Or=2654435761,Dr=1e5,q=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},Y=(e,t)=>{q(e,t.length);for(let r=0;r<t.length;r++)q(e,t.charCodeAt(r));},C=(e,t)=>{Y(e,t);},Dt=(e,t)=>{if(Number.isNaN(t)){C(e,"NaN");return}if(!Number.isFinite(t)){C(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){C(e,"-0");return}let r=t|0;if(t===r){C(e,"int"),q(e,r);return}C(e,"num"),Y(e,String(t));},oe=(e,t)=>{if(e.nodes++>Dr){C(e,"[max]");return}if(t===null){C(e,"null");return}let r=typeof t;if(r==="string"){C(e,"string"),Y(e,t);return}if(r==="number"){C(e,"number"),Dt(e,t);return}if(r==="boolean"){C(e,t?"true":"false");return}if(r==="undefined"){C(e,"undefined");return}if(r==="bigint"){C(e,"bigint"),Y(e,t.toString());return}if(r==="symbol"){C(e,"symbol");let l=t;Y(e,Symbol.keyFor(l)??l.description??String(l));return}if(r==="function"){C(e,"function"),Y(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){C(e,"ref"),q(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){C(e,"array"),q(e,n.length);for(let l=0;l<n.length;l++)Object.prototype.hasOwnProperty.call(n,l)?oe(e,n[l]):C(e,"hole");return}if(n instanceof Date){C(e,"date"),Dt(e,n.getTime());return}if(n instanceof Map){C(e,"map"),q(e,n.size),n.forEach((l,a)=>{oe(e,a),oe(e,l);});return}if(n instanceof Set){C(e,"set"),q(e,n.size),n.forEach(l=>{oe(e,l);});return}C(e,"object");let p=Object.getOwnPropertyDescriptors(n),g=[];Object.entries(p).forEach(([l,a])=>{a?.enumerable&&(ne.has(l)||"get"in a||"set"in a||g.push([l,a]));}),q(e,g.length);for(let[l,a]of g)Y(e,l),oe(e,a.value);},Le=e=>{if(typeof e=="string")return Nt(JSON.stringify(e));let t={h1:jr,h2:Or,seen:new WeakMap,nextId:1,nodes:0};oe(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 Nr=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",ge=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&&(ne.has(n)||"get"in o||"set"in o||(t[n]=o.value));}),t},Be=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},Ar=e=>Be(e)===null,Ir=e=>{let t=Be(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},J=(e,t=new WeakMap)=>{if(Ir(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,p)=>{o.set(J(p,t),J(s,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(s=>{o.add(J(s,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((s,p)=>{o[p]=J(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||ne.has(o)||"get"in s||"set"in s||(r[o]=J(s.value,t));}),r},I=e=>{if(Nr)try{return structuredClone(e)}catch(t){if(!Ar(e)){let r=Be(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return m(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),J(e)}return J(e)};var Pr=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},At=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?Pr(e):[String(e)];var Ce=(e,t)=>{let r=At(t),n=e;for(let o of r){if(n==null){m(Et(r,o));return}if(typeof n!="object"){m(Ft(o));return}n=n[o];}return n};var It=({name:e,label:t,fn:r,args:n,reportIssue:o})=>{if(typeof r=="function")try{r(...n);}catch(s){let p=`${t} for "${e}" failed: ${s?.message??s}`;o(p,"always");}};var Vr=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(n){let o=n?.message??n;te(`${t} callback threw: ${String(o)}`);}},ke=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(Vr(o,"onError",e),r==="critical"){n==="dev"&&m(e),we(e);return}if(n==="always"){te(e);return}m(e);};M("computed.order-resolver",()=>{},105);var _t=()=>B(ee(Z));var qe=()=>_t().computedEntries,$t=()=>_t().computedDependents;var Wt=e=>Object.prototype.hasOwnProperty.call(qe(),e);var Ue=e=>{let t=qe()[e];if(!t)return null;let r=$t()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Me=null;var $r=()=>{Me=null;};M("transaction.runner",$r,120);var zt=e=>{let t=Me?.get();return t||(e??B()).transaction};var Te=()=>Me?(Me.get()?.depth??0)>0:zt().depth>0;var Ht=e=>{let t=zt();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Bt=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")},ye=e=>(Bt(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),ve=e=>{if(!Bt(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 Ee=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},se=(e,t)=>{if(t==="ref"){if(!v())return e;try{return ye(e)}catch{return e}}if(t==="shallow"){let n=ge(e);if(!v())return n;try{return ye(n)}catch{return n}}let r=I(e);if(!v())return r;try{return ve(r)}catch{return r}};var Gt=new Map;var he=(e,t,r)=>{let n=Gt.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 Wr=()=>{};M("write-context.runner",Wr,121);var je=(e,t)=>{if(!(!e||typeof e!="object")){if(t==="ref"||t==="shallow"){ye(e);return}t==="deep"&&ve(e);}};var Lr=(e,t)=>{if(!Xt(e))return null;let r=P();Qt(e,r);let n=Ee(r.metaEntries[e],T().defaultSnapshotMode);if(Te()){let l=r.transaction.snapshotCache,a=tt(e);if(a===void 0)return null;let u=l.get(e);if(u&&u.source===a&&u.mode===n){let f=u.snapshot;return je(f,n),f}let y=se(a,n);return l.set(e,{source:a,snapshot:y,mode:n}),je(y,n),y}let o=r.notify.flushId,s=tt(e,r),p=r.snapshotCache[e];if(p&&p.source===s&&p.mode===n){let l=p.snapshot;return je(l,n),l}let g=se(s,n);return je(g,n),r.snapshotCache[e]={version:o,snapshot:g,source:s,mode:n},g},Jt=e=>Lr(e);var Br=()=>{let e=P().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};M("notify.reset",Br,40);var qr=()=>P().computedCleanups,Zt=new WeakMap;var Ur=e=>{let t=Zt.get(e);return t||(t=new Map,Zt.set(e,t)),t};var er=e=>{let t=qr(),r=t.get(e);if(!r){v()&&m(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var tr=(e,t=P())=>Ur(t).get(e)?.autoDispose===true;var rr=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,s=e.metaEntries,p=e.snapshotCache,g=e.featureRuntimes,l=e.deletingStores,a=(c,R)=>{ke(R,{onError:s[c]?.options?.onError,severity:"warn",visibility:"dev"});},u=({name:c,prev:R,options:b,initialState:E,getMeta:V,getStoreValue:$,hasStore:O})=>({name:c,options:b,prev:R,getMeta:V,getStoreValue:$,getAllStores:()=>t,getInitialState:()=>E,hasStore:O,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:k=>{ke(k,{onError:b.onError,severity:"warn",visibility:"dev"});},warn:m,warnAlways:te,log:re,hashState:Le,deepClone:I,sanitize:ze,validate:()=>({ok:true,value:R}),isDev:v}),y=({name:c,prev:R,options:b,initialState:E,phase:V})=>{let $=u({name:c,prev:R,options:b,initialState:E,getMeta:()=>s[c],getStoreValue:()=>t[c],hasStore:()=>K(e,c)}),O=u({name:c,prev:R,options:b,initialState:E,getMeta:()=>{},getStoreValue:()=>R,hasStore:()=>false});Q().forEach(k=>{let D=g.get(k);V==="before"?D?.beforeStoreDelete?.($):D?.afterStoreDelete?.(O);});},f=c=>{if(!K(e,c))return;let R=t[c],b=s[c].options,E=n[c],V=r[c];l.add(c);try{V?.forEach(k=>{try{k(null);}catch(D){m(`Subscriber for "${c}" threw during delete: ${D?.message??D}`);}}),It({name:c,label:"onDelete",fn:b.onDelete,args:[R],reportIssue:(k,D)=>{ke(k,{onError:b.onError,severity:"warn",visibility:D});}}),y({name:c,prev:R,options:b,initialState:E,phase:"before"}),delete t[c],delete r[c],delete n[c],delete o[c],delete s[c],delete p[c],Wt(c)&&er(c);let O=e.computedDependents[c];if(O)for(let k of [...O]){let D=Ue(k);if(D&&tr(k,e)&&D.deps.every(ce=>!K(e,ce))){f(k);continue}m(`[stroid] source store "${c}" was deleted. Computed store "${k}" depends on it and will return stale data. Call deleteComputed("${k}") to clean up.`);}y({name:c,prev:R,options:b,initialState:E,phase:"after"}),he("afterStoreDelete",c,{type:"afterStoreDelete",prev:R}),Ve(e,{type:"deleted",name:c}),re(`Store "${c}" deleted`);}finally{l.delete(c);}};return {deleteExistingStore:f,clearAllStores:()=>{let c=[],b=0,E=Number.POSITIVE_INFINITY;for(;b<20;){let $=Object.keys(t);if($.length===0)break;$.forEach(k=>{K(e,k)&&(f(k),c.push(k));}),b+=1;let O=Object.keys(t).length;if(O===0||O>=E)break;E=O;}let V=Object.keys(t).length;return V>0?m(`clearAllStores stopped after ${b} pass${b===1?"":"es"}; ${V} store(s) still registered (likely recreated during deletion).`):re(`All stores cleared (${c.length} stores removed)`),c},clearStores:c=>{let R=Object.keys(t).filter(b=>c?c.endsWith("*")?b.startsWith(c.slice(0,-1)):b===c:true);return R.forEach(b=>f(b)),R},reportStoreError:a}};var nt=Z,or=ee(nt);var j=()=>{let e=B(or);return Ie(e),e};var P=()=>j();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}}}),Gr=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)}),Kr=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)});ae(()=>j().stores);ae(()=>j().subscribers);ae(()=>j().initialStates);ae(()=>j().initialFactories);var sr=ae(()=>j().metaEntries);ae(()=>j().snapshotCache);var ie=Gr(()=>j().featureRuntimes),nr=new WeakMap,Yr=e=>{let t=nr.get(e);return t||(t=rr(e),nr.set(e,t)),t};Kr(()=>Yr(j()));var Jr=e=>{let t=ie.get(e);if(t)return t;let r=Se(e);if(!r)return;let n=r();return ie.set(e,n),n},Xr=()=>{Q().forEach(e=>{Jr(e);});};Xr();var Xt=(e,t)=>K(j(),e),tt=(e,t=j())=>{if(Te()){let r=Ht(e);if(r.has)return r.value}return rt(e,t)},rt=(e,t=j())=>{let r=be();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]};var Qt=(e,t=j())=>{let r=t.metaEntries[e];if(!r)return;r.readCount=(r.readCount??0)+1;let n=Date.now();r.lastReadAtMs=n,r.lastReadAt=new Date(n).toISOString();},Qr=()=>{St(j());},Zr=()=>{ie.forEach(e=>{try{e.resetAll?.();}catch{}}),ie.clear();};M("features.reset",Zr,10);M("registries.clear",Qr,20);M("registry.default",()=>{nt=Z,or=ee(nt);},115);var ot=e=>{let t=P();return Object.prototype.hasOwnProperty.call(t.stores,e)},ir=e=>P().stores[e],ar=(e,t)=>{let n=P().subscribers;return n[e]||(n[e]=new Set),n[e].add(t),()=>{n[e]?.delete(t),n[e]?.size===0&&delete n[e];}};var en=(e,t)=>{let r=new WeakMap,n=new WeakMap,o=new Set,s="\0",p=(a,u)=>{if(!a||typeof a!="object")return a;let y=r.get(a);if(y)return y;let f=new Proxy(a,{get(S,h,c){if(typeof h!="string")return Reflect.get(S,h,c);let R=[...u,h],b=Reflect.get(S,h,c);return (!b||typeof b!="object")&&o.add(R.join(s)),p(b,R)}});return n.set(f,u.join(s)),r.set(a,f),f},g=t(p(e,[])),l=(a,u)=>{if(!a||typeof a!="object"||u.has(a))return;u.add(a);let y=n.get(a);if(y){y&&o.add(y);return}for(let f of Object.values(a))l(f,u);};return l(g,new WeakSet),{result:g,deps:Array.from(o,a=>a.split(s))}},tn=(e,t,r)=>r.some(n=>!Object.is(Ce(e,n),Ce(t,n))),Ns=(e,t)=>{let r,n,o=[];return ()=>{let s=ir(e);if(s===void 0)return null;if(s===r)return n??null;if(r!==void 0&&o.length>0&&!tn(r,s,o))return r=s,n??null;let p=T().selectorCloneFrozen,g=s&&typeof s=="object"&&Object.isFrozen(s)&&p?I(s):s,l=en(g,t);return r=s,o=l.deps,n=l.result,n??null}},As=(e,t,r=Object.is,n)=>{if(typeof t!="function"||typeof n!="function")return m(`subscribeWithSelector("${e}") requires selector and listener functions.`),()=>{};let o=false,s,p=()=>{let a=sr[e]?.options?.snapshot;return a==="shallow"||a==="ref"?a:"deep"},g=a=>{let u=a!==void 0?a:Jt(e);if(u===null||typeof u!="object")return u;let y=p();return y==="ref"?u:y==="shallow"?ge(u):I(u)};return ot(e)&&(s=t(g()),o=true),ar(e,a=>{if(a===null||!ot(e)){o=false,s=void 0;return}let u=t(g(a));if(!o){let f=s;o=true,s=u,n(u,f);return}if(!r(u,s)){let f=s;s=u,n(u,f);}})};export{Ns as createSelector,As as subscribeWithSelector};//# sourceMappingURL=selectors.js.map
|
|
1
|
+
export{a as createSelector,b as subscribeWithSelector}from'./chunk-BWNLQKTY.js';import'./chunk-X2MKRN7O.js';import'./chunk-6IBJ7CIK.js';import'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';//# sourceMappingURL=selectors.js.map
|
|
2
2
|
//# sourceMappingURL=selectors.js.map
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { S as StoreRegistry } from '../store-registry.js';
|
|
2
|
+
import { c as StoreStateMap } from '../types.js';
|
|
3
|
+
import { e as RequestStoreName, f as RequestStoreValue, a as RequestSnapshot, b as RequestScopeCapture } from '../shared.js';
|
|
4
|
+
export { c as RequestHydrateOptions, d as RequestScopeOptions } from '../shared.js';
|
|
5
|
+
import { S as StoreOptions } from '../types-internal.js';
|
|
6
|
+
import '../feature.js';
|
|
7
|
+
import '../utility.js';
|
|
8
|
+
import '../types-internal-2.js';
|
|
9
|
+
import '../runtime-patch.js';
|
|
10
|
+
import '../registry.js';
|
|
11
|
+
import '../types-internal-3.js';
|
|
12
|
+
|
|
13
|
+
type RequestScopeApi<StateMap extends StoreStateMap = StoreStateMap> = {
|
|
14
|
+
create: <Name extends RequestStoreName<StateMap>>(name: Name, data: RequestStoreValue<StateMap, Name>, options?: StoreOptions<RequestStoreValue<StateMap, Name>>) => RequestStoreValue<StateMap, Name> | null;
|
|
15
|
+
set: <Name extends RequestStoreName<StateMap>>(name: Name, updater: RequestStoreValue<StateMap, Name> | ((draft: RequestStoreValue<StateMap, Name>) => void)) => RequestStoreValue<StateMap, Name> | null;
|
|
16
|
+
get: <Name extends RequestStoreName<StateMap>>(name: Name) => RequestStoreValue<StateMap, Name> | null;
|
|
17
|
+
snapshot: () => RequestSnapshot<StateMap>;
|
|
18
|
+
capture: () => RequestScopeCapture<StateMap>;
|
|
19
|
+
bind: <Args extends unknown[], Result>(callback: (...args: Args) => Result) => (...args: Args) => Result;
|
|
20
|
+
};
|
|
21
|
+
type RequestScopeContext<StateMap extends StoreStateMap = StoreStateMap> = RequestScopeApi<StateMap> & {
|
|
22
|
+
registry: StoreRegistry;
|
|
23
|
+
run: <T>(fn: (api: RequestScopeApi<StateMap>) => T) => T;
|
|
24
|
+
};
|
|
25
|
+
declare const createRequestScope: <StateMap extends StoreStateMap = StoreStateMap>(initial?: RequestScopeCapture<StateMap>) => RequestScopeContext<StateMap>;
|
|
26
|
+
|
|
27
|
+
export { type RequestScopeApi, RequestScopeCapture, type RequestScopeContext, RequestSnapshot, RequestStoreName, RequestStoreValue, createRequestScope };
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {b,c,a}from'../chunk-WE3ZR6OG.js';import {W,n,w,l}from'../chunk-X2MKRN7O.js';import {y,H}from'../chunk-6IBJ7CIK.js';import'../chunk-PHE2BCFG.js';import'../chunk-4C666HHU.js';var d=l,u=n,g=w,f=s=>s!==null&&(typeof s=="object"||typeof s=="function")&&typeof s.then=="function",V=s=>{let a$1=y("request"),r=0;if(s){let e=b(s);H(a$1,()=>{W(e.snapshot,e.options,{allowTrusted:true});});}let S=()=>b(c(a$1)),i={create:(e,t,n={})=>H(a$1,()=>(d(e,t,a(n)),u(e))),set:(e,t)=>H(a$1,()=>(g(e,t),u(e))),get:e=>H(a$1,()=>u(e)),snapshot:()=>S().snapshot,capture:S,bind:e=>(...t)=>{if(r<=0)throw new Error("Bound request scope callback invoked outside scope.run().");return H(a$1,()=>e(...t))}};return {registry:a$1,...i,run:e=>{r+=1;let t;try{t=H(a$1,()=>e(i));}catch(n){throw r-=1,n}return f(t)?Promise.resolve(t).finally(()=>{r-=1;}):(r-=1,t)}}};export{V as createRequestScope};//# sourceMappingURL=portable.js.map
|
|
2
|
+
//# sourceMappingURL=portable.js.map
|
package/dist/server.d.ts
CHANGED
|
@@ -1,32 +1,22 @@
|
|
|
1
|
-
import { S as StoreOptions } from './options.js';
|
|
2
1
|
import { c as StoreStateMap } from './types.js';
|
|
3
2
|
import { S as StoreRegistry } from './store-registry.js';
|
|
4
|
-
import './
|
|
3
|
+
import { R as RequestStoreApi, a as RequestSnapshot, b as RequestScopeCapture, c as RequestHydrateOptions } from './shared.js';
|
|
4
|
+
export { d as RequestScopeOptions, e as RequestStoreName, f as RequestStoreValue } from './shared.js';
|
|
5
|
+
import './types-internal-2.js';
|
|
5
6
|
import './feature.js';
|
|
7
|
+
import './types-internal.js';
|
|
8
|
+
import './utility.js';
|
|
6
9
|
import './runtime-patch.js';
|
|
7
10
|
import './registry.js';
|
|
8
|
-
import './
|
|
11
|
+
import './types-internal-3.js';
|
|
9
12
|
|
|
10
|
-
type RequestStoreName<StateMap> = keyof StateMap extends never ? string : keyof StateMap & string;
|
|
11
|
-
type RequestStoreValue<StateMap, Name extends RequestStoreName<StateMap>> = Name extends keyof StateMap ? StateMap[Name] : unknown;
|
|
12
|
-
type RequestSnapshot<StateMap> = Partial<{
|
|
13
|
-
[K in RequestStoreName<StateMap>]: RequestStoreValue<StateMap, K>;
|
|
14
|
-
}>;
|
|
15
|
-
type RequestHydrateOptions<StateMap> = Partial<{
|
|
16
|
-
[K in RequestStoreName<StateMap>]: StoreOptions<RequestStoreValue<StateMap, K>>;
|
|
17
|
-
}> & {
|
|
18
|
-
default?: StoreOptions;
|
|
19
|
-
};
|
|
20
|
-
type RequestStoreApi<StateMap extends StoreStateMap = StoreStateMap> = {
|
|
21
|
-
create: <Name extends RequestStoreName<StateMap>>(name: Name, data: RequestStoreValue<StateMap, Name>, options?: StoreOptions<RequestStoreValue<StateMap, Name>>) => RequestStoreValue<StateMap, Name>;
|
|
22
|
-
set: <Name extends RequestStoreName<StateMap>>(name: Name, updater: RequestStoreValue<StateMap, Name> | ((draft: RequestStoreValue<StateMap, Name>) => void)) => RequestStoreValue<StateMap, Name>;
|
|
23
|
-
get: <Name extends RequestStoreName<StateMap>>(name: Name) => RequestStoreValue<StateMap, Name> | undefined;
|
|
24
|
-
};
|
|
25
13
|
type RequestStoreContext<StateMap extends StoreStateMap> = {
|
|
26
14
|
registry: StoreRegistry;
|
|
27
15
|
snapshot: () => RequestSnapshot<StateMap>;
|
|
16
|
+
capture: () => RequestScopeCapture<StateMap>;
|
|
28
17
|
hydrate: <T>(renderFn: () => T, options?: RequestHydrateOptions<StateMap>) => T;
|
|
18
|
+
bind: <Args extends unknown[], Result>(callback: (...args: Args) => Result) => (...args: Args) => Result;
|
|
29
19
|
};
|
|
30
20
|
declare const createStoreForRequest: <StateMap extends StoreStateMap = StoreStateMap>(initializer?: (api: RequestStoreApi<StateMap>) => void) => RequestStoreContext<StateMap>;
|
|
31
21
|
|
|
32
|
-
export {
|
|
22
|
+
export { RequestHydrateOptions, RequestScopeCapture, RequestSnapshot, RequestStoreApi, StoreRegistry, createStoreForRequest };
|
package/dist/server.js
CHANGED
|
@@ -1,13 +1,2 @@
|
|
|
1
|
-
import {AsyncLocalStorage}from'async_hooks';var
|
|
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 {d,c as c$1,b}from'./chunk-WE3ZR6OG.js';import {L,s,W,R,Q}from'./chunk-X2MKRN7O.js';import {E as E$1,G,y as y$1,V,J}from'./chunk-6IBJ7CIK.js';import'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';import {AsyncLocalStorage}from'async_hooks';var f=new AsyncLocalStorage,y=new AsyncLocalStorage,C=new AsyncLocalStorage,A=new AsyncLocalStorage,c=new WeakMap,H=e=>e!==null&&(typeof e=="object"||typeof e=="function")&&typeof e.then=="function",h=(e,t,r)=>{if(!e)return r();let s=c.has(e),a=c.get(e);c.set(e,t);let n=()=>{if(s&&a){c.set(e,a);return}c.delete(e);};try{let p=r();return H(p)?Promise.resolve(p).finally(n):(n(),p)}catch(p){throw n(),p}};E$1({run:(e,t)=>h(y.getStore()??null,e,()=>f.run(e,t)),get:()=>{let e=y.getStore();return e?c.has(e)?c.get(e)??null:null:f.getStore()||null}});G({run:(e,t)=>y.run(e,t),get:()=>y.getStore()||null,enterWith:e=>y.enterWith(e)});L({run:(e,t)=>C.run(e,t),get:()=>C.getStore()||null,enterWith:e=>C.enterWith(e)});s({run:(e,t)=>A.run(e,t),get:()=>A.getStore()||null});var E=e=>{Object.keys(e).forEach(t=>{delete e[t];});},I=(e,t)=>{let r=J().flush.chunkDelayMs,s=n=>{if(r>0&&typeof setTimeout=="function"){setTimeout(n,r);return}if(typeof queueMicrotask=="function"){queueMicrotask(n);return}Promise.resolve().then(n);},a=()=>{let n=e.notify;if(!n.isFlushing&&!n.notifyScheduled&&n.pendingNotifications.size===0){E(t);return}s(a);};s(a);},N=(e,t,r)=>{Q(e),r(t),I(e,t);},B=async(e,t,r)=>{await R(e),r(t),I(e,t);},X=e=>{let t=y$1("request"),r={},s=Object.create(null),a=0,n=i=>{Object.keys(r).forEach(o=>{delete r[o];}),Object.keys(s).forEach(o=>{delete s[o];}),Object.entries(i.snapshot).forEach(([o,u])=>{r[o]=V(u);}),Object.entries(i.options).forEach(([o,u])=>{u!==void 0&&(s[o]=u);});},p=i=>{n(c$1(t,i));},P=d({buffer:r,bufferedOptions:s});return typeof e=="function"&&e(P),{registry:t,snapshot:()=>b({snapshot:r,options:s}).snapshot,capture:()=>{let i=c.get(t)??null;return i?c$1(t,i):b({snapshot:r,options:s})},hydrate:(i,o={})=>{let u={...o,default:o.default};return Object.keys(r).forEach(S=>{let l=S,W={...o.default||{},...o[l]||{},...s[S]||{}};u[l]=W;}),y.run(t,()=>f.run(V(r),()=>{a+=1;let S=f.getStore();if(!S)try{return W(r,u,{allowTrusted:!0}),i()}finally{a-=1;}return h(t,S,()=>{W(r,u,{allowTrusted:!0});try{let l=i();if(H(l))return Promise.resolve(l).finally(async()=>{try{await B(t,S,p);}finally{a-=1;}});try{return N(t,S,p),l}finally{a-=1;}}catch(l){try{throw N(t,S,p),l}finally{a-=1;}}})}))},bind:i=>(...o)=>{if(a<=0)throw new Error("Bound request callback invoked outside request lifecycle.");return y.run(t,()=>{let u=c.get(t);if(!u)throw new Error("Bound request callback missing active request carrier.");return h(t,u,()=>f.run(u,()=>i(...o)))})}}};export{X as createStoreForRequest};//# sourceMappingURL=server.js.map
|
|
13
2
|
//# sourceMappingURL=server.js.map
|
package/dist/shared.d.ts
ADDED
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { S as StoreOptions } from './types-internal.js';
|
|
2
|
+
import { c as StoreStateMap } from './types.js';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* @module server/shared
|
|
6
|
+
*
|
|
7
|
+
* LAYER: SSR
|
|
8
|
+
* OWNS: Shared request-scope types and capture helpers.
|
|
9
|
+
*
|
|
10
|
+
* Consumers: Node SSR and explicit portable request-scope adapters.
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
type RequestStoreName<StateMap> = keyof StateMap extends never ? string : keyof StateMap & string;
|
|
14
|
+
type RequestStoreValue<StateMap, Name extends RequestStoreName<StateMap>> = Name extends keyof StateMap ? StateMap[Name] : unknown;
|
|
15
|
+
|
|
16
|
+
type RequestSnapshot<StateMap extends StoreStateMap = StoreStateMap> = Partial<{
|
|
17
|
+
[K in RequestStoreName<StateMap>]: RequestStoreValue<StateMap, K>;
|
|
18
|
+
}>;
|
|
19
|
+
type RequestScopeOptions<StateMap extends StoreStateMap = StoreStateMap> = Partial<{
|
|
20
|
+
[K in RequestStoreName<StateMap>]: StoreOptions<RequestStoreValue<StateMap, K>>;
|
|
21
|
+
}>;
|
|
22
|
+
type RequestHydrateOptions<StateMap extends StoreStateMap = StoreStateMap> = RequestScopeOptions<StateMap> & {
|
|
23
|
+
default?: StoreOptions;
|
|
24
|
+
};
|
|
25
|
+
type RequestScopeCapture<StateMap extends StoreStateMap = StoreStateMap> = {
|
|
26
|
+
snapshot: RequestSnapshot<StateMap>;
|
|
27
|
+
options: RequestScopeOptions<StateMap>;
|
|
28
|
+
};
|
|
29
|
+
type RequestStoreApi<StateMap extends StoreStateMap = StoreStateMap> = {
|
|
30
|
+
create: <Name extends RequestStoreName<StateMap>>(name: Name, data: RequestStoreValue<StateMap, Name>, options?: StoreOptions<RequestStoreValue<StateMap, Name>>) => RequestStoreValue<StateMap, Name>;
|
|
31
|
+
set: <Name extends RequestStoreName<StateMap>>(name: Name, updater: RequestStoreValue<StateMap, Name> | ((draft: RequestStoreValue<StateMap, Name>) => void)) => RequestStoreValue<StateMap, Name>;
|
|
32
|
+
get: <Name extends RequestStoreName<StateMap>>(name: Name) => RequestStoreValue<StateMap, Name> | undefined;
|
|
33
|
+
snapshot: () => RequestSnapshot<StateMap>;
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
export type { RequestStoreApi as R, RequestSnapshot as a, RequestScopeCapture as b, RequestHydrateOptions as c, RequestScopeOptions as d, RequestStoreName as e, RequestStoreValue as f };
|
package/dist/store-registry.d.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { StoreFeatureMeta, FeatureName, StoreFeatureRuntime } from './feature.js';
|
|
2
2
|
import { R as RuntimePatch } from './runtime-patch.js';
|
|
3
3
|
import { A as AsyncRegistry } from './registry.js';
|
|
4
|
-
import { ComputedClassification } from './
|
|
4
|
+
import { C as ComputedClassification } from './types-internal-3.js';
|
|
5
|
+
import { h as HydrationRuntimeState } from './types-internal-2.js';
|
|
5
6
|
|
|
6
7
|
/**
|
|
7
8
|
* @module store-registry
|
|
@@ -50,6 +51,8 @@ type ComputedEntry = {
|
|
|
50
51
|
compute: (...args: unknown[]) => unknown;
|
|
51
52
|
stale: boolean;
|
|
52
53
|
classification: ComputedClassification;
|
|
54
|
+
hasLastOutput: boolean;
|
|
55
|
+
lastOutput: unknown;
|
|
53
56
|
};
|
|
54
57
|
type NotifyState = {
|
|
55
58
|
pendingNotifications: Set<string>;
|
|
@@ -78,6 +81,7 @@ type StoreRegistry = {
|
|
|
78
81
|
lastRuntimePatches: RuntimePatch[];
|
|
79
82
|
transaction: TransactionState;
|
|
80
83
|
async: AsyncRegistry;
|
|
84
|
+
hydration: HydrationRuntimeState;
|
|
81
85
|
notify: NotifyState;
|
|
82
86
|
lifecycleListener: StoreLifecycleListener | null;
|
|
83
87
|
};
|
package/dist/sync.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{a as installSync}from'./chunk-GZQGU64H.js';import'./chunk-4D6OA3DD.js';import'./chunk-X2MKRN7O.js';import'./chunk-6IBJ7CIK.js';import'./chunk-PHE2BCFG.js';import'./chunk-4C666HHU.js';//# sourceMappingURL=sync.js.map
|
|
2
2
|
//# sourceMappingURL=sync.js.map
|
package/dist/testing.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { a as StoreDefinition, b as StoreKey, P as PartialDeep, W as WriteResult } from './types.js';
|
|
2
|
+
import './types-internal-2.js';
|
|
2
3
|
|
|
3
4
|
declare const createMockStore: <Name extends string, State extends Record<string, unknown> = Record<string, unknown>>(name?: Name, initial?: State) => {
|
|
4
5
|
set: (update: PartialDeep<State> | ((draft: State) => void)) => WriteResult;
|