stroid 0.1.0 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +232 -108
- package/README.md +157 -577
- package/dist/async.d.ts +5 -3
- package/dist/async.js +28 -23
- package/dist/async.js.map +1 -0
- package/dist/cache.d.ts +12 -0
- package/dist/computed.d.ts +19 -8
- package/dist/computed.js +12 -10
- package/dist/computed.js.map +1 -0
- package/dist/core.d.ts +5 -5
- package/dist/core.js +16 -23
- package/dist/core.js.map +1 -0
- package/dist/devtools.d.ts +12 -1
- package/dist/devtools.js +2 -1
- package/dist/devtools.js.map +1 -0
- package/dist/feature.d.ts +92 -0
- package/dist/feature.js +2 -0
- package/dist/feature.js.map +1 -0
- package/dist/helpers.d.ts +13 -5
- package/dist/helpers.js +16 -13
- package/dist/helpers.js.map +1 -0
- package/dist/index-internal.d.ts +44 -0
- package/dist/index.d.cts +91 -52
- package/dist/index.d.ts +91 -52
- package/dist/index.js +27 -21
- package/dist/index.js.map +1 -0
- package/dist/install.d.ts +6 -0
- package/dist/install.js +2 -0
- package/dist/install.js.map +1 -0
- package/dist/{options-CB35e3Xo.d.cts → options.d.ts} +52 -2
- package/dist/persist.d.ts +1 -2
- package/dist/persist.js +2 -1
- package/dist/persist.js.map +1 -0
- package/dist/{react.d.cts → react/index.d.ts} +28 -10
- package/dist/react/index.js +38 -0
- package/dist/react/index.js.map +1 -0
- package/dist/registry.d.ts +117 -0
- package/dist/runtime-admin.js +2 -1
- package/dist/runtime-admin.js.map +1 -0
- package/dist/runtime-tools.d.ts +44 -17
- package/dist/runtime-tools.js +3 -2
- package/dist/runtime-tools.js.map +1 -0
- package/dist/selectors.js +2 -1
- package/dist/selectors.js.map +1 -0
- package/dist/server.d.ts +27 -11
- package/dist/server.js +12 -9
- package/dist/server.js.map +1 -0
- package/dist/store-registry.d.ts +80 -0
- package/dist/sync.d.ts +1 -2
- package/dist/sync.js +2 -1
- package/dist/sync.js.map +1 -0
- package/dist/testing.d.ts +1 -1
- package/dist/testing.js +16 -13
- package/dist/testing.js.map +1 -0
- package/dist/tsdoc-metadata.json +11 -0
- package/dist/types/adapters/options.d.ts +90 -2
- package/dist/types/async/cache.d.ts +39 -0
- package/dist/types/async/clone.d.ts +9 -1
- package/dist/types/{async-fetch.d.ts → async/fetch.d.ts} +2 -2
- package/dist/types/async/inflight.d.ts +1 -1
- package/dist/types/{async-registry.d.ts → async/registry.d.ts} +25 -5
- package/dist/types/async/request.d.ts +9 -1
- package/dist/types/async.d.ts +10 -2
- package/dist/types/{computed-graph.d.ts → computed/computed-graph.d.ts} +4 -6
- package/dist/types/{computed.d.ts → computed/index.d.ts} +3 -2
- package/dist/types/config.d.ts +9 -1
- package/dist/types/core/index.d.ts +11 -0
- package/dist/types/core/lifecycle-hooks.d.ts +16 -0
- package/dist/types/core/store-admin-impl.d.ts +9 -0
- package/dist/types/core/store-admin.d.ts +9 -0
- package/dist/types/core/store-core.d.ts +13 -0
- package/dist/types/core/store-create.d.ts +16 -0
- package/dist/types/core/store-hydrate-impl.d.ts +35 -0
- package/dist/types/core/store-hydrate.d.ts +9 -0
- package/dist/types/core/store-lifecycle/hooks.d.ts +19 -0
- package/dist/types/{store-lifecycle → core/store-lifecycle}/identity.d.ts +3 -3
- package/dist/types/{store-lifecycle → core/store-lifecycle}/registry.d.ts +22 -8
- package/dist/types/{store-lifecycle → core/store-lifecycle}/types.d.ts +29 -1
- package/dist/types/{store-lifecycle → core/store-lifecycle}/validation.d.ts +11 -3
- package/dist/types/core/store-name.d.ts +28 -0
- package/dist/types/{store-notify.d.ts → core/store-notify.d.ts} +1 -1
- package/dist/types/{store-read.d.ts → core/store-read.d.ts} +8 -2
- package/dist/types/{store-registry.d.ts → core/store-registry.d.ts} +44 -10
- package/dist/types/core/store-replace-impl.d.ts +11 -0
- package/dist/types/core/store-replace.d.ts +9 -0
- package/dist/types/core/store-set-impl.d.ts +13 -0
- package/dist/types/core/store-set.d.ts +9 -0
- package/dist/types/core/store-shared/core.d.ts +13 -0
- package/dist/types/core/store-shared/notify.d.ts +12 -0
- package/dist/types/{store-transaction.d.ts → core/store-transaction.d.ts} +15 -1
- package/dist/types/core/store-write-shared.d.ts +19 -0
- package/dist/types/core/store-write.d.ts +13 -0
- package/dist/types/features/feature-registry.d.ts +91 -0
- package/dist/types/features/lifecycle.d.ts +12 -0
- package/dist/types/index.d.ts +13 -2
- package/dist/types/integrations/query.d.ts +2 -2
- package/dist/types/internals/computed-order.d.ts +3 -0
- package/dist/types/internals/config.d.ts +56 -2
- package/dist/types/internals/reporting.d.ts +1 -0
- package/dist/types/internals/store-admin.d.ts +1 -1
- package/dist/types/internals/store-ops.d.ts +13 -3
- package/dist/types/internals/test-reset.d.ts +2 -0
- package/dist/types/internals/write-context.d.ts +15 -0
- package/dist/types/notification/delivery.d.ts +3 -0
- package/dist/types/notification/index.d.ts +10 -0
- package/dist/types/notification/metrics.d.ts +12 -0
- package/dist/types/notification/priority.d.ts +9 -0
- package/dist/types/notification/scheduler.d.ts +11 -0
- package/dist/types/notification/snapshot.d.ts +8 -0
- package/dist/types/runtime-tools/index.d.ts +58 -0
- package/dist/types/store.d.ts +16 -7
- package/dist/types/types/utility.d.ts +17 -0
- package/dist/types/utils/devfreeze.d.ts +2 -0
- package/dist/types/utils.d.ts +8 -0
- package/dist/{types-grvlY4BX.d.cts → types.d.ts} +30 -2
- package/dist/utility.d.ts +15 -0
- package/package.json +35 -11
- package/dist/async-cache-DFHwcBQL.d.cts +0 -52
- package/dist/async-cache-DFHwcBQL.d.ts +0 -52
- package/dist/async.cjs +0 -29
- package/dist/async.d.cts +0 -40
- package/dist/computed-BbAZm1Dq.d.cts +0 -17
- package/dist/computed-CccdgY5j.d.ts +0 -17
- package/dist/computed.cjs +0 -11
- package/dist/computed.d.cts +0 -29
- package/dist/core.cjs +0 -30
- package/dist/core.d.cts +0 -5
- package/dist/devtools.cjs +0 -1
- package/dist/devtools.d.cts +0 -19
- package/dist/helpers.cjs +0 -20
- package/dist/helpers.d.cts +0 -29
- package/dist/index.cjs +0 -30
- package/dist/options-CB35e3Xo.d.ts +0 -245
- package/dist/persist.cjs +0 -1
- package/dist/persist.d.cts +0 -2
- package/dist/react.cjs +0 -31
- package/dist/react.d.ts +0 -52
- package/dist/react.js +0 -31
- package/dist/runtime-admin.cjs +0 -1
- package/dist/runtime-admin.d.cts +0 -4
- package/dist/runtime-tools.cjs +0 -3
- package/dist/runtime-tools.d.cts +0 -39
- package/dist/selectors.cjs +0 -1
- package/dist/selectors.d.cts +0 -4
- package/dist/server.cjs +0 -10
- package/dist/server.d.cts +0 -14
- package/dist/sync.cjs +0 -1
- package/dist/sync.d.cts +0 -2
- package/dist/testing.cjs +0 -20
- package/dist/testing.d.cts +0 -16
- package/dist/types/async-cache.d.ts +0 -57
- package/dist/types/core.d.ts +0 -1
- package/dist/types/devfreeze.d.ts +0 -1
- package/dist/types/feature-registry.d.ts +0 -69
- package/dist/types/internals/hooks-warnings.d.ts +0 -6
- package/dist/types/store-lifecycle/bind.d.ts +0 -3
- package/dist/types/store-lifecycle/hooks.d.ts +0 -44
- package/dist/types/store-lifecycle.d.ts +0 -20
- package/dist/types/store-name.d.ts +0 -19
- package/dist/types/store-write.d.ts +0 -45
- package/dist/types-grvlY4BX.d.ts +0 -37
- /package/dist/types/{async-retry.d.ts → async/retry.d.ts} +0 -0
- /package/dist/types/{runtime-admin.d.ts → runtime-admin/index.d.ts} +0 -0
package/dist/runtime-tools.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
var
|
|
1
|
+
var Zt=new Map,M=(e,t,r=0)=>{!e||typeof t!="function"||Zt.set(e,{name:e,order:r,fn:t});};var at=new Map;var Se=e=>at.get(e),te=()=>Array.from(at.keys());var ut=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),lt=()=>({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:ut(),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}}),dt=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(),ut().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 Fe=new Map,ft=new WeakSet,Ee=e=>{ft.has(e)||(ft.add(e),te().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Se(t);r&&e.featureRuntimes.set(t,r());}}));},tr=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,pt,Te=e=>(pt||tr||e).replace(/\.ts(\?|$)/,".js$1"),q=Te(new URL("../../store.js",import.meta.url).href);var rr=()=>{pt=void 0,Fe.clear();};M("registry.scope-override",rr,110);var nr=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),or=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;},sr=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),ir=(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,transaction:sr(),async:lt(),notify:nr(),lifecycleListener:null};return Ee(t),t},K=e=>{let t=Te(e),r=Fe.get(t);if(r)return r;let n=ir();return Fe.set(t,n),n},Q=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var gt=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.failed=false,e.transaction.error=void 0,or(e.notify),dt(e.async),e.lifecycleListener=null;};var Ae=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var L=[],mt={run:(e,t)=>{L.push(e);try{return t()}finally{L.pop();}},get:()=>L.length>0?L[L.length-1]:null,enterWith:e=>{if(L.length>0){L[L.length-1]=e;return}L.push(e);}};var _=e=>(mt).get()||e||K(q);var cr={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}`));}},St={logSink:cr,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},je=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}),Oe=new WeakMap,bt=je(St),ur=e=>{let t=Oe.get(e);return t||(t=je(bt),Oe.set(e,t)),t};var F=()=>ur(_());var pr=()=>{Oe=new WeakMap,bt=je(St);};M("config.reset",pr,90);var gr=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,yr=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,wt=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,mr="production",hr=gr??yr??mr,de=typeof wt=="boolean"?wt:hr!=="production",v=()=>de,Ne=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Sr=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},br=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},be=(e,t)=>{if((F().logSink.critical??Sr)(e,t),F().assertRuntime)throw new Error(e)},f=(e,t)=>{if(!de)return;if((F().logSink.warn??Ne)(e,t),F().assertRuntime)throw new Error(e)},re=(e,t)=>{if((F().logSink.warn??Ne)(e,t),F().assertRuntime)throw new Error(e)},Ie=(e,t)=>{if(de&&(F().logSink.warn??Ne)(e,t),be(e,t),F().assertRuntime)throw new Error(e)},fe=(e,t)=>{if(!de)return;(F().logSink.log??br)(e,t);};var Rt=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Ct=()=>"Map detected; converting to plain object.",xt=()=>"Set detected; converting to array.";var wr=128,Rr=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=wr,Cr=(e,t)=>{if(e===t)return 0;if(e.length===0)return t.length;if(t.length===0)return e.length;let r=Array.from({length:e.length+1},(o,s)=>s),n=new Array(e.length+1);for(let o=1;o<=t.length;o++){n[0]=o;for(let s=1;s<=e.length;s++)n[s]=t[o-1]===e[s-1]?r[s-1]:Math.min(r[s-1],n[s-1],r[s])+1;[r,n]=[n,r];}return r[e.length]},$e=(e,t)=>{let r=t.find(n=>{let o=n.toLowerCase(),s=e.toLowerCase();return o.includes(s)||s.includes(o)||Rr(o,s)&&Cr(o,s)<=2});if(r){f(`Store "${e}" not found. Did you mean "${r}"?`);return}Ie(`Store "${e}" not found.
|
|
2
2
|
Available stores: [${t.join(", ")}]
|
|
3
|
-
Call createStore("${e}", data) first.`);};var H=new Set(["__proto__","constructor","prototype"]);var fe=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,Le=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 z=(e,t)=>{let r=Le(e);if(r)throw new Error(`${r} values are not supported`);let n=fe(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 w()&&d(le()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),w()&&d(de());let s={};for(let[o,a]of e){if(typeof o!="string")throw new Error("Map keys must be strings to remain JSON-safe");s[String(o)]=z(a,t);}return s}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),w()&&d(pe()),Array.from(e,s=>z(s,t))}if(n==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let s={},o=Object.getOwnPropertyDescriptors(e);for(let[a,g]of Object.entries(o))if(g.enumerable&&!H.has(a)){if("get"in g||"set"in g)throw new Error(`Accessor properties are not supported during sanitize ("${a}")`);s[a]=z(g.value,t);}return s}if(n==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(s=>z(s,t))}return e},Z=e=>z(e,new WeakSet);var ee=null,Ue=()=>{if(ee)return ee;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 ee=t,t},ye=e=>{let t=Ue(),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},Ye=2166136261,Ge=2654435761,Xe=1e5,C=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},M=(e,t)=>{C(e,t.length);for(let r=0;r<t.length;r++)C(e,t.charCodeAt(r));},c=(e,t)=>{M(e,t);},ge=(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"),C(e,r);return}c(e,"num"),M(e,String(t));},A=(e,t)=>{if(e.nodes++>Xe){c(e,"[max]");return}if(t===null){c(e,"null");return}let r=typeof t;if(r==="string"){c(e,"string"),M(e,t);return}if(r==="number"){c(e,"number"),ge(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"),M(e,t.toString());return}if(r==="symbol"){c(e,"symbol");let u=t;M(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){c(e,"function"),M(e,t.name||"anonymous");return}let n=t,s=e.seen.get(n);if(s!==void 0){c(e,"ref"),C(e,s);return}let o=e.nextId++;if(e.seen.set(n,o),Array.isArray(n)){c(e,"array"),C(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?A(e,n[u]):c(e,"hole");return}if(n instanceof Date){c(e,"date"),ge(e,n.getTime());return}if(n instanceof Map){c(e,"map"),C(e,n.size),n.forEach((u,S)=>{A(e,S),A(e,u);});return}if(n instanceof Set){c(e,"set"),C(e,n.size),n.forEach(u=>{A(e,u);});return}c(e,"object");let a=Object.getOwnPropertyDescriptors(n),g=[];Object.entries(a).forEach(([u,S])=>{S?.enumerable&&(H.has(u)||"get"in S||"set"in S||g.push([u,S]));}),C(e,g.length);for(let[u,S]of g)M(e,u),A(e,S.value);},te=e=>{if(typeof e=="string")return ye(JSON.stringify(e));let t={h1:Ye,h2:Ge,seen:new WeakMap,nextId:1,nodes:0};A(t,e);let r=t.h1>>>0,n=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,n^=n>>>16,n=Math.imul(n,668265261),n^=n>>>15,n=Math.imul(n,374761393),n^=n>>>16,(r&2097151)*4294967296+(n>>>0)};var Je=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function";var _=(e,t=new WeakMap)=>{if(e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let o=new Map;return t.set(e,o),e.forEach((a,g)=>{o.set(_(g,t),_(a,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(a=>{o.add(_(a,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((a,g)=>{o[g]=_(a,t);}),o}let r=globalThis?.WeakRef;if(r&&e instanceof r)return T("WeakRef values cannot be deep-cloned. Returning the original reference."),e;let n={};t.set(e,n);let s;try{s=Object.getOwnPropertyDescriptors(e);}catch{return T("deepClone failed to read object descriptors (possible Proxy or host object). Returning the original reference."),e}return Object.entries(s).forEach(([o,a])=>{!a.enumerable||H.has(o)||"get"in a||"set"in a||(n[o]=_(a.value,t));}),n},V=e=>{try{if(Je)return structuredClone(e)}catch{}return _(e)};var Se=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,noSignalWarned:new Set,shapeWarned:new Set,autoCreateWarned:new Set,cleanupSubs:Object.create(null),storeCleanupFns:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}});var me=new Map,Qe=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,re=e=>(Qe||e).replace(/\.ts(\?|$)/,".js$1"),v=re(new URL("./store.js",import.meta.url).href);var et=()=>({stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:{depth:0,pending:[],stagedValues:new Map,failed:false,error:void 0},async:Se()}),O=e=>{let t=re(e),r=me.get(t);if(r)return r;let n=et();return me.set(t,n),n},D=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var I=e=>e||O(v);var he=new Map;var ne=e=>he.get(e),B=()=>Array.from(he.keys());var we=({name:e,label:t,fn:r,args:n,reportIssue:s})=>{if(typeof r=="function")try{r(...n);}catch(o){let a=`${t} for "${e}" failed: ${o?.message??o}`;s(a,"always");}};var U=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:s}=t;if(s?.(e),r==="critical"){n==="dev"&&d(e),L(e);return}if(n==="always"){T(e);return}d(e);};var Re=()=>I(O(v)),oe=()=>Re().computedEntries,xe=()=>Re().computedDependents;var ke=e=>Object.prototype.hasOwnProperty.call(oe(),e);var Ce=()=>{let e=oe(),t=xe(),r=Object.keys(e),n=[];for(let[s,o]of Object.entries(e))for(let a of o.deps)n.push({from:a,to:s});return {nodes:r,edges:n,dependencies:Object.fromEntries(Object.entries(e).map(([s,o])=>[s,[...o.deps]])),dependents:Object.fromEntries(Object.entries(t).map(([s,o])=>[s,[...o]]))}},ve=e=>{let t=oe()[e];if(!t)return null;let r=xe()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var nt=()=>q().computedCleanups;var Fe=e=>{let t=nt(),r=t.get(e);if(!r){w()&&d(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var Ee=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,s=e.initialFactories,o=e.metaEntries,a=e.snapshotCache,g=e.featureRuntimes,u=e.deletingStores,S=(i,p)=>{U(p,{onError:o[i]?.options?.onError,severity:"warn",visibility:"dev"});},ae=({name:i,prev:p,options:l,initialState:m,getMeta:k,getStoreValue:F,hasStore:h})=>({name:i,options:l,prev:p,getMeta:k,getStoreValue:F,getAllStores:()=>t,getInitialState:()=>m,hasStore:h,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:y=>{U(y,{onError:l.onError,severity:"warn",visibility:"dev"});},warn:d,log:$,hashState:te,deepClone:V,sanitize:Z,validate:()=>({ok:true,value:p}),isDev:w}),ce=({name:i,prev:p,options:l,initialState:m,phase:k})=>{let F=ae({name:i,prev:p,options:l,initialState:m,getMeta:()=>o[i],getStoreValue:()=>t[i],hasStore:()=>D(e,i)}),h=ae({name:i,prev:p,options:l,initialState:m,getMeta:()=>{},getStoreValue:()=>p,hasStore:()=>false});B().forEach(y=>{let E=g.get(y);k==="before"?E?.beforeStoreDelete?.(F):E?.afterStoreDelete?.(h);});},G=i=>{if(!D(e,i))return;let p=t[i],l=o[i].options,m=n[i],k=r[i];u.add(i);try{k?.forEach(y=>{try{y(null);}catch(E){d(`Subscriber for "${i}" threw during delete: ${E?.message??E}`);}}),we({name:i,label:"onDelete",fn:l.onDelete,args:[p],reportIssue:(y,E)=>{U(y,{onError:l.onError,severity:"warn",visibility:E});}}),ce({name:i,prev:p,options:l,initialState:m,phase:"before"}),delete t[i],delete r[i],delete n[i],delete s[i],delete o[i],delete a[i],ke(i)&&Fe(i);let h=e.computedDependents[i];if(h)for(let y of h)d(`[stroid] source store "${i}" was deleted. Computed store "${y}" depends on it and will return stale data. Call deleteComputed("${y}") to clean up.`);ce({name:i,prev:p,options:l,initialState:m,phase:"after"}),$(`Store "${i}" deleted`);}finally{u.delete(i);}};return {deleteExistingStore:G,clearAllStores:()=>{let i=[],l=0,m=Number.POSITIVE_INFINITY;for(;l<20;){let F=Object.keys(t);if(F.length===0)break;F.forEach(y=>{D(e,y)&&(G(y),i.push(y));}),l+=1;let h=Object.keys(t).length;if(h===0||h>=m)break;m=h;}let k=Object.keys(t).length;return k>0?d(`clearAllStores stopped after ${l} pass${l===1?"":"es"}; ${k} store(s) still registered (likely recreated during deletion).`):d(`All stores cleared (${i.length} stores removed)`),i},clearStores:i=>{let p=Object.keys(t).filter(l=>i?i.endsWith("*")?l.startsWith(i.slice(0,-1)):l===i:true);return p.forEach(l=>G(l)),p},reportStoreError:S}};var ot=v,st=O(ot);var Me=new WeakSet,it=e=>{Me.has(e)||(Me.add(e),B().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ne(t);r&&e.featureRuntimes.set(t,r());}}));},R=()=>{let e=I(st);return it(e),e};var q=()=>R();var P=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}}}),at=e=>new Proxy(new Map,{get:(t,r)=>{let n=e();if(r==="size")return n.size;if(r===Symbol.iterator)return n[Symbol.iterator].bind(n);let s=n[r];return typeof s=="function"?s.bind(n):s},set:(t,r,n)=>(e()[r]=n,true)}),ct=e=>new Proxy({},{get:(t,r)=>{let n=e(),s=n[r];return typeof s=="function"?s.bind(n):s},set:(t,r,n)=>(e()[r]=n,true)});P(()=>R().stores);var se=P(()=>R().subscribers);P(()=>R().initialStates);P(()=>R().initialFactories);P(()=>R().metaEntries);P(()=>R().snapshotCache);var j=at(()=>R().featureRuntimes),Oe=new WeakMap,pt=e=>{let t=Oe.get(e);return t||(t=Ee(e),Oe.set(e,t)),t};ct(()=>pt(R()));var Te=e=>{let t=j.get(e);if(t)return t;let r=ne(e);if(!r)return;let n=r();return j.set(e,n),n},gt=()=>{B().forEach(e=>{Te(e);});};gt();var ie=e=>j.get(e)?.api;var f=()=>q().async,x=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,n)=>(e()[r]=n,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let n=Object.getOwnPropertyDescriptor(e(),r);if(n)return {...n,configurable:true}}}),N=e=>new Proxy({},{get:(t,r)=>{let n=e(),s=n[r];return typeof s=="function"?s.bind(n):s},set:(t,r,n)=>(e()[r]=n,true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let n=Object.getOwnPropertyDescriptor(e(),r);if(n)return {...n,configurable:true}}});x(()=>f().fetchRegistry);var St=x(()=>f().inflight);x(()=>f().requestVersion);x(()=>f().cacheMeta);x(()=>f().rateWindowStart);x(()=>f().rateCount);N(()=>f().ratePruneState);x(()=>f().cleanupSubs);x(()=>f().storeCleanupFns);x(()=>f().revalidateHandlers);N(()=>f().noSignalWarned);N(()=>f().shapeWarned);N(()=>f().autoCreateWarned);N(()=>f().revalidateKeys);N(()=>f().asyncMetrics);var Ae=e=>{let t=`${e}:`,r=0;return Object.keys(St).forEach(n=>{(n===e||n.startsWith(t))&&(r+=1);}),r};var K=()=>I(O(v)),Y=e=>{let t=K();return D(t,e)?true:(Q(e,Object.keys(t.stores)),false)},mt=(e,t)=>{if(!t)return true;if(t.endsWith("*")){let r=t.slice(0,-1);return e.startsWith(r)}return e===t},mn=e=>{let t=K();return Object.keys(t.stores).filter(r=>mt(r,e))},hn=e=>Y(e)?V(K().metaEntries[e]):null,bn=()=>V(K().initialStates),wn=e=>{let t=K().metaEntries[e];return t?.metrics?{...t.metrics}:null},Rn=e=>Y(e)?se[e]?.size??0:0,xn=e=>Y(e)?Ae(e):0,kn=e=>{if(!Y(e))return 0;let t=ie("persist");return t?.getPersistQueueDepth?t.getPersistQueueDepth(e)??0:0},Cn=()=>Ce(),vn=e=>ve(e);export{xn as getAsyncInflightCount,vn as getComputedDeps,Cn as getComputedGraph,bn as getInitialState,wn as getMetrics,kn as getPersistQueueDepth,hn as getStoreMeta,Rn as getSubscriberCount,mn as listStores};
|
|
3
|
+
Call createStore("${e}", data) first.`);};var ne=new Set(["__proto__","constructor","prototype"]);var vt=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,xr=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=xr(e);if(r)throw new Error(`${r} values are not supported`);let n=vt(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()&&f(Rt()),e.toISOString();if(n==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),v()&&f(Ct());let o={};for(let[s,d]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");o[String(s)]=pe(d,t);}return o}if(n==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),v()&&f(xt()),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[d,p]of Object.entries(s))if(p.enumerable&&!ne.has(d)){if("get"in p||"set"in p)throw new Error(`Accessor properties are not supported during sanitize ("${d}")`);o[d]=pe(p.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},_e=e=>pe(e,new WeakSet);var Pe=null,vr=()=>{if(Pe)return Pe;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 Pe=t,t},Mt=e=>{let t=vr(),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},kr=2166136261,Mr=2654435761,Fr=1e5,U=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},J=(e,t)=>{U(e,t.length);for(let r=0;r<t.length;r++)U(e,t.charCodeAt(r));},w=(e,t)=>{J(e,t);},kt=(e,t)=>{if(Number.isNaN(t)){w(e,"NaN");return}if(!Number.isFinite(t)){w(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){w(e,"-0");return}let r=t|0;if(t===r){w(e,"int"),U(e,r);return}w(e,"num"),J(e,String(t));},oe=(e,t)=>{if(e.nodes++>Fr){w(e,"[max]");return}if(t===null){w(e,"null");return}let r=typeof t;if(r==="string"){w(e,"string"),J(e,t);return}if(r==="number"){w(e,"number"),kt(e,t);return}if(r==="boolean"){w(e,t?"true":"false");return}if(r==="undefined"){w(e,"undefined");return}if(r==="bigint"){w(e,"bigint"),J(e,t.toString());return}if(r==="symbol"){w(e,"symbol");let u=t;J(e,Symbol.keyFor(u)??u.description??String(u));return}if(r==="function"){w(e,"function"),J(e,t.name||"anonymous");return}let n=t,o=e.seen.get(n);if(o!==void 0){w(e,"ref"),U(e,o);return}let s=e.nextId++;if(e.seen.set(n,s),Array.isArray(n)){w(e,"array"),U(e,n.length);for(let u=0;u<n.length;u++)Object.prototype.hasOwnProperty.call(n,u)?oe(e,n[u]):w(e,"hole");return}if(n instanceof Date){w(e,"date"),kt(e,n.getTime());return}if(n instanceof Map){w(e,"map"),U(e,n.size),n.forEach((u,S)=>{oe(e,S),oe(e,u);});return}if(n instanceof Set){w(e,"set"),U(e,n.size),n.forEach(u=>{oe(e,u);});return}w(e,"object");let d=Object.getOwnPropertyDescriptors(n),p=[];Object.entries(d).forEach(([u,S])=>{S?.enumerable&&(ne.has(u)||"get"in S||"set"in S||p.push([u,S]));}),U(e,p.length);for(let[u,S]of p)J(e,u),oe(e,S.value);},Ve=e=>{if(typeof e=="string")return Mt(JSON.stringify(e));let t={h1:kr,h2:Mr,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 Er=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",N=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},We=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},Tr=e=>We(e)===null,Ar=e=>{let t=We(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},Z=(e,t=new WeakMap)=>{if(Ar(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,d)=>{o.set(Z(d,t),Z(s,t));}),o}if(e instanceof Set){let o=new Set;return t.set(e,o),e.forEach(s=>{o.add(Z(s,t));}),o}if(Array.isArray(e)){let o=[];return t.set(e,o),e.forEach((s,d)=>{o[d]=Z(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]=Z(s.value,t));}),r},P=e=>{if(Er)try{return structuredClone(e)}catch(t){if(!Tr(e)){let r=We(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return f(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),Z(e)}return Z(e)};var Ft=({name:e,label:t,fn:r,args:n,reportIssue:o})=>{if(typeof r=="function")try{r(...n);}catch(s){let d=`${t} for "${e}" failed: ${s?.message??s}`;o(d,"always");}};var Dr=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(n){let o=n?.message??n;re(`${t} callback threw: ${String(o)}`);}},we=(e,t={})=>{let{severity:r="warn",visibility:n="dev",onError:o}=t;if(Dr(o,"onError",e),r==="critical"){n==="dev"&&f(e),be(e);return}if(n==="always"){re(e);return}f(e);};M("computed.order-resolver",()=>{},105);var At=()=>_(K(q)),Ce=()=>At().computedEntries,He=()=>At().computedDependents;var Dt=e=>Object.prototype.hasOwnProperty.call(Ce(),e);var Ot=()=>{let e=Ce(),t=He(),r=Object.keys(e),n=[];for(let[o,s]of Object.entries(e))for(let d of s.deps)n.push({from:d,to:o});return {nodes:r,edges:n,dependencies:Object.fromEntries(Object.entries(e).map(([o,s])=>[o,[...s.deps]])),dependents:Object.fromEntries(Object.entries(t).map(([o,s])=>[o,[...s]]))}},jt=e=>{let t=Ce()[e];if(!t)return null;let r=He()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var jr=new Set;var Nr=()=>{jr.clear();};M("ssr.warnings",Nr,60);var Nt=e=>G.get(e)?.api;var Ht=new Map;var ye=(e,t,r)=>{let n=Ht.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=()=>{let e=me().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.subscriberBuffer.length=0,e.notifyScheduled=false,e.batchDepth=0;};M("notify.reset",Wr,40);var Hr=()=>me().computedCleanups;var Bt=e=>{let t=Hr(),r=t.get(e);if(!r){v()&&f(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var qt=e=>{let t=e.stores,r=e.subscribers,n=e.initialStates,o=e.initialFactories,s=e.metaEntries,d=e.snapshotCache,p=e.featureRuntimes,u=e.deletingStores,S=(a,C)=>{we(C,{onError:s[a]?.options?.onError,severity:"warn",visibility:"dev"});},y=({name:a,prev:C,options:m,initialState:T,getMeta:A,getStoreValue:W,hasStore:D})=>({name:a,options:m,prev:C,getMeta:A,getStoreValue:W,getAllStores:()=>t,getInitialState:()=>T,hasStore:D,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:x=>{we(x,{onError:m.onError,severity:"warn",visibility:"dev"});},warn:f,warnAlways:re,log:fe,hashState:Ve,deepClone:P,sanitize:_e,validate:()=>({ok:true,value:C}),isDev:v}),h=({name:a,prev:C,options:m,initialState:T,phase:A})=>{let W=y({name:a,prev:C,options:m,initialState:T,getMeta:()=>s[a],getStoreValue:()=>t[a],hasStore:()=>Q(e,a)}),D=y({name:a,prev:C,options:m,initialState:T,getMeta:()=>{},getStoreValue:()=>C,hasStore:()=>false});te().forEach(x=>{let I=p.get(x);A==="before"?I?.beforeStoreDelete?.(W):I?.afterStoreDelete?.(D);});},g=a=>{if(!Q(e,a))return;let C=t[a],m=s[a].options,T=n[a],A=r[a];u.add(a);try{A?.forEach(x=>{try{x(null);}catch(I){f(`Subscriber for "${a}" threw during delete: ${I?.message??I}`);}}),Ft({name:a,label:"onDelete",fn:m.onDelete,args:[C],reportIssue:(x,I)=>{we(x,{onError:m.onError,severity:"warn",visibility:I});}}),h({name:a,prev:C,options:m,initialState:T,phase:"before"}),delete t[a],delete r[a],delete n[a],delete o[a],delete s[a],delete d[a],Dt(a)&&Bt(a);let D=e.computedDependents[a];if(D)for(let x of D)f(`[stroid] source store "${a}" was deleted. Computed store "${x}" depends on it and will return stale data. Call deleteComputed("${x}") to clean up.`);h({name:a,prev:C,options:m,initialState:T,phase:"after"}),ye("afterStoreDelete",a,{type:"afterStoreDelete",prev:C}),Ae(e,{type:"deleted",name:a}),fe(`Store "${a}" deleted`);}finally{u.delete(a);}};return {deleteExistingStore:g,clearAllStores:()=>{let a=[],m=0,T=Number.POSITIVE_INFINITY;for(;m<20;){let W=Object.keys(t);if(W.length===0)break;W.forEach(x=>{Q(e,x)&&(g(x),a.push(x));}),m+=1;let D=Object.keys(t).length;if(D===0||D>=T)break;T=D;}let A=Object.keys(t).length;return A>0?f(`clearAllStores stopped after ${m} pass${m===1?"":"es"}; ${A} store(s) still registered (likely recreated during deletion).`):f(`All stores cleared (${a.length} stores removed)`),a},clearStores:a=>{let C=Object.keys(t).filter(m=>a?a.endsWith("*")?m.startsWith(a.slice(0,-1)):m===a:true);return C.forEach(m=>g(m)),C},reportStoreError:S}};var Je=q,Ut=K(Je);var V=()=>{let e=_(Ut);return Ee(e),e};var me=()=>V();var se=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}}}),zr=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)}),Lr=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)});se(()=>V().stores);var Gt=se(()=>V().subscribers);se(()=>V().initialStates);se(()=>V().initialFactories);se(()=>V().metaEntries);se(()=>V().snapshotCache);var G=zr(()=>V().featureRuntimes),Kt=new WeakMap,Br=e=>{let t=Kt.get(e);return t||(t=qt(e),Kt.set(e,t)),t};Lr(()=>Br(V()));var qr=e=>{let t=G.get(e);if(t)return t;let r=Se(e);if(!r)return;let n=r();return G.set(e,n),n},Kr=()=>{te().forEach(e=>{qr(e);});};Kr();var Ur=()=>{gt(V());},Gr=()=>{G.forEach(e=>{try{e.resetAll?.();}catch{}}),G.clear();};M("features.reset",Gr,10);M("registries.clear",Ur,20);M("registry.default",()=>{Je=q,Ut=K(Je);},115);var Ze=()=>_().async;var Yr=()=>Ze().inflight;var Yt=()=>Ze().asyncMetrics;var et=e=>{let t=`${e}:`,r=Yr(),n=0;return Object.keys(r).forEach(o=>{(o===e||o.startsWith(t))&&(n+=1);}),n};var Xt=()=>({...Yt()});var ie=()=>_(K(q)),he=e=>{let t=ie();return Q(t,e)?true:($e(e,Object.keys(t.stores)),false)},Xr=(e,t)=>{if(!t)return true;if(t.endsWith("*")){let r=t.slice(0,-1);return e.startsWith(r)}return e===t},Qt=e=>{let t=ie();return Object.keys(t.stores).filter(r=>Xr(r,e))},Qr=e=>{if(!he(e))return null;let t=ie().metaEntries[e],r=N(t);r.metrics=N(t.metrics);let n=N(t.options),o=n;return o.persist&&typeof o.persist=="object"&&(o.persist=N(o.persist)),o.sync&&typeof o.sync=="object"&&(o.sync=N(o.sync)),o.devtools&&typeof o.devtools=="object"&&(o.devtools=N(o.devtools)),o.lifecycle&&typeof o.lifecycle=="object"&&(o.lifecycle=N(o.lifecycle)),r.options=n,r},Is=()=>P(ie().initialStates),Jr=e=>{let t=ie().metaEntries[e];return t?.metrics?{...t.metrics}:null},Zr=e=>he(e)?Gt[e]?.size??0:0,en=e=>he(e)?et(e):0,tn=(e={})=>{let t=e.unreadThresholdMs??6e4,r=Date.now();return Qt().map(n=>{let o=ie().metaEntries[n],s=o?.createdAt?new Date(o.createdAt).getTime():r,d=o?.lastReadAtMs??null,p=Math.max(0,r-s),u;return (o?.readCount??0)===0&&(o?.updateCount??0)===0?u="cold":(o?.readCount??0)===0?u="write-only":d&&r-d>t?u="stale":u="active",{name:n,createdAt:o?.createdAt??new Date(s).toISOString(),lastReadAt:o?.lastReadAt??null,updateCount:o?.updateCount??0,readCount:o?.readCount??0,subscriberCount:Zr(n),ageMs:p,verdict:u}}).filter(n=>n.verdict==="cold"||n.verdict==="stale"||e.includeWriteOnly&&n.verdict==="write-only")},rn=e=>{if(e){if(!he(e))return null;let r=Qr(e);return {name:e,meta:r,metrics:Jr(e),async:{inflight:en(e),lastCorrelationId:r?.lastCorrelationId??null,traceContext:r?.lastTraceContext??null},persist:{queueDepth:nn(e)}}}let t=Qt().map(r=>rn(r));return {stores:t,async:Xt(),registry:{totalStores:t.length,coldStores:tn({})}}},nn=e=>{if(!he(e))return 0;let t=Nt("persist");return t?.getPersistQueueDepth?t.getPersistQueueDepth(e)??0:0},$s=()=>Ot(),_s=e=>jt(e);export{tn as findColdStores,en as getAsyncInflightCount,_s as getComputedDeps,$s as getComputedGraph,Is as getInitialState,Jr as getMetrics,nn as getPersistQueueDepth,rn as getStoreHealth,Qr as getStoreMeta,Zr as getSubscriberCount,Qt as listStores};//# sourceMappingURL=runtime-tools.js.map
|
|
4
|
+
//# sourceMappingURL=runtime-tools.js.map
|