cross-state 0.56.1 → 0.56.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.
Files changed (61) hide show
  1. package/dist/{diff-D7XuntCn.d.cts → diff-BslUrJZE.d.cts} +2 -2
  2. package/dist/{diff-qAkLCsnM.d.ts → diff-CElc7pJI.d.ts} +2 -2
  3. package/dist/index.cjs +3 -3
  4. package/dist/index.d.cts +4 -4
  5. package/dist/index.d.ts +4 -4
  6. package/dist/index.js +3 -3
  7. package/dist/mutative/index.d.cts +2 -2
  8. package/dist/mutative/index.d.ts +2 -2
  9. package/dist/mutative/register.cjs +1 -1
  10. package/dist/mutative/register.d.cts +2 -2
  11. package/dist/mutative/register.d.ts +2 -2
  12. package/dist/mutative/register.js +1 -1
  13. package/dist/{mutativeMethods-DRYtjUcH.d.ts → mutativeMethods-Bhd1Yi22.d.ts} +2 -2
  14. package/dist/{mutativeMethods-Be_XPk5N.d.cts → mutativeMethods-DWhwZRzv.d.cts} +2 -2
  15. package/dist/{patchMethods-BlYtjRUU.d.cts → patchMethods-BT4Tg5aG.d.cts} +3 -3
  16. package/dist/{patchMethods-Dr2OFh02.d.ts → patchMethods-DXWygPZ6.d.ts} +3 -3
  17. package/dist/patches/index.d.cts +3 -3
  18. package/dist/patches/index.d.ts +3 -3
  19. package/dist/patches/register.cjs +1 -1
  20. package/dist/patches/register.d.cts +3 -3
  21. package/dist/patches/register.d.ts +3 -3
  22. package/dist/patches/register.js +1 -1
  23. package/dist/persist/register.cjs +2 -2
  24. package/dist/persist/register.d.cts +2 -2
  25. package/dist/persist/register.d.ts +2 -2
  26. package/dist/persist/register.js +2 -2
  27. package/dist/{persist-DFzbvNoJ.js → persist-CLgS5Cqw.js} +2 -2
  28. package/dist/{persist-DFzbvNoJ.js.map → persist-CLgS5Cqw.js.map} +1 -1
  29. package/dist/{persist-CR3mhti7.d.cts → persist-DVKRq8RQ.d.cts} +2 -2
  30. package/dist/{persist-CQhYPv4d.cjs → persist-DboMIMOK.cjs} +2 -2
  31. package/dist/{persist-CQhYPv4d.cjs.map → persist-DboMIMOK.cjs.map} +1 -1
  32. package/dist/{persist-CIEYJ0rO.d.ts → persist-olbNkcdZ.d.ts} +2 -2
  33. package/dist/react/index.cjs +40 -36
  34. package/dist/react/index.cjs.map +1 -1
  35. package/dist/react/index.d.cts +6 -4
  36. package/dist/react/index.d.ts +6 -4
  37. package/dist/react/index.js +40 -36
  38. package/dist/react/index.js.map +1 -1
  39. package/dist/react/register.cjs +3 -3
  40. package/dist/react/register.d.cts +3 -3
  41. package/dist/react/register.d.ts +3 -3
  42. package/dist/react/register.js +3 -3
  43. package/dist/{scope-Mhr133F_.js → scope-7LeON9bZ.js} +2 -2
  44. package/dist/{scope-Mhr133F_.js.map → scope-7LeON9bZ.js.map} +1 -1
  45. package/dist/{scope-DkO-RIMy.d.cts → scope-CcBxgcrs.d.cts} +2 -2
  46. package/dist/{scope-C9JXWddv.cjs → scope-CfLlLxo9.cjs} +2 -2
  47. package/dist/{scope-C9JXWddv.cjs.map → scope-CfLlLxo9.cjs.map} +1 -1
  48. package/dist/{scope-ByLCVzKk.d.ts → scope-D3jkIPgn.d.ts} +2 -2
  49. package/dist/{store-DQcFfgKD.cjs → store-CdST5wJZ.cjs} +2 -2
  50. package/dist/{store-DQcFfgKD.cjs.map → store-CdST5wJZ.cjs.map} +1 -1
  51. package/dist/{store-B3PWCx63.d.cts → store-DnZ6fsiJ.d.ts} +2 -2
  52. package/dist/{store-DOEc60aP.js → store-Dx8w7yT-.js} +2 -2
  53. package/dist/{store-DOEc60aP.js.map → store-Dx8w7yT-.js.map} +1 -1
  54. package/dist/{store-BJWoRQIs.d.ts → store-MBrcOgtz.d.cts} +2 -2
  55. package/dist/{storeMethods-YDnpa-6-.cjs → storeMethods-B_RzvMaV.cjs} +2 -2
  56. package/dist/{storeMethods-YDnpa-6-.cjs.map → storeMethods-B_RzvMaV.cjs.map} +1 -1
  57. package/dist/{storeMethods-C7bswcgj.js → storeMethods-BrKuusQ2.js} +2 -2
  58. package/dist/{storeMethods-C7bswcgj.js.map → storeMethods-BrKuusQ2.js.map} +1 -1
  59. package/dist/{storeMethods-wsbbfJzY.d.ts → storeMethods-Cb1ur5K3.d.ts} +3 -3
  60. package/dist/{storeMethods-Dt_mJTe3.d.cts → storeMethods-CmWv1YMe.d.cts} +3 -3
  61. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"scope-C9JXWddv.cjs","names":["factory: (...args: Args) => T","cacheTime?: number","simpleHash","name?: string","allResources: ResourceGroup","Store","args: Args","options: CacheOptions<T, Args>","derivedFromCache?: {\n cache: Cache<any, any>;\n selectors: (Selector<any, any> | AnyPath)[];\n }","createStore","calculatedValue","PromiseWithState","calcDuration","makeSelector","options","baseInstance: CacheBundle<T, Args, TCache> & TCache","defaultCacheOptions: CacheOptions<any, any>","deepEqual","createCache: typeof create & { defaultOptions: CacheOptions<any, any> }","defaultValue: T"],"sources":["../src/lib/instanceCache.ts","../src/core/resourceGroup.ts","../src/core/cache.ts","../src/core/scope.ts"],"sourcesContent":["import { simpleHash } from './hash';\n\nexport class InstanceCache<Args extends any[], T extends object> {\n private cache = new Map<string, { t: number; ref?: T; weakRef: WeakRef<T> }>();\n\n private interval = this.cacheTime\n ? setInterval(() => this.cleanup(), Math.max(this.cacheTime / 10, 1))\n : undefined;\n\n constructor(\n public readonly factory: (...args: Args) => T,\n public readonly cacheTime?: number,\n ) {}\n\n cleanup(): void {\n const cutoff = this.now() - (this.cacheTime ?? 0);\n\n for (const [key, entry] of this.cache.entries()) {\n if (entry.ref && entry.t <= cutoff) {\n delete entry.ref;\n }\n\n if (!entry.ref && !entry.weakRef?.deref()) {\n this.cache.delete(key);\n }\n }\n }\n\n get(...args: Args): T {\n return this.getWithKey(args, args);\n }\n\n getWithKey(args: Args, cacheKey: unknown): T {\n const key = simpleHash(cacheKey);\n let entry = this.cache.get(key);\n let value = entry?.ref ?? entry?.weakRef?.deref();\n\n if (!entry || !value) {\n value = this.factory(...args);\n entry = {\n t: this.now(),\n ref: value,\n weakRef: new WeakRef(value),\n };\n\n this.cache.set(key, entry);\n } else {\n entry.t = this.now();\n entry.ref ??= value;\n }\n\n return value;\n }\n\n values(): T[] {\n return [...this.cache.values()]\n .map((entry) => entry.ref ?? entry.weakRef?.deref())\n .filter((value): value is T => !!value);\n }\n\n stop(): void {\n if (this.interval) {\n clearInterval(this.interval);\n }\n }\n\n stats(): { count: number; withRef: number; withWeakRef: number } {\n return {\n count: this.cache.size,\n withRef: [...this.cache.values()].filter((x) => !!x.ref).length,\n withWeakRef: [...this.cache.values()].filter((x) => !!x.weakRef?.deref()).length,\n };\n }\n\n private now() {\n return performance.now();\n }\n}\n","import { autobind } from '@lib/autobind';\n\nexport interface Resource {\n invalidateAll(): void;\n clearAll(): void;\n}\n\nexport class ResourceGroup {\n private refMap = new WeakMap<Resource, WeakRef<Resource>>();\n\n private refSet = new Set<WeakRef<Resource>>();\n\n constructor(public readonly name?: string) {\n autobind(ResourceGroup);\n }\n\n add(resource: Resource): void {\n const ref = new WeakRef(resource);\n this.refMap.set(resource, ref);\n this.refSet.add(ref);\n }\n\n delete(resource: Resource): void {\n const ref = this.refMap.get(resource);\n if (ref) {\n this.refMap.delete(resource);\n this.refSet.delete(ref);\n }\n }\n\n invalidateAll(): void {\n for (const ref of this.refSet) {\n const resource = ref.deref();\n if (resource) {\n resource.invalidateAll();\n } else {\n this.refSet.delete(ref);\n }\n }\n }\n\n clearAll(): void {\n for (const ref of this.refSet) {\n const resource = ref.deref();\n if (resource) {\n resource.clearAll();\n } else {\n this.refSet.delete(ref);\n }\n }\n }\n}\n\nexport const allResources: ResourceGroup = /* @__PURE__ */ new ResourceGroup();\n\nexport function createResourceGroup(name?: string): ResourceGroup {\n return new ResourceGroup(name);\n}\n","import { autobind } from '@lib/autobind';\nimport type { CacheState, ErrorState, ValueState } from '@lib/cacheState';\nimport { calcDuration } from '@lib/calcDuration';\nimport { calculatedValue } from '@lib/calculatedValue';\nimport type { Constrain } from '@lib/constrain';\nimport { deepEqual } from '@lib/equals';\nimport { InstanceCache } from '@lib/instanceCache';\nimport { makeSelector } from '@lib/makeSelector';\nimport { type MaybePromise } from '@lib/maybePromise';\nimport type { AnyPath, Path, Value } from '@lib/path';\nimport { PromiseWithState } from '@lib/promiseWithState';\nimport type { Duration, Selector } from './commonTypes';\nimport { allResources, type ResourceGroup } from './resourceGroup';\nimport { Store, createStore, type Calculate, type StoreOptions } from './store';\n\nexport interface CacheGetOptions {\n /**\n * How to handle the cache when getting the value.\n * - `whenMissing`: Only fetch a new value if there is no cached value.\n * - `whenStale`: Fetch a new value if there is no cached value or if the cached value is stale.\n * - `force`: Always fetch a new value, regardless of the cache state.\n */\n update?: 'whenMissing' | 'whenStale' | 'force';\n\n /**\n * If set to `true`, the cache will be updated in the background.\n * This means that a stale value will be returned immediately, if available, while the new value is being fetched.\n */\n backgroundUpdate?: boolean;\n}\n\nexport interface CacheFunction<T, Args extends any[] = []> {\n (...args: Args): Promise<T> | Calculate<Promise<T>>;\n}\n\nexport interface CacheOptions<T, Args extends any[]> extends StoreOptions<Promise<T>> {\n /**\n * How long to keep the cache entry before it is considered stale.\n * If set to `undefined` or `null`, the cache entry will never be invalidated automatically.\n *\n * @example\n * ```typescript\n * createCache(fetchData, {\n * invalidateAfter: { seconds: 10 },\n * });\n * ```\n */\n invalidateAfter?: Duration | ((state: ValueState<T> | ErrorState) => Duration | null) | null;\n\n /**\n * If set, the cache will be invalidated when the window gets focused.\n * This is useful for caches that are used in a browser environment and might become stale when the user switches tabs.\n */\n invalidateOnWindowFocus?: boolean;\n\n /**\n * If set, the cached value will be cleared when the cache is invalidated.\n * Without this option, the cache will keep the last value as stale until a new value becomes available.\n */\n clearOnInvalidate?: boolean;\n\n /**\n * If set, cache entries will be cleared after approximately the specified duration.\n * This is useful for long lived pages or applications and helps to prevent memory leaks.\n * The exact time when the entry is cleared is not guaranteed, since it will be cleared during garbage collection.\n */\n clearUnusedAfter?: Duration | null;\n\n /**\n * Add the cache to the specified resource group(s).\n * This allows you to invalidate or clear multiple caches that belong to the same group.\n * All caches are always added to the `allResources` group.\n */\n resourceGroup?: ResourceGroup | ResourceGroup[];\n\n /**\n * Function to generate a custom cache key based on the provided arguments.\n * This allows you to control how cache entries are identified and reused.\n * By default, the arguments array is used as the cache key.\n *\n * @example\n * ```typescript\n * // Will use the same instance when provided with `undefined`, `{ num: 0 }`, `{ bool: false }`, etc.\n * createCache((filter?: { num?: number, bool?: boolean }) => fetchData(filter), {\n * getCacheKey: (filter?) => ({\n * num: filter?.num ?? 0,\n * bool: filter?.bool ?? false,\n * }),\n * });\n * ```\n */\n getCacheKey?: (...args: NoInfer<Args>) => unknown;\n}\n\nexport class Cache<T, Args extends any[] = []> extends Store<Promise<T>> {\n readonly state: Store<CacheState<T>> = createStore<CacheState<T>>({\n status: 'pending',\n isStale: true,\n isUpdating: false,\n isConnected: false,\n });\n\n protected stalePromise?: Promise<T>;\n\n protected invalidationTimer?: ReturnType<typeof setTimeout>;\n\n constructor(\n getter: Calculate<Promise<T>>,\n public readonly args: Args,\n public readonly options: CacheOptions<T, Args> = {},\n public readonly derivedFromCache?: {\n cache: Cache<any, any>;\n selectors: (Selector<any, any> | AnyPath)[];\n },\n ) {\n super(getter, options, undefined);\n autobind(Cache);\n\n this.watchPromise();\n this.watchFocus();\n }\n\n get({ update = 'whenStale', backgroundUpdate = false }: CacheGetOptions = {}): Promise<T> {\n if (!this.calculatedValue?.check()) {\n this.calculatedValue?.stop();\n this.calculatedValue = undefined;\n }\n\n const promise = this.calculatedValue?.value;\n const stalePromise = this.stalePromise;\n\n if (\n (update === 'whenMissing' && !promise && !stalePromise) ||\n (update === 'whenStale' && !promise) ||\n update === 'force'\n ) {\n this.calculatedValue = calculatedValue(this, this.notify);\n this.notify();\n\n if ((!promise && !stalePromise) || !backgroundUpdate) {\n return this.calculatedValue.value;\n }\n }\n\n if (!promise || (stalePromise && backgroundUpdate)) {\n return stalePromise!;\n }\n\n return promise;\n }\n\n updateValue(value: MaybePromise<T> | ((value: T | undefined) => T)): void {\n if (value instanceof Function) {\n value = value(this.state.get().value);\n }\n this.set(PromiseWithState.resolve(value));\n }\n\n updateError(error: unknown): void {\n this.set(PromiseWithState.reject(error));\n }\n\n invalidate(recursive?: boolean): void {\n const { clearOnInvalidate } = this.options;\n\n if (clearOnInvalidate) {\n return this.clear(recursive);\n }\n\n const { status, isStale, isUpdating } = this.state.get();\n if (status !== 'pending' && !isStale && !isUpdating) {\n this.stalePromise = this.calculatedValue?.value;\n }\n\n this.state.set((state) => ({\n ...state,\n isStale: true,\n isUpdating: false,\n }));\n\n super.invalidate(recursive);\n }\n\n clear(recursive?: boolean): void {\n this.state.set({\n status: 'pending',\n isStale: true,\n isUpdating: false,\n isConnected: false,\n });\n delete this.stalePromise;\n\n super.invalidate(recursive);\n }\n\n mapValue<S>(selector: Selector<T, S>): Cache<S, Args>;\n\n mapValue<const P extends AnyPath>(\n selector: P extends Path<T> ? P : Path<T>,\n ): Cache<Value<T, P>, Args>;\n\n mapValue(selector: Selector<any, any> | AnyPath) {\n return mapValue(this, selector);\n }\n\n protected watchPromise(): void {\n this.subscribe(\n async (promise) => {\n if (promise instanceof PromiseWithState && promise.state.status !== 'pending') {\n promise.catch(() => undefined);\n\n this.state.set((state) => ({\n ...promise.state,\n isStale: false,\n isUpdating: false,\n isConnected: state.isConnected,\n }));\n\n delete this.stalePromise;\n this.setTimers();\n return;\n }\n\n this.state.set((state) => ({\n ...state,\n isUpdating: true,\n }));\n\n this.setTimers();\n\n try {\n const value = await promise;\n\n if (promise !== this.calculatedValue?.value) {\n return;\n }\n\n this.state.set((state) => ({\n status: 'value',\n value,\n isStale: false,\n isUpdating: false,\n isConnected: state.isConnected,\n }));\n delete this.stalePromise;\n this.setTimers();\n } catch (error) {\n if (promise !== this.calculatedValue?.value) {\n return;\n }\n\n this.state.set((state) => ({\n status: 'error',\n error,\n isStale: false,\n isUpdating: false,\n isConnected: state.isConnected,\n }));\n delete this.stalePromise;\n this.setTimers();\n }\n },\n { passive: true },\n );\n }\n\n protected setTimers(): void {\n if (this.invalidationTimer) {\n clearTimeout(this.invalidationTimer);\n }\n this.invalidationTimer = undefined;\n\n const state = this.state.get();\n let { invalidateAfter } = this.options;\n const ref = new WeakRef(this);\n\n if (state.status === 'pending') {\n return;\n }\n\n if (invalidateAfter instanceof Function) {\n invalidateAfter = invalidateAfter(state);\n }\n\n if (invalidateAfter !== null && invalidateAfter !== undefined) {\n this.invalidationTimer = setTimeout(\n () => ref?.deref()?.invalidate(),\n calcDuration(invalidateAfter),\n );\n }\n }\n\n protected watchFocus(): void {\n const { invalidateOnWindowFocus } = this.options;\n\n if (\n !invalidateOnWindowFocus ||\n typeof document === 'undefined' ||\n typeof document.addEventListener === 'undefined'\n ) {\n return;\n }\n\n const ref = new WeakRef(this);\n\n const onFocus = () => {\n const that = ref?.deref();\n if (!that) {\n document.removeEventListener('visibilitychange', onFocus);\n return;\n }\n\n if (!document.hidden && !that.state.get().isConnected) {\n that.invalidate();\n }\n };\n\n document.addEventListener('visibilitychange', onFocus);\n }\n}\n\nfunction mapValue<T, S, Args extends any[]>(\n cache: Cache<T, Args>,\n _selector: Selector<T, S> | AnyPath,\n): Cache<S, Args> {\n const selector = makeSelector(_selector);\n const derivedFromCache = {\n cache: cache.derivedFromCache ? cache.derivedFromCache.cache : cache,\n selectors: cache.derivedFromCache\n ? [...cache.derivedFromCache.selectors, _selector]\n : [_selector],\n };\n\n return new Cache<S, Args>(\n async ({ use }) => {\n const value = await use(cache);\n return selector(value);\n },\n cache.args,\n {\n equals: cache.options.equals,\n },\n derivedFromCache,\n );\n}\n\nexport type CreateCacheResult<\n T,\n Args extends any[],\n TCache extends Cache<T, Args>,\n> = [] extends Args ? CacheBundle<T, Args, TCache> & TCache : CacheBundle<T, Args, TCache>;\n\nexport interface InvalidationOptions<T, Args extends any[], TCache extends Cache<T, Args>> {\n filter?: (cache: TCache) => boolean;\n}\n\nexport type CacheBundle<T, Args extends any[], TCache extends Cache<T, Args>> = {\n (...args: Args): TCache;\n mapCache<S>(selector: Selector<T, S>): CreateCacheResult<S, Args, Cache<S, Args>>;\n mapValue<const P>(\n selector: Constrain<P, Path<T>>,\n ): CreateCacheResult<Value<T, P>, Args, Cache<Value<T, P>, Args>>;\n invalidateAll: (options?: InvalidationOptions<T, Args, TCache>) => void;\n clearAll: (options?: InvalidationOptions<T, Args, TCache>) => void;\n getInstances: () => TCache[];\n};\n\nfunction create<T, Args extends any[] = []>(\n cacheFunction: CacheFunction<T, Args>,\n options?: CacheOptions<T, Args>,\n): CreateCacheResult<T, Args, Cache<T, Args>> {\n return internalCreate<T, Args, Cache<T, Args>>(\n (args, options) =>\n new Cache(\n (helpers) => {\n const result = cacheFunction.apply(helpers, args);\n\n if (result instanceof Function) {\n return result(helpers);\n }\n\n return result;\n },\n args,\n options,\n undefined,\n ),\n options,\n );\n}\n\nexport function internalCreate<T, Args extends any[], TCache extends Cache<T, Args>>(\n factory: (args: Args, options: CacheOptions<T, Args>) => TCache,\n options?: CacheOptions<T, Args>,\n): CreateCacheResult<T, Args, TCache> {\n options = { ...createCache.defaultOptions, ...options };\n const { clearUnusedAfter, resourceGroup } = options ?? {};\n\n let baseInstance: CacheBundle<T, Args, TCache> & TCache;\n\n const instanceCache = new InstanceCache<Args, TCache>(\n (...args) => factory(args, options),\n clearUnusedAfter ? calcDuration(clearUnusedAfter) : undefined,\n );\n\n function get(...args: Args) {\n const sliceAfter = args.lastIndexOf(undefined);\n if (sliceAfter !== -1) {\n args = args.slice(0, sliceAfter) as Args;\n }\n\n const cacheKey = options?.getCacheKey ? options.getCacheKey(...args) : args;\n return instanceCache.getWithKey(args, cacheKey);\n }\n\n const mapCache = (selector: any) => {\n return internalCreate<any, Args, Cache<any, Args>>((args: Args) =>\n mapValue(baseInstance(...args), selector),\n );\n };\n\n const invalidateAll = ({ filter = () => true }: InvalidationOptions<T, Args, TCache> = {}) => {\n for (const instance of instanceCache.values()) {\n if (filter(instance)) {\n instance.invalidate();\n }\n }\n };\n\n const clearAll = ({ filter = () => true }: InvalidationOptions<T, Args, TCache> = {}) => {\n for (const instance of instanceCache.values()) {\n if (filter(instance)) {\n instance.clear();\n }\n }\n };\n\n const getInstances = () => {\n return instanceCache.values();\n };\n\n baseInstance = new Proxy(\n Object.assign(() => undefined, {\n mapCache,\n invalidateAll,\n clearAll,\n getInstances,\n }),\n {\n apply(_target, _thisArg, argArray) {\n return get(...(argArray as unknown as Args));\n },\n get(target, p, receiver) {\n if (Reflect.has(target, p)) {\n return Reflect.get(target, p, receiver);\n }\n\n const baseCache = get(...([] as unknown as Args));\n return Reflect.get(baseCache, p, baseCache);\n },\n },\n ) as unknown as CacheBundle<T, Args, TCache> & TCache;\n\n const groups = Array.isArray(resourceGroup)\n ? resourceGroup\n : resourceGroup\n ? [resourceGroup]\n : [];\n\n for (const group of groups.concat(allResources)) {\n group.add(baseInstance);\n }\n\n return baseInstance;\n}\n\nexport const defaultCacheOptions: CacheOptions<any, any> = {\n invalidateOnWindowFocus: true,\n clearUnusedAfter: { days: 1 },\n retain: { milliseconds: 1 },\n equals: deepEqual,\n};\n\nexport const createCache: typeof create & { defaultOptions: CacheOptions<any, any> } =\n /* @__PURE__ */ Object.assign(create, {\n defaultOptions: defaultCacheOptions,\n });\n","import { autobind } from '@lib/autobind';\n\nexport class Scope<T> {\n constructor(public readonly defaultValue: T) {\n autobind(Scope);\n }\n}\n\nexport function createScope<T>(defaultValue: T): Scope<T> {\n return new Scope(defaultValue);\n}\n"],"mappings":";;;;;AAEA,IAAa,gBAAb,MAAiE;CAO/D,YACE,AAAgBA,SAChB,AAAgBC,WAChB;EAFgB;EACA;+BARF,IAAI;kBAED,KAAK,YACpB,kBAAkB,KAAK,WAAW,KAAK,IAAI,KAAK,YAAY,IAAI,MAChE;;CAOJ,UAAgB;EACd,MAAM,SAAS,KAAK,SAAS,KAAK,aAAa;AAE/C,OAAK,MAAM,CAAC,KAAK,UAAU,KAAK,MAAM,WAAW;AAC/C,OAAI,MAAM,OAAO,MAAM,KAAK,OAC1B,QAAO,MAAM;AAGf,OAAI,CAAC,MAAM,OAAO,CAAC,MAAM,SAAS,QAChC,MAAK,MAAM,OAAO;;;CAKxB,IAAI,GAAG,MAAe;AACpB,SAAO,KAAK,WAAW,MAAM;;CAG/B,WAAW,MAAY,UAAsB;EAC3C,MAAM,MAAMC,wBAAW;EACvB,IAAI,QAAQ,KAAK,MAAM,IAAI;EAC3B,IAAI,QAAQ,OAAO,OAAO,OAAO,SAAS;AAE1C,MAAI,CAAC,SAAS,CAAC,OAAO;AACpB,WAAQ,KAAK,QAAQ,GAAG;AACxB,WAAQ;IACN,GAAG,KAAK;IACR,KAAK;IACL,SAAS,IAAI,QAAQ;;AAGvB,QAAK,MAAM,IAAI,KAAK;SACf;AACL,SAAM,IAAI,KAAK;AACf,SAAM,QAAQ;;AAGhB,SAAO;;CAGT,SAAc;AACZ,SAAO,CAAC,GAAG,KAAK,MAAM,UACnB,KAAK,UAAU,MAAM,OAAO,MAAM,SAAS,SAC3C,QAAQ,UAAsB,CAAC,CAAC;;CAGrC,OAAa;AACX,MAAI,KAAK,SACP,eAAc,KAAK;;CAIvB,QAAiE;AAC/D,SAAO;GACL,OAAO,KAAK,MAAM;GAClB,SAAS,CAAC,GAAG,KAAK,MAAM,UAAU,QAAQ,MAAM,CAAC,CAAC,EAAE,KAAK;GACzD,aAAa,CAAC,GAAG,KAAK,MAAM,UAAU,QAAQ,MAAM,CAAC,CAAC,EAAE,SAAS,SAAS;;;CAI9E,AAAQ,MAAM;AACZ,SAAO,YAAY;;;;;;ACpEvB,IAAa,gBAAb,MAAa,cAAc;CAKzB,YAAY,AAAgBC,MAAe;EAAf;gCAJX,IAAI;gCAEJ,IAAI;AAGnB,yBAAS;;CAGX,IAAI,UAA0B;EAC5B,MAAM,MAAM,IAAI,QAAQ;AACxB,OAAK,OAAO,IAAI,UAAU;AAC1B,OAAK,OAAO,IAAI;;CAGlB,OAAO,UAA0B;EAC/B,MAAM,MAAM,KAAK,OAAO,IAAI;AAC5B,MAAI,KAAK;AACP,QAAK,OAAO,OAAO;AACnB,QAAK,OAAO,OAAO;;;CAIvB,gBAAsB;AACpB,OAAK,MAAM,OAAO,KAAK,QAAQ;GAC7B,MAAM,WAAW,IAAI;AACrB,OAAI,SACF,UAAS;OAET,MAAK,OAAO,OAAO;;;CAKzB,WAAiB;AACf,OAAK,MAAM,OAAO,KAAK,QAAQ;GAC7B,MAAM,WAAW,IAAI;AACrB,OAAI,SACF,UAAS;OAET,MAAK,OAAO,OAAO;;;;AAM3B,MAAaC,+BAA8C,IAAI;AAE/D,SAAgB,oBAAoB,MAA8B;AAChE,QAAO,IAAI,cAAc;;;;;ACsC3B,IAAa,QAAb,MAAa,cAA0CC,oBAAkB;CAYvE,YACE,QACA,AAAgBC,MAChB,AAAgBC,UAAiC,IACjD,AAAgBC,kBAIhB;AACA,QAAM,QAAQ,SAAS;EAPP;EACA;EACA;eAfqBC,0BAA2B;GAChE,QAAQ;GACR,SAAS;GACT,YAAY;GACZ,aAAa;;AAiBb,yBAAS;AAET,OAAK;AACL,OAAK;;CAGP,IAAI,EAAE,SAAS,aAAa,mBAAmB,UAA2B,IAAgB;AACxF,MAAI,CAAC,KAAK,iBAAiB,SAAS;AAClC,QAAK,iBAAiB;AACtB,QAAK,kBAAkB;;EAGzB,MAAM,UAAU,KAAK,iBAAiB;EACtC,MAAM,eAAe,KAAK;AAE1B,MACG,WAAW,iBAAiB,CAAC,WAAW,CAAC,gBACzC,WAAW,eAAe,CAAC,WAC5B,WAAW,SACX;AACA,QAAK,kBAAkBC,8BAAgB,MAAM,KAAK;AAClD,QAAK;AAEL,OAAK,CAAC,WAAW,CAAC,gBAAiB,CAAC,iBAClC,QAAO,KAAK,gBAAgB;;AAIhC,MAAI,CAAC,WAAY,gBAAgB,iBAC/B,QAAO;AAGT,SAAO;;CAGT,YAAY,OAA8D;AACxE,MAAI,iBAAiB,SACnB,SAAQ,MAAM,KAAK,MAAM,MAAM;AAEjC,OAAK,IAAIC,+BAAiB,QAAQ;;CAGpC,YAAY,OAAsB;AAChC,OAAK,IAAIA,+BAAiB,OAAO;;CAGnC,WAAW,WAA2B;EACpC,MAAM,EAAE,sBAAsB,KAAK;AAEnC,MAAI,kBACF,QAAO,KAAK,MAAM;EAGpB,MAAM,EAAE,QAAQ,SAAS,eAAe,KAAK,MAAM;AACnD,MAAI,WAAW,aAAa,CAAC,WAAW,CAAC,WACvC,MAAK,eAAe,KAAK,iBAAiB;AAG5C,OAAK,MAAM,KAAK,WAAW;GACzB,GAAG;GACH,SAAS;GACT,YAAY;;AAGd,QAAM,WAAW;;CAGnB,MAAM,WAA2B;AAC/B,OAAK,MAAM,IAAI;GACb,QAAQ;GACR,SAAS;GACT,YAAY;GACZ,aAAa;;AAEf,SAAO,KAAK;AAEZ,QAAM,WAAW;;CASnB,SAAS,UAAwC;AAC/C,SAAO,SAAS,MAAM;;CAGxB,AAAU,eAAqB;AAC7B,OAAK,UACH,OAAO,YAAY;AACjB,OAAI,mBAAmBA,kCAAoB,QAAQ,MAAM,WAAW,WAAW;AAC7E,YAAQ,YAAY;AAEpB,SAAK,MAAM,KAAK,WAAW;KACzB,GAAG,QAAQ;KACX,SAAS;KACT,YAAY;KACZ,aAAa,MAAM;;AAGrB,WAAO,KAAK;AACZ,SAAK;AACL;;AAGF,QAAK,MAAM,KAAK,WAAW;IACzB,GAAG;IACH,YAAY;;AAGd,QAAK;AAEL,OAAI;IACF,MAAM,QAAQ,MAAM;AAEpB,QAAI,YAAY,KAAK,iBAAiB,MACpC;AAGF,SAAK,MAAM,KAAK,WAAW;KACzB,QAAQ;KACR;KACA,SAAS;KACT,YAAY;KACZ,aAAa,MAAM;;AAErB,WAAO,KAAK;AACZ,SAAK;YACE,OAAO;AACd,QAAI,YAAY,KAAK,iBAAiB,MACpC;AAGF,SAAK,MAAM,KAAK,WAAW;KACzB,QAAQ;KACR;KACA,SAAS;KACT,YAAY;KACZ,aAAa,MAAM;;AAErB,WAAO,KAAK;AACZ,SAAK;;KAGT,EAAE,SAAS;;CAIf,AAAU,YAAkB;AAC1B,MAAI,KAAK,kBACP,cAAa,KAAK;AAEpB,OAAK,oBAAoB;EAEzB,MAAM,QAAQ,KAAK,MAAM;EACzB,IAAI,EAAE,oBAAoB,KAAK;EAC/B,MAAM,MAAM,IAAI,QAAQ;AAExB,MAAI,MAAM,WAAW,UACnB;AAGF,MAAI,2BAA2B,SAC7B,mBAAkB,gBAAgB;AAGpC,MAAI,oBAAoB,QAAQ,oBAAoB,OAClD,MAAK,oBAAoB,iBACjB,KAAK,SAAS,cACpBC,2BAAa;;CAKnB,AAAU,aAAmB;EAC3B,MAAM,EAAE,4BAA4B,KAAK;AAEzC,MACE,CAAC,2BACD,OAAO,aAAa,eACpB,OAAO,SAAS,qBAAqB,YAErC;EAGF,MAAM,MAAM,IAAI,QAAQ;EAExB,MAAM,gBAAgB;GACpB,MAAM,OAAO,KAAK;AAClB,OAAI,CAAC,MAAM;AACT,aAAS,oBAAoB,oBAAoB;AACjD;;AAGF,OAAI,CAAC,SAAS,UAAU,CAAC,KAAK,MAAM,MAAM,YACxC,MAAK;;AAIT,WAAS,iBAAiB,oBAAoB;;;AAIlD,SAAS,SACP,OACA,WACgB;CAChB,MAAM,WAAWC,2BAAa;CAC9B,MAAM,mBAAmB;EACvB,OAAO,MAAM,mBAAmB,MAAM,iBAAiB,QAAQ;EAC/D,WAAW,MAAM,mBACb,CAAC,GAAG,MAAM,iBAAiB,WAAW,aACtC,CAAC;;AAGP,QAAO,IAAI,MACT,OAAO,EAAE,UAAU;EACjB,MAAM,QAAQ,MAAM,IAAI;AACxB,SAAO,SAAS;IAElB,MAAM,MACN,EACE,QAAQ,MAAM,QAAQ,UAExB;;AAyBJ,SAAS,OACP,eACA,SAC4C;AAC5C,QAAO,gBACJ,MAAM,cACL,IAAI,OACD,YAAY;EACX,MAAM,SAAS,cAAc,MAAM,SAAS;AAE5C,MAAI,kBAAkB,SACpB,QAAO,OAAO;AAGhB,SAAO;IAET,MACAC,WACA,SAEJ;;AAIJ,SAAgB,eACd,SACA,SACoC;AACpC,WAAU;EAAE,GAAG,YAAY;EAAgB,GAAG;;CAC9C,MAAM,EAAE,kBAAkB,kBAAkB,WAAW;CAEvD,IAAIC;CAEJ,MAAM,gBAAgB,IAAI,eACvB,GAAG,SAAS,QAAQ,MAAM,UAC3B,mBAAmBH,2BAAa,oBAAoB;CAGtD,SAAS,IAAI,GAAG,MAAY;EAC1B,MAAM,aAAa,KAAK,YAAY;AACpC,MAAI,eAAe,GACjB,QAAO,KAAK,MAAM,GAAG;EAGvB,MAAM,WAAW,SAAS,cAAc,QAAQ,YAAY,GAAG,QAAQ;AACvE,SAAO,cAAc,WAAW,MAAM;;CAGxC,MAAM,YAAY,aAAkB;AAClC,SAAO,gBAA6C,SAClD,SAAS,aAAa,GAAG,OAAO;;CAIpC,MAAM,iBAAiB,EAAE,eAAe,SAA+C,OAAO;AAC5F,OAAK,MAAM,YAAY,cAAc,SACnC,KAAI,OAAO,UACT,UAAS;;CAKf,MAAM,YAAY,EAAE,eAAe,SAA+C,OAAO;AACvF,OAAK,MAAM,YAAY,cAAc,SACnC,KAAI,OAAO,UACT,UAAS;;CAKf,MAAM,qBAAqB;AACzB,SAAO,cAAc;;AAGvB,gBAAe,IAAI,MACjB,OAAO,aAAa,QAAW;EAC7B;EACA;EACA;EACA;KAEF;EACE,MAAM,SAAS,UAAU,UAAU;AACjC,UAAO,IAAI,GAAI;;EAEjB,IAAI,QAAQ,GAAG,UAAU;AACvB,OAAI,QAAQ,IAAI,QAAQ,GACtB,QAAO,QAAQ,IAAI,QAAQ,GAAG;GAGhC,MAAM,YAAY,IAAI,GAAI;AAC1B,UAAO,QAAQ,IAAI,WAAW,GAAG;;;CAKvC,MAAM,SAAS,MAAM,QAAQ,iBACzB,gBACA,gBACE,CAAC,iBACD;AAEN,MAAK,MAAM,SAAS,OAAO,OAAO,cAChC,OAAM,IAAI;AAGZ,QAAO;;AAGT,MAAaI,sBAA8C;CACzD,yBAAyB;CACzB,kBAAkB,EAAE,MAAM;CAC1B,QAAQ,EAAE,cAAc;CACxB,QAAQC;;AAGV,MAAaC,cACK,uBAAO,OAAO,QAAQ,EACpC,gBAAgB;;;;ACnepB,IAAa,QAAb,MAAa,MAAS;CACpB,YAAY,AAAgBC,cAAiB;EAAjB;AAC1B,yBAAS;;;AAIb,SAAgB,YAAe,cAA2B;AACxD,QAAO,IAAI,MAAM"}
