stroid 0.1.3 → 0.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +312 -265
- package/README.md +1017 -115
- package/dist/async.d.ts +1 -1
- package/dist/async.js +1 -33
- package/dist/chunk-645IESIU.js +2 -0
- package/dist/chunk-6ELWGQ4Q.js +2 -0
- package/dist/chunk-BW32TJGE.js +13 -0
- package/dist/chunk-FOQKGHPS.js +26 -0
- package/dist/chunk-KQCSFGHJ.js +2 -0
- package/dist/chunk-M2NJVI36.js +2 -0
- package/dist/chunk-PVATWAY4.js +2 -0
- package/dist/chunk-X3JR32JD.js +2 -0
- package/dist/chunk-YU5GMPCC.js +2 -0
- package/dist/computed-types.d.ts +42 -0
- package/dist/computed-types.js +2 -0
- package/dist/computed.d.ts +9 -2
- package/dist/computed.js +1 -12
- package/dist/core.js +1 -22
- package/dist/devtools.d.ts +1 -1
- package/dist/devtools.js +1 -1
- package/dist/feature.js +1 -1
- package/dist/helpers.js +1 -22
- package/dist/index-internal.d.ts +1 -1
- package/dist/index.d.cts +3 -1
- package/dist/index.d.ts +3 -1
- package/dist/index.js +1 -35
- package/dist/install.js +1 -1
- package/dist/options.d.ts +1 -1
- package/dist/persist.js +1 -1
- package/dist/psr.d.ts +48 -0
- package/dist/psr.js +2 -0
- package/dist/react/index.d.ts +3 -1
- package/dist/react/index.js +5 -36
- package/dist/registry.d.ts +1 -0
- package/dist/runtime-admin.js +1 -1
- package/dist/runtime-patch.d.ts +29 -0
- package/dist/runtime-tools.d.ts +6 -1
- package/dist/runtime-tools.js +1 -3
- package/dist/selectors.js +1 -1
- package/dist/server.d.ts +4 -1
- package/dist/server.js +1 -12
- package/dist/store-registry.d.ts +8 -0
- package/dist/sync.js +1 -1
- package/dist/testing.js +1 -22
- package/dist/types/adapters/options.d.ts +335 -0
- package/dist/types/async/cache.d.ts +40 -0
- package/dist/types/async/clone.d.ts +10 -0
- package/dist/types/async/errors.d.ts +3 -0
- package/dist/types/async/fetch.d.ts +37 -0
- package/dist/types/async/inflight.d.ts +30 -0
- package/dist/types/async/rate.d.ts +5 -0
- package/dist/types/async/registry.d.ts +117 -0
- package/dist/types/async/request.d.ts +11 -0
- package/dist/types/async/retry.d.ts +10 -0
- package/dist/types/async.d.ts +10 -0
- package/dist/types/computed/computed-graph.d.ts +33 -0
- package/dist/types/computed/index.d.ts +21 -0
- package/dist/types/computed/types.d.ts +40 -0
- package/dist/types/config.d.ts +10 -0
- package/dist/types/core/index.d.ts +11 -0
- package/dist/types/core/lifecycle-hooks.d.ts +16 -0
- package/dist/types/core/runtime-patch.d.ts +67 -0
- package/dist/types/core/store-admin-impl.d.ts +9 -0
- package/dist/types/core/store-admin.d.ts +9 -0
- package/dist/types/core/store-core.d.ts +13 -0
- package/dist/types/core/store-create.d.ts +16 -0
- package/dist/types/core/store-hydrate-impl.d.ts +35 -0
- package/dist/types/core/store-hydrate.d.ts +9 -0
- package/dist/types/core/store-lifecycle/hooks.d.ts +20 -0
- package/dist/types/core/store-lifecycle/identity.d.ts +23 -0
- package/dist/types/core/store-lifecycle/registry.d.ts +54 -0
- package/dist/types/core/store-lifecycle/types.d.ts +67 -0
- package/dist/types/core/store-lifecycle/validation.d.ts +53 -0
- package/dist/types/core/store-name.d.ts +28 -0
- package/dist/types/core/store-notify.d.ts +13 -0
- package/dist/types/core/store-read.d.ts +18 -0
- package/dist/types/core/store-registry.d.ts +115 -0
- package/dist/types/core/store-replace-impl.d.ts +11 -0
- package/dist/types/core/store-replace.d.ts +9 -0
- package/dist/types/core/store-set-impl.d.ts +13 -0
- package/dist/types/core/store-set.d.ts +9 -0
- package/dist/types/core/store-shared/core.d.ts +13 -0
- package/dist/types/core/store-shared/notify.d.ts +12 -0
- package/dist/types/core/store-transaction.d.ts +28 -0
- package/dist/types/core/store-write-shared.d.ts +25 -0
- package/dist/types/core/store-write.d.ts +13 -0
- package/dist/types/features/feature-registry.d.ts +91 -0
- package/dist/types/features/lifecycle.d.ts +40 -0
- package/dist/types/index.d.ts +17 -0
- package/dist/types/integrations/query.d.ts +8 -0
- package/dist/types/internals/computed-order.d.ts +3 -0
- package/dist/types/internals/config.d.ts +116 -0
- package/dist/types/internals/diagnostics.d.ts +21 -0
- package/dist/types/internals/reporting.d.ts +9 -0
- package/dist/types/internals/store-admin.d.ts +7 -0
- package/dist/types/internals/store-ops.d.ts +13 -0
- package/dist/types/internals/test-reset.d.ts +2 -0
- package/dist/types/internals/write-context.d.ts +20 -0
- package/dist/types/notification/delivery.d.ts +3 -0
- package/dist/types/notification/index.d.ts +10 -0
- package/dist/types/notification/metrics.d.ts +12 -0
- package/dist/types/notification/priority.d.ts +9 -0
- package/dist/types/notification/scheduler.d.ts +11 -0
- package/dist/types/notification/snapshot.d.ts +8 -0
- package/dist/types/runtime-admin/index.d.ts +2 -0
- package/dist/types/runtime-tools/index.d.ts +63 -0
- package/dist/types/store.d.ts +16 -0
- package/dist/types/types/utility.d.ts +17 -0
- package/dist/types/utils/clone.d.ts +4 -0
- package/dist/types/utils/devfreeze.d.ts +2 -0
- package/dist/types/utils/hash.d.ts +8 -0
- package/dist/types/utils/path.d.ts +5 -0
- package/dist/types/utils/validation.d.ts +14 -0
- package/dist/types/utils.d.ts +13 -0
- package/dist/types.d.ts +2 -2
- package/package.json +31 -20
- package/dist/async.js.map +0 -1
- package/dist/computed.js.map +0 -1
- package/dist/core.js.map +0 -1
- package/dist/devtools.js.map +0 -1
- package/dist/feature.js.map +0 -1
- package/dist/helpers.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/install.js.map +0 -1
- package/dist/persist.js.map +0 -1
- package/dist/react/index.js.map +0 -1
- package/dist/runtime-admin.js.map +0 -1
- package/dist/runtime-tools.js.map +0 -1
- package/dist/selectors.js.map +0 -1
- package/dist/server.js.map +0 -1
- package/dist/sync.js.map +0 -1
- package/dist/testing.js.map +0 -1
- package/dist/tsdoc-metadata.json +0 -11
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {n,q as q$1,J,t,A}from'./chunk-FOQKGHPS.js';import {b}from'./chunk-KQCSFGHJ.js';var Re=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",K=e=>!!e?.[Re],U=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}},ue=(e,t,r)=>{let s="__stroid_persist_roundtrip_probe__",i;try{i=t(s);}catch(l){return {ok:false,reason:`persist: encrypt failed for store "${e}" (${l?.message??l})`}}if(typeof i!="string")return {ok:false,reason:`persist: encrypt must return a string for store "${e}".`};let a;try{a=r(i);}catch(l){return {ok:false,reason:`persist: decrypt failed for store "${e}" (${l?.message??l})`}}return typeof a!="string"?{ok:false,reason:`persist: decrypt must return a string for store "${e}".`}:a!==s?{ok:false,reason:`persist: encrypt/decrypt must round-trip for store "${e}".`}:{ok:true}};var Le=e=>!!e&&typeof e.then=="function",ce=(e,t,r)=>{e[t]&&(e[t].lastPresent=r);},le=({name:e,persistConfig:t,persistWatchState:r})=>{let s=t?.onStorageCleared;if(!t||typeof s!="function"||typeof window>"u"||typeof window.addEventListener!="function")return;r[e]?.dispose();let i=window,a=()=>{try{let n=t.driver.getItem?.(t.key)??null;return Le(n)?Promise.resolve(n).then(o=>o!=null,()=>!1):n!=null}catch{return false}},l=n=>{let o=r[e];if(!o)return;let u=o.lastPresent,d=f=>{let b=r[e];if(b){if(!u||f){b.lastPresent=f;return}b.lastPresent=false,s({name:e,key:t.key,reason:n});}},S=a();if(typeof S=="boolean"){d(S);return}S.then(d);},y=n=>{if(n.key===null){l("clear");return}n.key===t.key&&n.newValue===null&&l("remove");},m=()=>{l("missing");};i.addEventListener("storage",y),i.addEventListener("focus",m);let g=a();r[e]={lastPresent:typeof g=="boolean"?g:false,dispose:()=>{i.removeEventListener("storage",y),i.removeEventListener("focus",m);}},typeof g!="boolean"&&g.then(n=>{let o=r[e];o&&(o.lastPresent=n);});};var I=({value:e,sanitize:t,validate:r,onSanitizeError:s})=>{let i;if(t)try{i=t(e);}catch(l){return s?.(l),{ok:false}}else i=e;let a=r(i);return a.ok?{ok:true,value:a.value??i}:{ok:false}},j=({value:e,fallbackMs:t=Date.now(),onInvalid:r})=>{if(typeof e=="number")return Number.isFinite(e)?e:(r?.(),t);if(typeof e=="string"){let s=Date.parse(e);return Number.isFinite(s)?s:(r?.(),t)}return r?.(),t};var ze=e=>{let t=new Uint8Array(e),r="";for(let s=0;s<t.length;s++)r+=t[s].toString(16).padStart(2,"0");return r},We=async e=>{if(typeof globalThis<"u"&&globalThis.crypto?.subtle){let t=typeof TextEncoder<"u"?new TextEncoder:null,r=t?t.encode(e):new Uint8Array(Buffer.from(e)),s=await globalThis.crypto.subtle.digest("SHA-256",r);return ze(s)}try{let{createHash:t}=await import('crypto');return t("sha256").update(e).digest("hex")}catch{throw new Error("sha256 checksum is not supported in this environment")}},q=async(e,t$1,r=t)=>e==="none"?null:e==="sha256"?We(t$1):r(t$1);var fe=1e6,Ie=e=>!!e&&typeof e.then=="function",Q=(e,t,r)=>(t(e,`Could not load store "${e}" (${r?.message||r})`),true),pe=(e,t)=>{let r=e?.options?.migrations??{};if(Object.keys(r).length>0)return r;let s=t?.migrate;if(typeof s!="function")return r;let i=e?.version??1;return !Number.isFinite(i)||i<=1?r:{[i]:s}},Y=({name:e,persisted:t,reason:r,persistConfig:s,initialState:i,reportStoreError:a,sanitize:l,deepClone:y})=>{a(e,r);let m=s?.onMigrationFail??"reset";if(m==="keep")return {state:t,requiresValidation:true};if(typeof m=="function")try{let g=m(y(t));if(g!==void 0)return {state:l(g),requiresValidation:!0};a(e,`onMigrationFail for "${e}" returned undefined. Falling back to initial state.`);}catch(g){a(e,`onMigrationFail for "${e}" failed: ${g?.message??g}`);}return {state:y(i),requiresValidation:true}},ye=e=>{let r=e.getMeta()?.options?.persist;if(!r)return false;let s;try{s=r.driver.getItem?.(r.key)??null;}catch(a){return Q(e.name,e.reportStoreError,a)}return Ie(s)||!!r.decryptAsync||r.checksum==="sha256"?de(e,s):Oe(e,s)},Oe=({name:e,silent:t=false,getMeta:r,getInitialState:s,applyFeatureState:i,reportStoreError:a,warnMissingMaxSize:l,validate:y,log:m,hashState:g,deepClone:n,sanitize:o,shouldApply:u},d)=>{let S=r(),f=S?.options?.persist;if(!f)return false;let b=pe(S,f),p=c=>I({value:c,validate:y});try{let c=d===void 0?f.driver.getItem?.(f.key)??null:d;if(c==null)return !1;if(typeof c!="string")return a(e,`Persist driver for "${e}" returned an async value during sync hydration. Provide async decrypt hooks or use an async-capable persist driver.`),!0;if(typeof f.maxSize!="number"&&c.length>fe&&l?.(c.length),typeof f.maxSize=="number"&&c.length>f.maxSize)return a(e,`Persist payload for "${e}" exceeds maxSize (${c.length} > ${f.maxSize}). Skipping hydration.`),!0;let h=f.decrypt(c),v=JSON.parse(h),{v:w=1,checksum:P,data:V,updatedAt:D,updatedAtMs:C}=v||{};if(V===void 0)return !0;let A=j({value:typeof C=="number"?C:D,fallbackMs:Date.now(),onInvalid:()=>{m(`persist: corrupt updatedAt in stored data for "${e}". Using current time to prevent sync overwrite.`);}});if(f.checksum!=="none"&&P!==g(V))return a(e,`Checksum mismatch loading store "${e}". Falling back to initial state.`),(!u||u())&&i(n(s()),Date.now()),!0;let _=f.deserialize(V),E=S?.version??1,M=ge({name:e,parsed:_,v:w,targetVersion:E,cfg:f,migrations:b,getInitialState:s,reportStoreError:a,sanitize:o,deepClone:n,validateState:p,safeUpdatedAt:A,applyFeatureState:i,shouldApply:u});return M.ok&&(_=M.state,(!u||u())&&(i(M.state,A),t||m(`Store "${e}" loaded from persistence`))),!0}catch(c){return Q(e,a,c)}},de=async({name:e,silent:t=false,getMeta:r,getInitialState:s,applyFeatureState:i,reportStoreError:a,warnMissingMaxSize:l,validate:y,log:m,hashState:g,deepClone:n,sanitize:o,shouldApply:u},d)=>{let S=r(),f=S?.options?.persist;if(!f)return false;let b=pe(S,f),p=c=>I({value:c,validate:y});try{let c=await Promise.resolve(d===void 0?f.driver.getItem?.(f.key)??null:d);if(c==null)return !1;if(typeof c!="string")return a(e,`Persist driver for "${e}" returned a non-string value during async hydration. Persist payloads must resolve to strings before decrypt/deserialize runs.`),!0;if(typeof f.maxSize!="number"&&c.length>fe&&l?.(c.length),typeof f.maxSize=="number"&&c.length>f.maxSize)return a(e,`Persist payload for "${e}" exceeds maxSize (${c.length} > ${f.maxSize}). Skipping hydration.`),!0;let h=f.decryptAsync?await f.decryptAsync(c):f.decrypt(c),v=JSON.parse(h),{v:w=1,checksum:P,data:V,updatedAt:D,updatedAtMs:C}=v||{};if(V===void 0)return !0;let A=j({value:typeof C=="number"?C:D,fallbackMs:Date.now(),onInvalid:()=>{m(`persist: corrupt updatedAt in stored data for "${e}". Using current time to prevent sync overwrite.`);}}),_=await q(f.checksum,V,g);if(f.checksum!=="none"&&P!==_)return a(e,`Checksum mismatch loading store "${e}". Falling back to initial state.`),(!u||u())&&i(n(s()),Date.now()),!0;let E=f.deserialize(V),M=S?.version??1,W=ge({name:e,parsed:E,v:w,targetVersion:M,cfg:f,migrations:b,getInitialState:s,reportStoreError:a,sanitize:o,deepClone:n,validateState:p,safeUpdatedAt:A,applyFeatureState:i,shouldApply:u});return W.ok&&(!u||u())&&(i(W.state,A),t||m(`Store "${e}" loaded from persistence`)),!0}catch(c){return Q(e,a,c)}},ge=({name:e,parsed:t,v:r,targetVersion:s,cfg:i,migrations:a,getInitialState:l,reportStoreError:y,sanitize:m,deepClone:g,validateState:n,safeUpdatedAt:o,applyFeatureState:u,shouldApply:d})=>{if(r!==s){let f=Object.keys(a).map(c=>Number(c)).filter(c=>c>r&&c<=s).sort((c,h)=>c-h);if(f.length===0){let c=Y({name:e,persisted:t,reason:`No migration path from v${r} to v${s} for "${e}". Applying onMigrationFail strategy.`,persistConfig:i,initialState:l(),reportStoreError:y,sanitize:m,deepClone:g});if(t=c.state,!c.requiresValidation)return (!d||d())&&u(t,o),{ok:false,state:t}}let b=false,p=true;if(f.forEach(c=>{if(!b)try{let h=a[c](t);h!==void 0&&(t=h);}catch(h){let v=Y({name:e,persisted:t,reason:`Migration to v${c} failed for "${e}": ${h?.message||h}`,persistConfig:i,initialState:l(),reportStoreError:y,sanitize:m,deepClone:g});t=v.state,p=v.requiresValidation,b=true;}}),b){if(!p)return (!d||d())&&u(t,o),{ok:false,state:t};let c=n(t);return c.ok?{ok:true,state:c.value??t}:((!d||d())&&u(g(l()),Date.now()),{ok:false,state:t})}}let S=n(t);if(!S.ok){if(r!==s){let f=i?.onMigrationFail??"reset",b=Y({name:e,persisted:t,reason:`Persisted state for "${e}" failed schema after version change. Applying onMigrationFail strategy.`,persistConfig:i,initialState:l(),reportStoreError:y,sanitize:m,deepClone:g});if(!b.requiresValidation)return (!d||d())&&u(b.state,o),{ok:false,state:b.state};let p=n(b.state);if(p.ok)return f==="reset"&&y(e,`Persisted state for "${e}" failed schema; resetting to initial.`),{ok:true,state:p.value??b.state}}return y(e,`Persisted state for "${e}" failed schema; resetting to initial.`),(!d||d())&&u(g(l()),Date.now()),{ok:false,state:t}}return {ok:true,state:S.value??t}};var me=({name:e,persistTimers:t,persistInFlight:r,persistSequence:s,persistWatchState:i,plaintextWarningsIssued:a,exists:l,getMeta:y,getStoreValue:m,reportStoreError:g,hashState:n},o=false)=>{let u=y()?.options?.persist;if(!u)return;let d=async b=>{let p=y();if(!(!p?.options?.persist||p.options.persist!==u||!l())&&!(b!==void 0&&s[e]!==b)){if(!u.allowPlaintext&&!a.has(e)&&K(u.encrypt)&&K(u.decrypt)){a.add(e);let c=`[stroid/persist] Store '${e}' is persisted in plaintext. Provide encrypt/decrypt hooks to protect sensitive data.`;A(p.options.onError,`onError(${e})`,c),q$1(c);}try{let c=u.serialize(m()),h=await q(u.checksum,c,n),v=JSON.stringify({v:p.version??1,updatedAt:p.updatedAt,updatedAtMs:p.updatedAtMs??Date.now(),checksum:h,data:c}),w=u.encryptAsync?await u.encryptAsync(v):u.encrypt(v);if(b!==void 0&&s[e]!==b)return;await Promise.resolve(u.driver.setItem?.(u.key,w)),ce(i,e,!0);}catch(c){g(e,`Could not persist store "${e}" (${c?.message||c})`);}}},S=b=>{let p=r[e],c=(s[e]??0)+1;s[e]=c;let v=(async()=>{p&&await p,!(b&&t[e]!==b)&&s[e]===c&&await d(c);})().finally(()=>{r[e]===v&&(r[e]=null),b&&t[e]===b&&delete t[e];});r[e]=v;};if(o){t[e]&&(clearTimeout(t[e]),delete t[e]),S();return}t[e]&&clearTimeout(t[e]);let f=setTimeout(()=>{t[e]===f&&S(f);},0);t[e]=f;},O=e=>me(e),Se=(e,t)=>me({...t,name:e},true);var he=false,Ne=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Ue=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,qe=Ne??Ue,Be=()=>qe==="production",He=()=>{let e={},t={},r=Object.create(null),s=Object.create(null),i=Object.create(null),a=new Set,l=new Set,y=Object.create(null),m=Object.create(null),g=n=>{n&&typeof n.then=="function"&&Promise.resolve(n).catch(()=>{});};return {api:{getPersistQueueDepth(n){return e[n]?1:0}},onStoreCreate(n){let o=n.options.persist;if(!o)return;if(!o.encryptAsync&&U(o.encrypt)&&U(o.decrypt)&&!o.allowPlaintext){let p=`[stroid/persist] Store "${n.name}" is configured for plaintext persistence. Provide encrypt/decrypt hooks or set persist.allowPlaintext: true to acknowledge.`;if(Be()){n.reportStoreError(p),n.options.persist=null;return}n.warn(p);}if(o.sensitiveData&&!o.encryptAsync&&U(o.encrypt)){n.reportStoreError(`persist: store "${n.name}" is marked sensitiveData but has no encrypt function. Plaintext data will be written to storage.`);return}let d=ue(n.name,o.encrypt,o.decrypt);if(!d.ok){n.reportStoreError(d.reason??`persist: encrypt/decrypt validation failed for store "${n.name}".`),n.options.persist=null;return}if(o.key){let p=s[o.key];p&&p!==n.name&&n.isDev()?n.warn(`Persist key collision: "${o.key}" already used by store "${p}". Store "${n.name}" will overwrite the same storage key.`):s[o.key]=n.name;}let S=n.getMeta()?.updateCount??0,f=()=>{let p=n.getMeta();return p?(p.updateCount??0)===S:false},b=ye({name:n.name,silent:true,getMeta:n.getMeta,getInitialState:n.getInitialState,applyFeatureState:n.applyFeatureState,reportStoreError:(p,c)=>n.reportStoreError(c),warnMissingMaxSize:p=>{l.has(n.name)||(l.add(n.name),n.warnAlways(`[stroid/persist] Store "${n.name}" loaded ${p} bytes without a maxSize guard. Set persist.maxSize to prevent oversized payloads.`));},validate:n.validate,log:n.log,hashState:n.hashState,deepClone:n.deepClone,sanitize:n.sanitize,shouldApply:f});if(typeof b?.then=="function"?(y[n.name]={loading:true,pendingSave:false},b.then(p=>{let c=y[n.name];c&&(c.loading=false,(!p||c.pendingSave)&&O({name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:i,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(h,v)=>n.reportStoreError(v),hashState:n.hashState}),delete y[n.name]);}).catch(()=>{let p=y[n.name];p&&(p.loading=false,p.pendingSave&&O({name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:i,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(c,h)=>n.reportStoreError(h),hashState:n.hashState}),delete y[n.name]);})):b||O({name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:i,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(p,c)=>n.reportStoreError(c),hashState:n.hashState}),typeof window<"u"&&typeof window.addEventListener=="function"){m[n.name]?.();let p=window,c=false,h=()=>{c||(c=true,p.removeEventListener("pagehide",v),p.removeEventListener("beforeunload",v),delete m[n.name]);},v=()=>{h(),Se(n.name,{name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:i,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(w,P)=>n.reportStoreError(P),hashState:n.hashState});};p.addEventListener("pagehide",v,{once:true}),p.addEventListener("beforeunload",v,{once:true}),m[n.name]=h;}le({name:n.name,persistConfig:o,persistWatchState:i});},onStoreWrite(n){if(!n.options.persist)return;let o=y[n.name];if(o?.loading){o.pendingSave=true;return}O({name:n.name,persistTimers:e,persistInFlight:t,persistSequence:r,persistWatchState:i,plaintextWarningsIssued:a,exists:()=>n.hasStore(),getMeta:n.getMeta,getStoreValue:n.getStoreValue,reportStoreError:(u,d)=>n.reportStoreError(d),hashState:n.hashState});},beforeStoreDelete(n){let o=n.options.persist;if(o){delete y[n.name],l.delete(n.name),e[n.name]&&(clearTimeout(e[n.name]),delete e[n.name]),t[n.name]=null,delete r[n.name];try{g(o.driver.removeItem?.(o.key));}catch{}o.key&&s[o.key]===n.name&&delete s[o.key],m[n.name]?.(),i[n.name]?.dispose(),delete m[n.name],delete i[n.name];}},resetAll(){Object.values(e).forEach(n=>clearTimeout(n)),Object.values(m).forEach(n=>{try{n();}catch{}}),Object.values(i).forEach(n=>{try{n.dispose();}catch{}}),Object.keys(e).forEach(n=>delete e[n]),Object.keys(t).forEach(n=>{t[n]=null,delete t[n];}),Object.keys(r).forEach(n=>delete r[n]),Object.keys(s).forEach(n=>delete s[n]),Object.keys(i).forEach(n=>delete i[n]),Object.keys(y).forEach(n=>delete y[n]),a.clear(),l.clear();}}},ve=()=>{he||(he=true,b("persist",He));};var be=false,z=1,Ge=e=>typeof e?.v=="number"?e.v:typeof e?.protocol=="number"?e.protocol:void 0,Z=new Set,x=new Set,B=100,Pe=e=>{if(!e)return null;if(e===true)return B;if(typeof e!="object")return null;let t=e.loopGuard;if(t===false)return null;if(t===true||t===void 0)return B;if(typeof t=="object"){let r=t.windowMs;return typeof r=="number"&&Number.isFinite(r)&&r>0?r:B}return B},Je=e=>typeof TextEncoder<"u"?new TextEncoder().encode(e).length:typeof Buffer<"u"?Buffer.byteLength(e):e.length,Xe=({incoming:e,accepted:t})=>{let r=t?.clock??0,s=typeof e.clock=="number"?e.clock:0;if(s!==r)return s-r;let i=e.source??"",a=t?.source??"";return i===a?0:i.localeCompare(a,"en",{sensitivity:"variant"})},Ke=e=>e?.updatedAtMs??j({value:e?.updatedAt,fallbackMs:0}),Ye=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"},ke=({name:e,syncChannels:t,instanceId:r,authToken:s,reportStoreError:i})=>{let a=t[e];if(a)try{let l={v:z,protocol:z,type:"sync-request",source:r,name:e,clock:0,requestedAt:Date.now()};s&&(l.token=s),a.postMessage(l);}catch(l){i(e,`Failed to request sync snapshot for "${e}": ${l?.message??l}`);}},Qe=(e,t)=>(t[e]=(t[e]??0)+1,t[e]),Ze=(e,t,r)=>(r[e]=Math.max(r[e]??0,t)+1,r[e]),xe=({name:e,syncChannels:t,syncWindowCleanup:r,syncClocks:s,syncVersions:i})=>{t[e]?.close(),delete t[e],r[e]?.(),delete r[e],delete s[e],delete i[e];},et=({syncChannels:e,syncWindowCleanup:t})=>{Object.values(t).forEach(r=>{try{r();}catch{}}),Object.values(e).forEach(r=>{try{r.close();}catch{}});},tt=({name:e,syncOption:t,syncChannels:r,syncClocks:s,syncVersions:i,syncWindowCleanup:a,instanceId:l,getMeta:y,getAcceptedSyncVersion:m,getStoreValue:g,hasStoreEntry:n$1,notify:o,validate:u,reportStoreError:d,warn:S,setStoreValue:f,normalizeIncomingState:b,acceptIncomingSyncVersion:p,resolveSyncVersion:c,broadcastSync:h,markLoopGuard:v,hashState:w})=>{if(!t)return;if(typeof window>"u"||typeof BroadcastChannel>"u"){d(e,`Sync enabled for "${e}" but BroadcastChannel not available in this environment.`);return}let P=typeof t=="object"?t.policy:void 0,V=P==="insecure"||P!=="strict"&&typeof t=="object"&&t.insecure===true,D=typeof t=="object"&&typeof t.authToken=="string"&&t.authToken.length>0,C=typeof t=="object"&&typeof t.verify=="function",A=typeof t=="object"&&typeof t.sign=="function",_=P==="strict"||!n()&&P!=="insecure";if(_&&!V&&!D&&!C){d(e,`Sync for "${e}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`);return}!_&&!V&&!D&&!C&&!Z.has(e)&&(Z.add(e),q$1(`Sync for "${e}" is unauthenticated. Any same-origin tab can forge sync messages. Provide sync.authToken or sync.verify to enforce authentication.`)),A&&!C&&!x.has(e)&&(x.add(e),S(`Sync for "${e}" is configured with "sign" but no "verify". "sign" has no effect unless incoming messages are verified.`));let E=typeof t=="object"?t.authToken:void 0,M=Pe(t),W=false,_e=typeof t=="object"&&t.channel?t.channel:`stroid_sync_${e}`;try{let F=new BroadcastChannel(_e);if(r[e]=F,F.onmessage=T=>{let k=T.data;if(!k||k.source===l||k.name!==e||r[e]!==F||!n$1(e)||!y(e))return;if(!Ye(k)){d(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(E&&k.token!==E){W||(d(e,`Sync message for "${e}" failed auth token verification; ignoring.`),W=!0);return}let ee=Ge(k);if(ee!==z){d(e,`Sync protocol mismatch for "${e}". Expected v${z} but received ${String(ee??"unknown")}. Ignoring message.`);return}let te=k.type==="sync-state";if(te&&(typeof k.data>"u"||typeof k.clock!="number")){d(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(typeof t=="object"&&typeof t.verify=="function"){let $=!1;try{$=!!t.verify(k);}catch(R){d(e,`Sync message verification failed for "${e}": ${R?.message??R}`);return}if(!$){d(e,`Sync message for "${e}" failed verification; ignoring.`);return}}let je=typeof t=="object"&&t.checksum==="none"?"none":"hash";if(te&&je!=="none"){let $=w(k.data);if(k.checksum!==$){d(e,`Sync checksum mismatch for "${e}". Expected ${String($)}, got ${String(k.checksum)}. Ignoring message.`);return}}if(k.type==="sync-request"){h(e);return}let re=typeof t=="object"?t.conflictResolver:null;if(Xe({incoming:{clock:k.clock,source:k.source},accepted:m(e)})<=0){let $=Ke(y(e)),R=typeof k.updatedAt=="number"?k.updatedAt:Date.now();if(re){let ne=re({local:g(e),incoming:k.data,localUpdated:$,incomingUpdated:R});if(ne!==void 0){let J$1=b(e,ne);if(J$1===null)return;let Fe=g(e);f(e,J$1);let oe=typeof t=="object"?t.resolveUpdatedAt:null,Te=oe?oe({localUpdated:$,incomingUpdated:R,now:Date.now()}):Math.max(Date.now(),$,R);c(e,Te,typeof k.clock=="number"?k.clock:0),J(e,"sync",Fe,J$1,()=>o(e),["sync"]),M&&v(e,M),o(e),h(e);}}return}let G=b(e,k.data);if(G===null)return;let De=g(e);f(e,G),p(e,typeof k.updatedAt=="number"?k.updatedAt:Date.now(),typeof k.clock=="number"?k.clock:0,typeof k.source=="string"?k.source:""),J(e,"sync",De,G,()=>o(e),["sync"]),M&&v(e,M),o(e);},typeof window<"u"&&typeof window.addEventListener=="function"){a[e]?.();let T=window,k=()=>{ke({name:e,syncChannels:r,instanceId:l,authToken:E,reportStoreError:d});};T.addEventListener("focus",k),T.addEventListener("online",k),a[e]=()=>{T.removeEventListener("focus",k),T.removeEventListener("online",k);};}queueMicrotask(()=>{ke({name:e,syncChannels:r,instanceId:l,authToken:E,reportStoreError:d});});}catch(F){S(`Failed to setup sync for "${e}": ${F?.message||F}`);}},we=({name:e,syncOption:t,syncChannels:r,syncClocks:s,instanceId:i,updatedAt:a,data:l,hashState:y,reportStoreError:m})=>{let g=r[e];if(g)try{let n=typeof t=="object"&&t.checksum==="none"?"none":"hash",o={v:z,protocol:z,type:"sync-state",source:i,name:e,clock:s[e]??0,updatedAt:j({value:a,fallbackMs:Date.now()}),data:l,checksum:n==="hash"?y(l):null};if(typeof t=="object"&&t.authToken&&(o.token=t.authToken),typeof t=="object"&&typeof t.sign=="function")try{let S=t.sign(o);if(S&&typeof S.then=="function"){m(e,`Sync signer for "${e}" returned a Promise. "sign" must be synchronous.`);return}S!==void 0&&(o.auth=S);}catch(S){m(e,`Failed to sign sync payload for "${e}": ${S?.message??S}`);return}let u=typeof t=="object"&&typeof t.maxPayloadBytes=="number"?t.maxPayloadBytes:64*1024,d=Je(JSON.stringify(o));if(d>u){m(e,`Sync payload for "${e}" exceeds ${u} bytes (${d} bytes). Skipping BroadcastChannel sync.`);return}try{g.postMessage(o);}catch(S){if(S&&typeof S=="object"&&S.name==="DataCloneError"){m(e,`Sync payload for "${e}" could not be cloned (DataCloneError). Remove non-serializable values or provide a custom serializer. Payload size ~${d} bytes.`);return}throw S}}catch(n){m(e,`Failed to broadcast sync for "${e}": ${n?.message??n}`);}},rt=()=>{let e=Object.create(null),t=Object.create(null),r=Object.create(null),s=Object.create(null),i=Object.create(null),a=new Set,l=`stroid_${Math.random().toString(16).slice(2)}`,y=(o,u)=>{r[o]={clock:t[o]??0,updatedAt:j({value:u,fallbackMs:Date.now()}),source:l};},m=(o,u)=>{Qe(o,t),y(o,u);},g=(o,u)=>{!u||!Number.isFinite(u)||(i[o]=Date.now()+u);},n=(o,u)=>{if(!u)return false;let d=i[o];return d?Date.now()>=d?(delete i[o],false):true:false};return {onStoreCreate(o){if(!o.options.sync)return;let u=o.options.sync,d=o.notify,S=typeof u=="object"?u.policy:void 0,f=S==="insecure"||S!=="strict"&&typeof u=="object"&&u.insecure===true,b=typeof u=="object"&&typeof u.authToken=="string"&&u.authToken.length>0,p=typeof u=="object"&&typeof u.verify=="function";if((S==="strict"||!o.isDev()&&S!=="insecure")&&u&&!f&&!b&&!p){o.reportStoreError(`Sync for "${o.name}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`),o.options.sync=false;return}if(tt({name:o.name,syncOption:u,syncChannels:e,syncClocks:t,syncVersions:r,syncWindowCleanup:s,instanceId:l,getMeta:o.getMeta,getAcceptedSyncVersion:h=>r[h],getStoreValue:h=>o.getStoreValue(),hasStoreEntry:()=>o.hasStore(),notify:()=>d(),validate:(h,v)=>o.validate(v),reportStoreError:(h,v)=>o.reportStoreError(v),warn:o.warn,setStoreValue:(h,v)=>o.setStoreValue(v),normalizeIncomingState:(h,v)=>{let w=I({value:v,sanitize:o.sanitize,validate:o.validate,onSanitizeError:P=>{o.reportStoreError(`Sanitize failed for incoming sync "${h}": ${P?.message??P}`);}});return w.ok?w.value:null},acceptIncomingSyncVersion:(h,v,w,P)=>{o.applyFeatureState(o.getStoreValue(),v),t[o.name]=Math.max(t[o.name]??0,w),r[o.name]={clock:w,updatedAt:v,source:P};},resolveSyncVersion:(h,v,w)=>{o.applyFeatureState(o.getStoreValue(),v);let P=Ze(o.name,w,t);return r[o.name]={clock:P,updatedAt:v,source:l},P},broadcastSync:()=>{let h=o.getMeta();h&&we({name:o.name,syncOption:o.options.sync,syncChannels:e,syncClocks:t,instanceId:l,updatedAt:h.updatedAtMs??h.updatedAt,data:o.getStoreValue(),hashState:o.hashState,reportStoreError:(v,w)=>o.reportStoreError(w)});},markLoopGuard:g,hashState:o.hashState}),e[o.name]){let h=o.getMeta();y(o.name,h?.updatedAtMs??h?.updatedAt??new Date().toISOString());}},onStoreWrite(o){if(!o.options.sync)return;let u=o.getMeta();if(!u)return;let d=Pe(o.options.sync);if(n(o.name,d)){m(o.name,u.updatedAtMs??u.updatedAt),a.has(o.name)||(a.add(o.name),o.warn(`Sync broadcast for "${o.name}" suppressed by loopGuard to prevent feedback loops.`));return}m(o.name,u.updatedAtMs??u.updatedAt),we({name:o.name,syncOption:o.options.sync,syncChannels:e,syncClocks:t,instanceId:l,updatedAt:u.updatedAtMs??u.updatedAt,data:o.next,hashState:o.hashState,reportStoreError:(S,f)=>o.reportStoreError(f)});},beforeStoreDelete(o){xe({name:o.name,syncChannels:e,syncWindowCleanup:s,syncClocks:t,syncVersions:r}),delete i[o.name],a.delete(o.name);},resetAll(){et({syncChannels:e,syncWindowCleanup:s}),Object.keys(e).forEach(o=>delete e[o]),Object.keys(t).forEach(o=>delete t[o]),Object.keys(r).forEach(o=>delete r[o]),Object.keys(s).forEach(o=>delete s[o]),Object.keys(i).forEach(o=>delete i[o]),Z.clear(),x.clear(),a.clear();}}},Ve=()=>{be||(be=true,b("sync",rt));};var Me=false,Ce=e=>{try{return typeof structuredClone=="function"?structuredClone(e):JSON.parse(JSON.stringify(e))}catch{return e}},nt=({name:e,useDevtools:t,existingDevtools:r,stores:s,warn:i})=>{if(!t||typeof window>"u")return r;let a=window.__REDUX_DEVTOOLS_EXTENSION__||window.__REDUX_DEVTOOLS_EXTENSION__;if(!a||typeof a.connect!="function")return i(`DevTools requested for "${e}" but Redux DevTools extension not found.`),r;if(r)return r;let l=a.connect({name:"stroid"});return l.init(s),l},H=({data:e,redactor:t,deepClone:r})=>{if(typeof t=="function")try{return t(r(e))}catch{return e}return e},ot=(e,t)=>{if(typeof e!="object"||typeof t!="object"||e===null||t===null)return null;let r=e,s=t,i=[],a=[],l=[],y=new Set(Object.keys(r)),m=new Set(Object.keys(s));return m.forEach(g=>{y.has(g)?Object.is(r[g],s[g])||l.push(g):i.push(g);}),y.forEach(g=>{m.has(g)||a.push(g);}),{added:i,removed:a,changed:l}},$e=({name:e,action:t,prev:r,next:s,history:i,historyLimit:a,applyRedactor:l,deepClone:y})=>{if(a===0)return;i[e]||(i[e]=[]);let m={ts:Date.now(),action:t,prev:y(l(r)),next:y(l(s)),diff:ot(r,s)};i[e].push(m),i[e].length>a&&i[e].splice(0,i[e].length-a);},Ee=({name:e,action:t,force:r=false,devtools:s,enabled:i,stores:a,applyRedactor:l})=>{if(!(!s||!r&&!i))try{let y={...a,[e]:l(a[e])};s.send({type:`${e}/${t}`},y);}catch{}},st=()=>{let e=Object.create(null),t;return {onStoreCreate(r){t=nt({name:r.name,useDevtools:!!r.options.devtools,existingDevtools:t,stores:r.getAllStores(),warn:r.warn}),$e({name:r.name,action:"create",prev:null,next:r.getStoreValue(),history:e,historyLimit:r.options.historyLimit??50,applyRedactor:s=>H({data:s,redactor:r.options.redactor,deepClone:r.deepClone}),deepClone:r.deepClone});},onStoreWrite(r){$e({name:r.name,action:r.action,prev:r.prev,next:r.next,history:e,historyLimit:r.options.historyLimit??50,applyRedactor:s=>H({data:s,redactor:r.options.redactor,deepClone:r.deepClone}),deepClone:r.deepClone}),Ee({name:r.name,action:r.action,devtools:t,enabled:!!r.options.devtools,stores:r.getAllStores(),applyRedactor:s=>H({data:s,redactor:r.options.redactor,deepClone:r.deepClone})});},afterStoreDelete(r){r.options.devtools&&Ee({name:r.name,action:"delete",force:true,devtools:t,enabled:true,stores:r.getAllStores(),applyRedactor:s=>H({data:s,redactor:r.options.redactor,deepClone:r.deepClone})}),delete e[r.name];},resetAll(){Object.keys(e).forEach(r=>{delete e[r];}),t=void 0;},api:{getHistory(r,s){if(!e[r])return [];let i=e[r];return s&&s>0?Ce(i.slice(-s)):Ce(i)},clearHistory(r){if(r){delete e[r];return}Object.keys(e).forEach(s=>{delete e[s];});}}}},Ae=()=>{Me||(Me=true,b("devtools",st));};var it=()=>{ve();},at=()=>{Ve();},ut=()=>{Ae();},Ot=()=>{it(),at(),ut();};export{it as a,at as b,ut as c,Ot as d};//# sourceMappingURL=chunk-PVATWAY4.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-PVATWAY4.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {l,v as v$1,p,oa,u,ha,fa,ba,z as z$1,da}from'./chunk-FOQKGHPS.js';var g=t=>fa(t),P=t=>ha(t),W=(t,c)=>{let r=ba().subscribers;return r[t]||(r[t]=new Set),r[t].add(c),()=>{r[t]?.delete(c),r[t]?.size===0&&delete r[t];}};var M=(t,c)=>{let s=new WeakMap,r=new WeakMap,l=new Set,o="\0",S=(e,n)=>{if(!e||typeof e!="object")return e;let i=s.get(e);if(i)return i;let u=new Proxy(e,{get(j,d,R){if(typeof d!="string")return Reflect.get(j,d,R);let h=[...n,d],p=Reflect.get(j,d,R);return (!p||typeof p!="object")&&l.add(h.join(o)),S(p,h)}});return r.set(u,n.join(o)),s.set(e,u),u},a=c(S(t,[])),f=(e,n)=>{if(!e||typeof e!="object"||n.has(e))return;n.add(e);let i=r.get(e);if(i){i&&l.add(i);return}for(let u of Object.values(e))f(u,n);};return f(a,new WeakSet),{result:a,deps:Array.from(l,e=>e.split(o))}},z=(t,c,s)=>s.some(r=>!Object.is(z$1(t,r),z$1(c,r))),$=(t,c)=>{let s,r,l$1=[];return ()=>{let o=P(t);if(o===void 0)return null;if(o===s)return r??null;if(s!==void 0&&l$1.length>0&&!z(s,o,l$1))return s=o,r??null;let S=l().selectorCloneFrozen,a=o&&typeof o=="object"&&Object.isFrozen(o)&&S?v$1(o):o,f=M(a,c);return s=o,l$1=f.deps,r=f.result,r??null}},v=(t,c,s=Object.is,r)=>{if(typeof c!="function"||typeof r!="function")return p(`subscribeWithSelector("${t}") requires selector and listener functions.`),()=>{};let l=false,o,S=()=>{let e=da[t]?.options?.snapshot;return e==="shallow"||e==="ref"?e:"deep"},a=e=>{let n=e!==void 0?e:oa(t);if(n===null||typeof n!="object")return n;let i=S();return i==="ref"?n:i==="shallow"?u(n):v$1(n)};return g(t)&&(o=c(a()),l=true),W(t,e=>{if(e===null||!g(t)){l=false,o=void 0;return}let n=c(a(e));if(!l){let u=o;l=true,o=n,r(n,u);return}if(!s(n,o)){let u=o;o=n,r(n,u);}})};export{$ as a,v as b};//# sourceMappingURL=chunk-X3JR32JD.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-X3JR32JD.js.map
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module computed/types
|
|
3
|
+
*
|
|
4
|
+
* LAYER: Module
|
|
5
|
+
* OWNS: Shared public and internal computed graph types.
|
|
6
|
+
*
|
|
7
|
+
* Consumers: Computed registry, runtime tools, and PSR surface.
|
|
8
|
+
*/
|
|
9
|
+
type RuntimeNodeId = string;
|
|
10
|
+
type RuntimePathSegment = string | number;
|
|
11
|
+
type RuntimeGraphGranularity = "store";
|
|
12
|
+
type RuntimeNodeType = "leaf" | "computed" | "async-boundary";
|
|
13
|
+
type RuntimeEdgeType = "leaf-input" | "computed-input";
|
|
14
|
+
interface RuntimeGraphNode {
|
|
15
|
+
id: RuntimeNodeId;
|
|
16
|
+
storeId: string;
|
|
17
|
+
path: readonly RuntimePathSegment[];
|
|
18
|
+
type: RuntimeNodeType;
|
|
19
|
+
estimatedCost?: number;
|
|
20
|
+
}
|
|
21
|
+
interface RuntimeGraphEdge {
|
|
22
|
+
from: RuntimeNodeId;
|
|
23
|
+
to: RuntimeNodeId;
|
|
24
|
+
type: RuntimeEdgeType;
|
|
25
|
+
}
|
|
26
|
+
interface RuntimeGraph {
|
|
27
|
+
granularity: RuntimeGraphGranularity;
|
|
28
|
+
nodes: readonly RuntimeGraphNode[];
|
|
29
|
+
edges: readonly RuntimeGraphEdge[];
|
|
30
|
+
}
|
|
31
|
+
type ComputedClassification = "deterministic" | "opaque" | "asyncBoundary";
|
|
32
|
+
interface ComputedDescriptor {
|
|
33
|
+
id: RuntimeNodeId;
|
|
34
|
+
storeId: string;
|
|
35
|
+
path: readonly RuntimePathSegment[];
|
|
36
|
+
dependencies: readonly RuntimeNodeId[];
|
|
37
|
+
nodeType: Extract<RuntimeNodeType, "computed" | "async-boundary">;
|
|
38
|
+
classification: ComputedClassification;
|
|
39
|
+
asyncBoundary?: boolean;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export type { ComputedClassification, ComputedDescriptor, RuntimeEdgeType, RuntimeGraph, RuntimeGraphEdge, RuntimeGraphGranularity, RuntimeGraphNode, RuntimeNodeId, RuntimeNodeType, RuntimePathSegment };
|
package/dist/computed.d.ts
CHANGED
|
@@ -1,8 +1,11 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { d as StoreName, a as StoreDefinition, S as StoreValue, b as StoreKey, e as StateFor } from './types.js';
|
|
2
2
|
import { S as StoreRegistry } from './store-registry.js';
|
|
3
|
+
import { RuntimeNodeId, ComputedDescriptor, RuntimeGraph, ComputedClassification } from './computed-types.js';
|
|
4
|
+
export { RuntimeEdgeType, RuntimeGraphEdge, RuntimeGraphGranularity, RuntimeGraphNode, RuntimeNodeType } from './computed-types.js';
|
|
3
5
|
import './feature.js';
|
|
4
6
|
import './options.js';
|
|
5
7
|
import './utility.js';
|
|
8
|
+
import './runtime-patch.js';
|
|
6
9
|
import './registry.js';
|
|
7
10
|
|
|
8
11
|
/**
|
|
@@ -14,6 +17,7 @@ import './registry.js';
|
|
|
14
17
|
* Consumers: Internal imports and public API.
|
|
15
18
|
*/
|
|
16
19
|
|
|
20
|
+
declare const getComputedDescriptor: (nodeId: RuntimeNodeId) => ComputedDescriptor | null;
|
|
17
21
|
declare const getFullComputedGraph: () => {
|
|
18
22
|
nodes: string[];
|
|
19
23
|
edges: Array<{
|
|
@@ -27,10 +31,13 @@ declare const getComputedDepsFor: (name: string) => {
|
|
|
27
31
|
deps: string[];
|
|
28
32
|
dependents: string[];
|
|
29
33
|
} | null;
|
|
34
|
+
declare const getRuntimeComputedGraph: () => RuntimeGraph;
|
|
35
|
+
declare const evaluateComputedFromSnapshot: (nodeId: RuntimeNodeId, snapshot: Record<string, unknown>) => unknown;
|
|
30
36
|
|
|
31
37
|
type ComputedOptions = {
|
|
32
38
|
autoDispose?: boolean;
|
|
33
39
|
onError?: (err: unknown) => void;
|
|
40
|
+
classification?: ComputedClassification;
|
|
34
41
|
};
|
|
35
42
|
type DepHandle = StoreDefinition<string, StoreValue> | StoreKey<string, StoreValue>;
|
|
36
43
|
type DepValue<T> = T extends StoreDefinition<string, infer S> ? Readonly<S> | null : T extends StoreKey<string, infer S> ? Readonly<S> | null : T extends StoreName ? Readonly<StateFor<T>> | null : StoreValue | null;
|
|
@@ -43,4 +50,4 @@ declare const isComputedStore: (name: string) => boolean;
|
|
|
43
50
|
declare const shouldAutoDisposeComputed: (name: string, registry?: StoreRegistry) => boolean;
|
|
44
51
|
declare const _resetComputedForTests: () => void;
|
|
45
52
|
|
|
46
|
-
export { type ComputedOptions, _resetComputedForTests, createComputed, deleteComputed, getComputedDepsFor, getFullComputedGraph, invalidateComputed, isComputedStore, shouldAutoDisposeComputed };
|
|
53
|
+
export { ComputedClassification, ComputedDescriptor, type ComputedOptions, RuntimeGraph, RuntimeNodeId, _resetComputedForTests, createComputed, deleteComputed, evaluateComputedFromSnapshot, getComputedDepsFor, getComputedDescriptor, getFullComputedGraph, getRuntimeComputedGraph, invalidateComputed, isComputedStore, shouldAutoDisposeComputed };
|
package/dist/computed.js
CHANGED
|
@@ -1,13 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
Store data only - handle functions outside the store.`,Er=()=>`Map/Set detected. stroid converts these to plain objects.
|
|
3
|
-
Use arrays or plain objects for best results.`,Fr=()=>`Date object detected. stroid stores it as ISO string.
|
|
4
|
-
Use new Date(value) to convert back when reading.`,Tr=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Or=()=>"Map detected; converting to plain object.",Vr=()=>"Set detected; converting to array.",Pr=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Ir=e=>`Store name "${e}" contains spaces.
|
|
5
|
-
Use camelCase or kebab-case: "userName" or "user-name"`,$r=e=>`Store name "${e}" is not allowed.
|
|
6
|
-
Reserved names: "__proto__", "constructor", "prototype".`,fn=128,gn=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=fn,yn=(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]},Dt=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||gn(n,s)&&yn(n,s)<=2});if(r){p(`Store "${e}" not found. Did you mean "${r}"?`);return}$(`Store "${e}" not found.
|
|
7
|
-
Available stores: [${t.join(", ")}]
|
|
8
|
-
Call createStore("${e}", data) first.`);};var re=new Set(["__proto__","constructor","prototype"]),At=(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,zr=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},jt=e=>{let t=De(e);return t==="function"?($(Mr()),false):t==="map"||t==="set"?(p(Er()),true):(t==="date"&&p(Fr()),true)},Nt=(e,t)=>{let r=zr(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&&!Nt(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||re.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Nt(i.value,t))return false}return true}return true},Pt=e=>Nt(e,new WeakSet),Ve=(e,t)=>{let r=zr(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()&&p(Tr()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),v()&&p(Or());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)]=Ve(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),v()&&p(Vr()),Array.from(e,n=>Ve(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&&!re.has(i)){if("get"in c||"set"in c)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=Ve(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=>Ve(n,t))}return e},ce=e=>Ve(e,new WeakSet),It=e=>typeof e!="string"||e.trim()===""?($(Pr(e)),false):re.has(e)?($($r(e)),false):e.includes(" ")?($(Ir(e)),false):true;var $t=null,Sn=()=>{if($t)return $t;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 $t=t,t},Wr=e=>{let t=Sn(),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},mn=2166136261,hn=2654435761,bn=1e5,oe=(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)=>{oe(e,t.length);for(let r=0;r<t.length;r++)oe(e,t.charCodeAt(r));},E=(e,t)=>{le(e,t);},_r=(e,t)=>{if(Number.isNaN(t)){E(e,"NaN");return}if(!Number.isFinite(t)){E(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){E(e,"-0");return}let r=t|0;if(t===r){E(e,"int"),oe(e,r);return}E(e,"num"),le(e,String(t));},me=(e,t)=>{if(e.nodes++>bn){E(e,"[max]");return}if(t===null){E(e,"null");return}let r=typeof t;if(r==="string"){E(e,"string"),le(e,t);return}if(r==="number"){E(e,"number"),_r(e,t);return}if(r==="boolean"){E(e,t?"true":"false");return}if(r==="undefined"){E(e,"undefined");return}if(r==="bigint"){E(e,"bigint"),le(e,t.toString());return}if(r==="symbol"){E(e,"symbol");let a=t;le(e,Symbol.keyFor(a)??a.description??String(a));return}if(r==="function"){E(e,"function"),le(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){E(e,"ref"),oe(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){E(e,"array"),oe(e,o.length);for(let a=0;a<o.length;a++)Object.prototype.hasOwnProperty.call(o,a)?me(e,o[a]):E(e,"hole");return}if(o instanceof Date){E(e,"date"),_r(e,o.getTime());return}if(o instanceof Map){E(e,"map"),oe(e,o.size),o.forEach((a,d)=>{me(e,d),me(e,a);});return}if(o instanceof Set){E(e,"set"),oe(e,o.size),o.forEach(a=>{me(e,a);});return}E(e,"object");let i=Object.getOwnPropertyDescriptors(o),c=[];Object.entries(i).forEach(([a,d])=>{d?.enumerable&&(re.has(a)||"get"in d||"set"in d||c.push([a,d]));}),oe(e,c.length);for(let[a,d]of c)le(e,a),me(e,d.value);},Ne=e=>{if(typeof e=="string")return Wr(JSON.stringify(e));let t={h1:mn,h2:hn,seen:new WeakMap,nextId:1,nodes:0};me(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 wn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Ae=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&&(re.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},zt=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},vn=e=>zt(e)===null,xn=e=>{let t=zt(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},ue=(e,t=new WeakMap)=>{if(xn(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(ue(i,t),ue(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(ue(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=ue(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||re.has(n)||"get"in s||"set"in s||(r[n]=ue(s.value,t));}),r},V=e=>{if(wn)try{return structuredClone(e)}catch(t){if(!vn(e)){let r=zt(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return p(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),ue(e)}return ue(e)};var Lt=new Set,Cn=()=>{Lt.clear();};x("options.legacy-warnings",Cn,30);var et=(()=>{let e=new Map;return {getItem:t=>e.has(t)?e.get(t):null,setItem:(t,r)=>{e.set(t,r);},removeItem:t=>{e.delete(t);},type:"memory"}})(),Ht=e=>{try{return typeof window>"u"?et:e==="session"||e==="sessionStorage"?window.sessionStorage??et:window.localStorage??et}catch{return et}},je=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),he=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Br=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}},Mn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Lr=e=>{try{e[Mn]=!0;}catch{}return e},En={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"},Fn=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Lr(g=>g),decrypt:Lr(g=>g),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Ht("localStorage"),...r};if(typeof e=="string")return {driver:Ht(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,c=e.sensitiveData===true,a=e.allowPlaintext===true,d=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,f=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&&Br(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||Ht("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:a,sensitiveData:c,maxSize:d,checksum:f,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},qr=e=>{if(!je(e))return [];let t=[];return Object.entries(En).forEach(([r,o])=>{he(e,r)&&(Lt.has(r)||(Lt.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},Ur=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=je(e.lifecycle)?e.lifecycle:void 0,c=je(e.persist)?e.persist:void 0,a=je(e.devtools)?e.devtools:void 0,d=e.validate??e.validator??e.schema,f=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",g=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,S=je(e.features)?{...e.features}:void 0,b=he(e,"persist"),h=he(e,"sync"),l=he(e,"devtools")||he(e,"historyLimit")||he(e,"redactor"),k=o==="global"?true:e.allowSSRGlobalStore??false,{persist:w=false,devtools:F=false,onError:j,sync:P}=e;if(c?.sensitiveData===true){let O=c.encrypt,m=c.encryptAsync;if((!O||Br(O))&&!m)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"&&!b?null:Fn(w,t),devtools:o==="temp"&&!l?false:typeof F=="boolean"?F:a?.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:d,migrations:c?.migrations??e.migrations??{},version:c?.version??e.version??1,redactor:o==="temp"&&!l?void 0:a?.redactor??e.redactor,historyLimit:o==="temp"&&!l?0:a?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!h?false:P??false,features:S,allowSSRGlobalStore:k,snapshot:f,snapshotSafety:g,explicitPersist:b,explicitSync:h,explicitDevtools:l}};var tt=Symbol("stroid.middleware.abort"),Gr=({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=V(t.next);for(let c of r){if(typeof c!="function")continue;let a,d=i;try{a=c({action:t.action,name:e,prev:t.prev,next:d,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(f){let g=`Middleware for "${e}" failed: ${f?.message??f}`;return o(g,"dev"),tt}if(a&&typeof a.then=="function"){let f=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(f,"dev"),tt}a===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=d):i=a;}return i},rt=({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 X=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;L(`${t} callback threw: ${String(n)}`);}},de=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(X(n,"onError",e),r==="critical"){o==="dev"&&p(e),ae(e);return}if(o==="always"){L(e);return}p(e);};var ot=null,Kr=e=>{ot=e;},Yr=e=>ot?ot(e):[];x("computed.order-resolver",()=>{ot=null;},105);var Jr=()=>J(Se(ye)),Q=()=>Jr().computedEntries,Pe=()=>Jr().computedDependents,Tn=(e,t)=>{let r=Q(),o=new Set,n=[],s=i=>{if(i===e)return true;if(o.has(i))return false;o.add(i),n.push(i);let c=r[i]?.deps??[];for(let a of c)if(s(a))return true;return n.pop(),false};for(let i of t)if(n.length=0,s(i))return [e,...n,e].join(" -> ");return null},Xr=(e,t)=>{let r=Pe();for(let o of t){let n=r[o];n&&(n.delete(e),n.size===0&&delete r[o]);}},Qr=(e,t,r)=>{let o=Tn(e,t);if(o)return $(`[stroid] createComputed("${e}") rejected: circular dependency detected -> ${o}
|
|
9
|
-
Define relationships without cycles.`),false;let n=Q(),s=Pe();n[e]&&Xr(e,n[e].deps),n[e]={deps:t,compute:r,stale:true};for(let i of t)s[i]||(s[i]=new Set),s[i].add(e);return true},Zr=e=>{let t=Q(),r=t[e];r&&(Xr(e,r.deps),delete t[e]);},Bt=e=>{let t=Q();t[e]&&(t[e].stale=true);},nt=e=>Object.prototype.hasOwnProperty.call(Q(),e),qt=e=>Q()[e],On=e=>{let t=Q(),r=Pe(),o=new Set,n=[...e];for(;n.length>0;){let f=n.shift(),g=r[f];if(g)for(let S of g)o.has(S)||(o.add(S),n.push(S));}if(o.size===0)return [];let s=f=>{let g=t[f];if(g)for(let S of g.deps)t[S]&&(o.has(S)||(o.add(S),s(S)));};Array.from(o).forEach(f=>s(f));let i=new Map,c=new Map;for(let f of o){let g=t[f];if(!g)continue;let S=0;for(let b of g.deps)o.has(b)&&(S++,c.has(b)||c.set(b,[]),c.get(b).push(f));i.set(f,S);}let a=[];for(let[f,g]of i)g===0&&a.push(f);a.sort();let d=[];for(;a.length>0;){let f=a.shift();d.push(f);let g=c.get(f)??[];for(let S of g){let b=(i.get(S)??1)-1;if(i.set(S,b),b===0){let h=a.findIndex(l=>l>S);h===-1?a.push(S):a.splice(h,0,S);}}}return d};Kr(On);var Vn=()=>{let e=Q(),t=Pe(),r=Object.keys(e),o=[];for(let[n,s]of Object.entries(e))for(let i of s.deps)o.push({from:i,to:n});return {nodes:r,edges:o,dependencies:Object.fromEntries(Object.entries(e).map(([n,s])=>[n,[...s.deps]])),dependents:Object.fromEntries(Object.entries(t).map(([n,s])=>[n,[...s]]))}},Ut=e=>{let t=Q()[e];if(!t)return null;let r=Pe()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var eo=new Map;var Gt=e=>{let t=eo.get(e);return !!t&&t.size>0},Ie=(e,t,r)=>{let o=eo.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 to=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,c=e.featureRuntimes,a=e.deletingStores,d=(l,k)=>{de(k,{onError:s[l]?.options?.onError,severity:"warn",visibility:"dev"});},f=({name:l,prev:k,options:w,initialState:F,getMeta:j,getStoreValue:P,hasStore:O})=>({name:l,options:w,prev:k,getMeta:j,getStoreValue:P,getAllStores:()=>t,getInitialState:()=>F,hasStore:O,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:m=>{de(m,{onError:w.onError,severity:"warn",visibility:"dev"});},warn:p,warnAlways:L,log:z,hashState:Ne,deepClone:V,sanitize:ce,validate:()=>({ok:true,value:k}),isDev:v}),g=({name:l,prev:k,options:w,initialState:F,phase:j})=>{let P=f({name:l,prev:k,options:w,initialState:F,getMeta:()=>s[l],getStoreValue:()=>t[l],hasStore:()=>ie(e,l)}),O=f({name:l,prev:k,options:w,initialState:F,getMeta:()=>{},getStoreValue:()=>k,hasStore:()=>false});ge().forEach(m=>{let I=c.get(m);j==="before"?I?.beforeStoreDelete?.(P):I?.afterStoreDelete?.(O);});},S=l=>{if(!ie(e,l))return;let k=t[l],w=s[l].options,F=o[l],j=r[l];a.add(l);try{j?.forEach(m=>{try{m(null);}catch(I){p(`Subscriber for "${l}" threw during delete: ${I?.message??I}`);}}),rt({name:l,label:"onDelete",fn:w.onDelete,args:[k],reportIssue:(m,I)=>{de(m,{onError:w.onError,severity:"warn",visibility:I});}}),g({name:l,prev:k,options:w,initialState:F,phase:"before"}),delete t[l],delete r[l],delete o[l],delete n[l],delete s[l],delete i[l],nt(l)&&ro(l);let O=e.computedDependents[l];if(O)for(let m of [...O]){let I=Ut(m);if(I&&oo(m,e)&&I.deps.every(Re=>!ie(e,Re))){S(m);continue}p(`[stroid] source store "${l}" was deleted. Computed store "${m}" depends on it and will return stale data. Call deleteComputed("${m}") to clean up.`);}g({name:l,prev:k,options:w,initialState:F,phase:"after"}),Ie("afterStoreDelete",l,{type:"afterStoreDelete",prev:k}),Xe(e,{type:"deleted",name:l}),z(`Store "${l}" deleted`);}finally{a.delete(l);}};return {deleteExistingStore:S,clearAllStores:()=>{let l=[],w=0,F=Number.POSITIVE_INFINITY;for(;w<20;){let P=Object.keys(t);if(P.length===0)break;P.forEach(m=>{ie(e,m)&&(S(m),l.push(m));}),w+=1;let O=Object.keys(t).length;if(O===0||O>=F)break;F=O;}let j=Object.keys(t).length;return j>0?p(`clearAllStores stopped after ${w} pass${w===1?"":"es"}; ${j} store(s) still registered (likely recreated during deletion).`):z(`All stores cleared (${l.length} stores removed)`),l},clearStores:l=>{let k=Object.keys(t).filter(w=>l?l.endsWith("*")?w.startsWith(l.slice(0,-1)):w===l:true);return k.forEach(w=>S(w)),k},reportStoreError:d}};var st=null;var Dn=()=>{st=null;};x("transaction.runner",Dn,120);var $e=e=>{let t=st?.get();return t||(e??J()).transaction},Nn=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 _=()=>st?(st.get()?.depth??0)>0:$e().depth>0,it=(e,t)=>{let r=$e(t);r.failed=true,r.error||(r.error=Nn(e));},at=e=>{let t=J();$e(t).pending.push(()=>Qe(t,e));},ct=(e,t)=>{let r=$e();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},be=e=>{let t=$e();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Kt=ye,so=Se(Kt),io=null,A=()=>{let e=J(so);return Et(e),e};var R=()=>A();var ao=(e,t)=>{Xe(e,t);};function co(e){io=e;}var we=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}}}),An=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)}),jn=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)}),ze=we(()=>A().stores);we(()=>A().subscribers);var lo=we(()=>A().initialStates);we(()=>A().initialFactories);var T=we(()=>A().metaEntries);we(()=>A().snapshotCache);var q=An(()=>A().featureRuntimes),no=new WeakMap,Pn=e=>{let t=no.get(e);return t||(t=to(e),no.set(e,t)),t};jn(()=>Pn(A()));var In=e=>{let t=q.get(e);if(t)return t;let r=Je(e);if(!r)return;let o=r();return q.set(e,o),o},lt=()=>{ge().forEach(e=>{In(e);});};lt();var Z=(e,t)=>ie(t??A(),e),_e=(e,t=A())=>{if(_()){let o=be(e);if(o.has)return o.value}let r=Te();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},U=(e,t,r=A())=>{r.stores[e]=t;},uo=(e,t,r=Date.now())=>{U(e,t),T[e]&&(T[e].updatedAt=new Date(r).toISOString(),T[e].updatedAtMs=r,T[e].lastCorrelationId=null,T[e].lastCorrelationAt=null,T[e].lastCorrelationAtMs=null,T[e].lastTraceContext=null,T[e].updateCount>=Number.MAX_SAFE_INTEGER?T[e].updateCount=0:T[e].updateCount+=1,io?.(e));},Yt=(e,t=A())=>{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();},$n=()=>{br(A());},zn=()=>{q.forEach(e=>{try{e.resetAll?.();}catch{}}),q.clear();};x("features.reset",zn,10);x("registries.clear",$n,20);x("registry.default",()=>{Kt=ye,so=Se(Kt);},115);var po=e=>hr(A(),e);var ut=new Set,go=e=>e?ut.has(e):ut.size>0,yo=e=>{e&&ut.add(e);},_n=()=>{ut.clear();};x("ssr.warnings",_n,60);var fo=new Set,Wn=e=>{let t=Rr();return !t||e.includes("::")?e:(v()&&!fo.has(e)&&(fo.add(e),p(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},dt=e=>Wn(typeof e=="string"?e:e.name),pt=e=>Z(e)&&!po(e)?true:(Dt(e,Object.keys(ze)),false),So=(e,t,r={})=>{de(t,{...r,onError:T[e]?.options?.onError});},mo=(e,t,r={})=>{de(e,{...r,onError:t});},pe=(e,t,r="dev")=>{So(e,t,{severity:"warn",visibility:r});},Hn=(e,t,r="dev")=>{mo(e,t,{severity:"warn",visibility:r});},We=(e,t)=>So(e,t,{severity:"critical",visibility:"always"}),He=(e,t)=>mo(e,t,{severity:"critical",visibility:"always"}),ft=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
10
|
-
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Hn(o,r,"always"),C().strictMissingFeatures)throw new Error(o)};var ho=new WeakMap,bo=new WeakMap;var gt=e=>{let t=ho.get(e);return t||(t=new Map,ho.set(e,t)),t},wo=e=>{let t=bo.get(e);return t||(t=new Map,bo.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=gt(R());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)=>(gt(R())[t]=r,true)});var ve=(e,t,r,o)=>{try{return o?.reuseInput&&Pt(t)?{ok:!0,value:t}:{ok:!0,value:ce(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return X(T[e]?.options?.onError,`onError(${e})`,s),X(r,`onError(${e})`,s),p(s),{ok:false}}},Ln=(e,t)=>{let r=new Set,o=T[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},Jt=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=Ln(e,o),s=(c,a)=>{n.forEach(d=>X(d,`onError(${e})`,c)),a==="critical"?ae(c):p(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=At(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=ve(e,t,o,n);if(!s.ok)return {ok:false};let i=Jt(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},ee=e=>{let t=R();gt(t).delete(e),wo(t).delete(e);},Bn=()=>{let e=R();gt(e).clear(),wo(e).clear();};x("validation.path-cache",Bn,50);co(ee);var vo=(e,t=R())=>{if((_()?be(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=ve(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(_()){let a=c.value;ct(e,a),at(()=>{U(e,a,t),t.initialStates[e]=V(a),delete t.initialFactories[e],ee(e);});}else U(e,c.value,t),t.initialStates[e]=V(c.value),delete t.initialFactories[e],ee(e);return !0}catch(n){return We(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var xo=new WeakMap,ko=e=>{let t=xo.get(e);return t||(t=new Map,xo.set(e,t)),t},qn=()=>{ko(R()).clear();};x("features.contexts",qn,100);var Ro=e=>{let t=R(),r=ko(t),o=r.get(e);if(o)return o;let n=T[e];if(!n)return p(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>T[e],getStoreValue:()=>ze[e],getAllStores:()=>ze,getInitialState:()=>lo[e],hasStore:()=>Z(e),setStoreValue:i=>{U(e,i);},applyFeatureState:(i,c)=>{uo(e,i,c),ee(e);},notify:()=>{},reportStoreError:i=>{We(e,i);},warn:p,warnAlways:L,log:z,hashState:Ne,deepClone:V,sanitize:ce,validate:i=>Jt(e,i,T[e]?.options?.validate),isDev:v};return r.set(e,s),s},Co=(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(We(e,n),r.assertRuntime)throw new Error(n)},Mo=(e,t)=>{lt();let r=Ro(e);r&&(r.notify=()=>t(e),Co(e,r),q.forEach(o=>{o.onStoreCreate?.(r);}));},Eo=(e,t,r,o,n)=>{lt();let s=Ro(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});Co(e,i),q.forEach(c=>{c.onStoreWrite?.(i);});};var Fo=(e,t)=>Gr({name:e,payload:t,middlewares:(()=>{let r=T[e]?.options?.middleware||[],o=C().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{pe(e,r,o);},warn:p}),yt=(e,t,r,o)=>rt({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{pe(e,n,s);}}),To=(e,t)=>{let r={...t};return r.persist&&!Ye("persist")&&(r.explicitPersist&&ft(e,"persist",r.onError),r.persist=null),r.sync&&!Ye("sync")&&(r.explicitSync&&ft(e,"sync",r.onError),r.sync=false),Ye("devtools")||(r.explicitDevtools&&ft(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var St=null,Oo=e=>(St=e,()=>{St===e&&(St=null);}),xe=e=>{St?.(e);};var mt=new Set,Un=e=>{mt.clear();};x("store-create.ssr-global-warned",()=>Un(),65);function Xt(e,t,r={}){if(_()){let m=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;He(m,r.onError),it(m);return}if(!It(e)){He(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!jt(t)){He(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&v()&&p(`createStore("${e}") received an undefined initial value. This can be indistinguishable from a missing store in some consumers; consider null or an explicit shape if that is intentional.`),qr(r).forEach(m=>{p(m);});let n=To(e,Ur(r,e,C().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let m=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;X(n.onError,`onError(${e})`,m),v()||L(m),$(m);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,c=s&&i==="production",a=n.allowSSRGlobalStore??false,d=R(),f=d.stores,g=d.subscribers,S=d.initialStates,b=d.initialFactories,h=d.metaEntries,l=d.scope==="request";if(c&&!a&&!l){let m=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
|
|
11
|
-
Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;He(m,r.onError);return}if(c&&a&&!l&&!mt.has(e)&&(mt.add(e),L(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
|
|
12
|
-
This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),Z(e,d)){let m=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return pe(e,m),{name:e}}s&&!a&&!l&&!go(e)&&v()&&(yo(e),p(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let k=ve(e,t,n.onError);if(!k.ok)return;let w=k.value,F=n.lazy===true&&typeof t=="function",j=(g[e]?.size??0)>0;if(F)f[e]=void 0,b[e]=t;else {let m=Le(e,w,n.validate,n.onError);if(!m.ok)return;U(e,m.value,d),S[e]=V(m.value);}let P=Date.now(),O=new Date(P).toISOString();return h[e]={createdAt:O,updatedAt:O,updatedAtMs:P,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},ee(e),Mo(e,xe),yt(e,"onCreate",h[e].options.onCreate,[w]),ao(d,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),j&&xe(e),z(`Store "${e}" created -> ${JSON.stringify(w)}`),{name:e}}var Vo=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")},Qt=e=>(Vo(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Do=e=>{if(!Vo(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 No=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Zt=(e,t)=>{if(t==="ref"){if(!v())return e;try{return Qt(e)}catch{return e}}if(t==="shallow"){let o=Ae(e);if(!v())return o;try{return Qt(o)}catch{return o}}let r=V(e);if(!v())return r;try{return Do(r)}catch{return r}};var Ao=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 a=Yr(o),d=new Set(o);for(let h of a)d.has(h)||(o.push(h),d.add(h));let f=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,g=n.chunkDelayMs,S=f===Number.POSITIVE_INFINITY&&g===0;return {names:o,sliceSize:f,chunkDelayMs:g,runInline:S,prioritySet:i}};var er=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}),tr=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),rr=(e,t)=>{e&&(e.metrics=t);};var Be=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},jo=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>Qe(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var qe=null,ht=null;var Gn=()=>{qe=null,ht=null;};x("write-context.runner",Gn,121);var bt=()=>ht?.get()??qe,or=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(ht)return ht.run(e,t);let r=qe;qe=e;try{return t()}finally{qe=r;}};var Po=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)},Io=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:c,runInline:a,prioritySet:d}=t,g=e.stores,S=e.subscribers,b=e.metaEntries,h=e.snapshotCache,l=C().defaultSnapshotMode,k=y=>No(b[y],l),w=y=>g[y],F=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),j=Gt("beforeFlush"),P=Gt("afterFlush"),O=y=>{j&&Ie("beforeFlush",y,{type:"beforeFlush"});},m=(y,D)=>{P&&Ie("afterFlush",y,{type:"afterFlush",elapsedMs:D});},I=y=>{let D=b[y];if(!D)return null;let M=D.lastCorrelationId??void 0,u=D.lastTraceContext??void 0;return !M&&!u?null:{correlationId:M,traceContext:u}},Re=()=>{o();};if(a){for(let y of s){let D=S[y];if(!D||D.size===0)continue;let M=b[y]?.updateCount??0,u=k(y),fe=w(y),W=h[y],H=W&&W.source===fe&&W.mode===u?W.snapshot:(()=>{let N=Zt(fe,u);return h[y]={version:r,snapshot:N,source:fe,mode:u},N})(),G=er(b[y]?.metrics);O(y);let ne=F(),te=Array.from(D),Ce=I(y),Me=()=>{for(let N of te)try{N(H);}catch(se){let K=b[y]?.options?.snapshotSafety??"warn";if(v()&&(u==="ref"||u==="shallow")&&Po(se)){if(K==="throw")throw se;if(K==="auto-clone")try{let Fe=V(H);p(`Snapshot mutation detected for "${y}". Delivered a cloned snapshot to the subscriber.`);try{N(Fe);}catch(Rt){p(`Subscriber for "${y}" threw on cloned snapshot: ${Rt?.message??Rt}`);}continue}catch{}p(`Snapshot mutation detected for "${y}": ${se?.message??se}`);continue}p(`Subscriber for "${y}" threw: ${se?.message??se}`);}};Ce?or(Ce,Me):Me();let Ee=F()-ne;m(y,Ee),tr(G,Ee),rr(b[y],G),(b[y]?.updateCount??M)!==M&&n.pendingNotifications.add(y);}Re();return}let ir=y=>{let D=[];for(let M of s){if(y&&!y(M))continue;let u=S[M];if(!u||u.size===0)continue;let fe=b[M]?.updateCount??0,W=k(M),H=w(M),G=h[M],ne=G&&G.source===H&&G.mode===W?G.snapshot:(()=>{let te=Zt(H,W);return h[M]={version:r,snapshot:te,source:H,mode:W},te})();D.push({name:M,snapshot:ne,version:fe,subscribers:Array.from(u),subscriberSet:new Set(u),notified:new Set,metrics:er(b[M]?.metrics),totalMs:0,beforeHooked:false});}return D},ar=d?ir(y=>d.has(y)):[],cr=ir(y=>!d||!d.has(y)),xt=(y,D)=>{let M=()=>{if(y.length===0){D();return}let u=y.shift();if((b[u.name]?.updateCount??u.version)!==u.version){if(n.pendingNotifications.add(u.name),y.length===0){D();return}Be(M,c);return}let W=()=>{let B=S[u.name];if(!(!B||B.size===0))for(let N of B)u.subscriberSet.has(N)||(u.subscriberSet.add(N),u.subscribers.push(N));};W();let H=u.subscribers;if(H.length===0){if(y.length===0){D();return}Be(M,c);return}u.beforeHooked||(u.beforeHooked=true,O(u.name));let G=F(),ne=0,te=false,Ce=I(u.name),Me=()=>{for(let B=0;B<H.length&&ne<i;B+=1){let N=H[B];if(u.notified.has(N))continue;u.notified.add(N);try{N(u.snapshot);}catch(K){let kt=b[u.name]?.options?.snapshotSafety??"warn",Fe=k(u.name);if(v()&&(Fe==="ref"||Fe==="shallow")&&Po(K)){if(kt==="throw")throw K;if(kt==="auto-clone")try{let lr=V(u.snapshot);p(`Snapshot mutation detected for "${u.name}". Delivered a cloned snapshot to the subscriber.`);try{N(lr);}catch(ur){p(`Subscriber for "${u.name}" threw on cloned snapshot: ${ur?.message??ur}`);}if(u.notified.add(N),ne+=1,(b[u.name]?.updateCount??u.version)!==u.version){te=!0,n.pendingNotifications.add(u.name);break}continue}catch{}p(`Snapshot mutation detected for "${u.name}": ${K?.message??K}`);continue}p(`Subscriber for "${u.name}" threw: ${K?.message??K}`);}if(ne+=1,(b[u.name]?.updateCount??u.version)!==u.version){te=true,n.pendingNotifications.add(u.name);break}}};if(Ce?or(Ce,Me):Me(),u.totalMs+=F()-G,te){if(y.length===0){D();return}Be(M,c);return}W();let Ee=false;for(let B of H)if(!u.notified.has(B)){Ee=true;break}if(Ee?y.push(u):(tr(u.metrics,u.totalMs),rr(b[u.name],u.metrics),m(u.name,u.totalMs)),y.length===0){D();return}Be(M,c);};M();};ar.length>0?xt(ar,()=>xt(cr,Re)):xt(cr,Re);};var Kn=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=Ao(t);Io(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&nr(e);});},nr=e=>{jo(e,Kn);};var Yn=e=>{let t=R(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&nr(t);};Oo(Yn);var sr=(e,t)=>{let o=R().subscribers;return o[e]||(o[e]=new Set),o[e].add(t),()=>{o[e]?.delete(t),o[e]?.size===0&&delete o[e];}};var Jn=()=>{let e=R().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};x("notify.reset",Jn,40);var Xn=new Set;x("store-write.slow-mutator-warned",()=>Xn.clear(),65);var Qn=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var zo=e=>bt(),$o=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:c})=>{let a=e.metaEntries;U(t,o,e),ee(t);let d=Date.now();a[t].updatedAt=new Date(d).toISOString(),a[t].updatedAtMs=d;let f=c??bt();f&&(f.correlationId||f.traceContext)?(a[t].lastCorrelationId=f.correlationId??null,a[t].lastCorrelationAt=new Date(d).toISOString(),a[t].lastCorrelationAtMs=d,a[t].lastTraceContext=f.traceContext??null):(a[t].lastCorrelationId=null,a[t].lastCorrelationAt=null,a[t].lastCorrelationAtMs=null,a[t].lastTraceContext=null),Qn(a[t]),Eo(t,n,r,o,xe),yt(t,s,a[t].options[s],[r,o]),xe(t),z(i);},_o=(e,t)=>{let r=t.context??bt();if(_()){ct(t.name,t.next),at(()=>$o(e,{...t,context:r}));return}$o(e,{...t,context:r});};function Ue(e,t){let r=dt(e);if(!r)return {ok:false,reason:"invalid-args"};let o=R(),n=Zn(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 Zn=(e,t,r,o="hydrate",n)=>{let s=(h,l)=>(_()&&it(l??h),{ok:false,reason:h});if(!pt(t))return s("not-found",`replaceStore("${t}") called before createStore().`);let i=_()?be(t):{has:false,value:void 0},c=i.has?i.value:_e(t,e),a=ve(t,r);if(!a.ok)return s("sanitize",`replaceStore("${t}") failed sanitize`);let d=a.value;if(d===void 0){let h=`Whole-store undefined replacement is blocked for "${t}". Use null for intentional empty state.`;return pe(t,h),s("undefined",h)}let f=e.metaEntries[t]?.options?.validate,g=zo(),S=Fo(t,{action:o,prev:c,next:d,path:null,correlationId:g?.correlationId,traceContext:g?.traceContext});if(S===tt)return s("middleware",`replaceStore("${t}") aborted by middleware`);let b=Le(t,S,f);return b.ok?(_o(e,{name:t,prev:c,next:b.value,action:o,hookLabel:"onSet",logMessage:`Store "${t}" ${o==="hydrate"?"hydrated":"replaced"}`,context:g}),{ok:true}):s("validate",`replaceStore("${t}") failed validation`)};var es=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Wo=(e,t)=>t==="ref"?e:t==="shallow"?Ae(e):V(e);function ke(e,t){let r=dt(e);if(!pt(r))return null;let o=R();if(!vo(r,o))return null;Yt(r,o);let n=_e(r,o),s=es(o.metaEntries[r],C().defaultSnapshotMode);return n===null||typeof n!="object"?n:Wo(n,s);}var Ge=e=>Z(e);var Ke=e=>({name:e});var wt=()=>R().computedCleanups,Ho=new WeakMap,Lo=new WeakMap,vt=e=>{let t=Ho.get(e);return t||(t=new Map,Ho.set(e,t)),t},ts=e=>{let t=Lo.get(e);return t||(t=new Map,Lo.set(e,t)),t};function vc(e,t,r,o={}){if(!e||typeof e!="string"){p("createComputed requires a store name as first argument");return}if(!Array.isArray(t)||t.length===0){p(`createComputed("${e}") requires at least one dependency`);return}if(typeof r!="function"){p(`createComputed("${e}") requires a compute function as third argument`);return}let n=wt(),s=n.get(e);s&&(s(),n.delete(e));let i=t.map(g=>typeof g=="string"?g:g?.name);if(i.some(g=>!g||typeof g!="string")){p(`createComputed("${e}") dependencies must be store names or store handles.`);return}if(v()){let g=i.filter(S=>!Ge(S));g.length>0&&p(`createComputed("${e}") dependencies not found at registration: ${g.join(", ")}. Computed values will receive null until those stores are created.`);}if(!Qr(e,i,r))return;vt(R()).set(e,{...o});let a=Bo(e,t,r,o.onError),d=Ke(e);Ge(e)?Ue(d,a):Xt(e,a);let f=[];for(let g of i){let S=sr(g,()=>{qo(e,i,r,o.onError);});f.push(S);}return wt().set(e,()=>{f.forEach(g=>g()),Zr(e),vt(R()).delete(e);}),v()&&z(`computed store "${e}" created, deps: [${i.join(", ")}]`),d}var Bo=(e,t,r,o)=>{let n=t.map(s=>typeof s=="string"?ke(Ke(s)):ke(s));try{return r(...n)}catch(s){p(`createComputed("${e}") compute function threw: ${s?.message??s}`),X(o,`computed.onError(${e})`,s);let i=Ke(e);return Ge(e)?ke(i):null}},qo=(e,t,r,o)=>{if(!qt(e))return;let s=R();if(s.notify.isFlushing){let d=s.notify.flushId,f=ts(s);if(f.get(e)===d)return;f.set(e,d);}let i=Bo(e,t,r,o),c=Ke(e),a=ke(c);Object.is(i,a)||(Ue(c,i),Bt(e));},xc=e=>{let t=qt(e);if(!t){p(`invalidateComputed("${e}") -- "${e}" is not a computed store`);return}Bt(e),qo(e,t.deps,t.compute);},ro=e=>{let t=wt(),r=t.get(e);if(!r){v()&&p(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);},kc=e=>nt(e),oo=(e,t=R())=>vt(t).get(e)?.autoDispose===true,Rc=()=>{let e=wt();e.forEach(t=>t()),e.clear(),vt(R()).clear();};export{Rc as _resetComputedForTests,vc as createComputed,ro as deleteComputed,Ut as getComputedDepsFor,Vn as getFullComputedGraph,xc as invalidateComputed,kc as isComputedStore,oo as shouldAutoDisposeComputed};//# sourceMappingURL=computed.js.map
|
|
1
|
+
export{$ as _resetComputedForTests,W as createComputed,Y as deleteComputed,F as evaluateComputedFromSnapshot,D as getComputedDepsFor,B as getComputedDescriptor,C as getFullComputedGraph,E as getRuntimeComputedGraph,X as invalidateComputed,Z as isComputedStore,_ as shouldAutoDisposeComputed}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';//# sourceMappingURL=computed.js.map
|
|
13
2
|
//# sourceMappingURL=computed.js.map
|
package/dist/core.js
CHANGED
|
@@ -1,23 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
Store data only - handle functions outside the store.`,Cr=()=>`Map/Set detected. stroid converts these to plain objects.
|
|
3
|
-
Use arrays or plain objects for best results.`,Mr=()=>`Date object detected. stroid stores it as ISO string.
|
|
4
|
-
Use new Date(value) to convert back when reading.`,Tr=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",Er=()=>"Map detected; converting to plain object.",Fr=()=>"Set detected; converting to array.",Vr=(e,t,r)=>`Path depth of ${e} exceeded maximum of ${t}.
|
|
5
|
-
"${r.join(".")}"
|
|
6
|
-
This is a data design issue. Split into separate stores:
|
|
7
|
-
createStore("${r[0]}", ...) and createStore("${r[1]}", ...)`,Dr=(e,t)=>`Deep nesting detected (${e} levels): "${t.join(".")}"
|
|
8
|
-
Consider splitting into separate stores for better readability.`,Or=(e,t)=>`Path "${e.join(".")}" not found - reached null at "${t}"`,Ar=e=>`Cannot go deeper at "${e}" - value is not an object`,Pr=e=>`Store name must be a non-empty string. Got: ${JSON.stringify(e)}`,Nr=e=>`Store name "${e}" contains spaces.
|
|
9
|
-
Use camelCase or kebab-case: "userName" or "user-name"`,jr=e=>`Store name "${e}" is not allowed.
|
|
10
|
-
Reserved names: "__proto__", "constructor", "prototype".`,un=128,dn=(e,t)=>Math.abs(e.length-t.length)>2?false:Math.max(e.length,t.length)<=un,fn=(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]},Dt=(e,t)=>{let r=t.find(o=>{let n=o.toLowerCase(),s=e.toLowerCase();return n.includes(s)||s.includes(n)||dn(n,s)&&fn(n,s)<=2});if(r){S(`Store "${e}" not found. Did you mean "${r}"?`);return}H(`Store "${e}" not found.
|
|
11
|
-
Available stores: [${t.join(", ")}]
|
|
12
|
-
Call createStore("${e}", data) first.`);};var G=new Set(["__proto__","constructor","prototype"]),At=(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 ce=e=>e===null?"null":Array.isArray(e)?"array":e instanceof Map?"map":e instanceof Set?"set":e instanceof Date?"date":typeof e=="function"?"function":typeof e,Ir=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null},Ce=e=>{let t=ce(e);return t==="function"?(H(Rr()),false):t==="map"||t==="set"?(S(Cr()),true):(t==="date"&&S(Mr()),true)},Ot=(e,t)=>{let r=Ir(e);if(r)throw new Error(`${r} values are not supported`);let o=ce(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&&!Ot(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||G.has(s))return false;if("get"in i||"set"in i)throw new Error(`Accessor properties are not supported during sanitize ("${s}")`);if(!Ot(i.value,t))return false}return true}return true},Pt=e=>Ot(e,new WeakSet),ze=(e,t)=>{let r=Ir(e);if(r)throw new Error(`${r} values are not supported`);let o=ce(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 M()&&S(Tr()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),M()&&S(Er());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)]=ze(i,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),M()&&S(Fr()),Array.from(e,n=>ze(n,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n={},s=Object.getOwnPropertyDescriptors(e);for(let[i,a]of Object.entries(s))if(a.enumerable&&!G.has(i)){if("get"in a||"set"in a)throw new Error(`Accessor properties are not supported during sanitize ("${i}")`);n[i]=ze(a.value,t);}return n}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(n=>ze(n,t))}return e},ge=e=>ze(e,new WeakSet),Nt=e=>typeof e!="string"||e.trim()===""?(H(Pr(e)),false):G.has(e)?(H(jr(e)),false):e.includes(" ")?(H(Nr(e)),false):true;var jt=null,pn=()=>{if(jt)return jt;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 jt=t,t},zr=e=>{let t=pn(),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},gn=2166136261,Sn=2654435761,yn=1e5,le=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},Se=(e,t)=>{le(e,t.length);for(let r=0;r<t.length;r++)le(e,t.charCodeAt(r));},P=(e,t)=>{Se(e,t);},$r=(e,t)=>{if(Number.isNaN(t)){P(e,"NaN");return}if(!Number.isFinite(t)){P(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){P(e,"-0");return}let r=t|0;if(t===r){P(e,"int"),le(e,r);return}P(e,"num"),Se(e,String(t));},Me=(e,t)=>{if(e.nodes++>yn){P(e,"[max]");return}if(t===null){P(e,"null");return}let r=typeof t;if(r==="string"){P(e,"string"),Se(e,t);return}if(r==="number"){P(e,"number"),$r(e,t);return}if(r==="boolean"){P(e,t?"true":"false");return}if(r==="undefined"){P(e,"undefined");return}if(r==="bigint"){P(e,"bigint"),Se(e,t.toString());return}if(r==="symbol"){P(e,"symbol");let c=t;Se(e,Symbol.keyFor(c)??c.description??String(c));return}if(r==="function"){P(e,"function"),Se(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){P(e,"ref"),le(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){P(e,"array"),le(e,o.length);for(let c=0;c<o.length;c++)Object.prototype.hasOwnProperty.call(o,c)?Me(e,o[c]):P(e,"hole");return}if(o instanceof Date){P(e,"date"),$r(e,o.getTime());return}if(o instanceof Map){P(e,"map"),le(e,o.size),o.forEach((c,l)=>{Me(e,l),Me(e,c);});return}if(o instanceof Set){P(e,"set"),le(e,o.size),o.forEach(c=>{Me(e,c);});return}P(e,"object");let i=Object.getOwnPropertyDescriptors(o),a=[];Object.entries(i).forEach(([c,l])=>{l?.enumerable&&(G.has(c)||"get"in l||"set"in l||a.push([c,l]));}),le(e,a.length);for(let[c,l]of a)Se(e,c),Me(e,l.value);},_e=e=>{if(typeof e=="string")return zr(JSON.stringify(e));let t={h1:gn,h2:Sn,seen:new WeakMap,nextId:1,nodes:0};Me(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 mn=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",We=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&&(G.has(o)||"get"in n||"set"in n||(t[o]=n.value));}),t},It=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},hn=e=>It(e)===null,bn=e=>{let t=It(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},ye=(e,t=new WeakMap)=>{if(bn(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(ye(i,t),ye(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(ye(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,i)=>{n[i]=ye(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||G.has(n)||"get"in s||"set"in s||(r[n]=ye(s.value,t));}),r},O=e=>{if(mn)try{return structuredClone(e)}catch(t){if(!hn(e)){let r=It(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return S(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),ye(e)}return ye(e)},$t=(e,t)=>{if(Object.is(e,t))return true;if(!e||!t||typeof e!="object"||typeof t!="object")return false;let r=e,o=t,n=Object.keys(r),s=Object.keys(o);if(n.length!==s.length)return false;for(let i of n)if(!Object.prototype.hasOwnProperty.call(o,i)||!Object.is(r[i],o[i]))return false;return true};var _r=10,wn=5,vn=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},Te=e=>Array.isArray(e)?[...e]:typeof e=="string"&&!e.includes(".")?[e]:typeof e=="string"?vn(e):[String(e)],He=e=>{let t=Te(e),r=t.length;return r>_r?(H(Vr(r,_r,t)),false):(r>wn&&S(Dr(r,t)),true)},zt=(e,t)=>{let r=Te(t),o=e;for(let n of r){if(o==null){S(Or(r,n));return}if(typeof o!="object"){S(Ar(n));return}o=o[n];}return o},_t=(e,t,r)=>{let o=Te(t);if(o.length===0)return e;for(let s of o)if(G.has(s))return $(`Blocked forbidden path segment "${String(s)}" in setStore path "${o.join(".")}".`),e;let n=(s,i)=>{let a=o[i],c=i===o.length-1;if(Array.isArray(s)){let l=Number(a);if(!Number.isInteger(l))return s;let u=[...s];return c?(u[l]=r,u):(u[l]=n(u[l],i+1),u)}if(s&&typeof s=="object"){if(G.has(a))return $(`Blocked unsafe path segment "${String(a)}" while setting "${o.join(".")}".`),s;let l={...s};return c?(l[a]=r,l):(l[a]=n(l[a],i+1),l)}if(s==null&&!c){let l=Number.isInteger(Number(a)),u=l?[]:{};if(l){let w=u,b=Number(a);return w[b]=n(void 0,i+1),w}return u[a]=n(void 0,i+1),u}return c?r:s};return n(e,0)};var Ht=new Set,xn=()=>{Ht.clear();};F("options.legacy-warnings",xn,30);var nt=(()=>{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"}})(),Wt=e=>{try{return typeof window>"u"?nt:e==="session"||e==="sessionStorage"?window.sessionStorage??nt:window.localStorage??nt}catch{return nt}},Le=e=>typeof e=="object"&&e!==null&&!Array.isArray(e),Ee=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),Hr=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}},kn=typeof Symbol=="function"?Symbol.for("stroid.persist.defaultCrypto"):"__stroid_persist_defaultCrypto__",Wr=e=>{try{e[kn]=!0;}catch{}return e},Rn={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"},Cn=(e,t)=>{if(!e)return null;let r={key:`stroid_${t}`,serialize:JSON.stringify,deserialize:JSON.parse,encrypt:Wr(w=>w),decrypt:Wr(w=>w),allowPlaintext:false,sensitiveData:false,onMigrationFail:"reset",checksum:"hash"};if(e===true)return {driver:Wt("localStorage"),...r};if(typeof e=="string")return {driver:Wt(e),...r};let o=e.encrypt||r.encrypt,n=e.decrypt||r.decrypt,s=e.encryptAsync,i=e.decryptAsync,a=e.sensitiveData===true,c=e.allowPlaintext===true,l=typeof e.maxSize=="number"&&Number.isFinite(e.maxSize)&&e.maxSize>0?e.maxSize:void 0,u=e.checksum==="sha256"?"sha256":e.checksum==="none"?"none":"hash";if(s&&!i||!s&&i)throw new Error(`[stroid/persist] Store "${t}" must provide both encryptAsync and decryptAsync when using async crypto.`);if(a&&Hr(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||Wt("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:c,sensitiveData:a,maxSize:l,checksum:u,onMigrationFail:e.onMigrationFail||"reset",onStorageCleared:e.onStorageCleared}},Lr=e=>{if(!Le(e))return [];let t=[];return Object.entries(Rn).forEach(([r,o])=>{Ee(e,r)&&(Ht.has(r)||(Ht.add(r),t.push(`createStore option "${r}" is deprecated. Use "${o}" instead.`)));}),t},Br=(e={},t,r="deep")=>{let o=e.scope??"request",n=e.lazy===true,s=e.pathCreate===true,i=Le(e.lifecycle)?e.lifecycle:void 0,a=Le(e.persist)?e.persist:void 0,c=Le(e.devtools)?e.devtools:void 0,l=e.validate??e.validator??e.schema,u=e.snapshot==="shallow"||e.snapshot==="ref"||e.snapshot==="deep"?e.snapshot:r==="shallow"||r==="ref"||r==="deep"?r:"deep",w=e.snapshotSafety==="warn"||e.snapshotSafety==="throw"||e.snapshotSafety==="auto-clone"?e.snapshotSafety:void 0,b=Le(e.features)?{...e.features}:void 0,h=Ee(e,"persist"),x=Ee(e,"sync"),d=Ee(e,"devtools")||Ee(e,"historyLimit")||Ee(e,"redactor"),f=o==="global"?true:e.allowSSRGlobalStore??false,{persist:g=false,devtools:R=false,onError:k,sync:T}=e;if(a?.sensitiveData===true){let V=a.encrypt,y=a.encryptAsync;if((!V||Hr(V))&&!y)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"&&!h?null:Cn(g,t),devtools:o==="temp"&&!d?false:typeof R=="boolean"?R:c?.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:k,validate:l,migrations:a?.migrations??e.migrations??{},version:a?.version??e.version??1,redactor:o==="temp"&&!d?void 0:c?.redactor??e.redactor,historyLimit:o==="temp"&&!d?0:c?.historyLimit??e.historyLimit??50,sync:o==="temp"&&!x?false:T??false,features:b,allowSSRGlobalStore:f,snapshot:u,snapshotSafety:w,explicitPersist:h,explicitSync:x,explicitDevtools:d}};var st=Symbol("stroid.middleware.abort"),Ur=({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=O(t.next);for(let a of r){if(typeof a!="function")continue;let c,l=i;try{c=a({action:t.action,name:e,prev:t.prev,next:l,path:t.path,correlationId:t.correlationId,traceContext:t.traceContext});}catch(u){let w=`Middleware for "${e}" failed: ${u?.message??u}`;return o(w,"dev"),st}if(c&&typeof c.then=="function"){let u=`Middleware for "${e}" must be synchronous. Promise-returning middleware is not supported.`;return o(u,"dev"),st}c===void 0?(M()&&!s.has(a)&&(s.add(a),n(`Middleware for "${e}" returned undefined; treating as pass-through. Return the new state to override.`)),i=l):i=c;}return i},it=({name:e,label:t,fn:r,args:o,reportIssue:n})=>{if(typeof r=="function")try{r(...o);}catch(s){let i=`${t} for "${e}" failed: ${s?.message??s}`;n(i,"always");}};var Q=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;K(`${t} callback threw: ${String(n)}`);}},me=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(Q(n,"onError",e),r==="critical"){o==="dev"&&S(e),$(e);return}if(o==="always"){K(e);return}S(e);};var at=null,qr=e=>{at=e;},Kr=e=>at?at(e):[];F("computed.order-resolver",()=>{at=null;},105);var Gr=()=>ne(Re(ke)),Lt=()=>Gr().computedEntries,Yr=()=>Gr().computedDependents;var Jr=e=>Object.prototype.hasOwnProperty.call(Lt(),e);var Mn=e=>{let t=Lt(),r=Yr(),o=new Set,n=[...e];for(;n.length>0;){let u=n.shift(),w=r[u];if(w)for(let b of w)o.has(b)||(o.add(b),n.push(b));}if(o.size===0)return [];let s=u=>{let w=t[u];if(w)for(let b of w.deps)t[b]&&(o.has(b)||(o.add(b),s(b)));};Array.from(o).forEach(u=>s(u));let i=new Map,a=new Map;for(let u of o){let w=t[u];if(!w)continue;let b=0;for(let h of w.deps)o.has(h)&&(b++,a.has(h)||a.set(h,[]),a.get(h).push(u));i.set(u,b);}let c=[];for(let[u,w]of i)w===0&&c.push(u);c.sort();let l=[];for(;c.length>0;){let u=c.shift();l.push(u);let w=a.get(u)??[];for(let b of w){let h=(i.get(b)??1)-1;if(i.set(b,h),h===0){let x=c.findIndex(d=>d>b);x===-1?c.push(b):c.splice(x,0,b);}}}return l};qr(Mn);var Bt=e=>{let t=Lt()[e];if(!t)return null;let r=Yr()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Xr=e=>{if(typeof e!="object"||e===null)return false;let t=e;if(t.$$typeof||typeof window<"u"&&e instanceof Element)return false;let r=t.constructor?.name;return !(r&&r!=="Object"&&r!=="Array")},Ut=e=>(Xr(e)&&(Object.isFrozen(e)||Object.freeze(e)),e),Qr=e=>{if(!Xr(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 ct=null;var Tn=()=>{ct=null;};F("transaction.runner",Tn,120);var Be=e=>{let t=ct?.get();return t||(e??ne()).transaction},En=e=>e instanceof Error?e:typeof e=="string"?new Error(e):e&&typeof e?.message=="string"?new Error(e.message):new Error("setStoreBatch aborted");var E=()=>ct?(ct.get()?.depth??0)>0:Be().depth>0,j=(e,t)=>{let r=Be(t);r.failed=true,r.error||(r.error=En(e));},lt=e=>{let t=ne();Be(t).pending.push(()=>ot(t,e));},ut=(e,t)=>{let r=Be();r.stagedValues.set(e,t),r.snapshotCache.delete(e);},ue=e=>{let t=Be();return t.stagedValues.has(e)?{has:true,value:t.stagedValues.get(e)}:{has:false,value:void 0}};var Zr=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},qt=(e,t)=>{if(t==="ref"){if(!M())return e;try{return Ut(e)}catch{return e}}if(t==="shallow"){let o=We(e);if(!M())return o;try{return Ut(o)}catch{return o}}let r=O(e);if(!M())return r;try{return Qr(r)}catch{return r}};var eo=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 a=new Set;if(i){for(let x of t)r.push(x),a.add(x);for(let x of s)a.has(x)&&o.push(x);for(let x of r)i.has(x)||o.push(x);}else for(let x of t)r.push(x),a.add(x),o.push(x);t.clear();let c=Kr(o),l=new Set(o);for(let x of c)l.has(x)||(o.push(x),l.add(x));let u=Number.isFinite(n.chunkSize)&&n.chunkSize>0?n.chunkSize:Number.POSITIVE_INFINITY,w=n.chunkDelayMs,b=u===Number.POSITIVE_INFINITY&&w===0;return {names:o,sliceSize:u,chunkDelayMs:w,runInline:b,prioritySet:i}};var Kt=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}),Gt=(e,t)=>(e.notifyCount+=1,e.totalNotifyMs+=t,e.lastNotifyMs=t,e),Yt=(e,t)=>{e&&(e.metrics=t);};var Ue=(e,t)=>{if(t>0&&typeof setTimeout=="function"){setTimeout(e,t);return}if(typeof queueMicrotask=="function"){queueMicrotask(e);return}Promise.resolve().then(e);},to=(e,t)=>{let r=e.notify;if(r.notifyScheduled)return;r.notifyScheduled=true;let o=()=>ot(e,()=>t(e));typeof queueMicrotask=="function"?queueMicrotask(o):Promise.resolve().then(o);};var ro=new Map;var Jt=e=>{let t=ro.get(e);return !!t&&t.size>0},qe=(e,t,r)=>{let o=ro.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 Ke=null,dt=null;var Fn=()=>{Ke=null,dt=null;};F("write-context.runner",Fn,121);var ft=()=>dt?.get()??Ke,Xt=(e,t)=>{if(!e||!e.correlationId&&!e.traceContext)return t();if(dt)return dt.run(e,t);let r=Ke;Ke=e;try{return t()}finally{Ke=r;}};var oo=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)},no=(e,t,r,o)=>{let n=e.notify,{names:s,sliceSize:i,chunkDelayMs:a,runInline:c,prioritySet:l}=t,w=e.stores,b=e.subscribers,h=e.metaEntries,x=e.snapshotCache,d=C().defaultSnapshotMode,f=m=>Zr(h[m],d),g=m=>w[m],R=()=>typeof performance<"u"&&performance.now?performance.now():Date.now(),k=Jt("beforeFlush"),T=Jt("afterFlush"),V=m=>{k&&qe("beforeFlush",m,{type:"beforeFlush"});},y=(m,I)=>{T&&qe("afterFlush",m,{type:"afterFlush",elapsedMs:I});},v=m=>{let I=h[m];if(!I)return null;let A=I.lastCorrelationId??void 0,p=I.lastTraceContext??void 0;return !A&&!p?null:{correlationId:A,traceContext:p}},L=()=>{o();};if(c){for(let m of s){let I=b[m];if(!I||I.size===0)continue;let A=h[m]?.updateCount??0,p=f(m),ve=g(m),U=x[m],q=U&&U.source===ve&&U.mode===p?U.snapshot:(()=>{let W=qt(ve,p);return x[m]={version:r,snapshot:W,source:ve,mode:p},W})(),te=Kt(h[m]?.metrics);V(m);let de=R(),ae=Array.from(I),Ae=v(m),Pe=()=>{for(let W of ae)try{W(q);}catch(fe){let re=h[m]?.options?.snapshotSafety??"warn";if(M()&&(p==="ref"||p==="shallow")&&oo(fe)){if(re==="throw")throw fe;if(re==="auto-clone")try{let je=O(q);S(`Snapshot mutation detected for "${m}". Delivered a cloned snapshot to the subscriber.`);try{W(je);}catch(kt){S(`Subscriber for "${m}" threw on cloned snapshot: ${kt?.message??kt}`);}continue}catch{}S(`Snapshot mutation detected for "${m}": ${fe?.message??fe}`);continue}S(`Subscriber for "${m}" threw: ${fe?.message??fe}`);}};Ae?Xt(Ae,Pe):Pe();let Ne=R()-de;y(m,Ne),Gt(te,Ne),Yt(h[m],te),(h[m]?.updateCount??A)!==A&&n.pendingNotifications.add(m);}L();return}let _=m=>{let I=[];for(let A of s){if(m&&!m(A))continue;let p=b[A];if(!p||p.size===0)continue;let ve=h[A]?.updateCount??0,U=f(A),q=g(A),te=x[A],de=te&&te.source===q&&te.mode===U?te.snapshot:(()=>{let ae=qt(q,U);return x[A]={version:r,snapshot:ae,source:q,mode:U},ae})();I.push({name:A,snapshot:de,version:ve,subscribers:Array.from(p),subscriberSet:new Set(p),notified:new Set,metrics:Kt(h[A]?.metrics),totalMs:0,beforeHooked:false});}return I},De=l?_(m=>l.has(m)):[],Oe=_(m=>!l||!l.has(m)),vt=(m,I)=>{let A=()=>{if(m.length===0){I();return}let p=m.shift();if((h[p.name]?.updateCount??p.version)!==p.version){if(n.pendingNotifications.add(p.name),m.length===0){I();return}Ue(A,a);return}let U=()=>{let X=b[p.name];if(!(!X||X.size===0))for(let W of X)p.subscriberSet.has(W)||(p.subscriberSet.add(W),p.subscribers.push(W));};U();let q=p.subscribers;if(q.length===0){if(m.length===0){I();return}Ue(A,a);return}p.beforeHooked||(p.beforeHooked=true,V(p.name));let te=R(),de=0,ae=false,Ae=v(p.name),Pe=()=>{for(let X=0;X<q.length&&de<i;X+=1){let W=q[X];if(p.notified.has(W))continue;p.notified.add(W);try{W(p.snapshot);}catch(re){let xt=h[p.name]?.options?.snapshotSafety??"warn",je=f(p.name);if(M()&&(je==="ref"||je==="shallow")&&oo(re)){if(xt==="throw")throw re;if(xt==="auto-clone")try{let ar=O(p.snapshot);S(`Snapshot mutation detected for "${p.name}". Delivered a cloned snapshot to the subscriber.`);try{W(ar);}catch(cr){S(`Subscriber for "${p.name}" threw on cloned snapshot: ${cr?.message??cr}`);}if(p.notified.add(W),de+=1,(h[p.name]?.updateCount??p.version)!==p.version){ae=!0,n.pendingNotifications.add(p.name);break}continue}catch{}S(`Snapshot mutation detected for "${p.name}": ${re?.message??re}`);continue}S(`Subscriber for "${p.name}" threw: ${re?.message??re}`);}if(de+=1,(h[p.name]?.updateCount??p.version)!==p.version){ae=true,n.pendingNotifications.add(p.name);break}}};if(Ae?Xt(Ae,Pe):Pe(),p.totalMs+=R()-te,ae){if(m.length===0){I();return}Ue(A,a);return}U();let Ne=false;for(let X of q)if(!p.notified.has(X)){Ne=true;break}if(Ne?m.push(p):(Gt(p.metrics,p.totalMs),Yt(h[p.name],p.metrics),y(p.name,p.totalMs)),m.length===0){I();return}Ue(A,a);};A();};De.length>0?vt(De,()=>vt(Oe,L)):vt(Oe,L);};var Vn=e=>{let t=e.notify;t.isFlushing=true,t.flushId=t.flushId+1>>>0;let r=t.flushId,o=eo(t);no(e,o,r,()=>{t.isFlushing=false,t.notifyScheduled=false,t.pendingNotifications.size>0&&Qt(e);});},Qt=e=>{to(e,Vn);};var pt=null,so=e=>(pt=e,()=>{pt===e&&(pt=null);}),Fe=e=>{pt?.(e);};var Dn=e=>{let t=D(),r=t.notify;r.pendingNotifications.add(e),r.batchDepth===0&&Qt(t);};so(Dn);var On=()=>{let e=D().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};F("notify.reset",On,40);var gt=new Set,ao=e=>e?gt.has(e):gt.size>0,co=e=>{e&>.add(e);},An=()=>{gt.clear();};F("ssr.warnings",An,60);var io=new Set,Pn=e=>{let t=xr();return !t||e.includes("::")?e:(M()&&!io.has(e)&&(io.add(e),S(`Namespace "${t}" is active; treating store "${e}" as "${t}::${e}". Consider using namespace("${t}").create("...") to be explicit.`)),`${t}::${e}`)},he=e=>Pn(typeof e=="string"?e:e.name),Ye=e=>Y(e)&&!fo(e)?true:(Dt(e,Object.keys(Xe)),false),lo=(e,t,r={})=>{me(t,{...r,onError:N[e]?.options?.onError});},uo=(e,t,r={})=>{me(e,{...r,onError:t});},se=(e,t,r="dev")=>{lo(e,t,{severity:"warn",visibility:r});},Nn=(e,t,r="dev")=>{uo(e,t,{severity:"warn",visibility:r});},ie=(e,t)=>lo(e,t,{severity:"critical",visibility:"always"}),Je=(e,t)=>uo(e,t,{severity:"critical",visibility:"always"}),St=(e,t,r)=>{let o=`Store "${e}" requested ${t} support, but "${t}" is not registered.
|
|
13
|
-
Import "stroid/${t}" before calling createStore("${e}", ...).`;if(Nn(o,r,"always"),C().strictMissingFeatures)throw new Error(o)};var po=new WeakMap,go=new WeakMap,jn=500,In="",Qe=e=>{let t=po.get(e);return t||(t=new Map,po.set(e,t)),t},er=e=>{let t=go.get(e);return t||(t=new Map,go.set(e,t)),t},$n=(e,t)=>{let r=er(e),o=r.get(t);return o||(o=new Map,r.set(t,o)),o},zn=()=>{let e=C().pathCacheSize;return typeof e!="number"||!Number.isFinite(e)?jn:Math.max(0,Math.floor(e))},So=(e,t,r,o)=>{if(o<=0){e.has(t)&&e.delete(t);return}for(e.has(t)&&e.delete(t),e.set(t,r);e.size>o;){let n=e.keys().next().value;if(!n)break;let s=e.get(n);e.delete(n),s?.node.verdicts&&(s.node.verdicts.delete(s.type),s.node.verdicts.size===0&&delete s.node.verdicts);}};new Proxy(new Map,{get:(e,t)=>{let r=Qe(D());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)=>(Qe(D())[t]=r,true)});var yo=(e,t,r,o)=>{let n=N[e];if(!n)return {ok:true};let s=Te(r);if(s.length===0)return {ok:true};let i=ce(o),a=zn(),c=D(),l=Qe(c),u=$n(c,e),w=s.join(In),b=l.get(e);b||(b={children:new Map},l.set(e,b));let h=b;for(let k of s){let T=h.children.get(k);T||(T={children:new Map},h.children.set(k,T)),h=T;}let x=h.verdicts?.get(i);if(x){let k=`${w}|${i}`;return So(u,k,{node:h,type:i},a),x}let d=n.options?.pathCreate===true,f=t,g={ok:true};for(let k=0;k<s.length;k++){let T=s[k],V=k===s.length-1;if(f==null){let v=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,k).join(".")||"root"}" is ${f===null?"null":"undefined"}.`;$(v),g={ok:false,reason:v};break}if(typeof f!="object"){let v=`Path "${s.join(".")}" is invalid for "${e}" - "${s.slice(0,k).join(".")||"root"}" is not an object.`;$(v),g={ok:false,reason:v};break}if(Array.isArray(f)){let v=Number(T);if(!Number.isInteger(v)||v<0){let _=`Path "${s.join(".")}" targets non-numeric index "${T}" on an array in "${e}".`;$(_),g={ok:false,reason:_};break}let L=f;if(v>=L.length){let _=`Path "${s.join(".")}" is invalid for "${e}" - index ${v} is out of bounds (length ${L.length}).`;$(_),g={ok:false,reason:_};break}if(V){let _=L[v];if(_!=null){let De=ce(_);if(De!==i){let Oe=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${De}, received ${i}.`;$(Oe),g={ok:false,reason:Oe};break}}g={ok:true};break}f=L[v];continue}if(!Object.prototype.hasOwnProperty.call(f,T)){if(d&&V){g={ok:true};break}let v=`Path "${s.join(".")}" is invalid for "${e}" - unknown key "${T}" at "${s.slice(0,k).join(".")||"root"}".`;$(v),g={ok:false,reason:v};break}if(V){let v=f[T];if(v!=null){let L=ce(v);if(L!==i){let _=`Type mismatch setting "${s.join(".")}" on "${e}": expected ${L}, received ${i}.`;$(_),g={ok:false,reason:_};break}}g={ok:true};break}f=f[T];}h.verdicts||(h.verdicts=new Map);let R=h.verdicts.has(i);if(h.verdicts.set(i,g),!R){let k=`${w}|${i}`;So(u,k,{node:h,type:i},a);}return g},be=(e,t,r,o)=>{try{return o?.reuseInput&&Pt(t)?{ok:!0,value:t}:{ok:!0,value:ge(t)}}catch(n){let s=`Sanitize failed for "${e}": ${n?.message??n}`;return Q(N[e]?.options?.onError,`onError(${e})`,s),Q(r,`onError(${e})`,s),S(s),{ok:false}}},_n=(e,t)=>{let r=new Set,o=N[e]?.options?.onError;return typeof o=="function"&&r.add(o),typeof t=="function"&&r.add(t),r},tr=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=_n(e,o),s=(a,c)=>{n.forEach(l=>Q(l,`onError(${e})`,a)),c==="critical"?$(a):S(a);};if(typeof r=="function")try{let a=r(t);return a===!1?(s(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:a===!0?t:a}}catch(a){return s(`Validation for "${e}" failed: ${a?.message??a}`,"critical"),{ok:false}}let i=At(r,t);return i.ok?{ok:true,value:i.data??t}:(s(`Validation failed for "${e}": ${i.error}`,"critical"),{ok:false})},Ze=(e,t,r,o,n)=>{let s=be(e,t,o,n);if(!s.ok)return {ok:false};let i=tr(e,s.value,r,o);return i.ok?{ok:true,value:i.value}:{ok:false}},J=e=>{let t=D();Qe(t).delete(e),er(t).delete(e);},Wn=()=>{let e=D();Qe(e).clear(),er(e).clear();};F("validation.path-cache",Wn,50);mo(J);var we=(e,t=D())=>{if((E()?ue(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=be(e,n,t.metaEntries[e]?.options?.onError);if(!s.ok)return !1;let i=t.metaEntries[e]?.options?.validate,a=Ze(e,s.value,i,t.metaEntries[e]?.options?.onError);if(!a.ok)return !1;if(E()){let c=a.value;ut(e,c),lt(()=>{ee(e,c,t),t.initialStates[e]=O(c),delete t.initialFactories[e],J(e);});}else ee(e,a.value,t),t.initialStates[e]=O(a.value),delete t.initialFactories[e],J(e);return !0}catch(n){return ie(e,`Lazy initializer for "${e}" failed: ${n?.message??n}`),false}};var ho=new WeakMap,bo=e=>{let t=ho.get(e);return t||(t=new Map,ho.set(e,t)),t},Hn=()=>{bo(D()).clear();};F("features.contexts",Hn,100);var wo=e=>{let t=D(),r=bo(t),o=r.get(e);if(o)return o;let n=N[e];if(!n)return S(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let s={name:e,options:n.options,getMeta:()=>N[e],getStoreValue:()=>Xe[e],getAllStores:()=>Xe,getInitialState:()=>Mo[e],hasStore:()=>Y(e),setStoreValue:i=>{ee(e,i);},applyFeatureState:(i,a)=>{To(e,i,a),J(e);},notify:()=>{},reportStoreError:i=>{ie(e,i);},warn:S,warnAlways:K,log:B,hashState:_e,deepClone:O,sanitize:ge,validate:i=>tr(e,i,N[e]?.options?.validate),isDev:M};return r.set(e,s),s},vo=(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(ie(e,n),r.assertRuntime)throw new Error(n)},xo=(e,t)=>{mt();let r=wo(e);r&&(r.notify=()=>t(e),vo(e,r),Z.forEach(o=>{o.onStoreCreate?.(r);}));},ko=(e,t,r,o,n)=>{mt();let s=wo(e);if(!s)return;s.notify=()=>n(e);let i=Object.assign(Object.create(s),{action:t,prev:r,next:o});vo(e,i),Z.forEach(a=>{a.onStoreWrite?.(i);});};var Ro=(e,t)=>Ur({name:e,payload:t,middlewares:(()=>{let r=N[e]?.options?.middleware||[],o=C().middleware||[];return r.length===0?o:o.length===0?r:[...r,...o]})(),reportIssue:(r,o)=>{se(e,r,o);},warn:S}),yt=(e,t,r,o)=>it({name:e,label:t,fn:r,args:o,reportIssue:(n,s)=>{se(e,n,s);}}),Co=(e,t)=>{let r={...t};return r.persist&&!et("persist")&&(r.explicitPersist&&St(e,"persist",r.onError),r.persist=null),r.sync&&!et("sync")&&(r.explicitSync&&St(e,"sync",r.onError),r.sync=false),et("devtools")||(r.explicitDevtools&&St(e,"devtools",r.onError),r.devtools=false,r.historyLimit=0,r.redactor=void 0),r};var Ln=32,ht=new Set;F("store-write.slow-mutator-warned",()=>ht.clear(),65);var Bn=e=>{if(e.updateCount>=Number.MAX_SAFE_INTEGER){e.updateCount=0;return}e.updateCount+=1;};var Fo=e=>{ht.delete(e);},Vo=(e,t)=>{M()&&(t<Ln||ht.has(e)||(ht.add(e),S(`setStore("${e}", mutator) took ${t}ms. Mutator writes clone the entire store; consider path writes or smaller stores for hot paths.`)));},Do=e=>ft(),Eo=(e,{name:t,prev:r,next:o,action:n,hookLabel:s,logMessage:i,context:a})=>{let c=e.metaEntries;ee(t,o,e),J(t);let l=Date.now();c[t].updatedAt=new Date(l).toISOString(),c[t].updatedAtMs=l;let u=a??ft();u&&(u.correlationId||u.traceContext)?(c[t].lastCorrelationId=u.correlationId??null,c[t].lastCorrelationAt=new Date(l).toISOString(),c[t].lastCorrelationAtMs=l,c[t].lastTraceContext=u.traceContext??null):(c[t].lastCorrelationId=null,c[t].lastCorrelationAt=null,c[t].lastCorrelationAtMs=null,c[t].lastTraceContext=null),Bn(c[t]),ko(t,n,r,o,Fe),yt(t,s,c[t].options[s],[r,o]),Fe(t),B(i);},bt=(e,t)=>{let r=t.context??ft();if(E()){ut(t.name,t.next),lt(()=>Eo(e,{...t,context:r}));return}Eo(e,{...t,context:r});};function rr(e,t,r){return Un(e,t,r)}var Un=(e,t,r,o)=>{let n=he(e),s=D(),i=s.metaEntries;if(!we(n,s))return {ok:false,reason:"validate"};if(!Y(n,s)){let f=`setStore("${n}") called before createStore(). Create the store first or pass a valid StoreDefinition.`;return ie(n,f),E()&&j(f),{ok:false,reason:"not-found"}}let a,c=E()?ue(n):{has:false,value:void 0},l=c.has?c.value:Ge(n,s),u=typeof t=="function"&&r===void 0;if(u){let f=M()?Date.now():0;try{let g=C().mutatorProduce,R=!1,k,T=y=>{let v=t(y);return v!==void 0&&(R=!0,k=v),v},V=g?g(l,T):(()=>{let y=O(l);return T(y),y})();if(R&&C().strictMutatorReturns){let y=`setStore("${n}", mutator) returned a value. Strict mutator mode forbids return values; mutate the draft instead.`;return ie(n,y),E()&&j(y),{ok:!1,reason:"validate"}}R&&M()&&!C().strictMutatorReturns&&S(`setStore("${n}", mutator) returned a value. Return values replace the entire store; return void to apply draft mutations instead.`),a=R&&!C().strictMutatorReturns?k:V;}catch(g){return ie(n,`Mutator for "${n}" failed: ${g?.message??g}`),E()&&j(g),{ok:false,reason:"validate"}}finally{f&&Vo(n,Date.now()-f);}}else if(typeof t=="object"&&!Array.isArray(t)&&r===void 0){if(!Ce(t))return E()&&j(`setStore("${n}") received invalid data`),{ok:false,reason:"invalid-args"};if(typeof l!="object"||l===null||Array.isArray(l))return H(`setStore("${n}", data) only merges into object stores.
|
|
14
|
-
Use setStore("${n}", "path", value) or recreate the store with an object shape.`),E()&&j(`setStore("${n}") attempted object merge on non-object store`),{ok:false,reason:"validate"};let f=be(n,t);if(!f.ok)return E()&&j(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};a={...l,...f.value};}else if(typeof t=="string"||Array.isArray(t)){if(!He(t))return E()&&j(`setStore("${n}") received invalid path`),{ok:false,reason:"invalid-args"};let f=be(n,r);if(!f.ok)return E()&&j(`setStore("${n}") failed sanitize`),{ok:false,reason:"validate"};let g=f.value,R=yo(n,l,t,g);if(!R.ok)return Q(i[n]?.options?.onError,`onError(${n})`,R.reason??`Invalid path for "${n}".`),E()&&j(R.reason),{ok:false,reason:"path"};a=_t(l,t,g);}else {let f=`setStore("${n}") - invalid arguments.
|
|
15
|
-
Usage:
|
|
16
|
-
setStore("${n}", "field", value)
|
|
17
|
-
setStore("${n}", "nested.field", value)
|
|
18
|
-
setStore("${n}", { field: value })
|
|
19
|
-
setStore(storeDef, draft => { draft.field = value })
|
|
20
|
-
replaceStore("${n}", value) // full-store replace`;return H(f),Q(i[n]?.options?.onError,`onError(${n})`,f),E()&&j(f),{ok:false,reason:"invalid-args"}}if(!Ce(a))return E()&&j(`setStore("${n}") produced invalid data`),{ok:false,reason:"validate"};let w=i[n]?.options?.validate,b=Do(),h=Ro(n,{action:"set",prev:l,next:a,path:t,correlationId:b?.correlationId,traceContext:b?.traceContext});if(h===st)return E()&&j(`setStore("${n}") aborted by middleware`),{ok:false,reason:"middleware"};let d=Ze(n,h,w,void 0,u&&h===a?{reuseInput:true}:void 0);if(!d.ok)return E()&&j(`setStore("${n}") failed validation`),{ok:false,reason:"validate"};try{if($t(l,d.value))return {ok:!0}}catch{}return bt(s,{name:n,prev:l,next:d.value,action:"set",hookLabel:"onSet",logMessage:`Store "${n}" updated`,context:b}),{ok:true}};var Kn=(e,t)=>{let r=e?.options?.snapshot??t;return r==="shallow"||r==="ref"?r:"deep"},Oo=(e,t)=>t==="ref"?e:t==="shallow"?We(e):O(e);function Gn(e,t){let r=he(e);if(!Ye(r))return null;let o=D();if(!we(r,o))return null;Zt(r,o);let n=Ge(r,o),s=Kn(o.metaEntries[r],C().defaultSnapshotMode);if(t===void 0)return n===null||typeof n!="object"?n:Oo(n,s);if(!He(t))return null;let i=zt(n,t);return i===null||typeof i!="object"?i:Oo(i,s)}var Yn=e=>Y(e);function or(e){let t=he(e);if(!Ye(t))return;let r=D();if(!we(t,r))return;if(E()){let n=`deleteStore("${t}") cannot be called inside setStoreBatch. Move deleteStore outside the batch to preserve transaction semantics.`;se(t,n),j(n);return}Ao().deleteExistingStore(t),J(t),Fo(t),sr(t);}function nr(e){let t=he(e);if(!Ye(t))return {ok:false,reason:"not-found"};let r=D();if(r.metaEntries[t]?.options?.lazy===true&&!!r.initialFactories[t]){let u=`resetStore("${t}") cannot run on a lazy store before it is initialized. Read the store once (getStore) to materialize it before resetting.`;return se(t,u),E()&&j(u),{ok:false,reason:"lazy-uninitialized"}}if(!we(t,r))return {ok:false,reason:"validate"};if(!Object.prototype.hasOwnProperty.call(r.initialStates,t)){let u=`resetStore("${t}") has no initial state to reset to. If this is a lazy store, ensure it has been initialized before calling resetStore.`;return se(t,u),E()&&j(u),{ok:false,reason:"not-found"}}let n=E()?ue(t):{has:false,value:void 0},s=n.has?n.value:r.stores[t],i=typeof performance<"u"&&performance.now?performance.now():Date.now(),a=O(r.initialStates[t]),c=(typeof performance<"u"&&performance.now?performance.now():Date.now())-i,l=r.metaEntries[t]?.metrics;return l&&(l.resetCount=(l.resetCount??0)+1,l.totalResetMs=(l.totalResetMs??0)+c,l.lastResetMs=c),bt(r,{name:t,prev:s,next:a,action:"reset",hookLabel:"onReset",logMessage:`Store "${t}" reset to initial state/value`}),{ok:true}}var Qn=()=>D().computedCleanups,Po=new WeakMap;var Zn=e=>{let t=Po.get(e);return t||(t=new Map,Po.set(e,t)),t};var No=e=>{let t=Qn(),r=t.get(e);if(!r){M()&&S(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var jo=(e,t=D())=>Zn(t).get(e)?.autoDispose===true;var Io=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,i=e.snapshotCache,a=e.featureRuntimes,c=e.deletingStores,l=(d,f)=>{me(f,{onError:s[d]?.options?.onError,severity:"warn",visibility:"dev"});},u=({name:d,prev:f,options:g,initialState:R,getMeta:k,getStoreValue:T,hasStore:V})=>({name:d,options:g,prev:f,getMeta:k,getStoreValue:T,getAllStores:()=>t,getInitialState:()=>R,hasStore:V,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:y=>{me(y,{onError:g.onError,severity:"warn",visibility:"dev"});},warn:S,warnAlways:K,log:B,hashState:_e,deepClone:O,sanitize:ge,validate:()=>({ok:true,value:f}),isDev:M}),w=({name:d,prev:f,options:g,initialState:R,phase:k})=>{let T=u({name:d,prev:f,options:g,initialState:R,getMeta:()=>s[d],getStoreValue:()=>t[d],hasStore:()=>pe(e,d)}),V=u({name:d,prev:f,options:g,initialState:R,getMeta:()=>{},getStoreValue:()=>f,hasStore:()=>false});xe().forEach(y=>{let v=a.get(y);k==="before"?v?.beforeStoreDelete?.(T):v?.afterStoreDelete?.(V);});},b=d=>{if(!pe(e,d))return;let f=t[d],g=s[d].options,R=o[d],k=r[d];c.add(d);try{k?.forEach(y=>{try{y(null);}catch(v){S(`Subscriber for "${d}" threw during delete: ${v?.message??v}`);}}),it({name:d,label:"onDelete",fn:g.onDelete,args:[f],reportIssue:(y,v)=>{me(y,{onError:g.onError,severity:"warn",visibility:v});}}),w({name:d,prev:f,options:g,initialState:R,phase:"before"}),delete t[d],delete r[d],delete o[d],delete n[d],delete s[d],delete i[d],Jr(d)&&No(d);let V=e.computedDependents[d];if(V)for(let y of [...V]){let v=Bt(y);if(v&&jo(y,e)&&v.deps.every(L=>!pe(e,L))){b(y);continue}S(`[stroid] source store "${d}" was deleted. Computed store "${y}" depends on it and will return stale data. Call deleteComputed("${y}") to clean up.`);}w({name:d,prev:f,options:g,initialState:R,phase:"after"}),qe("afterStoreDelete",d,{type:"afterStoreDelete",prev:f}),rt(e,{type:"deleted",name:d}),B(`Store "${d}" deleted`);}finally{c.delete(d);}};return {deleteExistingStore:b,clearAllStores:()=>{let d=[],g=0,R=Number.POSITIVE_INFINITY;for(;g<20;){let T=Object.keys(t);if(T.length===0)break;T.forEach(y=>{pe(e,y)&&(b(y),d.push(y));}),g+=1;let V=Object.keys(t).length;if(V===0||V>=R)break;R=V;}let k=Object.keys(t).length;return k>0?S(`clearAllStores stopped after ${g} pass${g===1?"":"es"}; ${k} store(s) still registered (likely recreated during deletion).`):B(`All stores cleared (${d.length} stores removed)`),d},clearStores:d=>{let f=Object.keys(t).filter(g=>d?d.endsWith("*")?g.startsWith(d.slice(0,-1)):g===d:true);return f.forEach(g=>b(g)),f},reportStoreError:l}};var ir=ke,zo=Re(ir),_o=null,z=()=>{let e=ne(zo);return Mt(e),e};var D=()=>z();var Wo=(e,t)=>{rt(e,t);};function mo(e){_o=e;}var Ve=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}}}),es=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)}),ts=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)}),Xe=Ve(()=>z().stores);Ve(()=>z().subscribers);var Mo=Ve(()=>z().initialStates);Ve(()=>z().initialFactories);var N=Ve(()=>z().metaEntries);Ve(()=>z().snapshotCache);var Z=es(()=>z().featureRuntimes),$o=new WeakMap,Ho=e=>{let t=$o.get(e);return t||(t=Io(e),$o.set(e,t)),t};ts(()=>Ho(z()));var Ao=()=>Ho(z()),rs=e=>{let t=Z.get(e);if(t)return t;let r=tt(e);if(!r)return;let o=r();return Z.set(e,o),o},mt=()=>{xe().forEach(e=>{rs(e);});};mt();var Y=(e,t)=>pe(t??z(),e),Ge=(e,t=z())=>{if(E()){let o=ue(e);if(o.has)return o.value}let r=Ie();return r&&Object.prototype.hasOwnProperty.call(r,e)?r[e]:t.stores[e]},ee=(e,t,r=z())=>{r.stores[e]=t;},To=(e,t,r=Date.now())=>{ee(e,t),N[e]&&(N[e].updatedAt=new Date(r).toISOString(),N[e].updatedAtMs=r,N[e].lastCorrelationId=null,N[e].lastCorrelationAt=null,N[e].lastCorrelationAtMs=null,N[e].lastTraceContext=null,N[e].updateCount>=Number.MAX_SAFE_INTEGER?N[e].updateCount=0:N[e].updateCount+=1,_o?.(e));},Zt=(e,t=z())=>{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=()=>{mr(z());},ns=()=>{Z.forEach(e=>{try{e.resetAll?.();}catch{}}),Z.clear();};F("features.reset",ns,10);F("registries.clear",os,20);F("registry.default",()=>{ir=ke,zo=Re(ir);},115);var fo=e=>yr(z(),e);var wt=new Set,sr=e=>{if(e){wt.delete(e);return}wt.clear();};F("store-create.ssr-global-warned",()=>sr(),65);function ss(e,t,r={}){if(E()){let y=`createStore("${String(e)}") cannot be called inside setStoreBatch. Move createStore outside the batch to preserve transaction semantics.`;Je(y,r.onError),j(y);return}if(!Nt(e)){Je(`createStore("${String(e)}") is not a valid store name.`,r.onError);return}if(!(r.lazy===true&&typeof t=="function")&&!Ce(t)){Je(`createStore("${e}") received invalid initial data.`,r.onError);return}t===void 0&&M()&&S(`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.`),Lr(r).forEach(y=>{S(y);});let n=Co(e,Br(r,e,C().defaultSnapshotMode));if(n.scope==="temp"&&r.persist){let y=`Store "${e}" has scope: "temp" but persist is enabled. Temp stores are intended to be ephemeral.`;Q(n.onError,`onError(${e})`,y),M()||K(y),H(y);}let s=typeof window>"u",i=typeof process<"u"?process.env?.NODE_ENV:void 0,a=s&&i==="production",c=n.allowSSRGlobalStore??false,l=D(),u=l.stores,w=l.subscribers,b=l.initialStates,h=l.initialFactories,x=l.metaEntries,d=l.scope==="request";if(a&&!c&&!d){let y=`createStore("${e}") is blocked on the server in production to prevent cross-request memory leaks.
|
|
21
|
-
Call createStoreForRequest(...) inside each request scope or pass { scope: "global" } to opt in.`;Je(y,r.onError);return}if(a&&c&&!d&&!wt.has(e)&&(wt.add(e),K(`createStore("${e}") is allowed on the server in production because allowSSRGlobalStore is true.
|
|
22
|
-
This can leak data across concurrent requests. Prefer createStoreForRequest(...) or scope: "request" unless you truly need a global SSR store.`)),Y(e,l)){let y=`Store "${e}" already exists. Call setStore("${e}", data) to update instead.`;return se(e,y),{name:e}}s&&!c&&!d&&!ao(e)&&M()&&(co(e),S(`createStore("${e}") called in a server environment. Use createStoreForRequest(...) per request to avoid cross-request leaks or pass { allowSSRGlobalStore: true } if you really want a global store on the server.`));let f=be(e,t,n.onError);if(!f.ok)return;let g=f.value,R=n.lazy===true&&typeof t=="function",k=(w[e]?.size??0)>0;if(R)u[e]=void 0,h[e]=t;else {let y=Ze(e,g,n.validate,n.onError);if(!y.ok)return;ee(e,y.value,l),b[e]=O(y.value);}let T=Date.now(),V=new Date(T).toISOString();return x[e]={createdAt:V,updatedAt:V,updatedAtMs:T,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},J(e),xo(e,Fe),yt(e,"onCreate",x[e].options.onCreate,[g]),Wo(l,{type:"created",name:e,isGlobal:n.scope==="global",isTemp:n.scope==="temp"}),k&&Fe(e),B(`Store "${e}" created -> ${JSON.stringify(g)}`),{name:e}}export{ss as createStore,or as deleteStore,Gn as getStore,Yn as hasStore,nr as resetStore,rr as setStore};//# sourceMappingURL=core.js.map
|
|
1
|
+
export{K as createStore,ra as deleteStore,M as getStore,N as hasStore,sa as resetStore,U as setStore}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';//# sourceMappingURL=core.js.map
|
|
23
2
|
//# sourceMappingURL=core.js.map
|
package/dist/devtools.d.ts
CHANGED
package/dist/devtools.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var ve=new Map,ot=null,nt=(e,t)=>{ve.set(e,t),ot?.(e,t);};var ye=e=>ve.get(e),X=()=>Array.from(ve.keys()),st=e=>{ot=e;};var Qt=new Map,v=(e,t,r=0)=>{!e||typeof t!="function"||Qt.set(e,{name:e,order:r,fn:t});};var it=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),at=()=>({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:it(),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}}),ct=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(),it().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 Me=new Map,ut=new WeakSet,Fe=e=>{ut.has(e)||(ut.add(e),X().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=ye(t);r&&e.featureRuntimes.set(t,r());}}));},Zt=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,lt,Ee=e=>(lt||Zt||e).replace(/\.ts(\?|$)/,".js$1"),J=Ee("stroid:default-registry");var er=()=>{lt=void 0,Me.clear();};v("registry.scope-override",er,110);var tr=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),rr=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},or=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),nr=(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:or(),async:at(),notify:tr(),lifecycleListener:null};return Fe(t),t},Q=e=>{let t=Ee(e),r=Me.get(t);if(r)return r;let o=nr();return Me.set(t,o),o},Z=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var dt=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,rr(e.notify),ct(e.async),e.lifecycleListener=null;};var Te=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var $=[],ft={run:(e,t)=>{$.push(e);try{return t()}finally{$.pop();}},get:()=>$.length>0?$[$.length-1]:null,enterWith:e=>{if($.length>0){$[$.length-1]=e;return}$.push(e);}};var ee=e=>(ft).get()||e||Q(J);var ir={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}`));}},yt={logSink:ir,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},Oe=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}),je=new WeakMap,St=Oe(yt),ar=e=>{let t=je.get(e);return t||(t=Oe(St),je.set(e,t)),t};var j=()=>ar(ee());var dr=()=>{je=new WeakMap,St=Oe(yt);};v("config.reset",dr,90);var pr=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,fr=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,mt=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,gr="production",yr=pr??fr??gr,Se=typeof mt=="boolean"?mt:yr!=="production",M=()=>Se,ht=(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}`));},mr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},Ne=(e,t)=>{if((j().logSink.critical??Sr)(e,t),j().assertRuntime)throw new Error(e)},g=(e,t)=>{if(!Se)return;if((j().logSink.warn??ht)(e,t),j().assertRuntime)throw new Error(e)},te=(e,t)=>{if((j().logSink.warn??ht)(e,t),j().assertRuntime)throw new Error(e)};var re=(e,t)=>{if(!Se)return;(j().logSink.log??mr)(e,t);};var bt=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",wt=()=>"Map detected; converting to plain object.",Rt=()=>"Set detected; converting to array.";var oe=new Set(["__proto__","constructor","prototype"]);var Ct=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,br=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=br(e);if(r)throw new Error(`${r} values are not supported`);let o=Ct(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 M()&&g(bt()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),M()&&g(wt());let n={};for(let[s,u]of e){if(typeof s!="string")throw new Error("Map keys must be strings to remain JSON-safe");n[String(s)]=pe(u,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),M()&&g(Rt()),Array.from(e,n=>pe(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[u,d]of Object.entries(s))if(d.enumerable&&!oe.has(u)){if("get"in d||"set"in d)throw new Error(`Accessor properties are not supported during sanitize ("${u}")`);n[u]=pe(d.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=>pe(n,t))}return e},Ae=e=>pe(e,new WeakSet);var Ve=null,wr=()=>{if(Ve)return Ve;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 Ve=t,t},xt=e=>{let t=wr(),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},Rr=2166136261,Cr=2654435761,kr=1e5,z=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},K=(e,t)=>{z(e,t.length);for(let r=0;r<t.length;r++)z(e,t.charCodeAt(r));},R=(e,t)=>{K(e,t);},kt=(e,t)=>{if(Number.isNaN(t)){R(e,"NaN");return}if(!Number.isFinite(t)){R(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){R(e,"-0");return}let r=t|0;if(t===r){R(e,"int"),z(e,r);return}R(e,"num"),K(e,String(t));},ne=(e,t)=>{if(e.nodes++>kr){R(e,"[max]");return}if(t===null){R(e,"null");return}let r=typeof t;if(r==="string"){R(e,"string"),K(e,t);return}if(r==="number"){R(e,"number"),kt(e,t);return}if(r==="boolean"){R(e,t?"true":"false");return}if(r==="undefined"){R(e,"undefined");return}if(r==="bigint"){R(e,"bigint"),K(e,t.toString());return}if(r==="symbol"){R(e,"symbol");let l=t;K(e,Symbol.keyFor(l)??l.description??String(l));return}if(r==="function"){R(e,"function"),K(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){R(e,"ref"),z(e,n);return}let s=e.nextId++;if(e.seen.set(o,s),Array.isArray(o)){R(e,"array"),z(e,o.length);for(let l=0;l<o.length;l++)Object.prototype.hasOwnProperty.call(o,l)?ne(e,o[l]):R(e,"hole");return}if(o instanceof Date){R(e,"date"),kt(e,o.getTime());return}if(o instanceof Map){R(e,"map"),z(e,o.size),o.forEach((l,p)=>{ne(e,p),ne(e,l);});return}if(o instanceof Set){R(e,"set"),z(e,o.size),o.forEach(l=>{ne(e,l);});return}R(e,"object");let u=Object.getOwnPropertyDescriptors(o),d=[];Object.entries(u).forEach(([l,p])=>{p?.enumerable&&(oe.has(l)||"get"in p||"set"in p||d.push([l,p]));}),z(e,d.length);for(let[l,p]of d)K(e,l),ne(e,p.value);},Ie=e=>{if(typeof e=="string")return xt(JSON.stringify(e));let t={h1:Rr,h2:Cr,seen:new WeakMap,nextId:1,nodes:0};ne(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 xr=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Pe=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},vr=e=>Pe(e)===null,Mr=e=>{let t=Pe(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},Y=(e,t=new WeakMap)=>{if(Mr(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,u)=>{n.set(Y(u,t),Y(s,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(s=>{n.add(Y(s,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((s,u)=>{n[u]=Y(s,t);}),n}let r={};t.set(e,r);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch(n){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${n?.message??n}`)}return Object.entries(o).forEach(([n,s])=>{!s.enumerable||oe.has(n)||"get"in s||"set"in s||(r[n]=Y(s.value,t));}),r},L=e=>{if(xr)try{return structuredClone(e)}catch(t){if(!vr(e)){let r=Pe(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return g(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),Y(e)}return Y(e)};var Fr=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;te(`${t} callback threw: ${String(n)}`);}},me=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(Fr(n,"onError",e),r==="critical"){o==="dev"&&g(e),Ne(e);return}if(o==="always"){te(e);return}g(e);};var vt=({name:e,label:t,fn:r,args:o,reportIssue:n})=>{if(typeof r=="function")try{r(...o);}catch(s){let u=`${t} for "${e}" failed: ${s?.message??s}`;n(u,"always");}};v("computed.order-resolver",()=>{},105);var Et=()=>ee(Q(J)),He=()=>Et().computedEntries,Tt=()=>Et().computedDependents;var Dt=e=>Object.prototype.hasOwnProperty.call(He(),e);var $e=e=>{let t=He()[e];if(!t)return null;let r=Tt()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var Tr=new Set;var Dr=()=>{Tr.clear();};v("ssr.warnings",Dr,60);var be=e=>B.get(e)?.api;var _t=new Map;var ge=(e,t,r)=>{let o=_t.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 Ar=()=>{};v("write-context.runner",Ar,121);var _r=()=>{let e=se().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};v("notify.reset",_r,40);var Pr=()=>se().computedCleanups,$t=new WeakMap;var Hr=e=>{let t=$t.get(e);return t||(t=new Map,$t.set(e,t)),t};var Wt=e=>{let t=Pr(),r=t.get(e);if(!r){M()&&g(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var zt=(e,t=se())=>Hr(t).get(e)?.autoDispose===true;var Lt=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,s=e.metaEntries,u=e.snapshotCache,d=e.featureRuntimes,l=e.deletingStores,p=(a,b)=>{me(b,{onError:s[a]?.options?.onError,severity:"warn",visibility:"dev"});},S=({name:a,prev:b,options:h,initialState:F,getMeta:A,getStoreValue:_,hasStore:T})=>({name:a,options:h,prev:b,getMeta:A,getStoreValue:_,getAllStores:()=>t,getInitialState:()=>F,hasStore:T,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:k=>{me(k,{onError:h.onError,severity:"warn",visibility:"dev"});},warn:g,warnAlways:te,log:re,hashState:Ie,deepClone:L,sanitize:Ae,validate:()=>({ok:true,value:b}),isDev:M}),C=({name:a,prev:b,options:h,initialState:F,phase:A})=>{let _=S({name:a,prev:b,options:h,initialState:F,getMeta:()=>s[a],getStoreValue:()=>t[a],hasStore:()=>Z(e,a)}),T=S({name:a,prev:b,options:h,initialState:F,getMeta:()=>{},getStoreValue:()=>b,hasStore:()=>false});X().forEach(k=>{let D=d.get(k);A==="before"?D?.beforeStoreDelete?.(_):D?.afterStoreDelete?.(T);});},f=a=>{if(!Z(e,a))return;let b=t[a],h=s[a].options,F=o[a],A=r[a];l.add(a);try{A?.forEach(k=>{try{k(null);}catch(D){g(`Subscriber for "${a}" threw during delete: ${D?.message??D}`);}}),vt({name:a,label:"onDelete",fn:h.onDelete,args:[b],reportIssue:(k,D)=>{me(k,{onError:h.onError,severity:"warn",visibility:D});}}),C({name:a,prev:b,options:h,initialState:F,phase:"before"}),delete t[a],delete r[a],delete o[a],delete n[a],delete s[a],delete u[a],Dt(a)&&Wt(a);let T=e.computedDependents[a];if(T)for(let k of [...T]){let D=$e(k);if(D&&zt(k,e)&&D.deps.every(ae=>!Z(e,ae))){f(k);continue}g(`[stroid] source store "${a}" was deleted. Computed store "${k}" depends on it and will return stale data. Call deleteComputed("${k}") to clean up.`);}C({name:a,prev:b,options:h,initialState:F,phase:"after"}),ge("afterStoreDelete",a,{type:"afterStoreDelete",prev:b}),Te(e,{type:"deleted",name:a}),re(`Store "${a}" deleted`);}finally{l.delete(a);}};return {deleteExistingStore:f,clearAllStores:()=>{let a=[],h=0,F=Number.POSITIVE_INFINITY;for(;h<20;){let _=Object.keys(t);if(_.length===0)break;_.forEach(k=>{Z(e,k)&&(f(k),a.push(k));}),h+=1;let T=Object.keys(t).length;if(T===0||T>=F)break;F=T;}let A=Object.keys(t).length;return A>0?g(`clearAllStores stopped after ${h} pass${h===1?"":"es"}; ${A} store(s) still registered (likely recreated during deletion).`):re(`All stores cleared (${a.length} stores removed)`),a},clearStores:a=>{let b=Object.keys(t).filter(h=>a?a.endsWith("*")?h.startsWith(a.slice(0,-1)):h===a:true);return b.forEach(h=>f(h)),b},reportStoreError:p}};var Je=J,Ut=Q(Je);var I=()=>{let e=ee(Ut);return Fe(e),e};var se=()=>I();var ie=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}}}),$r=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)}),Wr=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)});ie(()=>I().stores);ie(()=>I().subscribers);ie(()=>I().initialStates);ie(()=>I().initialFactories);ie(()=>I().metaEntries);ie(()=>I().snapshotCache);var B=$r(()=>I().featureRuntimes),Bt=new WeakMap,zr=e=>{let t=Bt.get(e);return t||(t=Lt(e),Bt.set(e,t)),t};Wr(()=>zr(I()));var Lr=e=>{let t=B.get(e);if(t)return t;let r=ye(e);if(!r)return;let o=r();return B.set(e,o),o},Br=()=>{X().forEach(e=>{Lr(e);});};st((e,t)=>{B.get(e)||B.set(e,t());});Br();var Ur=()=>{dt(I());},qr=()=>{B.forEach(e=>{try{e.resetAll?.();}catch{}}),B.clear();};v("features.reset",qr,10);v("registries.clear",Ur,20);v("registry.default",()=>{Je=J,Ut=Q(Je);},115);var qt=false,Kt=e=>{try{return typeof structuredClone=="function"?structuredClone(e):JSON.parse(JSON.stringify(e))}catch{return e}},Kr=({name:e,useDevtools:t,existingDevtools:r,stores:o,warn:n})=>{if(!t||typeof window>"u")return r;let s=window.__REDUX_DEVTOOLS_EXTENSION__||window.__REDUX_DEVTOOLS_EXTENSION__;if(!s||typeof s.connect!="function")return n(`DevTools requested for "${e}" but Redux DevTools extension not found.`),r;if(r)return r;let u=s.connect({name:"stroid"});return u.init(o),u},Re=({data:e,redactor:t,deepClone:r})=>{if(typeof t=="function")try{return t(r(e))}catch{return e}return e},Yr=(e,t)=>{if(typeof e!="object"||typeof t!="object"||e===null||t===null)return null;let r=e,o=t,n=[],s=[],u=[],d=new Set(Object.keys(r)),l=new Set(Object.keys(o));return l.forEach(p=>{d.has(p)?Object.is(r[p],o[p])||u.push(p):n.push(p);}),d.forEach(p=>{l.has(p)||s.push(p);}),{added:n,removed:s,changed:u}},Yt=({name:e,action:t,prev:r,next:o,history:n,historyLimit:s,applyRedactor:u,deepClone:d})=>{if(s===0)return;n[e]||(n[e]=[]);let l={ts:Date.now(),action:t,prev:d(u(r)),next:d(u(o)),diff:Yr(r,o)};n[e].push(l),n[e].length>s&&n[e].splice(0,n[e].length-s);},Gt=({name:e,action:t,force:r=false,devtools:o,enabled:n,stores:s,applyRedactor:u})=>{if(!(!o||!r&&!n))try{let d={...s,[e]:u(s[e])};o.send({type:`${e}/${t}`},d);}catch{}},Gr=()=>{let e=Object.create(null),t;return {onStoreCreate(r){t=Kr({name:r.name,useDevtools:!!r.options.devtools,existingDevtools:t,stores:r.getAllStores(),warn:r.warn}),Yt({name:r.name,action:"create",prev:null,next:r.getStoreValue(),history:e,historyLimit:r.options.historyLimit??50,applyRedactor:o=>Re({data:o,redactor:r.options.redactor,deepClone:r.deepClone}),deepClone:r.deepClone});},onStoreWrite(r){Yt({name:r.name,action:r.action,prev:r.prev,next:r.next,history:e,historyLimit:r.options.historyLimit??50,applyRedactor:o=>Re({data:o,redactor:r.options.redactor,deepClone:r.deepClone}),deepClone:r.deepClone}),Gt({name:r.name,action:r.action,devtools:t,enabled:!!r.options.devtools,stores:r.getAllStores(),applyRedactor:o=>Re({data:o,redactor:r.options.redactor,deepClone:r.deepClone})});},afterStoreDelete(r){r.options.devtools&&Gt({name:r.name,action:"delete",force:true,devtools:t,enabled:true,stores:r.getAllStores(),applyRedactor:o=>Re({data:o,redactor:r.options.redactor,deepClone:r.deepClone})}),delete e[r.name];},resetAll(){Object.keys(e).forEach(r=>{delete e[r];}),t=void 0;},api:{getHistory(r,o){if(!e[r])return [];let n=e[r];return o&&o>0?Kt(n.slice(-o)):Kt(n)},clearHistory(r){if(r){delete e[r];return}Object.keys(e).forEach(o=>{delete e[o];});}}}},Xt=()=>{qt||(qt=true,nt("devtools",Gr));};var Jt=()=>{Xt();};var Xr=(e,t)=>be("devtools")?.getHistory?.(e,t)??[],Jr=e=>{be("devtools")?.clearHistory?.(e);};Jt();export{Jr as clearHistory,Xr as getHistory,Jt as installDevtools};//# sourceMappingURL=devtools.js.map
|
|
1
|
+
export{c as installDevtools}from'./chunk-PVATWAY4.js';import {H}from'./chunk-FOQKGHPS.js';import'./chunk-KQCSFGHJ.js';var s=(t,r)=>H("devtools")?.getHistory?.(t,r)??[],i=t=>{H("devtools")?.clearHistory?.(t);};export{i as clearHistory,s as getHistory};//# sourceMappingURL=devtools.js.map
|
|
2
2
|
//# sourceMappingURL=devtools.js.map
|
package/dist/feature.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
export{e as getRegisteredFeatureNames,c as hasRegisteredStoreFeature,b as registerStoreFeature}from'./chunk-KQCSFGHJ.js';//# sourceMappingURL=feature.js.map
|
|
2
2
|
//# sourceMappingURL=feature.js.map
|