1
+ {"version":3,"file":"scope-CfLlLxo9.cjs","names":["factory: (...args: Args) => T","cacheTime?: number","simpleHash","name?: string","allResources: ResourceGroup","Store","args: Args","options: CacheOptions<T, Args>","derivedFromCache?: {\n cache: Cache<any, any>;\n selectors: (Selector<any, any> | AnyPath)[];\n }","createStore","calculatedValue","PromiseWithState","calcDuration","makeSelector","options","baseInstance: CacheBundle<T, Args, TCache> & TCache","defaultCacheOptions: CacheOptions<any, any>","deepEqual","createCache: typeof create & { defaultOptions: CacheOptions<any, any> }","defaultValue: T"],"sources":["../src/lib/instanceCache.ts","../src/core/resourceGroup.ts","../src/core/cache.ts","../src/core/scope.ts"],"sourcesContent":["import { simpleHash } from './hash';\n\nexport class InstanceCache<Args extends any[], T extends object> {\n private cache = new Map<string, { t: number; ref?: T; weakRef: WeakRef<T> }>();\n\n private interval = this.cacheTime\n ? setInterval(() => this.cleanup(), Math.max(this.cacheTime / 10, 1))\n : undefined;\n\n constructor(\n public readonly factory: (...args: Args) => T,\n public readonly cacheTime?: number,\n ) {}\n\n cleanup(): void {\n const cutoff = this.now() - (this.cacheTime ?? 0);\n\n for (const [key, entry] of this.cache.entries()) {\n if (entry.ref && entry.t <= cutoff) {\n delete entry.ref;\n }\n\n if (!entry.ref && !entry.weakRef?.deref()) {\n this.cache.delete(key);\n }\n }\n }\n\n get(...args: Args): T {\n return this.getWithKey(args, args);\n }\n\n getWithKey(args: Args, cacheKey: unknown): T {\n const key = simpleHash(cacheKey);\n let entry = this.cache.get(key);\n let value = entry?.ref ?? entry?.weakRef?.deref();\n\n if (!entry || !value) {\n value = this.factory(...args);\n entry = {\n t: this.now(),\n ref: value,\n weakRef: new WeakRef(value),\n };\n\n this.cache.set(key, entry);\n } else {\n entry.t = this.now();\n entry.ref ??= value;\n }\n\n return value;\n }\n\n values(): T[] {\n return [...this.cache.values()]\n .map((entry) => entry.ref ?? entry.weakRef?.deref())\n .filter((value): value is T => !!value);\n }\n\n stop(): void {\n if (this.interval) {\n clearInterval(this.interval);\n }\n }\n\n stats(): { count: number; withRef: number; withWeakRef: number } {\n return {\n count: this.cache.size,\n withRef: [...this.cache.values()].filter((x) => !!x.ref).length,\n withWeakRef: [...this.cache.values()].filter((x) => !!x.weakRef?.deref()).length,\n };\n }\n\n private now() {\n return performance.now();\n }\n}\n","import { autobind } from '@lib/autobind';\n\nexport interface Resource {\n invalidateAll(): void;\n clearAll(): void;\n}\n\nexport class ResourceGroup {\n private refMap = new WeakMap<Resource, WeakRef<Resource>>();\n\n private refSet = new Set<WeakRef<Resource>>();\n\n constructor(public readonly name?: string) {\n autobind(ResourceGroup);\n }\n\n add(resource: Resource): void {\n const ref = new WeakRef(resource);\n this.refMap.set(resource, ref);\n this.refSet.add(ref);\n }\n\n delete(resource: Resource): void {\n const ref = this.refMap.get(resource);\n if (ref) {\n this.refMap.delete(resource);\n this.refSet.delete(ref);\n }\n }\n\n invalidateAll(): void {\n for (const ref of this.refSet) {\n const resource = ref.deref();\n if (resource) {\n resource.invalidateAll();\n } else {\n this.refSet.delete(ref);\n }\n }\n }\n\n clearAll(): void {\n for (const ref of this.refSet) {\n const resource = ref.deref();\n if (resource) {\n resource.clearAll();\n } else {\n this.refSet.delete(ref);\n }\n }\n }\n}\n\nexport const allResources: ResourceGroup = /* @__PURE__ */ new ResourceGroup();\n\nexport function createResourceGroup(name?: string): ResourceGroup {\n return new ResourceGroup(name);\n}\n","import { autobind } from '@lib/autobind';\nimport type { CacheState, ErrorState, ValueState } from '@lib/cacheState';\nimport { calcDuration } from '@lib/calcDuration';\nimport { calculatedValue } from '@lib/calculatedValue';\nimport type { Constrain } from '@lib/constrain';\nimport { deepEqual } from '@lib/equals';\nimport { InstanceCache } from '@lib/instanceCache';\nimport { makeSelector } from '@lib/makeSelector';\nimport { type MaybePromise } from '@lib/maybePromise';\nimport type { AnyPath, Path, Value } from '@lib/path';\nimport { PromiseWithState } from '@lib/promiseWithState';\nimport type { Duration, Selector } from './commonTypes';\nimport { allResources, type ResourceGroup } from './resourceGroup';\nimport { Store, createStore, type Calculate, type StoreOptions } from './store';\n\nexport interface CacheGetOptions {\n /**\n * How to handle the cache when getting the value.\n * - `whenMissing`: Only fetch a new value if there is no cached value.\n * - `whenStale`: Fetch a new value if there is no cached value or if the cached value is stale.\n * - `force`: Always fetch a new value, regardless of the cache state.\n */\n update?: 'whenMissing' | 'whenStale' | 'force';\n\n /**\n * If set to `true`, the cache will be updated in the background.\n * This means that a stale value will be returned immediately, if available, while the new value is being fetched.\n */\n backgroundUpdate?: boolean;\n}\n\nexport interface CacheFunction<T, Args extends any[] = []> {\n (...args: Args): Promise<T> | Calculate<Promise<T>>;\n}\n\nexport interface CacheOptions<T, Args extends any[]> extends StoreOptions<Promise<T>> {\n /**\n * How long to keep the cache entry before it is considered stale.\n * If set to `undefined` or `null`, the cache entry will never be invalidated automatically.\n *\n * @example\n * ```typescript\n * createCache(fetchData, {\n * invalidateAfter: { seconds: 10 },\n * });\n * ```\n */\n invalidateAfter?: Duration | ((state: ValueState<T> | ErrorState) => Duration | null) | null;\n\n /**\n * If set, the cache will be invalidated when the window gets focused.\n * This is useful for caches that are used in a browser environment and might become stale when the user switches tabs.\n */\n invalidateOnWindowFocus?: boolean;\n\n /**\n * If set, the cached value will be cleared when the cache is invalidated.\n * Without this option, the cache will keep the last value as stale until a new value becomes available.\n */\n clearOnInvalidate?: boolean;\n\n /**\n * If set, cache entries will be cleared after approximately the specified duration.\n * This is useful for long lived pages or applications and helps to prevent memory leaks.\n * The exact time when the entry is cleared is not guaranteed, since it will be cleared during garbage collection.\n */\n clearUnusedAfter?: Duration | null;\n\n /**\n * Add the cache to the specified resource group(s).\n * This allows you to invalidate or clear multiple caches that belong to the same group.\n * All caches are always added to the `allResources` group.\n */\n resourceGroup?: ResourceGroup | ResourceGroup[];\n\n /**\n * Function to generate a custom cache key based on the provided arguments.\n * This allows you to control how cache entries are identified and reused.\n * By default, the arguments array is used as the cache key.\n *\n * @example\n * ```typescript\n * // Will use the same instance when provided with `undefined`, `{ num: 0 }`, `{ bool: false }`, etc.\n * createCache((filter?: { num?: number, bool?: boolean }) => fetchData(filter), {\n * getCacheKey: (filter?) => ({\n * num: filter?.num ?? 0,\n * bool: filter?.bool ?? false,\n * }),\n * });\n * ```\n */\n getCacheKey?: (...args: NoInfer<Args>) => unknown;\n}\n\nexport class Cache<T, Args extends any[] = []> extends Store<Promise<T>> {\n readonly state: Store<CacheState<T>> = createStore<CacheState<T>>({\n status: 'pending',\n isStale: true,\n isUpdating: false,\n isConnected: false,\n });\n\n protected stalePromise?: Promise<T>;\n\n protected invalidationTimer?: ReturnType<typeof setTimeout>;\n\n constructor(\n getter: Calculate<Promise<T>>,\n public readonly args: Args,\n public readonly options: CacheOptions<T, Args> = {},\n public readonly derivedFromCache?: {\n cache: Cache<any, any>;\n selectors: (Selector<any, any> | AnyPath)[];\n },\n ) {\n super(getter, options, undefined);\n autobind(Cache);\n\n this.watchPromise();\n this.watchFocus();\n }\n\n get({ update = 'whenStale', backgroundUpdate = false }: CacheGetOptions = {}): Promise<T> {\n if (!this.calculatedValue?.check()) {\n this.calculatedValue?.stop();\n this.calculatedValue = undefined;\n }\n\n const promise = this.calculatedValue?.value;\n const stalePromise = this.stalePromise;\n\n if (\n (update === 'whenMissing' && !promise && !stalePromise) ||\n (update === 'whenStale' && !promise) ||\n update === 'force'\n ) {\n this.calculatedValue = calculatedValue(this, this.notify);\n this.notify();\n\n if ((!promise && !stalePromise) || !backgroundUpdate) {\n return this.calculatedValue.value;\n }\n }\n\n if (!promise || (stalePromise && backgroundUpdate)) {\n return stalePromise!;\n }\n\n return promise;\n }\n\n updateValue(value: MaybePromise<T> | ((value: T | undefined) => T)): void {\n if (value instanceof Function) {\n value = value(this.state.get().value);\n }\n this.set(PromiseWithState.resolve(value));\n }\n\n updateError(error: unknown): void {\n this.set(PromiseWithState.reject(error));\n }\n\n invalidate(recursive?: boolean): void {\n const { clearOnInvalidate } = this.options;\n\n if (clearOnInvalidate) {\n return this.clear(recursive);\n }\n\n const { status, isStale, isUpdating } = this.state.get();\n if (status !== 'pending' && !isStale && !isUpdating) {\n this.stalePromise = this.calculatedValue?.value;\n }\n\n this.state.set((state) => ({\n ...state,\n isStale: true,\n isUpdating: false,\n }));\n\n super.invalidate(recursive);\n }\n\n clear(recursive?: boolean): void {\n this.state.set({\n status: 'pending',\n isStale: true,\n isUpdating: false,\n isConnected: false,\n });\n delete this.stalePromise;\n\n super.invalidate(recursive);\n }\n\n mapValue<S>(selector: Selector<T, S>): Cache<S, Args>;\n\n mapValue<const P extends AnyPath>(\n selector: P extends Path<T> ? P : Path<T>,\n ): Cache<Value<T, P>, Args>;\n\n mapValue(selector: Selector<any, any> | AnyPath) {\n return mapValue(this, selector);\n }\n\n protected watchPromise(): void {\n this.subscribe(\n async (promise) => {\n if (promise instanceof PromiseWithState && promise.state.status !== 'pending') {\n promise.catch(() => undefined);\n\n this.state.set((state) => ({\n ...promise.state,\n isStale: false,\n isUpdating: false,\n isConnected: state.isConnected,\n }));\n\n delete this.stalePromise;\n this.setTimers();\n return;\n }\n\n this.state.set((state) => ({\n ...state,\n isUpdating: true,\n }));\n\n this.setTimers();\n\n try {\n const value = await promise;\n\n if (promise !== this.calculatedValue?.value) {\n return;\n }\n\n this.state.set((state) => ({\n status: 'value',\n value,\n isStale: false,\n isUpdating: false,\n isConnected: state.isConnected,\n }));\n delete this.stalePromise;\n this.setTimers();\n } catch (error) {\n if (promise !== this.calculatedValue?.value) {\n return;\n }\n\n this.state.set((state) => ({\n status: 'error',\n error,\n isStale: false,\n isUpdating: false,\n isConnected: state.isConnected,\n }));\n delete this.stalePromise;\n this.setTimers();\n }\n },\n { passive: true },\n );\n }\n\n protected setTimers(): void {\n if (this.invalidationTimer) {\n clearTimeout(this.invalidationTimer);\n }\n this.invalidationTimer = undefined;\n\n const state = this.state.get();\n let { invalidateAfter } = this.options;\n const ref = new WeakRef(this);\n\n if (state.status === 'pending') {\n return;\n }\n\n if (invalidateAfter instanceof Function) {\n invalidateAfter = invalidateAfter(state);\n }\n\n if (invalidateAfter !== null && invalidateAfter !== undefined) {\n this.invalidationTimer = setTimeout(\n () => ref?.deref()?.invalidate(),\n calcDuration(invalidateAfter),\n );\n }\n }\n\n protected watchFocus(): void {\n const { invalidateOnWindowFocus } = this.options;\n\n if (\n !invalidateOnWindowFocus ||\n typeof document === 'undefined' ||\n typeof document.addEventListener === 'undefined'\n ) {\n return;\n }\n\n const ref = new WeakRef(this);\n\n const onFocus = () => {\n const that = ref?.deref();\n if (!that) {\n document.removeEventListener('visibilitychange', onFocus);\n return;\n }\n\n if (!document.hidden && !that.state.get().isConnected) {\n that.invalidate();\n }\n };\n\n document.addEventListener('visibilitychange', onFocus);\n }\n}\n\nfunction mapValue<T, S, Args extends any[]>(\n cache: Cache<T, Args>,\n _selector: Selector<T, S> | AnyPath,\n): Cache<S, Args> {\n const selector = makeSelector(_selector);\n const derivedFromCache = {\n cache: cache.derivedFromCache ? cache.derivedFromCache.cache : cache,\n selectors: cache.derivedFromCache\n ? [...cache.derivedFromCache.selectors, _selector]\n : [_selector],\n };\n\n return new Cache<S, Args>(\n async ({ use }) => {\n const value = await use(cache);\n return selector(value);\n },\n cache.args,\n {\n equals: cache.options.equals,\n },\n derivedFromCache,\n );\n}\n\nexport type CreateCacheResult<\n T,\n Args extends any[],\n TCache extends Cache<T, Args>,\n> = [] extends Args ? CacheBundle<T, Args, TCache> & TCache : CacheBundle<T, Args, TCache>;\n\nexport interface InvalidationOptions<T, Args extends any[], TCache extends Cache<T, Args>> {\n filter?: (cache: TCache) => boolean;\n}\n\nexport type CacheBundle<T, Args extends any[], TCache extends Cache<T, Args>> = {\n (...args: Args): TCache;\n mapCache<S>(selector: Selector<T, S>): CreateCacheResult<S, Args, Cache<S, Args>>;\n mapValue<const P>(\n selector: Constrain<P, Path<T>>,\n ): CreateCacheResult<Value<T, P>, Args, Cache<Value<T, P>, Args>>;\n invalidateAll: (options?: InvalidationOptions<T, Args, TCache>) => void;\n clearAll: (options?: InvalidationOptions<T, Args, TCache>) => void;\n getInstances: () => TCache[];\n};\n\nfunction create<T, Args extends any[] = []>(\n cacheFunction: CacheFunction<T, Args>,\n options?: CacheOptions<T, Args>,\n): CreateCacheResult<T, Args, Cache<T, Args>> {\n return internalCreate<T, Args, Cache<T, Args>>(\n (args, options) =>\n new Cache(\n (helpers) => {\n const result = cacheFunction.apply(helpers, args);\n\n if (result instanceof Function) {\n return result(helpers);\n }\n\n return result;\n },\n args,\n options,\n undefined,\n ),\n options,\n );\n}\n\nexport function internalCreate<T, Args extends any[], TCache extends Cache<T, Args>>(\n factory: (args: Args, options: CacheOptions<T, Args>) => TCache,\n options?: CacheOptions<T, Args>,\n): CreateCacheResult<T, Args, TCache> {\n options = { ...createCache.defaultOptions, ...options };\n const { clearUnusedAfter, resourceGroup } = options ?? {};\n\n let baseInstance: CacheBundle<T, Args, TCache> & TCache;\n\n const instanceCache = new InstanceCache<Args, TCache>(\n (...args) => factory(args, options),\n clearUnusedAfter ? calcDuration(clearUnusedAfter) : undefined,\n );\n\n function get(...args: Args) {\n const sliceAfter = args.lastIndexOf(undefined);\n if (sliceAfter !== -1) {\n args = args.slice(0, sliceAfter) as Args;\n }\n\n const cacheKey = options?.getCacheKey ? options.getCacheKey(...args) : args;\n return instanceCache.getWithKey(args, cacheKey);\n }\n\n const mapCache = (selector: any) => {\n return internalCreate<any, Args, Cache<any, Args>>((args: Args) =>\n mapValue(baseInstance(...args), selector),\n );\n };\n\n const invalidateAll = ({ filter = () => true }: InvalidationOptions<T, Args, TCache> = {}) => {\n for (const instance of instanceCache.values()) {\n if (filter(instance)) {\n instance.invalidate();\n }\n }\n };\n\n const clearAll = ({ filter = () => true }: InvalidationOptions<T, Args, TCache> = {}) => {\n for (const instance of instanceCache.values()) {\n if (filter(instance)) {\n instance.clear();\n }\n }\n };\n\n const getInstances = () => {\n return instanceCache.values();\n };\n\n baseInstance = new Proxy(\n Object.assign(() => undefined, {\n mapCache,\n invalidateAll,\n clearAll,\n getInstances,\n }),\n {\n apply(_target, _thisArg, argArray) {\n return get(...(argArray as unknown as Args));\n },\n get(target, p, receiver) {\n if (Reflect.has(target, p)) {\n return Reflect.get(target, p, receiver);\n }\n\n const baseCache = get(...([] as unknown as Args));\n return Reflect.get(baseCache, p, baseCache);\n },\n },\n ) as unknown as CacheBundle<T, Args, TCache> & TCache;\n\n const groups = Array.isArray(resourceGroup)\n ? resourceGroup\n : resourceGroup\n ? [resourceGroup]\n : [];\n\n for (const group of groups.concat(allResources)) {\n group.add(baseInstance);\n }\n\n return baseInstance;\n}\n\nexport const defaultCacheOptions: CacheOptions<any, any> = {\n invalidateOnWindowFocus: true,\n clearUnusedAfter: { days: 1 },\n retain: { milliseconds: 1 },\n equals: deepEqual,\n};\n\nexport const createCache: typeof create & { defaultOptions: CacheOptions<any, any> } =\n /* @__PURE__ */ Object.assign(create, {\n defaultOptions: defaultCacheOptions,\n });\n","import { autobind } from '@lib/autobind';\n\nexport class Scope<T> {\n constructor(public readonly defaultValue: T) {\n autobind(Scope);\n }\n}\n\nexport function createScope<T>(defaultValue: T): Scope<T> {\n return new Scope(defaultValue);\n}\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { AnyPath, Calculate, Constrain, Duration, MaybePromise, Path, Selector, Store, StoreOptions, Value } from "./store-BJWoRQIs.js";
1
+ import { AnyPath, Calculate, Constrain, Duration, MaybePromise, Path, Selector, Store, StoreOptions, Value } from "./store-DnZ6fsiJ.js";
2
2
 
3
3
  //#region src/lib/cacheState.d.ts
4
4
  type ValueState<T> = {
@@ -164,4 +164,4 @@ declare class Scope<T> {
164
164
  declare function createScope<T>(defaultValue: T): Scope<T>;
165
165
  //#endregion
166
166
  export { Cache, CacheBundle, CacheFunction, CacheGetOptions, CacheOptions, CacheState, CreateCacheResult, ErrorState, PendingState, Resource, ResourceGroup, Scope, ValueState, allResources, createCache, createResourceGroup, createScope };
167
- //# sourceMappingURL=scope-ByLCVzKk.d.ts.map
167
+ //# sourceMappingURL=scope-D3jkIPgn.d.ts.map
@@ -579,7 +579,7 @@ var Store = class Store {
579
579
  return disposable(cancel);
580
580
  }
581
581
  once(...args) {
582
- const condition = args[0] instanceof Function ? args[0] : Boolean;
582
+ const condition = args[0] instanceof Function ? args[0] : (x) => x !== void 0;
583
583
  const options = args[0] instanceof Function ? args[1] : args[0];
584
584
  return new PromiseWithCancel((resolve, reject, signal) => {
585
585
  let stopped = false;
@@ -818,4 +818,4 @@ Object.defineProperty(exports, 'throttle', {
818
818
  return throttle;
819
819
  }
820
820
  });
821
- //# sourceMappingURL=store-DQcFfgKD.cjs.map
821
+ //# sourceMappingURL=store-CdST5wJZ.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"store-DQcFfgKD.cjs","names":["state: ValueState<T> | ErrorState | PendingState","value","q: {\n action: Action<any>;\n resolve: (value: any) => void;\n reject: (error: unknown) => void;\n ref?: any;\n }[]","value: T | undefined","connection: { active: boolean; cancel?: Cancel } | undefined","value","cancel: Cancel | undefined","actions: AsyncConnectionActions<any>","_cancel: Cancel | undefined","deepEqual","get","run: (() => void) | undefined","timeout: ReturnType<typeof setTimeout> | undefined","timeoutStarted: number | undefined","debounce","arrayMethods: {\n [P in 'splice' | 'push' | 'pop' | 'shift' | 'unshift' | 'reverse' | 'sort']: <\n T extends Array<any>,\n >(\n this: Store<T>,\n ...args: T[P] extends Function_ ? Parameters<T[P]> : never\n ) => T[P] extends Function_ ? ReturnType<T[P]> : never;\n}","timeout: ReturnType<typeof setTimeout> | undefined","getter: T | Calculate<T>","options: StoreOptions<T>","derivedFrom?: {\n store: Store<any>;\n selectors: (Selector<any, any> | AnyPath)[];\n updater: (state: any) => void;\n }","path: any","update: Update<any>","get","set","deepEqual","previousValue: { value: T } | undefined","timer: ReturnType<typeof setTimeout> | undefined","updater: ((value: any) => Update<T>) | undefined","active","methods: StoreMethods | undefined","isObject","createStore: typeof create & { defaultOptions: StoreOptions<any> }"],"sources":["../src/lib/autobind.ts","../src/lib/calcDuration.ts","../src/lib/deferred.ts","../src/lib/isPromise.ts","../src/lib/promiseWithState.ts","../src/lib/queue.ts","../src/lib/calculatedValue.ts","../src/lib/makeSelector.ts","../src/lib/debounce.ts","../src/lib/disposable.ts","../src/lib/forwardError.ts","../src/lib/promiseWithCancel.ts","../src/lib/standardMethods.ts","../src/lib/throttle.ts","../src/core/store.ts"],"sourcesContent":["const marker = Symbol('autobind');\n\nexport const autobind = <\n TClass extends abstract new (...args: any) => any = abstract new (...args: any) => any,\n>(\n _class: TClass,\n): TClass => {\n for (const key of Reflect.ownKeys(_class.prototype)) {\n if (key === 'constructor') {\n continue;\n }\n\n const descriptor = Reflect.getOwnPropertyDescriptor(_class.prototype, key);\n let method = descriptor?.get?.() ?? descriptor?.value;\n let isBinding = false;\n\n if (typeof method !== 'function' || method[marker]) {\n continue;\n }\n\n Reflect.defineProperty(_class.prototype, key, {\n configurable: true,\n get() {\n if (\n isBinding ||\n this === _class.prototype ||\n Object.prototype.hasOwnProperty.call(this, key) ||\n typeof method !== 'function'\n ) {\n return method;\n }\n\n const boundMethod = (...args: any[]) => Reflect.apply(method, this, args);\n boundMethod[marker] = true;\n isBinding = true;\n\n Object.defineProperty(this, key, {\n configurable: true,\n get() {\n return boundMethod;\n },\n });\n\n isBinding = false;\n return boundMethod;\n },\n set(v) {\n method = v;\n },\n });\n }\n\n return _class;\n};\n","import type { Duration } from '../core/commonTypes';\n\nexport function calcDuration(t: Duration): number {\n if (typeof t === 'number') return t;\n return (\n (t.milliseconds ?? 0) +\n (t.seconds ?? 0) * 1000 +\n (t.minutes ?? 0) * 60 * 1000 +\n (t.hours ?? 0) * 60 * 60 * 1000 +\n (t.days ?? 0) * 24 * 60 * 60 * 1000\n );\n}\n","export class Deferred<T = void> extends Promise<T> {\n resolve: (value: T | PromiseLike<T>) => void = () => undefined;\n reject: (reason?: any) => void = () => undefined;\n\n constructor() {\n Object.defineProperty(Deferred, Symbol.species, {\n value: Promise,\n });\n\n const that = {};\n\n super((resolve, reject) => {\n Object.assign(that, { resolve, reject });\n });\n\n Object.assign(this, that);\n }\n}\n","export default function isPromise(value: unknown): value is Promise<unknown> {\n return (\n typeof value === 'object' &&\n value !== null &&\n 'then' in value &&\n typeof value.then === 'function'\n );\n}\n","import isPromise from '@lib/isPromise';\nimport { type ErrorState, type PendingState, type ValueState } from './cacheState';\nimport { type MaybePromise } from './maybePromise';\n\nexport class PromiseWithState<T> extends Promise<T> {\n static override resolve(): PromiseWithState<void>;\n\n static override resolve<T>(value: MaybePromise<T>): PromiseWithState<T>;\n\n static override resolve<T>(value?: MaybePromise<T>) {\n return new PromiseWithState<T>(value as MaybePromise<T>);\n }\n\n static override reject<T = never>(error: unknown): PromiseWithState<T> {\n return new PromiseWithState<T>(Promise.reject(error), { status: 'error', error });\n }\n\n constructor(\n value: MaybePromise<T>,\n public state: ValueState<T> | ErrorState | PendingState = { status: 'pending' },\n ) {\n super((resolve) => resolve(value));\n\n Object.defineProperty(PromiseWithState, Symbol.species, {\n value: Promise,\n });\n\n if (isPromise(value)) {\n value\n .then((value) => {\n this.state = { status: 'value', value: value };\n })\n .catch((error) => {\n this.state = { status: 'error', error };\n });\n } else {\n this.state = { status: 'value', value: value };\n }\n }\n}\n","import isPromise from '@lib/isPromise';\nimport type { MaybePromise } from './maybePromise';\nimport type { Listener } from '@core';\n\ntype Action<T> = () => MaybePromise<T>;\n\nexport interface Queue {\n <T>(action: Action<T>, ref?: any): Promise<T>;\n clear: () => void;\n whenDone: () => Promise<void>;\n size: number;\n getRefs: () => any[];\n}\n\nexport function queue(): Queue {\n const q: {\n action: Action<any>;\n resolve: (value: any) => void;\n reject: (error: unknown) => void;\n ref?: any;\n }[] = [];\n const completionListeners = new Set<Listener<void>>();\n let active = false;\n\n const notify = () => {\n for (const listener of completionListeners) {\n listener();\n }\n\n completionListeners.clear();\n };\n\n const run = async () => {\n if (!active) {\n active = true;\n\n let next;\n while ((next = q.shift())) {\n try {\n let result = next.action();\n if (isPromise(result)) {\n result = await result;\n }\n\n next.resolve(result);\n } catch (error) {\n next.reject(error);\n }\n }\n\n active = false;\n notify();\n }\n };\n\n return Object.assign(\n <T>(action: Action<T>, ref?: any) => {\n return new Promise<T>((resolve, reject) => {\n q.push({ action, resolve, reject, ref });\n run();\n });\n },\n {\n clear() {\n q.length = 0;\n },\n\n whenDone() {\n if (!active) {\n return Promise.resolve();\n }\n\n return new Promise<void>((resolve) => {\n completionListeners.add(resolve);\n });\n },\n\n get size() {\n return q.length;\n },\n\n getRefs() {\n return q.map((item) => item.ref).filter((x) => x !== undefined);\n },\n },\n );\n}\n","import type { Cache } from '@core';\nimport type { AsyncConnectionActions, Cancel, Connection, StoreLike } from '@core/commonTypes';\nimport type { Store } from '@core/store';\nimport { Deferred } from '@lib/deferred';\nimport isPromise from '@lib/isPromise';\nimport { PromiseWithState } from '@lib/promiseWithState';\nimport { queue } from '@lib/queue';\nimport { deepEqual } from './equals';\n\nexport interface CalculatedValue<T> {\n value: T;\n check: () => void;\n stop(): void;\n invalidateDependencies(recursive?: boolean): void;\n}\n\nexport function calculatedValue<T>(store: Store<T>, notify: () => void): CalculatedValue<T> {\n if (!(store.getter instanceof Function)) {\n return staticValue(store.getter);\n }\n\n let active = false;\n const deps = new Array<{ store: StoreLike<any>; value: any; on: () => void; off: () => void }>();\n let value: T | undefined;\n const whenConnected = new Deferred();\n const whenExecuted = new Deferred();\n const ac = new AbortController();\n let connection: { active: boolean; cancel?: Cancel } | undefined;\n const q = queue();\n q(() => whenExecuted);\n\n const cancelEffect = store.addEffect(() => {\n if (connection) {\n store.invalidate();\n return;\n }\n\n active = true;\n\n for (const dep of deps) {\n dep.on();\n }\n\n return () => {\n active = false;\n\n for (const dep of deps) {\n dep.off();\n }\n\n if (connection) {\n connection.active = false;\n connection.cancel?.();\n q.clear();\n\n if ('state' in store) {\n (store as unknown as Cache<any>).state.set((state) => ({\n ...state,\n isConnected: false,\n isStale: true,\n }));\n }\n }\n };\n });\n\n function use<S>(dep: StoreLike<S>) {\n const value = dep.get();\n let cancel: Cancel | undefined;\n\n const on = () => {\n cancel ||= dep.subscribe(() => store.invalidate(), { runNow: false });\n };\n\n const off = () => {\n cancel?.();\n cancel = undefined;\n };\n\n deps.push({ store: dep, value, on, off });\n\n if (active) {\n on();\n }\n\n return value;\n }\n\n async function connect(createConnection: Connection<T>) {\n if (!active) {\n connection = { active: false };\n return;\n }\n\n const actions: AsyncConnectionActions<any> = {\n set(_value) {\n q(() => {\n if (!connection?.active) {\n return;\n }\n\n value = _value;\n notify();\n });\n },\n updateValue(update) {\n q(async () => {\n if (!connection?.active) {\n return;\n }\n\n if (update instanceof Function) {\n const currentValue = await value;\n\n if (!connection?.active) {\n return;\n }\n\n try {\n update = update(currentValue);\n } catch (error) {\n value = PromiseWithState.reject(error) as T;\n notify();\n connection.active = false;\n connection.cancel?.();\n return;\n }\n }\n\n value = PromiseWithState.resolve(update) as T;\n notify();\n });\n },\n updateError(error) {\n q(() => {\n if (!connection?.active) {\n return;\n }\n\n connection.active = false;\n connection.cancel?.();\n\n if ('state' in store) {\n (store as unknown as Cache<any>).state.set({\n status: 'error',\n error,\n isConnected: false,\n isUpdating: false,\n isStale: false,\n });\n }\n\n value = PromiseWithState.reject(error) as T;\n notify();\n });\n },\n updateIsConnected(isConnected) {\n if (isConnected) {\n whenConnected.resolve();\n }\n\n q(() => {\n if (!connection?.active) {\n return;\n }\n\n if ('state' in store) {\n (store as unknown as Cache<any>).state.set('isConnected', isConnected);\n }\n });\n },\n close() {\n if (connection?.active) {\n store.invalidate();\n }\n },\n };\n\n connection = { active: true };\n let _cancel: Cancel | undefined = createConnection(actions as any);\n\n connection.cancel = () => {\n _cancel?.();\n _cancel = undefined;\n };\n\n if (!connection.active) {\n connection.cancel();\n }\n\n return whenConnected;\n }\n\n try {\n value = store.getter({ signal: ac.signal, use, connect });\n } catch (error) {\n value = PromiseWithState.reject(error) as T;\n\n if (connection) {\n connection.active = false;\n connection.cancel?.();\n q.clear();\n }\n }\n\n if (isPromise(value)) {\n value.finally(() => whenExecuted.resolve()).catch(() => undefined);\n } else {\n whenExecuted.resolve();\n }\n\n function check() {\n if (store.options.cacheValue === false) {\n return false;\n }\n\n for (const dep of deps) {\n if (!deepEqual(dep.store.get(), dep.value)) {\n return false;\n }\n }\n return true;\n }\n\n function stop() {\n cancelEffect();\n whenExecuted.resolve();\n whenConnected.resolve();\n ac.abort();\n\n if (connection) {\n connection.active = false;\n connection.cancel?.();\n q.clear();\n }\n }\n\n function invalidateDependencies(recursive?: boolean) {\n for (const dep of deps) {\n dep.store.invalidate(recursive);\n }\n }\n\n return {\n get value() {\n return value!;\n },\n check,\n stop,\n invalidateDependencies,\n };\n}\n\nexport function staticValue<T>(value: T): CalculatedValue<T> {\n return {\n value,\n check: () => true,\n stop: () => undefined,\n invalidateDependencies: () => undefined,\n };\n}\n\nexport function staleValue<T>(value: T): CalculatedValue<T> {\n return {\n value,\n check: () => false,\n stop: () => undefined,\n invalidateDependencies: () => undefined,\n };\n}\n","import type { AnyPath } from './path';\nimport { get } from './propAccess';\n\nexport function makeSelector<T, S>(selector?: ((value: T) => S) | AnyPath): (value: T) => S {\n if (!selector) {\n return (x) => x as any;\n }\n\n if (selector instanceof Function) {\n return selector;\n }\n\n return (x) => get(x, selector as any) as any;\n}\n","import { calcDuration } from './calcDuration';\nimport type { Duration } from '@core';\n\nexport type DebounceOptions =\n | Duration\n | {\n wait: Duration;\n maxWait?: Duration;\n waitOnRunNow?: boolean;\n };\n\nexport function debounce<Args extends any[]>(\n action: (...args: Args) => void,\n options: Duration | DebounceOptions,\n): {\n (...args: Args): void;\n flush(): void;\n cancel(): void;\n isScheduled(): boolean;\n} {\n const wait =\n typeof options === 'object' && 'wait' in options\n ? calcDuration(options.wait)\n : calcDuration(options);\n\n const maxWait =\n typeof options === 'object' && 'maxWait' in options && options.maxWait !== undefined\n ? calcDuration(options.maxWait)\n : undefined;\n\n let run: (() => void) | undefined;\n let timeout: ReturnType<typeof setTimeout> | undefined;\n let timeoutStarted: number | undefined;\n\n function flush() {\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n run?.();\n }\n\n function cancel() {\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n run = undefined;\n timeout = undefined;\n timeoutStarted = undefined;\n }\n\n function isScheduled() {\n return timeout !== undefined;\n }\n\n function debounce(...args: Args) {\n const now = Date.now();\n timeoutStarted ??= now;\n\n const deadline = Math.min(\n //\n now + wait,\n timeoutStarted + (maxWait ?? Number.POSITIVE_INFINITY),\n );\n\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n run = () => {\n run = undefined;\n timeout = undefined;\n timeoutStarted = undefined;\n\n action(...args);\n };\n\n timeout = setTimeout(run, deadline - now);\n }\n\n return Object.assign(debounce, { flush, cancel, isScheduled });\n}\n","import type { Cancel } from '@core';\nimport type { DisposableCancel } from '@core/commonTypes';\n\nexport default function disposable(dispose: Cancel): DisposableCancel {\n return Object.assign(\n dispose,\n Symbol.dispose ? { [Symbol.dispose]: dispose } : {},\n ) as DisposableCancel;\n}\n","export function forwardError(error: unknown): void {\n setTimeout(() => {\n throw error;\n });\n}\n","import { autobind } from '@lib/autobind';\n\nexport class PromiseCancelError extends Error {\n constructor() {\n super('cancelled');\n }\n}\n\nexport class PromiseWithCancel<T> extends Promise<T> {\n private abortController;\n\n constructor(\n executor: (\n resolve: (value: T) => void,\n reject: (error: unknown) => void,\n signal: AbortSignal,\n ) => void,\n ) {\n autobind(PromiseWithCancel);\n const abortController = new AbortController();\n\n super((resolve, reject) => {\n executor(resolve, reject, abortController.signal);\n\n abortController.signal.addEventListener('abort', () => {\n reject(abortController.signal.reason);\n });\n });\n\n this.abortController = abortController;\n }\n\n cancel(reason: any = new PromiseCancelError()): void {\n this.abortController.abort(reason);\n }\n}\n","import type { Store } from '../core/store';\nimport type { OptionalProperties, OptionalPropertyOf } from './typeHelpers';\n\ntype Function_ = (...args: any) => any;\n\nfunction createArrayAction<P extends keyof Array<any>>(prop: P) {\n return function arrayAction<T extends Array<any>>(\n this: Store<T>,\n ...args: T[P] extends Function_ ? Parameters<T[P]> : never\n ): T[P] extends Function_ ? ReturnType<T[P]> : never {\n const newArray = this.get().slice() as T;\n const result = (newArray[prop] as Function_)(...(args as any));\n this.set(newArray);\n return result;\n };\n}\nexport const arrayMethods: {\n [P in 'splice' | 'push' | 'pop' | 'shift' | 'unshift' | 'reverse' | 'sort']: <\n T extends Array<any>,\n >(\n this: Store<T>,\n ...args: T[P] extends Function_ ? Parameters<T[P]> : never\n ) => T[P] extends Function_ ? ReturnType<T[P]> : never;\n} = {\n splice: /* @__PURE__ */ createArrayAction('splice'),\n push: /* @__PURE__ */ createArrayAction('push'),\n pop: /* @__PURE__ */ createArrayAction('pop'),\n shift: /* @__PURE__ */ createArrayAction('shift'),\n unshift: /* @__PURE__ */ createArrayAction('unshift'),\n reverse: /* @__PURE__ */ createArrayAction('reverse'),\n sort: /* @__PURE__ */ createArrayAction('sort'),\n};\n\nexport const recordMethods = {\n delete<T extends Record<any, any>, K extends OptionalPropertyOf<T>>(\n this: Store<T>,\n key: K,\n ): void {\n const copy = { ...this.get() };\n delete copy[key];\n this.set(copy);\n },\n\n clear<T extends Record<any, any>>(\n this: OptionalProperties<T> extends T ? Store<T> : never,\n ): void {\n this.set({} as T);\n },\n};\n\nexport const mapMethods = {\n delete<K, V>(this: Store<Map<K, V>>, key: K): boolean {\n const newMap = new Map(this.get());\n const result = newMap.delete(key);\n this.set(newMap);\n return result;\n },\n\n clear<K, V>(this: Store<Map<K, V>>): void {\n this.set(new Map());\n },\n};\n\nexport const setMethods = {\n add<T>(this: Store<Set<T>>, value: T): void {\n const newSet = new Set(this.get());\n newSet.add(value);\n this.set(newSet);\n },\n\n delete<T>(this: Store<Set<T>>, value: T): void {\n const newSet = new Set(this.get());\n newSet.delete(value);\n this.set(newSet);\n },\n\n clear<T>(this: Store<Set<T>>): void {\n this.set(new Set());\n },\n};\n","import { calcDuration } from './calcDuration';\nimport type { Duration } from '@core';\n\nexport function throttle<Args extends any[]>(\n action: (...args: Args) => void,\n duration: Duration,\n): (...args: Args) => void {\n const ms = calcDuration(duration);\n\n let t = 0;\n let timeout: ReturnType<typeof setTimeout> | undefined;\n\n return (...args: Args) => {\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n const dt = t + ms - Date.now();\n if (dt <= 0) {\n action(...args);\n t = Date.now();\n return;\n }\n\n timeout = setTimeout(() => {\n action(...args);\n t = Date.now();\n }, dt);\n };\n}\n","import { autobind } from '@lib/autobind';\nimport { calcDuration } from '@lib/calcDuration';\nimport { calculatedValue, staticValue, type CalculatedValue } from '@lib/calculatedValue';\nimport type { Constrain } from '@lib/constrain';\nimport { debounce } from '@lib/debounce';\nimport disposable from '@lib/disposable';\nimport { deepEqual } from '@lib/equals';\nimport { forwardError } from '@lib/forwardError';\nimport { isObject } from '@lib/helpers';\nimport { makeSelector } from '@lib/makeSelector';\nimport type { AnyPath, Path, SettablePath, Value } from '@lib/path';\nimport { PromiseWithCancel } from '@lib/promiseWithCancel';\nimport { get, set } from '@lib/propAccess';\nimport { arrayMethods, mapMethods, recordMethods, setMethods } from '@lib/standardMethods';\nimport { throttle } from '@lib/throttle';\nimport type {\n CalculationActions,\n Cancel,\n DisposableCancel,\n Duration,\n Effect,\n Listener,\n Selector,\n SubscribeOptions,\n Update,\n} from './commonTypes';\n\nexport type StoreMethods = Record<string, (...args: any[]) => any>;\n\nexport type BoundStoreMethods<T, Methods extends StoreMethods> = Methods &\n ThisType<Store<T> & Methods>;\n\nexport interface StoreOptions<T> {\n retain?: Duration;\n equals?: SubscribeOptions['equals'];\n effect?: Effect<Store<T>> | { effect: Effect<Store<T>>; retain?: Duration };\n cacheValue?: boolean;\n}\n\nexport interface StoreOptionsWithMethods<T, Methods extends StoreMethods> extends StoreOptions<T> {\n methods?: Methods & ThisType<Store<T> & Methods & StandardMethods<T>>;\n}\n\nexport type Calculate<T> = (helpers: CalculationActions<T>) => T;\n\ntype StandardMethods<T> =\n T extends Map<any, any>\n ? typeof mapMethods\n : T extends Set<any>\n ? typeof setMethods\n : T extends Array<any>\n ? typeof arrayMethods\n : T extends Record<any, any>\n ? typeof recordMethods\n : Record<string, never>;\n\ntype StoreWithMethods<T, Methods extends StoreMethods> = Store<T> &\n Omit<BoundStoreMethods<T, Methods>, keyof Store<T>> &\n StandardMethods<T>;\n\nexport interface OnceOptions {\n signal?: AbortSignal;\n timeout?: Duration;\n}\n\nfunction noop() {\n return undefined;\n}\n\nexport class Store<T> {\n private static hooks?: Set<(this: Store<any>, store: Store<any>) => void>;\n\n static addHook(hook: (store: Store<any>) => void): DisposableCancel {\n this.hooks ??= new Set();\n this.hooks.add(hook);\n return disposable(() => this.hooks?.delete(hook));\n }\n\n version?: string;\n\n protected calculatedValue?: CalculatedValue<T>;\n protected defaultValue?: CalculatedValue<T>;\n\n protected listeners: Map<Listener, boolean> = new Map();\n\n protected effects: Map<\n Effect<Store<T>>,\n { handle?: Cancel; retain?: number; timeout?: ReturnType<typeof setTimeout> }\n > = new Map();\n\n protected notifyId = {};\n\n constructor(\n public readonly getter: T | Calculate<T>,\n public readonly options: StoreOptions<T> = {},\n public readonly derivedFrom?: {\n store: Store<any>;\n selectors: (Selector<any, any> | AnyPath)[];\n updater: (state: any) => void;\n },\n ) {\n autobind(Store);\n\n if (typeof getter !== 'function') {\n this.calculatedValue = this.defaultValue = staticValue(getter);\n }\n\n for (const hook of Store.hooks ?? []) {\n hook.apply(this, [this]);\n }\n\n if (options.effect instanceof Function) {\n this.addEffect(options.effect);\n } else if (options.effect) {\n this.addEffect(options.effect.effect, options.effect.retain);\n }\n }\n\n get(): T {\n if (!this.calculatedValue?.check()) {\n this.calculatedValue?.stop();\n this.calculatedValue = undefined;\n }\n\n if (!this.calculatedValue) {\n this.calculatedValue = calculatedValue(this, this.notify);\n }\n\n return this.calculatedValue.value;\n }\n\n set(update: Update<T>): void;\n\n set<const P>(path: Constrain<P, Path<T>>, update: Update<Value<T, P>>): void;\n\n set(...args: any[]): void {\n const path: any = args.length > 1 ? args[0] : [];\n let update: Update<any> = args.length > 1 ? args[1] : args[0];\n\n if (update instanceof Function) {\n const before = this.get();\n const valueBefore = get(before, path);\n const valueAfter = update(valueBefore);\n update = set(before, path, valueAfter);\n } else if (path.length > 0) {\n update = set(this.get(), path, update);\n }\n\n if (this.derivedFrom) {\n this.derivedFrom.updater(update);\n return;\n }\n\n this.calculatedValue?.stop();\n this.calculatedValue = staticValue(update);\n this.notify();\n }\n\n invalidate(recursive?: boolean): void {\n if (recursive) {\n this.calculatedValue?.invalidateDependencies(recursive);\n }\n\n this.calculatedValue?.stop();\n this.calculatedValue = this.defaultValue;\n this.notify();\n }\n\n subscribe(\n listener: Listener<T, { cancel: Cancel }>,\n options?: SubscribeOptions,\n ): DisposableCancel {\n const {\n passive,\n runNow = true,\n throttle: throttleOption,\n debounce: debounceOption,\n equals = this.options.equals ?? deepEqual,\n } = options ?? {};\n\n let isSetup = false;\n let previousValue: { value: T } | undefined;\n\n let innerListener = () => {\n if (!isSetup) {\n return;\n }\n\n const value = passive ? this.calculatedValue : { value: this.get() };\n\n if (!value) {\n return;\n }\n\n if (previousValue && equals(value.value, previousValue.value)) {\n return;\n }\n\n const _previousValue = previousValue?.value;\n previousValue = this.calculatedValue && { value: this.calculatedValue?.value };\n\n try {\n listener.apply({ cancel }, [value.value, _previousValue]);\n } catch (error) {\n forwardError(error);\n }\n };\n\n if (throttleOption) {\n innerListener = throttle(innerListener, throttleOption);\n } else if (debounceOption) {\n innerListener = debounce(innerListener, debounceOption);\n }\n\n this.listeners.set(innerListener, !passive);\n const cancel = () => {\n if (this.listeners.delete(innerListener) && !passive) {\n this.onUnsubscribe();\n }\n };\n\n if (!passive) {\n this.onSubscribe();\n }\n\n isSetup = true;\n\n if (runNow) {\n innerListener();\n\n if (\n !throttleOption &&\n typeof debounceOption === 'object' &&\n 'waitOnRunNow' in debounceOption &&\n debounceOption.waitOnRunNow === false &&\n 'flush' in innerListener\n ) {\n (innerListener as { flush: () => void }).flush();\n }\n } else {\n previousValue = passive\n ? this.calculatedValue && { value: this.calculatedValue.value }\n : { value: this.get() };\n }\n\n return disposable(cancel);\n }\n\n once<S extends T>(\n condition: (value: T) => value is S,\n options?: OnceOptions,\n ): PromiseWithCancel<S>;\n\n once(condition: (value: T) => boolean, options?: OnceOptions): PromiseWithCancel<T>;\n\n once(options?: OnceOptions): PromiseWithCancel<T>;\n\n once(\n ...args: [condition: (value: any) => boolean, options?: OnceOptions] | [options?: OnceOptions]\n ): PromiseWithCancel<any> {\n const condition = args[0] instanceof Function ? args[0] : Boolean;\n const options = args[0] instanceof Function ? args[1] : args[0];\n\n return new PromiseWithCancel<T>((resolve, reject, signal) => {\n let stopped = false;\n let timer: ReturnType<typeof setTimeout> | undefined;\n\n const cancel = this.subscribe(\n (value) => {\n if (stopped || !condition(value)) {\n return;\n }\n\n resolve(value);\n stopped = true;\n if (timer) {\n clearTimeout(timer);\n }\n setTimeout(() => cancel());\n },\n {\n runNow: !!condition,\n },\n );\n\n if (stopped) {\n return;\n }\n\n signal.addEventListener('abort', cancel);\n\n options?.signal?.addEventListener('abort', () => {\n cancel();\n reject(options.signal?.reason ?? new Error('cancelled'));\n });\n\n if (options?.timeout !== undefined) {\n timer = setTimeout(() => {\n cancel();\n reject(new Error('timeout'));\n }, calcDuration(options.timeout));\n }\n });\n }\n\n map<S>(selector: Selector<T, S>, updater?: (value: S) => Update<T>): Store<S>;\n\n map<const P>(selector: Constrain<P, SettablePath<T>>): Store<Value<T, P>>;\n\n map(_selector: Selector<T, any> | SettablePath<any>, ...args: any[]): Store<any> {\n const updater: ((value: any) => Update<T>) | undefined =\n _selector instanceof Function\n ? args[0]\n : (value) => (state) => set(state, _selector as any, value);\n\n const selector = makeSelector(_selector);\n\n const derivedFrom = {\n store: this.derivedFrom ? this.derivedFrom.store : this,\n selectors: this.derivedFrom ? [...this.derivedFrom.selectors, _selector] : [_selector],\n\n updater: (value: any) => {\n if (!updater) {\n throw new TypeError(\n 'Can only update computed stores that either are derived from other stores using string selectors or have an updater function.',\n );\n }\n\n let update = updater(value);\n\n if (update instanceof Function) {\n update = update(this.get());\n }\n\n if (this.derivedFrom) {\n this.derivedFrom.updater(update);\n } else {\n this.set(update);\n }\n },\n };\n\n return new Store(\n ({ use }) => {\n return selector(use(this));\n },\n undefined,\n derivedFrom,\n );\n }\n\n /** Add an effect that will be executed when the store becomes active, which means when it has at least one subscriber.\n * @param effect\n * If there is already a subscriber, the effect will be executed immediately.\n * Otherweise it will be executed as soon as the first subscription is created.\n * Every time all subscriptions are removed and the first is created again, the effect will be executed again.\n * @param retain\n * If provided, delay tearing down effects when the last subscriber is removed. This is useful if a short gap in subscriber coverage is supposed to be ignored. E.g. when switching pages, the old page might unsubscribe, while the new page subscribes immediately after.\n * @returns\n * The effect can return a teardown callback, which will be executed when the last subscription is removed and potentially the ratain time has passed.\n */\n addEffect(\n effect: Effect<Store<T>>,\n retain: Duration | undefined = this.options.retain,\n ): DisposableCancel {\n this.effects.set(effect, {\n handle: this.isActive() ? (effect.apply(this, [this]) ?? noop) : undefined,\n retain: retain !== undefined ? calcDuration(retain) : undefined,\n });\n\n return disposable(() => {\n const { handle, timeout } = this.effects.get(effect) ?? {};\n handle?.();\n\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n this.effects.delete(effect);\n });\n }\n\n /** Return whether the store is currently active, which means whether it has at least one subscriber. */\n isActive(): boolean {\n return [...this.listeners.values()].some(Boolean);\n }\n\n protected onSubscribe(): void {\n if ([...this.listeners.values()].filter(Boolean).length > 1) return;\n\n for (const [effect, { handle, retain, timeout }] of this.effects.entries()) {\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n this.effects.set(effect, {\n handle: handle ?? effect.apply(this, [this]) ?? noop,\n retain,\n timeout: undefined,\n });\n }\n }\n\n protected onUnsubscribe(): void {\n if ([...this.listeners.values()].some(Boolean)) return;\n\n for (const [effect, { handle, retain, timeout }] of this.effects.entries()) {\n if (!retain) {\n handle?.();\n\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n this.effects.set(effect, {\n handle: undefined,\n retain,\n timeout: undefined,\n });\n\n continue;\n }\n\n const newTimeout =\n timeout ??\n (handle\n ? setTimeout(() => {\n handle();\n this.effects.set(effect, {\n handle: undefined,\n retain,\n timeout: undefined,\n });\n }, retain)\n : undefined);\n\n this.effects.set(effect, {\n handle,\n retain,\n timeout: newTimeout,\n });\n }\n }\n\n protected notify(): void {\n const n = {};\n this.notifyId = n;\n\n const snapshot = [...this.listeners.entries()];\n const active = snapshot.filter(([, active]) => active);\n const passive = snapshot.filter(([, active]) => !active);\n for (const [listener] of [...active, ...passive]) {\n listener();\n if (n !== this.notifyId) break;\n }\n }\n}\n\nfunction create<T>(calculate: Calculate<T>, options?: StoreOptions<T>): Store<T>;\nfunction create<T, Methods extends StoreMethods = {}>(\n initialState: T,\n options?: StoreOptionsWithMethods<T, Methods>,\n): StoreWithMethods<T, Methods>;\nfunction create<T, Methods extends StoreMethods>(\n initialState: T | Calculate<T>,\n options?: StoreOptionsWithMethods<T, Methods>,\n): StoreWithMethods<T, Methods> | Store<T> {\n options = { ...createStore.defaultOptions, ...options };\n\n const store = new Store(initialState, options);\n\n if (initialState instanceof Function) {\n return store;\n }\n\n let methods: StoreMethods | undefined = options?.methods;\n\n if (initialState instanceof Map) {\n methods = { ...mapMethods, ...methods };\n } else if (initialState instanceof Set) {\n methods = { ...setMethods, ...methods };\n } else if (Array.isArray(initialState)) {\n methods = { ...arrayMethods, ...methods };\n } else if (isObject(initialState)) {\n methods = { ...recordMethods, ...methods };\n }\n\n const boundMethods = Object.fromEntries(\n Object.entries(methods ?? ({} as BoundStoreMethods<T, any>))\n .filter(([name]) => !(name in store))\n .map(([name, action]) => [name, (action as any).bind(store)]),\n ) as BoundStoreMethods<T, any>;\n\n return Object.assign(store, boundMethods);\n}\n\nexport const createStore: typeof create & { defaultOptions: StoreOptions<any> } =\n /* @__PURE__ */ Object.assign(create, {\n defaultOptions: {\n equals: deepEqual,\n } as StoreOptions<any>,\n });\n"],"mappings":"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"}
1
+ {"version":3,"file":"store-CdST5wJZ.cjs","names":["state: ValueState<T> | ErrorState | PendingState","value","q: {\n action: Action<any>;\n resolve: (value: any) => void;\n reject: (error: unknown) => void;\n ref?: any;\n }[]","value: T | undefined","connection: { active: boolean; cancel?: Cancel } | undefined","value","cancel: Cancel | undefined","actions: AsyncConnectionActions<any>","_cancel: Cancel | undefined","deepEqual","get","run: (() => void) | undefined","timeout: ReturnType<typeof setTimeout> | undefined","timeoutStarted: number | undefined","debounce","arrayMethods: {\n [P in 'splice' | 'push' | 'pop' | 'shift' | 'unshift' | 'reverse' | 'sort']: <\n T extends Array<any>,\n >(\n this: Store<T>,\n ...args: T[P] extends Function_ ? Parameters<T[P]> : never\n ) => T[P] extends Function_ ? ReturnType<T[P]> : never;\n}","timeout: ReturnType<typeof setTimeout> | undefined","getter: T | Calculate<T>","options: StoreOptions<T>","derivedFrom?: {\n store: Store<any>;\n selectors: (Selector<any, any> | AnyPath)[];\n updater: (state: any) => void;\n }","path: any","update: Update<any>","get","set","deepEqual","previousValue: { value: T } | undefined","timer: ReturnType<typeof setTimeout> | undefined","updater: ((value: any) => Update<T>) | undefined","active","methods: StoreMethods | undefined","isObject","createStore: typeof create & { defaultOptions: StoreOptions<any> }"],"sources":["../src/lib/autobind.ts","../src/lib/calcDuration.ts","../src/lib/deferred.ts","../src/lib/isPromise.ts","../src/lib/promiseWithState.ts","../src/lib/queue.ts","../src/lib/calculatedValue.ts","../src/lib/makeSelector.ts","../src/lib/debounce.ts","../src/lib/disposable.ts","../src/lib/forwardError.ts","../src/lib/promiseWithCancel.ts","../src/lib/standardMethods.ts","../src/lib/throttle.ts","../src/core/store.ts"],"sourcesContent":["const marker = Symbol('autobind');\n\nexport const autobind = <\n TClass extends abstract new (...args: any) => any = abstract new (...args: any) => any,\n>(\n _class: TClass,\n): TClass => {\n for (const key of Reflect.ownKeys(_class.prototype)) {\n if (key === 'constructor') {\n continue;\n }\n\n const descriptor = Reflect.getOwnPropertyDescriptor(_class.prototype, key);\n let method = descriptor?.get?.() ?? descriptor?.value;\n let isBinding = false;\n\n if (typeof method !== 'function' || method[marker]) {\n continue;\n }\n\n Reflect.defineProperty(_class.prototype, key, {\n configurable: true,\n get() {\n if (\n isBinding ||\n this === _class.prototype ||\n Object.prototype.hasOwnProperty.call(this, key) ||\n typeof method !== 'function'\n ) {\n return method;\n }\n\n const boundMethod = (...args: any[]) => Reflect.apply(method, this, args);\n boundMethod[marker] = true;\n isBinding = true;\n\n Object.defineProperty(this, key, {\n configurable: true,\n get() {\n return boundMethod;\n },\n });\n\n isBinding = false;\n return boundMethod;\n },\n set(v) {\n method = v;\n },\n });\n }\n\n return _class;\n};\n","import type { Duration } from '../core/commonTypes';\n\nexport function calcDuration(t: Duration): number {\n if (typeof t === 'number') return t;\n return (\n (t.milliseconds ?? 0) +\n (t.seconds ?? 0) * 1000 +\n (t.minutes ?? 0) * 60 * 1000 +\n (t.hours ?? 0) * 60 * 60 * 1000 +\n (t.days ?? 0) * 24 * 60 * 60 * 1000\n );\n}\n","export class Deferred<T = void> extends Promise<T> {\n resolve: (value: T | PromiseLike<T>) => void = () => undefined;\n reject: (reason?: any) => void = () => undefined;\n\n constructor() {\n Object.defineProperty(Deferred, Symbol.species, {\n value: Promise,\n });\n\n const that = {};\n\n super((resolve, reject) => {\n Object.assign(that, { resolve, reject });\n });\n\n Object.assign(this, that);\n }\n}\n","export default function isPromise(value: unknown): value is Promise<unknown> {\n return (\n typeof value === 'object' &&\n value !== null &&\n 'then' in value &&\n typeof value.then === 'function'\n );\n}\n","import isPromise from '@lib/isPromise';\nimport { type ErrorState, type PendingState, type ValueState } from './cacheState';\nimport { type MaybePromise } from './maybePromise';\n\nexport class PromiseWithState<T> extends Promise<T> {\n static override resolve(): PromiseWithState<void>;\n\n static override resolve<T>(value: MaybePromise<T>): PromiseWithState<T>;\n\n static override resolve<T>(value?: MaybePromise<T>) {\n return new PromiseWithState<T>(value as MaybePromise<T>);\n }\n\n static override reject<T = never>(error: unknown): PromiseWithState<T> {\n return new PromiseWithState<T>(Promise.reject(error), { status: 'error', error });\n }\n\n constructor(\n value: MaybePromise<T>,\n public state: ValueState<T> | ErrorState | PendingState = { status: 'pending' },\n ) {\n super((resolve) => resolve(value));\n\n Object.defineProperty(PromiseWithState, Symbol.species, {\n value: Promise,\n });\n\n if (isPromise(value)) {\n value\n .then((value) => {\n this.state = { status: 'value', value: value };\n })\n .catch((error) => {\n this.state = { status: 'error', error };\n });\n } else {\n this.state = { status: 'value', value: value };\n }\n }\n}\n","import isPromise from '@lib/isPromise';\nimport type { MaybePromise } from './maybePromise';\nimport type { Listener } from '@core';\n\ntype Action<T> = () => MaybePromise<T>;\n\nexport interface Queue {\n <T>(action: Action<T>, ref?: any): Promise<T>;\n clear: () => void;\n whenDone: () => Promise<void>;\n size: number;\n getRefs: () => any[];\n}\n\nexport function queue(): Queue {\n const q: {\n action: Action<any>;\n resolve: (value: any) => void;\n reject: (error: unknown) => void;\n ref?: any;\n }[] = [];\n const completionListeners = new Set<Listener<void>>();\n let active = false;\n\n const notify = () => {\n for (const listener of completionListeners) {\n listener();\n }\n\n completionListeners.clear();\n };\n\n const run = async () => {\n if (!active) {\n active = true;\n\n let next;\n while ((next = q.shift())) {\n try {\n let result = next.action();\n if (isPromise(result)) {\n result = await result;\n }\n\n next.resolve(result);\n } catch (error) {\n next.reject(error);\n }\n }\n\n active = false;\n notify();\n }\n };\n\n return Object.assign(\n <T>(action: Action<T>, ref?: any) => {\n return new Promise<T>((resolve, reject) => {\n q.push({ action, resolve, reject, ref });\n run();\n });\n },\n {\n clear() {\n q.length = 0;\n },\n\n whenDone() {\n if (!active) {\n return Promise.resolve();\n }\n\n return new Promise<void>((resolve) => {\n completionListeners.add(resolve);\n });\n },\n\n get size() {\n return q.length;\n },\n\n getRefs() {\n return q.map((item) => item.ref).filter((x) => x !== undefined);\n },\n },\n );\n}\n","import type { Cache } from '@core';\nimport type { AsyncConnectionActions, Cancel, Connection, StoreLike } from '@core/commonTypes';\nimport type { Store } from '@core/store';\nimport { Deferred } from '@lib/deferred';\nimport isPromise from '@lib/isPromise';\nimport { PromiseWithState } from '@lib/promiseWithState';\nimport { queue } from '@lib/queue';\nimport { deepEqual } from './equals';\n\nexport interface CalculatedValue<T> {\n value: T;\n check: () => void;\n stop(): void;\n invalidateDependencies(recursive?: boolean): void;\n}\n\nexport function calculatedValue<T>(store: Store<T>, notify: () => void): CalculatedValue<T> {\n if (!(store.getter instanceof Function)) {\n return staticValue(store.getter);\n }\n\n let active = false;\n const deps = new Array<{ store: StoreLike<any>; value: any; on: () => void; off: () => void }>();\n let value: T | undefined;\n const whenConnected = new Deferred();\n const whenExecuted = new Deferred();\n const ac = new AbortController();\n let connection: { active: boolean; cancel?: Cancel } | undefined;\n const q = queue();\n q(() => whenExecuted);\n\n const cancelEffect = store.addEffect(() => {\n if (connection) {\n store.invalidate();\n return;\n }\n\n active = true;\n\n for (const dep of deps) {\n dep.on();\n }\n\n return () => {\n active = false;\n\n for (const dep of deps) {\n dep.off();\n }\n\n if (connection) {\n connection.active = false;\n connection.cancel?.();\n q.clear();\n\n if ('state' in store) {\n (store as unknown as Cache<any>).state.set((state) => ({\n ...state,\n isConnected: false,\n isStale: true,\n }));\n }\n }\n };\n });\n\n function use<S>(dep: StoreLike<S>) {\n const value = dep.get();\n let cancel: Cancel | undefined;\n\n const on = () => {\n cancel ||= dep.subscribe(() => store.invalidate(), { runNow: false });\n };\n\n const off = () => {\n cancel?.();\n cancel = undefined;\n };\n\n deps.push({ store: dep, value, on, off });\n\n if (active) {\n on();\n }\n\n return value;\n }\n\n async function connect(createConnection: Connection<T>) {\n if (!active) {\n connection = { active: false };\n return;\n }\n\n const actions: AsyncConnectionActions<any> = {\n set(_value) {\n q(() => {\n if (!connection?.active) {\n return;\n }\n\n value = _value;\n notify();\n });\n },\n updateValue(update) {\n q(async () => {\n if (!connection?.active) {\n return;\n }\n\n if (update instanceof Function) {\n const currentValue = await value;\n\n if (!connection?.active) {\n return;\n }\n\n try {\n update = update(currentValue);\n } catch (error) {\n value = PromiseWithState.reject(error) as T;\n notify();\n connection.active = false;\n connection.cancel?.();\n return;\n }\n }\n\n value = PromiseWithState.resolve(update) as T;\n notify();\n });\n },\n updateError(error) {\n q(() => {\n if (!connection?.active) {\n return;\n }\n\n connection.active = false;\n connection.cancel?.();\n\n if ('state' in store) {\n (store as unknown as Cache<any>).state.set({\n status: 'error',\n error,\n isConnected: false,\n isUpdating: false,\n isStale: false,\n });\n }\n\n value = PromiseWithState.reject(error) as T;\n notify();\n });\n },\n updateIsConnected(isConnected) {\n if (isConnected) {\n whenConnected.resolve();\n }\n\n q(() => {\n if (!connection?.active) {\n return;\n }\n\n if ('state' in store) {\n (store as unknown as Cache<any>).state.set('isConnected', isConnected);\n }\n });\n },\n close() {\n if (connection?.active) {\n store.invalidate();\n }\n },\n };\n\n connection = { active: true };\n let _cancel: Cancel | undefined = createConnection(actions as any);\n\n connection.cancel = () => {\n _cancel?.();\n _cancel = undefined;\n };\n\n if (!connection.active) {\n connection.cancel();\n }\n\n return whenConnected;\n }\n\n try {\n value = store.getter({ signal: ac.signal, use, connect });\n } catch (error) {\n value = PromiseWithState.reject(error) as T;\n\n if (connection) {\n connection.active = false;\n connection.cancel?.();\n q.clear();\n }\n }\n\n if (isPromise(value)) {\n value.finally(() => whenExecuted.resolve()).catch(() => undefined);\n } else {\n whenExecuted.resolve();\n }\n\n function check() {\n if (store.options.cacheValue === false) {\n return false;\n }\n\n for (const dep of deps) {\n if (!deepEqual(dep.store.get(), dep.value)) {\n return false;\n }\n }\n return true;\n }\n\n function stop() {\n cancelEffect();\n whenExecuted.resolve();\n whenConnected.resolve();\n ac.abort();\n\n if (connection) {\n connection.active = false;\n connection.cancel?.();\n q.clear();\n }\n }\n\n function invalidateDependencies(recursive?: boolean) {\n for (const dep of deps) {\n dep.store.invalidate(recursive);\n }\n }\n\n return {\n get value() {\n return value!;\n },\n check,\n stop,\n invalidateDependencies,\n };\n}\n\nexport function staticValue<T>(value: T): CalculatedValue<T> {\n return {\n value,\n check: () => true,\n stop: () => undefined,\n invalidateDependencies: () => undefined,\n };\n}\n\nexport function staleValue<T>(value: T): CalculatedValue<T> {\n return {\n value,\n check: () => false,\n stop: () => undefined,\n invalidateDependencies: () => undefined,\n };\n}\n","import type { AnyPath } from './path';\nimport { get } from './propAccess';\n\nexport function makeSelector<T, S>(selector?: ((value: T) => S) | AnyPath): (value: T) => S {\n if (!selector) {\n return (x) => x as any;\n }\n\n if (selector instanceof Function) {\n return selector;\n }\n\n return (x) => get(x, selector as any) as any;\n}\n","import { calcDuration } from './calcDuration';\nimport type { Duration } from '@core';\n\nexport type DebounceOptions =\n | Duration\n | {\n wait: Duration;\n maxWait?: Duration;\n waitOnRunNow?: boolean;\n };\n\nexport function debounce<Args extends any[]>(\n action: (...args: Args) => void,\n options: Duration | DebounceOptions,\n): {\n (...args: Args): void;\n flush(): void;\n cancel(): void;\n isScheduled(): boolean;\n} {\n const wait =\n typeof options === 'object' && 'wait' in options\n ? calcDuration(options.wait)\n : calcDuration(options);\n\n const maxWait =\n typeof options === 'object' && 'maxWait' in options && options.maxWait !== undefined\n ? calcDuration(options.maxWait)\n : undefined;\n\n let run: (() => void) | undefined;\n let timeout: ReturnType<typeof setTimeout> | undefined;\n let timeoutStarted: number | undefined;\n\n function flush() {\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n run?.();\n }\n\n function cancel() {\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n run = undefined;\n timeout = undefined;\n timeoutStarted = undefined;\n }\n\n function isScheduled() {\n return timeout !== undefined;\n }\n\n function debounce(...args: Args) {\n const now = Date.now();\n timeoutStarted ??= now;\n\n const deadline = Math.min(\n //\n now + wait,\n timeoutStarted + (maxWait ?? Number.POSITIVE_INFINITY),\n );\n\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n run = () => {\n run = undefined;\n timeout = undefined;\n timeoutStarted = undefined;\n\n action(...args);\n };\n\n timeout = setTimeout(run, deadline - now);\n }\n\n return Object.assign(debounce, { flush, cancel, isScheduled });\n}\n","import type { Cancel } from '@core';\nimport type { DisposableCancel } from '@core/commonTypes';\n\nexport default function disposable(dispose: Cancel): DisposableCancel {\n return Object.assign(\n dispose,\n Symbol.dispose ? { [Symbol.dispose]: dispose } : {},\n ) as DisposableCancel;\n}\n","export function forwardError(error: unknown): void {\n setTimeout(() => {\n throw error;\n });\n}\n","import { autobind } from '@lib/autobind';\n\nexport class PromiseCancelError extends Error {\n constructor() {\n super('cancelled');\n }\n}\n\nexport class PromiseWithCancel<T> extends Promise<T> {\n private abortController;\n\n constructor(\n executor: (\n resolve: (value: T) => void,\n reject: (error: unknown) => void,\n signal: AbortSignal,\n ) => void,\n ) {\n autobind(PromiseWithCancel);\n const abortController = new AbortController();\n\n super((resolve, reject) => {\n executor(resolve, reject, abortController.signal);\n\n abortController.signal.addEventListener('abort', () => {\n reject(abortController.signal.reason);\n });\n });\n\n this.abortController = abortController;\n }\n\n cancel(reason: any = new PromiseCancelError()): void {\n this.abortController.abort(reason);\n }\n}\n","import type { Store } from '../core/store';\nimport type { OptionalProperties, OptionalPropertyOf } from './typeHelpers';\n\ntype Function_ = (...args: any) => any;\n\nfunction createArrayAction<P extends keyof Array<any>>(prop: P) {\n return function arrayAction<T extends Array<any>>(\n this: Store<T>,\n ...args: T[P] extends Function_ ? Parameters<T[P]> : never\n ): T[P] extends Function_ ? ReturnType<T[P]> : never {\n const newArray = this.get().slice() as T;\n const result = (newArray[prop] as Function_)(...(args as any));\n this.set(newArray);\n return result;\n };\n}\nexport const arrayMethods: {\n [P in 'splice' | 'push' | 'pop' | 'shift' | 'unshift' | 'reverse' | 'sort']: <\n T extends Array<any>,\n >(\n this: Store<T>,\n ...args: T[P] extends Function_ ? Parameters<T[P]> : never\n ) => T[P] extends Function_ ? ReturnType<T[P]> : never;\n} = {\n splice: /* @__PURE__ */ createArrayAction('splice'),\n push: /* @__PURE__ */ createArrayAction('push'),\n pop: /* @__PURE__ */ createArrayAction('pop'),\n shift: /* @__PURE__ */ createArrayAction('shift'),\n unshift: /* @__PURE__ */ createArrayAction('unshift'),\n reverse: /* @__PURE__ */ createArrayAction('reverse'),\n sort: /* @__PURE__ */ createArrayAction('sort'),\n};\n\nexport const recordMethods = {\n delete<T extends Record<any, any>, K extends OptionalPropertyOf<T>>(\n this: Store<T>,\n key: K,\n ): void {\n const copy = { ...this.get() };\n delete copy[key];\n this.set(copy);\n },\n\n clear<T extends Record<any, any>>(\n this: OptionalProperties<T> extends T ? Store<T> : never,\n ): void {\n this.set({} as T);\n },\n};\n\nexport const mapMethods = {\n delete<K, V>(this: Store<Map<K, V>>, key: K): boolean {\n const newMap = new Map(this.get());\n const result = newMap.delete(key);\n this.set(newMap);\n return result;\n },\n\n clear<K, V>(this: Store<Map<K, V>>): void {\n this.set(new Map());\n },\n};\n\nexport const setMethods = {\n add<T>(this: Store<Set<T>>, value: T): void {\n const newSet = new Set(this.get());\n newSet.add(value);\n this.set(newSet);\n },\n\n delete<T>(this: Store<Set<T>>, value: T): void {\n const newSet = new Set(this.get());\n newSet.delete(value);\n this.set(newSet);\n },\n\n clear<T>(this: Store<Set<T>>): void {\n this.set(new Set());\n },\n};\n","import { calcDuration } from './calcDuration';\nimport type { Duration } from '@core';\n\nexport function throttle<Args extends any[]>(\n action: (...args: Args) => void,\n duration: Duration,\n): (...args: Args) => void {\n const ms = calcDuration(duration);\n\n let t = 0;\n let timeout: ReturnType<typeof setTimeout> | undefined;\n\n return (...args: Args) => {\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n const dt = t + ms - Date.now();\n if (dt <= 0) {\n action(...args);\n t = Date.now();\n return;\n }\n\n timeout = setTimeout(() => {\n action(...args);\n t = Date.now();\n }, dt);\n };\n}\n","import { autobind } from '@lib/autobind';\nimport { calcDuration } from '@lib/calcDuration';\nimport { calculatedValue, staticValue, type CalculatedValue } from '@lib/calculatedValue';\nimport type { Constrain } from '@lib/constrain';\nimport { debounce } from '@lib/debounce';\nimport disposable from '@lib/disposable';\nimport { deepEqual } from '@lib/equals';\nimport { forwardError } from '@lib/forwardError';\nimport { isObject } from '@lib/helpers';\nimport { makeSelector } from '@lib/makeSelector';\nimport type { AnyPath, Path, SettablePath, Value } from '@lib/path';\nimport { PromiseWithCancel } from '@lib/promiseWithCancel';\nimport { get, set } from '@lib/propAccess';\nimport { arrayMethods, mapMethods, recordMethods, setMethods } from '@lib/standardMethods';\nimport { throttle } from '@lib/throttle';\nimport type {\n CalculationActions,\n Cancel,\n DisposableCancel,\n Duration,\n Effect,\n Listener,\n Selector,\n SubscribeOptions,\n Update,\n} from './commonTypes';\n\nexport type StoreMethods = Record<string, (...args: any[]) => any>;\n\nexport type BoundStoreMethods<T, Methods extends StoreMethods> = Methods &\n ThisType<Store<T> & Methods>;\n\nexport interface StoreOptions<T> {\n retain?: Duration;\n equals?: SubscribeOptions['equals'];\n effect?: Effect<Store<T>> | { effect: Effect<Store<T>>; retain?: Duration };\n cacheValue?: boolean;\n}\n\nexport interface StoreOptionsWithMethods<T, Methods extends StoreMethods> extends StoreOptions<T> {\n methods?: Methods & ThisType<Store<T> & Methods & StandardMethods<T>>;\n}\n\nexport type Calculate<T> = (helpers: CalculationActions<T>) => T;\n\ntype StandardMethods<T> =\n T extends Map<any, any>\n ? typeof mapMethods\n : T extends Set<any>\n ? typeof setMethods\n : T extends Array<any>\n ? typeof arrayMethods\n : T extends Record<any, any>\n ? typeof recordMethods\n : Record<string, never>;\n\ntype StoreWithMethods<T, Methods extends StoreMethods> = Store<T> &\n Omit<BoundStoreMethods<T, Methods>, keyof Store<T>> &\n StandardMethods<T>;\n\nexport interface OnceOptions {\n signal?: AbortSignal;\n timeout?: Duration;\n}\n\nfunction noop() {\n return undefined;\n}\n\nexport class Store<T> {\n private static hooks?: Set<(this: Store<any>, store: Store<any>) => void>;\n\n static addHook(hook: (store: Store<any>) => void): DisposableCancel {\n this.hooks ??= new Set();\n this.hooks.add(hook);\n return disposable(() => this.hooks?.delete(hook));\n }\n\n version?: string;\n\n protected calculatedValue?: CalculatedValue<T>;\n protected defaultValue?: CalculatedValue<T>;\n\n protected listeners: Map<Listener, boolean> = new Map();\n\n protected effects: Map<\n Effect<Store<T>>,\n { handle?: Cancel; retain?: number; timeout?: ReturnType<typeof setTimeout> }\n > = new Map();\n\n protected notifyId = {};\n\n constructor(\n public readonly getter: T | Calculate<T>,\n public readonly options: StoreOptions<T> = {},\n public readonly derivedFrom?: {\n store: Store<any>;\n selectors: (Selector<any, any> | AnyPath)[];\n updater: (state: any) => void;\n },\n ) {\n autobind(Store);\n\n if (typeof getter !== 'function') {\n this.calculatedValue = this.defaultValue = staticValue(getter);\n }\n\n for (const hook of Store.hooks ?? []) {\n hook.apply(this, [this]);\n }\n\n if (options.effect instanceof Function) {\n this.addEffect(options.effect);\n } else if (options.effect) {\n this.addEffect(options.effect.effect, options.effect.retain);\n }\n }\n\n get(): T {\n if (!this.calculatedValue?.check()) {\n this.calculatedValue?.stop();\n this.calculatedValue = undefined;\n }\n\n if (!this.calculatedValue) {\n this.calculatedValue = calculatedValue(this, this.notify);\n }\n\n return this.calculatedValue.value;\n }\n\n set(update: Update<T>): void;\n\n set<const P>(path: Constrain<P, Path<T>>, update: Update<Value<T, P>>): void;\n\n set(...args: any[]): void {\n const path: any = args.length > 1 ? args[0] : [];\n let update: Update<any> = args.length > 1 ? args[1] : args[0];\n\n if (update instanceof Function) {\n const before = this.get();\n const valueBefore = get(before, path);\n const valueAfter = update(valueBefore);\n update = set(before, path, valueAfter);\n } else if (path.length > 0) {\n update = set(this.get(), path, update);\n }\n\n if (this.derivedFrom) {\n this.derivedFrom.updater(update);\n return;\n }\n\n this.calculatedValue?.stop();\n this.calculatedValue = staticValue(update);\n this.notify();\n }\n\n invalidate(recursive?: boolean): void {\n if (recursive) {\n this.calculatedValue?.invalidateDependencies(recursive);\n }\n\n this.calculatedValue?.stop();\n this.calculatedValue = this.defaultValue;\n this.notify();\n }\n\n subscribe(\n listener: Listener<T, { cancel: Cancel }>,\n options?: SubscribeOptions,\n ): DisposableCancel {\n const {\n passive,\n runNow = true,\n throttle: throttleOption,\n debounce: debounceOption,\n equals = this.options.equals ?? deepEqual,\n } = options ?? {};\n\n let isSetup = false;\n let previousValue: { value: T } | undefined;\n\n let innerListener = () => {\n if (!isSetup) {\n return;\n }\n\n const value = passive ? this.calculatedValue : { value: this.get() };\n\n if (!value) {\n return;\n }\n\n if (previousValue && equals(value.value, previousValue.value)) {\n return;\n }\n\n const _previousValue = previousValue?.value;\n previousValue = this.calculatedValue && { value: this.calculatedValue?.value };\n\n try {\n listener.apply({ cancel }, [value.value, _previousValue]);\n } catch (error) {\n forwardError(error);\n }\n };\n\n if (throttleOption) {\n innerListener = throttle(innerListener, throttleOption);\n } else if (debounceOption) {\n innerListener = debounce(innerListener, debounceOption);\n }\n\n this.listeners.set(innerListener, !passive);\n const cancel = () => {\n if (this.listeners.delete(innerListener) && !passive) {\n this.onUnsubscribe();\n }\n };\n\n if (!passive) {\n this.onSubscribe();\n }\n\n isSetup = true;\n\n if (runNow) {\n innerListener();\n\n if (\n !throttleOption &&\n typeof debounceOption === 'object' &&\n 'waitOnRunNow' in debounceOption &&\n debounceOption.waitOnRunNow === false &&\n 'flush' in innerListener\n ) {\n (innerListener as { flush: () => void }).flush();\n }\n } else {\n previousValue = passive\n ? this.calculatedValue && { value: this.calculatedValue.value }\n : { value: this.get() };\n }\n\n return disposable(cancel);\n }\n\n once<S extends T>(\n condition: (value: T) => value is S,\n options?: OnceOptions,\n ): PromiseWithCancel<S>;\n\n once(condition: (value: T) => boolean, options?: OnceOptions): PromiseWithCancel<T>;\n\n once(options?: OnceOptions): PromiseWithCancel<Exclude<T, undefined>>;\n\n once(\n ...args: [condition: (value: any) => boolean, options?: OnceOptions] | [options?: OnceOptions]\n ): PromiseWithCancel<any> {\n const condition = args[0] instanceof Function ? args[0] : (x: T) => x !== undefined;\n const options = args[0] instanceof Function ? args[1] : args[0];\n\n return new PromiseWithCancel<T>((resolve, reject, signal) => {\n let stopped = false;\n let timer: ReturnType<typeof setTimeout> | undefined;\n\n const cancel = this.subscribe(\n (value) => {\n if (stopped || !condition(value)) {\n return;\n }\n\n resolve(value);\n stopped = true;\n if (timer) {\n clearTimeout(timer);\n }\n setTimeout(() => cancel());\n },\n {\n runNow: !!condition,\n },\n );\n\n if (stopped) {\n return;\n }\n\n signal.addEventListener('abort', cancel);\n\n options?.signal?.addEventListener('abort', () => {\n cancel();\n reject(options.signal?.reason ?? new Error('cancelled'));\n });\n\n if (options?.timeout !== undefined) {\n timer = setTimeout(() => {\n cancel();\n reject(new Error('timeout'));\n }, calcDuration(options.timeout));\n }\n });\n }\n\n map<S>(selector: Selector<T, S>, updater?: (value: S) => Update<T>): Store<S>;\n\n map<const P>(selector: Constrain<P, SettablePath<T>>): Store<Value<T, P>>;\n\n map(_selector: Selector<T, any> | SettablePath<any>, ...args: any[]): Store<any> {\n const updater: ((value: any) => Update<T>) | undefined =\n _selector instanceof Function\n ? args[0]\n : (value) => (state) => set(state, _selector as any, value);\n\n const selector = makeSelector(_selector);\n\n const derivedFrom = {\n store: this.derivedFrom ? this.derivedFrom.store : this,\n selectors: this.derivedFrom ? [...this.derivedFrom.selectors, _selector] : [_selector],\n\n updater: (value: any) => {\n if (!updater) {\n throw new TypeError(\n 'Can only update computed stores that either are derived from other stores using string selectors or have an updater function.',\n );\n }\n\n let update = updater(value);\n\n if (update instanceof Function) {\n update = update(this.get());\n }\n\n if (this.derivedFrom) {\n this.derivedFrom.updater(update);\n } else {\n this.set(update);\n }\n },\n };\n\n return new Store(\n ({ use }) => {\n return selector(use(this));\n },\n undefined,\n derivedFrom,\n );\n }\n\n /** Add an effect that will be executed when the store becomes active, which means when it has at least one subscriber.\n * @param effect\n * If there is already a subscriber, the effect will be executed immediately.\n * Otherweise it will be executed as soon as the first subscription is created.\n * Every time all subscriptions are removed and the first is created again, the effect will be executed again.\n * @param retain\n * If provided, delay tearing down effects when the last subscriber is removed. This is useful if a short gap in subscriber coverage is supposed to be ignored. E.g. when switching pages, the old page might unsubscribe, while the new page subscribes immediately after.\n * @returns\n * The effect can return a teardown callback, which will be executed when the last subscription is removed and potentially the ratain time has passed.\n */\n addEffect(\n effect: Effect<Store<T>>,\n retain: Duration | undefined = this.options.retain,\n ): DisposableCancel {\n this.effects.set(effect, {\n handle: this.isActive() ? (effect.apply(this, [this]) ?? noop) : undefined,\n retain: retain !== undefined ? calcDuration(retain) : undefined,\n });\n\n return disposable(() => {\n const { handle, timeout } = this.effects.get(effect) ?? {};\n handle?.();\n\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n this.effects.delete(effect);\n });\n }\n\n /** Return whether the store is currently active, which means whether it has at least one subscriber. */\n isActive(): boolean {\n return [...this.listeners.values()].some(Boolean);\n }\n\n protected onSubscribe(): void {\n if ([...this.listeners.values()].filter(Boolean).length > 1) return;\n\n for (const [effect, { handle, retain, timeout }] of this.effects.entries()) {\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n this.effects.set(effect, {\n handle: handle ?? effect.apply(this, [this]) ?? noop,\n retain,\n timeout: undefined,\n });\n }\n }\n\n protected onUnsubscribe(): void {\n if ([...this.listeners.values()].some(Boolean)) return;\n\n for (const [effect, { handle, retain, timeout }] of this.effects.entries()) {\n if (!retain) {\n handle?.();\n\n if (timeout !== undefined) {\n clearTimeout(timeout);\n }\n\n this.effects.set(effect, {\n handle: undefined,\n retain,\n timeout: undefined,\n });\n\n continue;\n }\n\n const newTimeout =\n timeout ??\n (handle\n ? setTimeout(() => {\n handle();\n this.effects.set(effect, {\n handle: undefined,\n retain,\n timeout: undefined,\n });\n }, retain)\n : undefined);\n\n this.effects.set(effect, {\n handle,\n retain,\n timeout: newTimeout,\n });\n }\n }\n\n protected notify(): void {\n const n = {};\n this.notifyId = n;\n\n const snapshot = [...this.listeners.entries()];\n const active = snapshot.filter(([, active]) => active);\n const passive = snapshot.filter(([, active]) => !active);\n for (const [listener] of [...active, ...passive]) {\n listener();\n if (n !== this.notifyId) break;\n }\n }\n}\n\nfunction create<T>(calculate: Calculate<T>, options?: StoreOptions<T>): Store<T>;\nfunction create<T, Methods extends StoreMethods = {}>(\n initialState: T,\n options?: StoreOptionsWithMethods<T, Methods>,\n): StoreWithMethods<T, Methods>;\nfunction create<T, Methods extends StoreMethods>(\n initialState: T | Calculate<T>,\n options?: StoreOptionsWithMethods<T, Methods>,\n): StoreWithMethods<T, Methods> | Store<T> {\n options = { ...createStore.defaultOptions, ...options };\n\n const store = new Store(initialState, options);\n\n if (initialState instanceof Function) {\n return store;\n }\n\n let methods: StoreMethods | undefined = options?.methods;\n\n if (initialState instanceof Map) {\n methods = { ...mapMethods, ...methods };\n } else if (initialState instanceof Set) {\n methods = { ...setMethods, ...methods };\n } else if (Array.isArray(initialState)) {\n methods = { ...arrayMethods, ...methods };\n } else if (isObject(initialState)) {\n methods = { ...recordMethods, ...methods };\n }\n\n const boundMethods = Object.fromEntries(\n Object.entries(methods ?? ({} as BoundStoreMethods<T, any>))\n .filter(([name]) => !(name in store))\n .map(([name, action]) => [name, (action as any).bind(store)]),\n ) as BoundStoreMethods<T, any>;\n\n return Object.assign(store, boundMethods);\n}\n\nexport const createStore: typeof create & { defaultOptions: StoreOptions<any> } =\n /* @__PURE__ */ Object.assign(create, {\n defaultOptions: {\n equals: deepEqual,\n } as StoreOptions<any>,\n });\n"],"mappings":"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"}
@@ -213,7 +213,7 @@ declare class Store<T> {
213
213
  }>, options?: SubscribeOptions): DisposableCancel;
214
214
  once<S extends T>(condition: (value: T) => value is S, options?: OnceOptions): PromiseWithCancel<S>;
215
215
  once(condition: (value: T) => boolean, options?: OnceOptions): PromiseWithCancel<T>;
216
- once(options?: OnceOptions): PromiseWithCancel<T>;
216
+ once(options?: OnceOptions): PromiseWithCancel<Exclude<T, undefined>>;
217
217
  map<S>(selector: Selector<T, S>, updater?: (value: S) => Update<T>): Store<S>;
218
218
  map<const P>(selector: Constrain<P, SettablePath<T>>): Store<Value$1<T, P>>;
219
219
  /** Add an effect that will be executed when the store becomes active, which means when it has at least one subscriber.
@@ -240,4 +240,4 @@ declare const createStore: typeof create & {
240
240
  };
241
241
  //#endregion
242
242
  export { AnyPath, AsyncConnectionActions, AsyncUpdateFunction, BaseConnectionActions, BoundStoreMethods, Calculate, CalculationActions, Cancel, Connection, ConnectionActions, Constrain, DisposableCancel, Duration, Effect, GetKeys, Join, KeyType, Listener, MaybePromise, Object_, Path, PathAsArray, PathAsString, Selector, SettablePath, SettablePathAsArray, SettablePathAsString, SettableValue, Store, StoreMethods, StoreOptions, StoreOptionsWithMethods, SubscribeOptions, Update, UpdateFrom, UpdateFunction, Use, Value$1 as Value, WildcardPath, WildcardPathAsString, WildcardValue, arrayMethods, createStore, mapMethods, recordMethods, setMethods };
243
- //# sourceMappingURL=store-B3PWCx63.d.cts.map
243
+ //# sourceMappingURL=store-DnZ6fsiJ.d.ts.map
@@ -579,7 +579,7 @@ var Store = class Store {
579
579
  return disposable(cancel);
580
580
  }
581
581
  once(...args) {
582
- const condition = args[0] instanceof Function ? args[0] : Boolean;
582
+ const condition = args[0] instanceof Function ? args[0] : (x) => x !== void 0;
583
583
  const options = args[0] instanceof Function ? args[1] : args[0];
584
584
  return new PromiseWithCancel((resolve, reject, signal) => {
585
585
  let stopped = false;
@@ -729,4 +729,4 @@ const createStore = /* @__PURE__ */ Object.assign(create, { defaultOptions: { eq
729
729
 
730
730
  //#endregion
731
731
  export { PromiseWithState, Store, arrayMethods, autobind, calcDuration, calculatedValue, createStore, debounce, isPromise, makeSelector, mapMethods, queue, recordMethods, setMethods, throttle };
732
- //# sourceMappingURL=store-DOEc60aP.js.map
732
+ //# sourceMappingURL=store-Dx8w7yT-.js.map