@mmstack/primitives 20.4.5 → 20.4.7

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.
@@ -1 +1 @@
1
- {"version":3,"file":"mmstack-primitives.mjs","sources":["../tmp-esm2022/lib/to-writable.js","../tmp-esm2022/lib/debounced.js","../tmp-esm2022/lib/mutable.js","../tmp-esm2022/lib/derived.js","../tmp-esm2022/lib/element-visibility.js","../tmp-esm2022/lib/map-array.js","../tmp-esm2022/lib/pipeable/operators.js","../tmp-esm2022/lib/pipeable/pipeble.js","../tmp-esm2022/lib/sensors/media-query.js","../tmp-esm2022/lib/throttled.js","../tmp-esm2022/lib/sensors/mouse-position.js","../tmp-esm2022/lib/sensors/network-status.js","../tmp-esm2022/lib/sensors/page-visibility.js","../tmp-esm2022/lib/sensors/scroll-position.js","../tmp-esm2022/lib/sensors/window-size.js","../tmp-esm2022/lib/sensors/sensor.js","../tmp-esm2022/lib/stored.js","../tmp-esm2022/lib/tabSync.js","../tmp-esm2022/lib/until.js","../tmp-esm2022/lib/get-signal-equality.js","../tmp-esm2022/lib/with-history.js","../tmp-esm2022/mmstack-primitives.js"],"sourcesContent":["import { untracked } from '@angular/core';\n/**\n * Converts a read-only `Signal` into a `WritableSignal` by providing custom `set` and, optionally, `update` functions.\n * This can be useful for creating controlled write access to a signal that is otherwise read-only.\n *\n * @typeParam T - The type of value held by the signal.\n *\n * @param signal - The read-only `Signal` to be made writable.\n * @param set - A function that will be used to set the signal's value. This function *must* handle\n * the actual update mechanism (e.g., updating a backing store, emitting an event, etc.).\n * @param update - (Optional) A function that will be used to update the signal's value based on its\n * previous value. If not provided, a default `update` implementation is used that\n * calls the provided `set` function with the result of the updater function. The\n * default implementation uses `untracked` to avoid creating unnecessary dependencies\n * within the updater function.\n *\n * @returns A `WritableSignal` that uses the provided `set` and `update` functions. The `asReadonly`\n * method of the returned signal will still return the original read-only signal.\n *\n * @example\n * // Basic usage: Making a read-only signal writable with a custom set function.\n * const originalValue = signal({a: 0});\n * const readOnlySignal = computed(() => originalValue().a);\n * const writableSignal = toWritable(readOnlySignal, (newValue) => {\n * originalValue.update((prev) => { ...prev, a: newValue });\n * });\n *\n * writableSignal.set(5); // sets value of originalValue.a to 5 & triggers all signals\n */\nexport function toWritable(signal, set, update) {\n const internal = signal;\n internal.asReadonly = () => signal;\n internal.set = set;\n internal.update = update ?? ((updater) => set(updater(untracked(internal))));\n return internal;\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG8td3JpdGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3NyYy9saWIvdG8td3JpdGFibGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFVLFNBQVMsRUFBa0IsTUFBTSxlQUFlLENBQUM7QUFFbEU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTJCRztBQUNILE1BQU0sVUFBVSxVQUFVLENBQ3hCLE1BQWlCLEVBQ2pCLEdBQXVCLEVBQ3ZCLE1BQTJDO0lBRTNDLE1BQU0sUUFBUSxHQUFHLE1BQTJCLENBQUM7SUFDN0MsUUFBUSxDQUFDLFVBQVUsR0FBRyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUM7SUFDbkMsUUFBUSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7SUFDbkIsUUFBUSxDQUFDLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFFN0UsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNpZ25hbCwgdW50cmFja2VkLCBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIENvbnZlcnRzIGEgcmVhZC1vbmx5IGBTaWduYWxgIGludG8gYSBgV3JpdGFibGVTaWduYWxgIGJ5IHByb3ZpZGluZyBjdXN0b20gYHNldGAgYW5kLCBvcHRpb25hbGx5LCBgdXBkYXRlYCBmdW5jdGlvbnMuXHJcbiAqIFRoaXMgY2FuIGJlIHVzZWZ1bCBmb3IgY3JlYXRpbmcgY29udHJvbGxlZCB3cml0ZSBhY2Nlc3MgdG8gYSBzaWduYWwgdGhhdCBpcyBvdGhlcndpc2UgcmVhZC1vbmx5LlxyXG4gKlxyXG4gKiBAdHlwZVBhcmFtIFQgLSBUaGUgdHlwZSBvZiB2YWx1ZSBoZWxkIGJ5IHRoZSBzaWduYWwuXHJcbiAqXHJcbiAqIEBwYXJhbSBzaWduYWwgLSBUaGUgcmVhZC1vbmx5IGBTaWduYWxgIHRvIGJlIG1hZGUgd3JpdGFibGUuXHJcbiAqIEBwYXJhbSBzZXQgLSBBIGZ1bmN0aW9uIHRoYXQgd2lsbCBiZSB1c2VkIHRvIHNldCB0aGUgc2lnbmFsJ3MgdmFsdWUuICBUaGlzIGZ1bmN0aW9uICptdXN0KiBoYW5kbGVcclxuICogICAgICAgICAgICAgIHRoZSBhY3R1YWwgdXBkYXRlIG1lY2hhbmlzbSAoZS5nLiwgdXBkYXRpbmcgYSBiYWNraW5nIHN0b3JlLCBlbWl0dGluZyBhbiBldmVudCwgZXRjLikuXHJcbiAqIEBwYXJhbSB1cGRhdGUgLSAoT3B0aW9uYWwpIEEgZnVuY3Rpb24gdGhhdCB3aWxsIGJlIHVzZWQgdG8gdXBkYXRlIHRoZSBzaWduYWwncyB2YWx1ZSBiYXNlZCBvbiBpdHNcclxuICogICAgICAgICAgICAgICAgIHByZXZpb3VzIHZhbHVlLiAgSWYgbm90IHByb3ZpZGVkLCBhIGRlZmF1bHQgYHVwZGF0ZWAgaW1wbGVtZW50YXRpb24gaXMgdXNlZCB0aGF0XHJcbiAqICAgICAgICAgICAgICAgICBjYWxscyB0aGUgcHJvdmlkZWQgYHNldGAgZnVuY3Rpb24gd2l0aCB0aGUgcmVzdWx0IG9mIHRoZSB1cGRhdGVyIGZ1bmN0aW9uLiBUaGVcclxuICogICAgICAgICAgICAgICAgIGRlZmF1bHQgaW1wbGVtZW50YXRpb24gdXNlcyBgdW50cmFja2VkYCB0byBhdm9pZCBjcmVhdGluZyB1bm5lY2Vzc2FyeSBkZXBlbmRlbmNpZXNcclxuICogICAgICAgICAgICAgICAgIHdpdGhpbiB0aGUgdXBkYXRlciBmdW5jdGlvbi5cclxuICpcclxuICogQHJldHVybnMgQSBgV3JpdGFibGVTaWduYWxgIHRoYXQgdXNlcyB0aGUgcHJvdmlkZWQgYHNldGAgYW5kIGB1cGRhdGVgIGZ1bmN0aW9ucy4gIFRoZSBgYXNSZWFkb25seWBcclxuICogICAgICAgICAgbWV0aG9kIG9mIHRoZSByZXR1cm5lZCBzaWduYWwgd2lsbCBzdGlsbCByZXR1cm4gdGhlIG9yaWdpbmFsIHJlYWQtb25seSBzaWduYWwuXHJcbiAqXHJcbiAqIEBleGFtcGxlXHJcbiAqIC8vIEJhc2ljIHVzYWdlOiBNYWtpbmcgYSByZWFkLW9ubHkgc2lnbmFsIHdyaXRhYmxlIHdpdGggYSBjdXN0b20gc2V0IGZ1bmN0aW9uLlxyXG4gKiBjb25zdCBvcmlnaW5hbFZhbHVlID0gc2lnbmFsKHthOiAwfSk7XHJcbiAqIGNvbnN0IHJlYWRPbmx5U2lnbmFsID0gY29tcHV0ZWQoKCkgPT4gb3JpZ2luYWxWYWx1ZSgpLmEpO1xyXG4gKiBjb25zdCB3cml0YWJsZVNpZ25hbCA9IHRvV3JpdGFibGUocmVhZE9ubHlTaWduYWwsIChuZXdWYWx1ZSkgPT4ge1xyXG4gKiAgb3JpZ2luYWxWYWx1ZS51cGRhdGUoKHByZXYpID0+IHsgLi4ucHJldiwgYTogbmV3VmFsdWUgfSk7XHJcbiAqIH0pO1xyXG4gKlxyXG4gKiB3cml0YWJsZVNpZ25hbC5zZXQoNSk7IC8vIHNldHMgdmFsdWUgb2Ygb3JpZ2luYWxWYWx1ZS5hIHRvIDUgJiB0cmlnZ2VycyBhbGwgc2lnbmFsc1xyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIHRvV3JpdGFibGU8VD4oXHJcbiAgc2lnbmFsOiBTaWduYWw8VD4sXHJcbiAgc2V0OiAodmFsdWU6IFQpID0+IHZvaWQsXHJcbiAgdXBkYXRlPzogKHVwZGF0ZXI6ICh2YWx1ZTogVCkgPT4gVCkgPT4gdm9pZCxcclxuKTogV3JpdGFibGVTaWduYWw8VD4ge1xyXG4gIGNvbnN0IGludGVybmFsID0gc2lnbmFsIGFzIFdyaXRhYmxlU2lnbmFsPFQ+O1xyXG4gIGludGVybmFsLmFzUmVhZG9ubHkgPSAoKSA9PiBzaWduYWw7XHJcbiAgaW50ZXJuYWwuc2V0ID0gc2V0O1xyXG4gIGludGVybmFsLnVwZGF0ZSA9IHVwZGF0ZSA/PyAoKHVwZGF0ZXIpID0+IHNldCh1cGRhdGVyKHVudHJhY2tlZChpbnRlcm5hbCkpKSk7XHJcblxyXG4gIHJldHVybiBpbnRlcm5hbDtcclxufVxyXG4iXX0=","import { computed, DestroyRef, inject, signal, untracked, } from '@angular/core';\nimport { toWritable } from './to-writable';\n/**\n * A convenience function that creates and debounces a new `WritableSignal` in one step.\n *\n * @see {debounce} for the core implementation details.\n *\n * @template T The type of value the signal holds.\n * @param initial The initial value of the signal.\n * @param opt Options for signal creation, including debounce time `ms`.\n * @returns A `DebouncedSignal<T>` instance.\n *\n * @example\n * // The existing example remains perfect here.\n * const query = debounced('', { ms: 500 });\n * effect(() => console.log('Debounced Query:', query()));\n * query.set('abc');\n * // ...500ms later...\n * // Output: Debounced Query: abc\n */\nexport function debounced(initial, opt) {\n return debounce(signal(initial, opt), opt);\n}\n/**\n * Wraps an existing `WritableSignal` to create a new one whose readable value is debounced.\n *\n * This implementation avoids using `effect` by pairing a trigger signal with an `untracked`\n * read of the source signal to control when the debounced value is re-evaluated.\n *\n * @template T The type of value the signal holds.\n * @param source The source `WritableSignal` to wrap. Writes are applied to this signal immediately.\n * @param opt Options for debouncing, including debounce time `ms` and an optional `DestroyRef`.\n * @returns A new `DebouncedSignal<T>` whose read value is debounced. The `.original` property\n * of the returned signal is a reference back to the provided `source` signal.\n *\n * @example\n * ```ts\n * import { signal, effect } from '@angular/core';\n *\n * // 1. Create a standard source signal.\n * const sourceQuery = signal('');\n *\n * // 2. Create a debounced version of it.\n * const debouncedQuery = debounce(sourceQuery, { ms: 500 });\n *\n * // This effect tracks the original signal and runs immediately.\n * effect(() => {\n * console.log('Original Query:', debouncedQuery.original());\n * });\n *\n * // This effect tracks the debounced signal and runs after the delay.\n * effect(() => {\n * console.log('Debounced Query:', debouncedQuery());\n * });\n *\n * console.log('Setting query to \"a\"');\n * debouncedQuery.set('a');\n * // Output: Original Query: a\n *\n * // ...500ms later...\n * // Output: Debounced Query: a\n * ```\n */\nexport function debounce(source, opt) {\n const ms = opt?.ms ?? 0;\n const trigger = signal(false, ...(ngDevMode ? [{ debugName: \"trigger\" }] : []));\n let timeout;\n try {\n const destroyRef = opt?.destroyRef ?? inject(DestroyRef, { optional: true });\n destroyRef?.onDestroy(() => {\n if (timeout)\n clearTimeout(timeout);\n timeout = undefined;\n });\n }\n catch {\n // not in injection context & no destroyRef provided opting out of cleanup\n }\n const triggerFn = (afterClean) => {\n if (timeout)\n clearTimeout(timeout);\n afterClean();\n timeout = setTimeout(() => {\n trigger.update((c) => !c);\n }, ms);\n };\n const set = (value) => {\n triggerFn(() => source.set(value));\n };\n const update = (fn) => {\n triggerFn(() => source.update(fn));\n };\n const writable = toWritable(computed(() => {\n trigger();\n return untracked(source);\n }, opt), set, update);\n writable.original = source;\n return writable;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"debounced.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/debounced.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAER,UAAU,EACV,MAAM,EAEN,MAAM,EACN,SAAS,GAEV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAwC3C;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,UAAU,SAAS,CACvB,OAAU,EACV,GAA+B;IAE/B,OAAO,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;AAC7C,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,MAAM,UAAU,QAAQ,CACtB,MAAyB,EACzB,GAA+B;IAE/B,MAAM,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,CAAC,CAAC;IAExB,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,mDAAC,CAAC;IAE9B,IAAI,OAAkD,CAAC;IAEvD,IAAI,CAAC;QACH,MAAM,UAAU,GACd,GAAG,EAAE,UAAU,IAAI,MAAM,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAE5D,UAAU,EAAE,SAAS,CAAC,GAAG,EAAE;YACzB,IAAI,OAAO;gBAAE,YAAY,CAAC,OAAO,CAAC,CAAC;YACnC,OAAO,GAAG,SAAS,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IAAC,MAAM,CAAC;QACP,0EAA0E;IAC5E,CAAC;IAED,MAAM,SAAS,GAAG,CAAC,UAAsB,EAAE,EAAE;QAC3C,IAAI,OAAO;YAAE,YAAY,CAAC,OAAO,CAAC,CAAC;QACnC,UAAU,EAAE,CAAC;QACb,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;YACxB,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5B,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC,CAAC;IAEF,MAAM,GAAG,GAAG,CAAC,KAAQ,EAAE,EAAE;QACvB,SAAS,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC;IAEF,MAAM,MAAM,GAAG,CAAC,EAAkB,EAAE,EAAE;QACpC,SAAS,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC;IAEF,MAAM,QAAQ,GAAG,UAAU,CACzB,QAAQ,CAAC,GAAG,EAAE;QACZ,OAAO,EAAE,CAAC;QACV,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC,EAAE,GAAG,CAAC,EACP,GAAG,EACH,MAAM,CACe,CAAC;IACxB,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC;IAE3B,OAAO,QAAQ,CAAC;AAClB,CAAC","sourcesContent":["import {\r\n  computed,\r\n  type CreateSignalOptions,\r\n  DestroyRef,\r\n  inject,\r\n  type Signal,\r\n  signal,\r\n  untracked,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * Options for creating a debounced writable signal.\r\n * Extends Angular's `CreateSignalOptions` with a debounce time setting.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type CreateDebouncedOptions<T> = CreateSignalOptions<T> & {\r\n  /**\r\n   * The debounce delay in milliseconds. Specifies how long to wait after the\r\n   * last `set` or `update` call before the debounced signal reflects the new value.\r\n   */\r\n  ms?: number;\r\n  /**\r\n   * Optional `DestroyRef` to clean up the debounce timer when the signal is destroyed.\r\n   * If provided, the timer will be cleared when the signal is destroyed.\r\n   * If the signal is called within a reactive context a DestroyRef is injected automatically.\r\n   * If it is not provided or injected, the timer will not be cleared automatically...which is usually fine :)\r\n   */\r\n  destroyRef?: DestroyRef;\r\n};\r\n\r\n/**\r\n * A specialized `WritableSignal` whose publicly readable value updates are debounced.\r\n *\r\n * It provides access to the underlying, non-debounced signal via the `original` property.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type DebouncedSignal<T> = WritableSignal<T> & {\r\n  /**\r\n   * A reference to the original, inner `WritableSignal`.\r\n   * This signal's value is updated *immediately* upon calls to `set` or `update`\r\n   * on the parent `DebouncedSignal`. Useful for accessing the latest value\r\n   * without the debounce delay.\r\n   */\r\n  original: Signal<T>;\r\n};\r\n\r\n/**\r\n * A convenience function that creates and debounces a new `WritableSignal` in one step.\r\n *\r\n * @see {debounce} for the core implementation details.\r\n *\r\n * @template T The type of value the signal holds.\r\n * @param initial The initial value of the signal.\r\n * @param opt Options for signal creation, including debounce time `ms`.\r\n * @returns A `DebouncedSignal<T>` instance.\r\n *\r\n * @example\r\n * // The existing example remains perfect here.\r\n * const query = debounced('', { ms: 500 });\r\n * effect(() => console.log('Debounced Query:', query()));\r\n * query.set('abc');\r\n * // ...500ms later...\r\n * // Output: Debounced Query: abc\r\n */\r\nexport function debounced<T>(\r\n  initial: T,\r\n  opt?: CreateDebouncedOptions<T>,\r\n): DebouncedSignal<T> {\r\n  return debounce(signal(initial, opt), opt);\r\n}\r\n\r\n/**\r\n * Wraps an existing `WritableSignal` to create a new one whose readable value is debounced.\r\n *\r\n * This implementation avoids using `effect` by pairing a trigger signal with an `untracked`\r\n * read of the source signal to control when the debounced value is re-evaluated.\r\n *\r\n * @template T The type of value the signal holds.\r\n * @param source The source `WritableSignal` to wrap. Writes are applied to this signal immediately.\r\n * @param opt Options for debouncing, including debounce time `ms` and an optional `DestroyRef`.\r\n * @returns A new `DebouncedSignal<T>` whose read value is debounced. The `.original` property\r\n * of the returned signal is a reference back to the provided `source` signal.\r\n *\r\n * @example\r\n * ```ts\r\n * import { signal, effect } from '@angular/core';\r\n *\r\n * // 1. Create a standard source signal.\r\n * const sourceQuery = signal('');\r\n *\r\n * // 2. Create a debounced version of it.\r\n * const debouncedQuery = debounce(sourceQuery, { ms: 500 });\r\n *\r\n * // This effect tracks the original signal and runs immediately.\r\n * effect(() => {\r\n * console.log('Original Query:', debouncedQuery.original());\r\n * });\r\n *\r\n * // This effect tracks the debounced signal and runs after the delay.\r\n * effect(() => {\r\n * console.log('Debounced Query:', debouncedQuery());\r\n * });\r\n *\r\n * console.log('Setting query to \"a\"');\r\n * debouncedQuery.set('a');\r\n * // Output: Original Query: a\r\n *\r\n * // ...500ms later...\r\n * // Output: Debounced Query: a\r\n * ```\r\n */\r\nexport function debounce<T>(\r\n  source: WritableSignal<T>,\r\n  opt?: CreateDebouncedOptions<T>,\r\n): DebouncedSignal<T> {\r\n  const ms = opt?.ms ?? 0;\r\n\r\n  const trigger = signal(false);\r\n\r\n  let timeout: ReturnType<typeof setTimeout> | undefined;\r\n\r\n  try {\r\n    const destroyRef =\r\n      opt?.destroyRef ?? inject(DestroyRef, { optional: true });\r\n\r\n    destroyRef?.onDestroy(() => {\r\n      if (timeout) clearTimeout(timeout);\r\n      timeout = undefined;\r\n    });\r\n  } catch {\r\n    // not in injection context & no destroyRef provided opting out of cleanup\r\n  }\r\n\r\n  const triggerFn = (afterClean: () => void) => {\r\n    if (timeout) clearTimeout(timeout);\r\n    afterClean();\r\n    timeout = setTimeout(() => {\r\n      trigger.update((c) => !c);\r\n    }, ms);\r\n  };\r\n\r\n  const set = (value: T) => {\r\n    triggerFn(() => source.set(value));\r\n  };\r\n\r\n  const update = (fn: (prev: T) => T) => {\r\n    triggerFn(() => source.update(fn));\r\n  };\r\n\r\n  const writable = toWritable(\r\n    computed(() => {\r\n      trigger();\r\n      return untracked(source);\r\n    }, opt),\r\n    set,\r\n    update,\r\n  ) as DebouncedSignal<T>;\r\n  writable.original = source;\r\n\r\n  return writable;\r\n}\r\n"]}","import { signal, } from '@angular/core';\nconst { is } = Object;\nexport function mutable(initial, opt) {\n const baseEqual = opt?.equal ?? is;\n let trigger = false;\n const equal = (a, b) => {\n if (trigger)\n return false;\n return baseEqual(a, b);\n };\n const sig = signal(initial, {\n ...opt,\n equal,\n });\n const internalUpdate = sig.update;\n sig.mutate = (updater) => {\n trigger = true;\n internalUpdate(updater);\n trigger = false;\n };\n sig.inline = (updater) => {\n sig.mutate((prev) => {\n updater(prev);\n return prev;\n });\n };\n return sig;\n}\n/**\n * Type guard function to check if a given `WritableSignal` is a `MutableSignal`. This is useful\n * for situations where you need to conditionally use the `mutate` or `inline` methods.\n *\n * @typeParam T - The type of the signal's value (optional, defaults to `any`).\n * @param value - The `WritableSignal` to check.\n * @returns `true` if the signal is a `MutableSignal`, `false` otherwise.\n *\n * @example\n * const mySignal = signal(0);\n * const myMutableSignal = mutable(0);\n *\n * if (isMutable(mySignal)) {\n * mySignal.mutate(x => x + 1); // This would cause a type error, as mySignal is not a MutableSignal.\n * }\n *\n * if (isMutable(myMutableSignal)) {\n * myMutableSignal.mutate(x => x + 1); // This is safe.\n * }\n */\nexport function isMutable(value) {\n return 'mutate' in value && typeof value.mutate === 'function';\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mutable.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/mutable.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,MAAM,GAIP,MAAM,eAAe,CAAC;AAEvB,MAAM,EAAE,EAAE,EAAE,GAAG,MAAM,CAAC;AAiFtB,MAAM,UAAU,OAAO,CACrB,OAAW,EACX,GAA4B;IAE5B,MAAM,SAAS,GAAG,GAAG,EAAE,KAAK,IAAI,EAAE,CAAC;IACnC,IAAI,OAAO,GAAG,KAAK,CAAC;IAEpB,MAAM,KAAK,GAAmC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACrD,IAAI,OAAO;YAAE,OAAO,KAAK,CAAC;QAC1B,OAAO,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzB,CAAC,CAAC;IAEF,MAAM,GAAG,GAAG,MAAM,CAAgB,OAAO,EAAE;QACzC,GAAG,GAAG;QACN,KAAK;KACN,CAAqB,CAAC;IAEvB,MAAM,cAAc,GAAG,GAAG,CAAC,MAAM,CAAC;IAElC,GAAG,CAAC,MAAM,GAAG,CAAC,OAAO,EAAE,EAAE;QACvB,OAAO,GAAG,IAAI,CAAC;QACf,cAAc,CAAC,OAAO,CAAC,CAAC;QACxB,OAAO,GAAG,KAAK,CAAC;IAClB,CAAC,CAAC;IAEF,GAAG,CAAC,MAAM,GAAG,CAAC,OAAO,EAAE,EAAE;QACvB,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YAClB,OAAO,CAAC,IAAI,CAAC,CAAC;YACd,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,OAAO,GAAG,CAAC;AACb,CAAC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,SAAS,CACvB,KAAwB;IAExB,OAAO,QAAQ,IAAI,KAAK,IAAI,OAAO,KAAK,CAAC,MAAM,KAAK,UAAU,CAAC;AACjE,CAAC","sourcesContent":["import {\r\n  signal,\r\n  type CreateSignalOptions,\r\n  type ValueEqualityFn,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\n\r\nconst { is } = Object;\r\n\r\n/**\r\n * A `MutableSignal` is a special type of `WritableSignal` that allows for in-place mutation of its value.\r\n * In addition to the standard `set` and `update` methods, it provides a `mutate` method.  This is useful\r\n * for performance optimization when dealing with complex objects or arrays, as it avoids unnecessary\r\n * object copying.\r\n *\r\n * @typeParam T - The type of value held by the signal.\r\n */\r\nexport type MutableSignal<T> = WritableSignal<T> & {\r\n  /**\r\n   * Mutates the signal's value in-place.  This is similar to `update`, but it's optimized for\r\n   * scenarios where you want to modify the existing object directly rather than creating a new one.\r\n   *\r\n   * @param updater - A function that takes the current value as input and modifies it directly.\r\n   *\r\n   * @example\r\n   * const myArray = mutable([1, 2, 3]);\r\n   * myArray.mutate((arr) => {\r\n   *  arr.push(4);\r\n   *  return arr;\r\n   * }); // myArray() now returns [1, 2, 3, 4]\r\n   */\r\n  mutate: WritableSignal<T>['update'];\r\n\r\n  /**\r\n   * Mutates the signal's value in-place, similar to `mutate`, but with a void-returning value in updater\r\n   * function. This further emphasizes that the mutation is happening inline, improving readability\r\n   * in some cases.\r\n   * @param updater - Function to change to the current value\r\n   * @example\r\n   * const myObject = mutable({ a: 1, b: 2 });\r\n   * myObject.inline((obj) => (obj.a = 3)); // myObject() now returns { a: 3, b: 2 }\r\n   */\r\n  inline: (updater: (value: T) => void) => void;\r\n};\r\n\r\n/**\r\n * Creates a `MutableSignal`. This function overloads the standard `signal` function to provide\r\n * the additional `mutate` and `inline` methods.\r\n *\r\n * @typeParam T The type of value held by the signal.\r\n * @param initial The initial value of the signal.\r\n * @param options Optional signal options, including a custom `equal` function.\r\n * @returns A `MutableSignal` instance.\r\n *\r\n * ### Important Note on `computed` Signals\r\n *\r\n * When creating a `computed` signal that derives a non-primitive value (e.g., an object or array)\r\n * from a `mutable` signal, you **must** provide the `{ equal: false }` option to the `computed`\r\n * function.\r\n *\r\n * This is because a `.mutate()` call notifies its dependents that it has changed, but if the\r\n * reference to a derived object hasn't changed, the `computed` signal will not trigger its\r\n * own dependents by default.\r\n *\r\n * @example\r\n * ```ts\r\n * const state = mutable({ user: { name: 'John' }, lastUpdated: new Date() });\r\n *\r\n * // ✅ CORRECT: Deriving a primitive value works as expected.\r\n * const name = computed(() => state().user.name);\r\n *\r\n * // ❌ INCORRECT: This will not update reliably after the first change.\r\n * const userObject = computed(() => state().user);\r\n *\r\n * // ✅ CORRECT: For object derivations, `equal: false` is required.\r\n * const userObjectFixed = computed(() => state().user, { equal: false });\r\n *\r\n * // This mutation will now correctly trigger effects depending on `userObjectFixed`.\r\n * state.mutate(s => s.lastUpdated = new Date());\r\n * ```\r\n */\r\nexport function mutable<T>(): MutableSignal<T | undefined>;\r\nexport function mutable<T>(initial: T): MutableSignal<T>;\r\nexport function mutable<T>(\r\n  initial: T,\r\n  opt?: CreateSignalOptions<T>,\r\n): MutableSignal<T>;\r\n\r\nexport function mutable<T>(\r\n  initial?: T,\r\n  opt?: CreateSignalOptions<T>,\r\n): MutableSignal<T> {\r\n  const baseEqual = opt?.equal ?? is;\r\n  let trigger = false;\r\n\r\n  const equal: ValueEqualityFn<T | undefined> = (a, b) => {\r\n    if (trigger) return false;\r\n    return baseEqual(a, b);\r\n  };\r\n\r\n  const sig = signal<T | undefined>(initial, {\r\n    ...opt,\r\n    equal,\r\n  }) as MutableSignal<T>;\r\n\r\n  const internalUpdate = sig.update;\r\n\r\n  sig.mutate = (updater) => {\r\n    trigger = true;\r\n    internalUpdate(updater);\r\n    trigger = false;\r\n  };\r\n\r\n  sig.inline = (updater) => {\r\n    sig.mutate((prev) => {\r\n      updater(prev);\r\n      return prev;\r\n    });\r\n  };\r\n\r\n  return sig;\r\n}\r\n\r\n/**\r\n * Type guard function to check if a given `WritableSignal` is a `MutableSignal`.  This is useful\r\n * for situations where you need to conditionally use the `mutate` or `inline` methods.\r\n *\r\n * @typeParam T - The type of the signal's value (optional, defaults to `any`).\r\n * @param value - The `WritableSignal` to check.\r\n * @returns `true` if the signal is a `MutableSignal`, `false` otherwise.\r\n *\r\n * @example\r\n * const mySignal = signal(0);\r\n * const myMutableSignal = mutable(0);\r\n *\r\n * if (isMutable(mySignal)) {\r\n *   mySignal.mutate(x => x + 1); // This would cause a type error, as mySignal is not a MutableSignal.\r\n * }\r\n *\r\n * if (isMutable(myMutableSignal)) {\r\n *   myMutableSignal.mutate(x => x + 1); // This is safe.\r\n * }\r\n */\r\nexport function isMutable<T = any>(\r\n  value: WritableSignal<T>,\r\n): value is MutableSignal<T> {\r\n  return 'mutate' in value && typeof value.mutate === 'function';\r\n}\r\n"]}","import { computed, signal, untracked, } from '@angular/core';\nimport { isMutable } from './mutable';\nimport { toWritable } from './to-writable';\nexport function derived(source, optOrKey, opt) {\n const isArray = Array.isArray(untracked(source)) && typeof optOrKey === 'number';\n const from = typeof optOrKey === 'object' ? optOrKey.from : (v) => v[optOrKey];\n const onChange = typeof optOrKey === 'object'\n ? optOrKey.onChange\n : isArray\n ? isMutable(source)\n ? (next) => {\n source.mutate((cur) => {\n cur[optOrKey] = next;\n return cur;\n });\n }\n : (next) => {\n source.update((cur) => {\n const newArray = [...cur];\n newArray[optOrKey] = next;\n return newArray;\n });\n }\n : isMutable(source)\n ? (next) => {\n source.mutate((cur) => {\n cur[optOrKey] = next;\n return cur;\n });\n }\n : (next) => {\n source.update((cur) => ({ ...cur, [optOrKey]: next }));\n };\n const rest = typeof optOrKey === 'object' ? optOrKey : opt;\n const baseEqual = rest?.equal ?? Object.is;\n let trigger = false;\n const equal = isMutable(source)\n ? (a, b) => {\n if (trigger)\n return false;\n return baseEqual(a, b);\n }\n : baseEqual;\n const sig = toWritable(computed(() => from(source()), { ...rest, equal }), (newVal) => onChange(newVal));\n sig.from = from;\n if (isMutable(source)) {\n sig.mutate = (updater) => {\n trigger = true;\n sig.update(updater);\n trigger = false;\n };\n sig.inline = (updater) => {\n sig.mutate((prev) => {\n updater(prev);\n return prev;\n });\n };\n }\n return sig;\n}\n/**\n * Creates a \"fake\" `DerivedSignal` from a simple value. This is useful for creating\n * `FormControlSignal` instances that are not directly derived from another signal.\n * The returned signal's `from` function will always return the initial value.\n *\n * @typeParam T - This type parameter is not used in the implementation but is kept for type compatibility with `DerivedSignal`.\n * @typeParam U - The type of the signal's value.\n * @param initial - The initial value of the signal.\n * @returns A `DerivedSignal` instance.\n * @internal\n */\nexport function toFakeDerivation(initial) {\n const sig = signal(initial);\n sig.from = () => initial;\n return sig;\n}\n/**\n * Creates a \"fake\" `DerivedSignal` from an existing `WritableSignal`. This is useful\n * for treating a regular `WritableSignal` as a `DerivedSignal` without changing its behavior.\n * The returned signal's `from` function returns the current value of signal, using `untracked`.\n *\n * @typeParam T - This type parameter is not used in the implementation but is kept for type compatibility with `DerivedSignal`.\n * @typeParam U - The type of the signal's value.\n * @param initial - The existing `WritableSignal`.\n * @returns A `DerivedSignal` instance.\n * @internal\n */\nexport function toFakeSignalDerivation(initial) {\n const sig = initial;\n sig.from = () => untracked(initial);\n return sig;\n}\n/**\n * Type guard function to check if a given `WritableSignal` is a `DerivedSignal`.\n *\n * @typeParam T - The type of the source signal's value (optional, defaults to `any`).\n * @typeParam U - The type of the derived signal's value (optional, defaults to `any`).\n * @param sig - The `WritableSignal` to check.\n * @returns `true` if the signal is a `DerivedSignal`, `false` otherwise.\n */\nexport function isDerivation(sig) {\n return 'from' in sig;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"derived.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/derived.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  CreateSignalOptions,\r\n  signal,\r\n  untracked,\r\n  ValueEqualityFn,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { isMutable, MutableSignal } from './mutable';\r\nimport { toWritable } from './to-writable';\r\n\r\ntype UnknownObject = Record<PropertyKey, unknown>;\r\n\r\n/**\r\n * Options for creating a derived signal using the full `derived` function signature.\r\n * @typeParam T - The type of the source signal's value (parent).\r\n * @typeParam U - The type of the derived signal's value (child).\r\n */\r\ntype CreateDerivedOptions<T, U> = CreateSignalOptions<U> & {\r\n  /**\r\n   * A function that extracts the derived value (`U`) from the source signal's value (`T`).\r\n   */\r\n  from: (v: T) => U;\r\n  /**\r\n   * A function that updates the source signal's value (`T`) when the derived signal's value (`U`) changes.\r\n   * This establishes the two-way binding.\r\n   */\r\n  onChange: (newValue: U) => void;\r\n};\r\n\r\n/**\r\n * A `WritableSignal` that derives its value from another `WritableSignal` (the \"source\" signal).\r\n * It provides two-way binding: changes to the source signal update the derived signal, and\r\n * changes to the derived signal update the source signal.\r\n *\r\n * @typeParam T - The type of the source signal's value (parent).\r\n * @typeParam U - The type of the derived signal's value (child).\r\n */\r\nexport type DerivedSignal<T, U> = WritableSignal<U> & {\r\n  /**\r\n   * The function used to derive the derived signal's value from the source signal's value.\r\n   * This is primarily for internal use and introspection.\r\n   */\r\n  from: (v: T) => U;\r\n};\r\n\r\n/**\r\n * Creates a `DerivedSignal` that derives its value from another `WritableSignal`.\r\n * This overload provides the most flexibility, allowing you to specify custom `from` and `onChange` functions.\r\n *\r\n * @typeParam T The type of the source signal's value.\r\n * @typeParam U The type of the derived signal's value.\r\n * @param source The source `WritableSignal`.\r\n * @param options An object containing the `from` and `onChange` functions, and optional signal options.\r\n * @returns A `DerivedSignal` instance.\r\n *\r\n * @example\r\n * ```ts\r\n * const user = signal({ name: 'John', age: 30 });\r\n * const name = derived(user, {\r\n * from: (u) => u.name,\r\n * onChange: (newName) => user.update((u) => ({ ...u, name: newName })),\r\n * });\r\n *\r\n * name.set('Jane'); // Updates the original signal\r\n * console.log(user().name); // Outputs: Jane\r\n * ```\r\n */\r\nexport function derived<T, U>(\r\n  source: WritableSignal<T>,\r\n  opt: CreateDerivedOptions<T, U>,\r\n): DerivedSignal<T, U>;\r\n\r\n/**\r\n * Creates a `DerivedSignal` that derives a property from an object held by the source signal.\r\n * This overload is a convenient shorthand for accessing object properties.\r\n *\r\n * @typeParam T The type of the source signal's value (must be an object).\r\n * @typeParam TKey The key of the property to derive.\r\n * @param source The source `WritableSignal` (holding an object).\r\n * @param key The key of the property to derive.\r\n * @param options Optional signal options for the derived signal.\r\n * @returns A `DerivedSignal` instance.\r\n *\r\n * @example\r\n * ```ts\r\n * const user = signal({ name: 'John', age: 30 });\r\n * const name = derived(user, 'name');\r\n *\r\n * console.log(name()); // Outputs: John\r\n *\r\n * // Update the derived signal, which also updates the source\r\n * name.set('Jane');\r\n *\r\n * console.log(user().name); // Outputs: Jane\r\n * ```\r\n */\r\nexport function derived<T extends UnknownObject, TKey extends keyof T>(\r\n  source: WritableSignal<T>,\r\n  key: TKey,\r\n  opt?: CreateSignalOptions<T[TKey]>,\r\n): DerivedSignal<T, T[TKey]>;\r\n\r\n/**\r\n * Creates a `DerivedSignal` from an array, deriving an element by its index.\r\n * This overload is a convenient shorthand for accessing array elements.\r\n *\r\n * @typeParam T The type of the source signal's value (must be an array).\r\n * @param source The source `WritableSignal` (holding an array).\r\n * @param index The index of the element to derive.\r\n * @param options Optional signal options for the derived signal.\r\n * @returns A `DerivedSignal` instance.\r\n *\r\n * @example\r\n * ```ts\r\n * const numbers = signal([1, 2, 3]);\r\n * const secondNumber = derived(numbers, 1);\r\n *\r\n * console.log(secondNumber()); // Outputs: 2\r\n *\r\n * // Update the derived signal, which also updates the source\r\n * secondNumber.set(5);\r\n *\r\n * console.log(numbers()); // Outputs: [1, 5, 3]\r\n * ```\r\n */\r\nexport function derived<T extends any[]>(\r\n  source: WritableSignal<T>,\r\n  index: number,\r\n  opt?: CreateSignalOptions<T[number]>,\r\n): DerivedSignal<T, T[number]>;\r\n\r\n/**\r\n * Creates a `DerivedSignal` that derives its value from another `MutableSignal`.\r\n * Use mutuable signals with caution, but very useful for deeply nested structures.\r\n *\r\n * @typeParam T The type of the source signal's value.\r\n * @typeParam U The type of the derived signal's value.\r\n * @param source The source `WritableSignal`.\r\n * @param options An object containing the `from` and `onChange` functions, and optional signal options.\r\n * @returns A `DerivedSignal & MutableSignal` instance.\r\n *\r\n * @example\r\n * ```ts\r\n * const user = signal({ name: 'John', age: 30 });\r\n * const name = derived(user, {\r\n * from: (u) => u.name,\r\n * onChange: (newName) => user.update((u) => ({ ...u, name: newName })),\r\n * });\r\n *\r\n * name.set('Jane'); // Updates the original signal\r\n * console.log(user().name); // Outputs: Jane\r\n * ```\r\n */\r\nexport function derived<T, U>(\r\n  source: MutableSignal<T>,\r\n  optOrKey: CreateDerivedOptions<T, U> | keyof T,\r\n  opt?: CreateSignalOptions<U>,\r\n): DerivedSignal<T, U> & MutableSignal<U>;\r\n\r\nexport function derived<T, U>(\r\n  source: WritableSignal<T> | MutableSignal<T>,\r\n  optOrKey: CreateDerivedOptions<T, U> | keyof T,\r\n  opt?: CreateSignalOptions<U>,\r\n): DerivedSignal<T, U> | (DerivedSignal<T, U> & MutableSignal<U>) {\r\n  const isArray =\r\n    Array.isArray(untracked(source)) && typeof optOrKey === 'number';\r\n\r\n  const from =\r\n    typeof optOrKey === 'object' ? optOrKey.from : (v: T) => v[optOrKey] as U;\r\n\r\n  const onChange =\r\n    typeof optOrKey === 'object'\r\n      ? optOrKey.onChange\r\n      : isArray\r\n        ? isMutable(source)\r\n          ? (next: U) => {\r\n              source.mutate((cur) => {\r\n                (cur as any[])[optOrKey] = next;\r\n                return cur as T;\r\n              });\r\n            }\r\n          : (next: U) => {\r\n              source.update((cur) => {\r\n                const newArray = [...(cur as unknown as any[])];\r\n                newArray[optOrKey] = next;\r\n                return newArray as T;\r\n              });\r\n            }\r\n        : isMutable(source)\r\n          ? (next: U) => {\r\n              source.mutate((cur) => {\r\n                (cur as UnknownObject)[optOrKey] = next as T[keyof T];\r\n                return cur;\r\n              });\r\n            }\r\n          : (next: U) => {\r\n              source.update((cur) => ({ ...cur, [optOrKey]: next }));\r\n            };\r\n\r\n  const rest = typeof optOrKey === 'object' ? optOrKey : opt;\r\n\r\n  const baseEqual = rest?.equal ?? Object.is;\r\n  let trigger = false;\r\n\r\n  const equal: ValueEqualityFn<U> = isMutable(source)\r\n    ? (a: U, b: U) => {\r\n        if (trigger) return false;\r\n        return baseEqual(a, b);\r\n      }\r\n    : baseEqual;\r\n\r\n  const sig = toWritable<U>(\r\n    computed(() => from(source()), { ...rest, equal }),\r\n    (newVal) => onChange(newVal),\r\n  ) as DerivedSignal<T, U> & MutableSignal<U>;\r\n\r\n  sig.from = from;\r\n\r\n  if (isMutable(source)) {\r\n    sig.mutate = (updater) => {\r\n      trigger = true;\r\n      sig.update(updater);\r\n      trigger = false;\r\n    };\r\n\r\n    sig.inline = (updater) => {\r\n      sig.mutate((prev) => {\r\n        updater(prev);\r\n        return prev;\r\n      });\r\n    };\r\n  }\r\n\r\n  return sig;\r\n}\r\n\r\n/**\r\n * Creates a \"fake\" `DerivedSignal` from a simple value. This is useful for creating\r\n * `FormControlSignal` instances that are not directly derived from another signal.\r\n * The returned signal's `from` function will always return the initial value.\r\n *\r\n * @typeParam T -  This type parameter is not used in the implementation but is kept for type compatibility with `DerivedSignal`.\r\n * @typeParam U - The type of the signal's value.\r\n * @param initial - The initial value of the signal.\r\n * @returns A `DerivedSignal` instance.\r\n * @internal\r\n */\r\nexport function toFakeDerivation<T, U>(initial: U): DerivedSignal<T, U> {\r\n  const sig = signal(initial) as DerivedSignal<T, U>;\r\n  sig.from = () => initial;\r\n\r\n  return sig;\r\n}\r\n\r\n/**\r\n * Creates a \"fake\" `DerivedSignal` from an existing `WritableSignal`. This is useful\r\n * for treating a regular `WritableSignal` as a `DerivedSignal` without changing its behavior.\r\n *  The returned signal's `from` function returns the current value of signal, using `untracked`.\r\n *\r\n * @typeParam T - This type parameter is not used in the implementation but is kept for type compatibility with `DerivedSignal`.\r\n * @typeParam U - The type of the signal's value.\r\n * @param initial - The existing `WritableSignal`.\r\n * @returns A `DerivedSignal` instance.\r\n * @internal\r\n */\r\nexport function toFakeSignalDerivation<T, U>(\r\n  initial: WritableSignal<U>,\r\n): DerivedSignal<T, U> {\r\n  const sig = initial as DerivedSignal<T, U>;\r\n  sig.from = () => untracked(initial);\r\n  return sig;\r\n}\r\n\r\n/**\r\n * Type guard function to check if a given `WritableSignal` is a `DerivedSignal`.\r\n *\r\n * @typeParam T - The type of the source signal's value (optional, defaults to `any`).\r\n * @typeParam U - The type of the derived signal's value (optional, defaults to `any`).\r\n * @param sig - The `WritableSignal` to check.\r\n * @returns `true` if the signal is a `DerivedSignal`, `false` otherwise.\r\n */\r\nexport function isDerivation<T, U>(\r\n  sig: WritableSignal<U>,\r\n): sig is DerivedSignal<T, U> {\r\n  return 'from' in sig;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, effect, ElementRef, inject, isSignal, PLATFORM_ID, signal, } from '@angular/core';\nfunction observerSupported() {\n return typeof IntersectionObserver !== 'undefined';\n}\n/**\n * Creates a read-only signal that tracks the intersection status of a target DOM element\n * with the viewport or a specified root element, using the `IntersectionObserver` API.\n *\n * It can observe a static `ElementRef`/`Element` or a `Signal` that resolves to one,\n * allowing for dynamic targets.\n *\n * @param target The DOM element (or `ElementRef`, or a `Signal` resolving to one) to observe.\n * If the signal resolves to `null`, observation stops.\n * @param options Optional `IntersectionObserverInit` options (e.g., `root`, `rootMargin`, `threshold`)\n * and an optional `debugName`.\n * @returns A `Signal<IntersectionObserverEntry | undefined>`. It emits `undefined` initially,\n * on the server, or if the target is `null`. Otherwise, it emits the latest\n * `IntersectionObserverEntry`. Consumers can derive a boolean `isVisible` from\n * this entry's `isIntersecting` property.\n *\n * @example\n * ```ts\n * import { Component, effect, ElementRef, viewChild } from '@angular/core';\n * import { elementVisibility } from '@mmstack/primitives';\n * import { computed } from '@angular/core'; // For derived boolean\n *\n * @Component({\n * selector: 'app-lazy-image',\n * template: `\n * <div #imageContainer style=\"height: 200px; border: 1px dashed grey;\">\n * @if (isVisible()) {\n * <img src=\"your-image-url.jpg\" alt=\"Lazy loaded image\" />\n * <p>Image is VISIBLE!</p>\n * } @else {\n * <p>Scroll down to see the image...</p>\n * }\n * </div>\n * `\n * })\n * export class LazyImageComponent {\n * readonly imageContainer = viewChild.required<ElementRef<HTMLDivElement>>('imageContainer');\n *\n * // Observe the element, get the full IntersectionObserverEntry\n * readonly intersectionEntry = elementVisibility(this.imageContainer);\n *\n * // Derive a simple boolean for visibility\n * readonly isVisible = computed(() => this.intersectionEntry()?.isIntersecting ?? false);\n *\n * constructor() {\n * effect(() => {\n * console.log('Intersection Entry:', this.intersectionEntry());\n * console.log('Is Visible:', this.isVisible());\n * });\n * }\n * }\n * ```\n */\nexport function elementVisibility(target = inject(ElementRef), opt) {\n if (isPlatformServer(inject(PLATFORM_ID)) || !observerSupported()) {\n const base = computed(() => undefined, {\n debugName: opt?.debugName,\n });\n base.visible = computed(() => false, ...(ngDevMode ? [{ debugName: \"visible\" }] : []));\n return base;\n }\n const state = signal(undefined, {\n debugName: opt?.debugName,\n equal: (a, b) => {\n if (!a && !b)\n return true;\n if (!a || !b)\n return false;\n return (a.target === b.target &&\n a.isIntersecting === b.isIntersecting &&\n a.intersectionRatio === b.intersectionRatio &&\n a.boundingClientRect.top === b.boundingClientRect.top &&\n a.boundingClientRect.left === b.boundingClientRect.left &&\n a.boundingClientRect.width === b.boundingClientRect.width &&\n a.boundingClientRect.height === b.boundingClientRect.height);\n },\n });\n const targetSignal = isSignal(target) ? target : computed(() => target);\n effect((cleanup) => {\n const el = targetSignal();\n if (!el)\n return state.set(undefined);\n let observer = null;\n observer = new IntersectionObserver(([entry]) => state.set(entry), opt);\n observer.observe(el instanceof ElementRef ? el.nativeElement : el);\n cleanup(() => {\n observer?.disconnect();\n });\n });\n const base = state.asReadonly();\n base.visible = computed(() => {\n const s = state();\n if (!s)\n return false;\n return s.isIntersecting;\n }, ...(ngDevMode ? [{ debugName: \"visible\" }] : []));\n return base;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element-visibility.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/element-visibility.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common';\r\nimport {\r\n  computed,\r\n  effect,\r\n  ElementRef,\r\n  inject,\r\n  isSignal,\r\n  PLATFORM_ID,\r\n  signal,\r\n  Signal,\r\n} from '@angular/core';\r\n\r\n/**\r\n * Options for configuring the `elementVisibility` sensor, extending\r\n * standard `IntersectionObserverInit` options.\r\n */\r\nexport type ElementVisibilityOptions = IntersectionObserverInit & {\r\n  /** Optional debug name for the internal signal. */\r\n  debugName?: string;\r\n};\r\n\r\nfunction observerSupported() {\r\n  return typeof IntersectionObserver !== 'undefined';\r\n}\r\n\r\ntype InternalElementVisibilitySignal = Signal<\r\n  IntersectionObserverEntry | undefined\r\n> & {\r\n  visible: Signal<boolean>;\r\n};\r\n\r\nexport type ElementVisibilitySignal = Signal<\r\n  IntersectionObserverEntry | undefined\r\n> & {\r\n  readonly visible: Signal<boolean>;\r\n};\r\n\r\n/**\r\n * Creates a read-only signal that tracks the intersection status of a target DOM element\r\n * with the viewport or a specified root element, using the `IntersectionObserver` API.\r\n *\r\n * It can observe a static `ElementRef`/`Element` or a `Signal` that resolves to one,\r\n * allowing for dynamic targets.\r\n *\r\n * @param target The DOM element (or `ElementRef`, or a `Signal` resolving to one) to observe.\r\n * If the signal resolves to `null`, observation stops.\r\n * @param options Optional `IntersectionObserverInit` options (e.g., `root`, `rootMargin`, `threshold`)\r\n * and an optional `debugName`.\r\n * @returns A `Signal<IntersectionObserverEntry | undefined>`. It emits `undefined` initially,\r\n * on the server, or if the target is `null`. Otherwise, it emits the latest\r\n * `IntersectionObserverEntry`. Consumers can derive a boolean `isVisible` from\r\n * this entry's `isIntersecting` property.\r\n *\r\n * @example\r\n * ```ts\r\n * import { Component, effect, ElementRef, viewChild } from '@angular/core';\r\n * import { elementVisibility } from '@mmstack/primitives';\r\n * import { computed } from '@angular/core'; // For derived boolean\r\n *\r\n * @Component({\r\n * selector: 'app-lazy-image',\r\n * template: `\r\n * <div #imageContainer style=\"height: 200px; border: 1px dashed grey;\">\r\n * @if (isVisible()) {\r\n * <img src=\"your-image-url.jpg\" alt=\"Lazy loaded image\" />\r\n * <p>Image is VISIBLE!</p>\r\n * } @else {\r\n * <p>Scroll down to see the image...</p>\r\n * }\r\n * </div>\r\n * `\r\n * })\r\n * export class LazyImageComponent {\r\n * readonly imageContainer = viewChild.required<ElementRef<HTMLDivElement>>('imageContainer');\r\n *\r\n * // Observe the element, get the full IntersectionObserverEntry\r\n * readonly intersectionEntry = elementVisibility(this.imageContainer);\r\n *\r\n * // Derive a simple boolean for visibility\r\n * readonly isVisible = computed(() => this.intersectionEntry()?.isIntersecting ?? false);\r\n *\r\n * constructor() {\r\n * effect(() => {\r\n * console.log('Intersection Entry:', this.intersectionEntry());\r\n * console.log('Is Visible:', this.isVisible());\r\n * });\r\n * }\r\n * }\r\n * ```\r\n */\r\nexport function elementVisibility(\r\n  target:\r\n    | ElementRef<Element>\r\n    | Element\r\n    | Signal<ElementRef<Element> | Element | null> = inject(ElementRef),\r\n  opt?: ElementVisibilityOptions,\r\n): ElementVisibilitySignal {\r\n  if (isPlatformServer(inject(PLATFORM_ID)) || !observerSupported()) {\r\n    const base = computed(() => undefined, {\r\n      debugName: opt?.debugName,\r\n    }) as InternalElementVisibilitySignal;\r\n    base.visible = computed(() => false);\r\n    return base;\r\n  }\r\n\r\n  const state = signal<IntersectionObserverEntry | undefined>(undefined, {\r\n    debugName: opt?.debugName,\r\n    equal: (a, b) => {\r\n      if (!a && !b) return true;\r\n      if (!a || !b) return false;\r\n      return (\r\n        a.target === b.target &&\r\n        a.isIntersecting === b.isIntersecting &&\r\n        a.intersectionRatio === b.intersectionRatio &&\r\n        a.boundingClientRect.top === b.boundingClientRect.top &&\r\n        a.boundingClientRect.left === b.boundingClientRect.left &&\r\n        a.boundingClientRect.width === b.boundingClientRect.width &&\r\n        a.boundingClientRect.height === b.boundingClientRect.height\r\n      );\r\n    },\r\n  });\r\n\r\n  const targetSignal = isSignal(target) ? target : computed(() => target);\r\n\r\n  effect((cleanup) => {\r\n    const el = targetSignal();\r\n\r\n    if (!el) return state.set(undefined);\r\n\r\n    let observer: IntersectionObserver | null = null;\r\n    observer = new IntersectionObserver(([entry]) => state.set(entry), opt);\r\n    observer.observe(el instanceof ElementRef ? el.nativeElement : el);\r\n\r\n    cleanup(() => {\r\n      observer?.disconnect();\r\n    });\r\n  });\r\n\r\n  const base = state.asReadonly() as InternalElementVisibilitySignal;\r\n  base.visible = computed(() => {\r\n    const s = state();\r\n    if (!s) return false;\r\n    return s.isIntersecting;\r\n  });\r\n  return base;\r\n}\r\n"]}","import { computed, isSignal, linkedSignal, } from '@angular/core';\nimport { derived } from './derived';\nimport { isMutable } from './mutable';\nimport { toWritable } from './to-writable';\n/**\n * @internal\n * Checks if a signal is a WritableSignal.\n * @param sig The signal to check.\n */\nfunction isWritable(sig) {\n // We just need to check for the presence of a 'set' method.\n return 'set' in sig;\n}\n/**\n * @internal\n * Creates a setter function for a source signal of type `Signal<T[]>` or a function returning `T[]`.\n * @param source The source signal of type `Signal<T[]>` or a function returning `T[]`.\n * @returns\n */\nfunction createSetter(source) {\n if (!isWritable(source))\n return () => {\n // noop;\n };\n if (isMutable(source))\n return (value, index) => {\n source.inline((arr) => {\n arr[index] = value;\n });\n };\n return (value, index) => {\n source.update((arr) => arr.map((v, i) => (i === index ? value : v)));\n };\n}\nexport function mapArray(source, map, options) {\n const data = isSignal(source) ? source : computed(source);\n const len = computed(() => data().length, ...(ngDevMode ? [{ debugName: \"len\" }] : []));\n const setter = createSetter(data);\n const opt = { ...options };\n const writableData = isWritable(data)\n ? data\n : toWritable(data, () => {\n // noop\n });\n if (isWritable(data) && isMutable(data) && !opt.equal) {\n opt.equal = (a, b) => {\n if (a !== b)\n return false; // actually check primitives and references\n return false; // opt out for same refs\n };\n }\n return linkedSignal({\n source: () => len(),\n computation: (len, prev) => {\n if (!prev)\n return Array.from({ length: len }, (_, i) => {\n const derivation = derived(writableData, // typcase to largest type\n {\n from: (src) => src[i],\n onChange: (value) => setter(value, i),\n }, opt);\n return map(derivation, i);\n });\n if (len === prev.value.length)\n return prev.value;\n if (len < prev.value.length) {\n const slice = prev.value.slice(0, len);\n if (opt.onDestroy) {\n for (let i = len; i < prev.value.length; i++) {\n opt.onDestroy?.(prev.value[i]);\n }\n }\n return slice;\n }\n else {\n const next = [...prev.value];\n for (let i = prev.value.length; i < len; i++) {\n const derivation = derived(writableData, // typcase to largest type\n {\n from: (src) => src[i],\n onChange: (value) => setter(value, i),\n }, opt);\n next[i] = map(derivation, i);\n }\n return next;\n }\n },\n equal: (a, b) => a.length === b.length,\n });\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-array.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/map-array.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  type CreateSignalOptions,\r\n  isSignal,\r\n  linkedSignal,\r\n  type Signal,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { derived } from './derived';\r\nimport { isMutable, MutableSignal } from './mutable';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * @internal\r\n * Checks if a signal is a WritableSignal.\r\n * @param sig The signal to check.\r\n */\r\nfunction isWritable<T>(sig: Signal<T>): sig is WritableSignal<T> {\r\n  // We just need to check for the presence of a 'set' method.\r\n  return 'set' in sig;\r\n}\r\n\r\n/**\r\n * @internal\r\n * Creates a setter function for a source signal of type `Signal<T[]>` or a function returning `T[]`.\r\n * @param source The source signal of type `Signal<T[]>` or a function returning `T[]`.\r\n * @returns\r\n */\r\nfunction createSetter<T>(\r\n  source: Signal<T[]>,\r\n): (value: T, index: number) => void {\r\n  if (!isWritable(source))\r\n    return () => {\r\n      // noop;\r\n    };\r\n\r\n  if (isMutable(source))\r\n    return (value, index) => {\r\n      source.inline((arr) => {\r\n        arr[index] = value;\r\n      });\r\n    };\r\n\r\n  return (value, index) => {\r\n    source.update((arr) => arr.map((v, i) => (i === index ? value : v)));\r\n  };\r\n}\r\n\r\n/**\r\n * Reactively maps items from a source array to a new array, creating stable signals for each item.\r\n *\r\n * This function is highly optimized for performance, similar to SolidJS's `mapArray`.\r\n * For each item in the source array, it creates a stable signal that is passed to the mapping function.\r\n * This ensures that downstream consumers only re-evaluate for items that have actually changed,\r\n * or when items are added or removed from the list.\r\n *\r\n * The type of signal passed to the `map` function depends on the source:\r\n * - **Readonly `Signal`**: `map` receives a readonly `Signal<T>`.\r\n * - **`WritableSignal`**: `map` receives a `WritableSignal<T>`, allowing two-way binding.\r\n * - **`MutableSignal`**: `map` receives a `MutableSignal<T>`, allowing in-place mutation for performance.\r\n *\r\n * @template T The type of items in the source array.\r\n * @template U The type of items in the resulting mapped array.\r\n *\r\n * @param source A `Signal<T[]>` or a function returning `T[]`.\r\n * @param map The mapping function. It receives a stable signal for the item and its index.\r\n * @param options Optional configuration, including `CreateSignalOptions` for the item signals\r\n * (e.g., a custom `equal` function) and an `onDestroy` callback for cleanup.\r\n * @returns A `Signal<U[]>` containing the mapped array.\r\n *\r\n * @example\r\n * // Writable example\r\n * const sourceItems = signal([\r\n * { id: 1, name: 'Apple' },\r\n * { id: 2, name: 'Banana' }\r\n * ]);\r\n *\r\n * // The `itemSignal` is writable because `sourceItems` is a WritableSignal.\r\n * const mappedItems = mapArray(sourceItems, (itemSignal, index) => ({\r\n * label: computed(() => `${index}: ${itemSignal().name.toUpperCase()}`),\r\n * setName: (newName: string) => itemSignal.update(item => ({ ...item, name: newName }))\r\n * }));\r\n *\r\n * // This will update the original source signal.\r\n * mappedItems()[0].setName('Avocado');\r\n * // sourceItems() is now: [{ id: 1, name: 'Avocado' }, { id: 2, name: 'Banana' }]\r\n */\r\nexport function mapArray<T, U>(\r\n  source: MutableSignal<T[]>,\r\n  map: (value: MutableSignal<T>, index: number) => U,\r\n  options?: CreateSignalOptions<T> & {\r\n    onDestroy?: (value: U) => void;\r\n  },\r\n): Signal<U[]>;\r\n\r\nexport function mapArray<T, U>(\r\n  source: WritableSignal<T[]>,\r\n  map: (value: WritableSignal<T>, index: number) => U,\r\n  options?: CreateSignalOptions<T> & {\r\n    onDestroy?: (value: U) => void;\r\n  },\r\n): Signal<U[]>;\r\n\r\nexport function mapArray<T, U>(\r\n  source: Signal<T[]> | (() => T[]),\r\n  map: (value: Signal<T>, index: number) => U,\r\n  options?: CreateSignalOptions<T> & {\r\n    onDestroy?: (value: U) => void;\r\n  },\r\n): Signal<U[]>;\r\n\r\nexport function mapArray<T, U>(\r\n  source: Signal<T[]> | (() => T[]),\r\n  map:\r\n    | ((value: Signal<T>, index: number) => U)\r\n    | ((value: WritableSignal<T>, index: number) => U)\r\n    | ((value: MutableSignal<T>, index: number) => U),\r\n  options?: CreateSignalOptions<T> & {\r\n    onDestroy?: (value: U) => void;\r\n  },\r\n): Signal<U[]> {\r\n  const data = isSignal(source) ? source : computed(source);\r\n  const len = computed(() => data().length);\r\n\r\n  const setter = createSetter(data);\r\n\r\n  const opt = { ...options };\r\n\r\n  const writableData = isWritable(data)\r\n    ? data\r\n    : toWritable(data, () => {\r\n        // noop\r\n      });\r\n\r\n  if (isWritable(data) && isMutable(data) && !opt.equal) {\r\n    opt.equal = (a: T, b: T) => {\r\n      if (a !== b) return false; // actually check primitives and references\r\n      return false; // opt out for same refs\r\n    };\r\n  }\r\n\r\n  return linkedSignal<number, U[]>({\r\n    source: () => len(),\r\n    computation: (len, prev) => {\r\n      if (!prev)\r\n        return Array.from({ length: len }, (_, i) => {\r\n          const derivation = derived(\r\n            writableData as MutableSignal<T[]>, // typcase to largest type\r\n            {\r\n              from: (src) => src[i],\r\n              onChange: (value) => setter(value, i),\r\n            },\r\n            opt,\r\n          );\r\n\r\n          return map(derivation, i);\r\n        });\r\n\r\n      if (len === prev.value.length) return prev.value;\r\n\r\n      if (len < prev.value.length) {\r\n        const slice = prev.value.slice(0, len);\r\n\r\n        if (opt.onDestroy) {\r\n          for (let i = len; i < prev.value.length; i++) {\r\n            opt.onDestroy?.(prev.value[i]);\r\n          }\r\n        }\r\n\r\n        return slice;\r\n      } else {\r\n        const next = [...prev.value];\r\n        for (let i = prev.value.length; i < len; i++) {\r\n          const derivation = derived(\r\n            writableData as MutableSignal<T[]>, // typcase to largest type\r\n            {\r\n              from: (src) => src[i],\r\n              onChange: (value) => setter(value, i),\r\n            },\r\n            opt,\r\n          );\r\n          next[i] = map(derivation, i);\r\n        }\r\n        return next;\r\n      }\r\n    },\r\n    equal: (a, b) => a.length === b.length,\r\n  });\r\n}\r\n"]}","import { computed, effect, linkedSignal, } from '@angular/core';\n/** Project with optional equality. Pure & sync. */\nexport const select = (projector, opt) => (src) => computed(() => projector(src()), opt);\n/** Combine with another signal using a projector. */\nexport const combineWith = (other, project, opt) => (src) => computed(() => project(src(), other()), opt);\n/** Only re-emit when equal(prev, next) is false. */\nexport const distinct = (equal = Object.is) => (src) => computed(() => src(), { equal });\n/** map to new value */\nexport const map = (fn) => (src) => computed(() => fn(src()));\n/** filter values, keeping the last value if it was ever available, if first value is filtered will return undefined */\nexport const filter = (predicate) => (src) => linkedSignal({\n source: src,\n computation: (next, prev) => {\n if (predicate(next))\n return next;\n return prev?.source;\n },\n});\n/** tap into the value */\nexport const tap = (fn) => (src) => {\n effect(() => fn(src()));\n return src;\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3BlcmF0b3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9zcmMvbGliL3BpcGVhYmxlL29wZXJhdG9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsUUFBUSxFQUVSLE1BQU0sRUFDTixZQUFZLEdBRWIsTUFBTSxlQUFlLENBQUM7QUFHdkIsbURBQW1EO0FBQ25ELE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FDakIsQ0FDRSxTQUFzQixFQUN0QixHQUE0QixFQUNaLEVBQUUsQ0FDcEIsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUNOLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQztBQUUxQyxxREFBcUQ7QUFDckQsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUN0QixDQUNFLEtBQWdCLEVBQ2hCLE9BQTBCLEVBQzFCLEdBQTRCLEVBQ1osRUFBRSxDQUNwQixDQUFDLEdBQUcsRUFBRSxFQUFFLENBQ04sUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBRWpELG9EQUFvRDtBQUNwRCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQ25CLENBQUksUUFBaUMsTUFBTSxDQUFDLEVBQUUsRUFBa0IsRUFBRSxDQUNsRSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQ04sUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztBQUVyQyx1QkFBdUI7QUFDdkIsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUNkLENBQU8sRUFBZSxFQUFrQixFQUFFLENBQzFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FDTixRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUU5Qix1SEFBdUg7QUFDdkgsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUNqQixDQUFJLFNBQTRCLEVBQThCLEVBQUUsQ0FDaEUsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUNOLFlBQVksQ0FBQztJQUNYLE1BQU0sRUFBRSxHQUFHO0lBQ1gsV0FBVyxFQUFFLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxFQUFFO1FBQzFCLElBQUksU0FBUyxDQUFDLElBQUksQ0FBQztZQUFFLE9BQU8sSUFBSSxDQUFDO1FBQ2pDLE9BQU8sSUFBSSxFQUFFLE1BQU0sQ0FBQztJQUN0QixDQUFDO0NBQ0YsQ0FBQyxDQUFDO0FBRVAseUJBQXlCO0FBQ3pCLE1BQU0sQ0FBQyxNQUFNLEdBQUcsR0FDZCxDQUFJLEVBQWtCLEVBQWtCLEVBQUUsQ0FDMUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtJQUNOLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBRXhCLE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgY29tcHV0ZWQsXG4gIENyZWF0ZVNpZ25hbE9wdGlvbnMsXG4gIGVmZmVjdCxcbiAgbGlua2VkU2lnbmFsLFxuICBTaWduYWwsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT3BlcmF0b3IgfSBmcm9tICcuL3R5cGVzJztcblxuLyoqIFByb2plY3Qgd2l0aCBvcHRpb25hbCBlcXVhbGl0eS4gUHVyZSAmIHN5bmMuICovXG5leHBvcnQgY29uc3Qgc2VsZWN0ID1cbiAgPEksIE8+KFxuICAgIHByb2plY3RvcjogKHY6IEkpID0+IE8sXG4gICAgb3B0PzogQ3JlYXRlU2lnbmFsT3B0aW9uczxPPixcbiAgKTogT3BlcmF0b3I8SSwgTz4gPT5cbiAgKHNyYykgPT5cbiAgICBjb21wdXRlZCgoKSA9PiBwcm9qZWN0b3Ioc3JjKCkpLCBvcHQpO1xuXG4vKiogQ29tYmluZSB3aXRoIGFub3RoZXIgc2lnbmFsIHVzaW5nIGEgcHJvamVjdG9yLiAqL1xuZXhwb3J0IGNvbnN0IGNvbWJpbmVXaXRoID1cbiAgPEEsIEIsIFI+KFxuICAgIG90aGVyOiBTaWduYWw8Qj4sXG4gICAgcHJvamVjdDogKGE6IEEsIGI6IEIpID0+IFIsXG4gICAgb3B0PzogQ3JlYXRlU2lnbmFsT3B0aW9uczxSPixcbiAgKTogT3BlcmF0b3I8QSwgUj4gPT5cbiAgKHNyYykgPT5cbiAgICBjb21wdXRlZCgoKSA9PiBwcm9qZWN0KHNyYygpLCBvdGhlcigpKSwgb3B0KTtcblxuLyoqIE9ubHkgcmUtZW1pdCB3aGVuIGVxdWFsKHByZXYsIG5leHQpIGlzIGZhbHNlLiAqL1xuZXhwb3J0IGNvbnN0IGRpc3RpbmN0ID1cbiAgPFQ+KGVxdWFsOiAoYTogVCwgYjogVCkgPT4gYm9vbGVhbiA9IE9iamVjdC5pcyk6IE9wZXJhdG9yPFQsIFQ+ID0+XG4gIChzcmMpID0+XG4gICAgY29tcHV0ZWQoKCkgPT4gc3JjKCksIHsgZXF1YWwgfSk7XG5cbi8qKiBtYXAgdG8gbmV3IHZhbHVlICovXG5leHBvcnQgY29uc3QgbWFwID1cbiAgPEksIE8+KGZuOiAodjogSSkgPT4gTyk6IE9wZXJhdG9yPEksIE8+ID0+XG4gIChzcmMpID0+XG4gICAgY29tcHV0ZWQoKCkgPT4gZm4oc3JjKCkpKTtcblxuLyoqIGZpbHRlciB2YWx1ZXMsIGtlZXBpbmcgdGhlIGxhc3QgdmFsdWUgaWYgaXQgd2FzIGV2ZXIgYXZhaWxhYmxlLCBpZiBmaXJzdCB2YWx1ZSBpcyBmaWx0ZXJlZCB3aWxsIHJldHVybiB1bmRlZmluZWQgKi9cbmV4cG9ydCBjb25zdCBmaWx0ZXIgPVxuICA8VD4ocHJlZGljYXRlOiAodjogVCkgPT4gYm9vbGVhbik6IE9wZXJhdG9yPFQsIFQgfCB1bmRlZmluZWQ+ID0+XG4gIChzcmMpID0+XG4gICAgbGlua2VkU2lnbmFsKHtcbiAgICAgIHNvdXJjZTogc3JjLFxuICAgICAgY29tcHV0YXRpb246IChuZXh0LCBwcmV2KSA9PiB7XG4gICAgICAgIGlmIChwcmVkaWNhdGUobmV4dCkpIHJldHVybiBuZXh0O1xuICAgICAgICByZXR1cm4gcHJldj8uc291cmNlO1xuICAgICAgfSxcbiAgICB9KTtcblxuLyoqIHRhcCBpbnRvIHRoZSB2YWx1ZSAqL1xuZXhwb3J0IGNvbnN0IHRhcCA9XG4gIDxUPihmbjogKHY6IFQpID0+IHZvaWQpOiBPcGVyYXRvcjxULCBUPiA9PlxuICAoc3JjKSA9PiB7XG4gICAgZWZmZWN0KCgpID0+IGZuKHNyYygpKSk7XG5cbiAgICByZXR1cm4gc3JjO1xuICB9O1xuIl19","import { computed, signal, } from '@angular/core';\n/**\n * Decorate any `Signal<T>` with a chainable `.pipe(...)` method.\n *\n * @example\n * const s = pipeable(signal(1)); // WritableSignal<number> (+ pipe)\n * const label = s.pipe(n => n * 2, n => `#${n}`); // Signal<string> (+ pipe)\n * label(); // \"#2\"\n */\nexport function pipeable(signal) {\n const internal = signal;\n const mapImpl = (...fns) => {\n const last = fns.at(-1);\n let opt;\n if (last && typeof last !== 'function') {\n fns = fns.slice(0, -1);\n opt = last;\n }\n if (fns.length === 0)\n return internal;\n if (fns.length === 1) {\n const fn = fns[0];\n return pipeable(computed(() => fn(internal()), opt));\n }\n const transformer = (input) => fns.reduce((acc, fn) => fn(acc), input);\n return pipeable(computed(() => transformer(internal()), opt));\n };\n const pipeImpl = (...ops) => {\n if (ops.length === 0)\n return internal;\n return ops.reduce((src, op) => pipeable(op(src)), internal);\n };\n Object.defineProperties(internal, {\n map: {\n value: mapImpl,\n configurable: true,\n enumerable: false,\n writable: false,\n },\n pipe: {\n value: pipeImpl,\n configurable: true,\n enumerable: false,\n writable: false,\n },\n });\n return internal;\n}\n/**\n * Create a new **writable** signal and return it as a `PipableSignal`.\n *\n * The returned value is a `WritableSignal<T>` with `.set`, `.update`, `.asReadonly`\n * still available (via intersection type), plus a chainable `.pipe(...)`.\n *\n * @example\n * const count = piped(1); // WritableSignal<number> (+ pipe)\n * const even = count.pipe(n => n % 2 === 0); // Signal<boolean> (+ pipe)\n * count.update(n => n + 1);\n */\nexport function piped(initial, opt) {\n return pipeable(signal(initial, opt));\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlwZWJsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc3JjL2xpYi9waXBlYWJsZS9waXBlYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxRQUFRLEVBQ1IsTUFBTSxHQUlQLE1BQU0sZUFBZSxDQUFDO0FBUXZCOzs7Ozs7O0dBT0c7QUFDSCxNQUFNLFVBQVUsUUFBUSxDQUN0QixNQUFZO0lBRVosTUFBTSxRQUFRLEdBQUcsTUFBaUQsQ0FBQztJQUVuRSxNQUFNLE9BQU8sR0FBRyxDQUFDLEdBQUcsR0FBOEIsRUFBRSxFQUFFO1FBQ3BELE1BQU0sSUFBSSxHQUFHLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4QixJQUFJLEdBQXlDLENBQUM7UUFDOUMsSUFBSSxJQUFJLElBQUksT0FBTyxJQUFJLEtBQUssVUFBVSxFQUFFLENBQUM7WUFDdkMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdkIsR0FBRyxHQUFHLElBQUksQ0FBQztRQUNiLENBQUM7UUFFRCxJQUFJLEdBQUcsQ0FBQyxNQUFNLEtBQUssQ0FBQztZQUFFLE9BQU8sUUFBUSxDQUFDO1FBRXRDLElBQUksR0FBRyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUNyQixNQUFNLEVBQUUsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDbEIsT0FBTyxRQUFRLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDdkQsQ0FBQztRQUVELE1BQU0sV0FBVyxHQUFHLENBQUMsS0FBVSxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBRTVFLE9BQU8sUUFBUSxDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxXQUFXLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ2hFLENBQUMsQ0FBQztJQUVGLE1BQU0sUUFBUSxHQUFHLENBQUMsR0FBRyxHQUF5QixFQUFFLEVBQUU7UUFDaEQsSUFBSSxHQUFHLENBQUMsTUFBTSxLQUFLLENBQUM7WUFBRSxPQUFPLFFBQVEsQ0FBQztRQUN0QyxPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQ2YsQ0FBQyxHQUFHLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQzlCLFFBQStCLENBQ2hDLENBQUM7SUFDSixDQUFDLENBQUM7SUFFRixNQUFNLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFO1FBQ2hDLEdBQUcsRUFBRTtZQUNILEtBQUssRUFBRSxPQUFPO1lBQ2QsWUFBWSxFQUFFLElBQUk7WUFDbEIsVUFBVSxFQUFFLEtBQUs7WUFDakIsUUFBUSxFQUFFLEtBQUs7U0FDaEI7UUFFRCxJQUFJLEVBQUU7WUFDSixLQUFLLEVBQUUsUUFBUTtZQUNmLFlBQVksRUFBRSxJQUFJO1lBQ2xCLFVBQVUsRUFBRSxLQUFLO1lBQ2pCLFFBQVEsRUFBRSxLQUFLO1NBQ2hCO0tBQ0YsQ0FBQyxDQUFDO0lBRUgsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQztBQUVEOzs7Ozs7Ozs7O0dBVUc7QUFDSCxNQUFNLFVBQVUsS0FBSyxDQUNuQixPQUFVLEVBQ1YsR0FBNEI7SUFFNUIsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO0FBQ3hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIGNvbXB1dGVkLFxyXG4gIHNpZ25hbCxcclxuICB0eXBlIENyZWF0ZVNpZ25hbE9wdGlvbnMsXHJcbiAgdHlwZSBTaWduYWwsXHJcbiAgdHlwZSBXcml0YWJsZVNpZ25hbCxcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHR5cGUge1xyXG4gIE9wZXJhdG9yLFxyXG4gIFBpcGVhYmxlU2lnbmFsLFxyXG4gIFNpZ25hbFZhbHVlLFxyXG4gIFVuYXJ5RnVuY3Rpb24sXHJcbn0gZnJvbSAnLi90eXBlcyc7XHJcblxyXG4vKipcclxuICogRGVjb3JhdGUgYW55IGBTaWduYWw8VD5gIHdpdGggYSBjaGFpbmFibGUgYC5waXBlKC4uLilgIG1ldGhvZC5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogY29uc3QgcyA9IHBpcGVhYmxlKHNpZ25hbCgxKSk7IC8vIFdyaXRhYmxlU2lnbmFsPG51bWJlcj4gKCsgcGlwZSlcclxuICogY29uc3QgbGFiZWwgPSBzLnBpcGUobiA9PiBuICogMiwgbiA9PiBgIyR7bn1gKTsgLy8gU2lnbmFsPHN0cmluZz4gKCsgcGlwZSlcclxuICogbGFiZWwoKTsgLy8gXCIjMlwiXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gcGlwZWFibGU8VFNpZyBleHRlbmRzIFNpZ25hbDxhbnk+PihcclxuICBzaWduYWw6IFRTaWcsXHJcbik6IFBpcGVhYmxlU2lnbmFsPFNpZ25hbFZhbHVlPFRTaWc+LCBUU2lnPiB7XHJcbiAgY29uc3QgaW50ZXJuYWwgPSBzaWduYWwgYXMgUGlwZWFibGVTaWduYWw8U2lnbmFsVmFsdWU8VFNpZz4sIFRTaWc+O1xyXG5cclxuICBjb25zdCBtYXBJbXBsID0gKC4uLmZuczogVW5hcnlGdW5jdGlvbjxhbnksIGFueT5bXSkgPT4ge1xyXG4gICAgY29uc3QgbGFzdCA9IGZucy5hdCgtMSk7XHJcbiAgICBsZXQgb3B0OiBDcmVhdGVTaWduYWxPcHRpb25zPGFueT4gfCB1bmRlZmluZWQ7XHJcbiAgICBpZiAobGFzdCAmJiB0eXBlb2YgbGFzdCAhPT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgICBmbnMgPSBmbnMuc2xpY2UoMCwgLTEpO1xyXG4gICAgICBvcHQgPSBsYXN0O1xyXG4gICAgfVxyXG5cclxuICAgIGlmIChmbnMubGVuZ3RoID09PSAwKSByZXR1cm4gaW50ZXJuYWw7XHJcblxyXG4gICAgaWYgKGZucy5sZW5ndGggPT09IDEpIHtcclxuICAgICAgY29uc3QgZm4gPSBmbnNbMF07XHJcbiAgICAgIHJldHVybiBwaXBlYWJsZShjb21wdXRlZCgoKSA9PiBmbihpbnRlcm5hbCgpKSwgb3B0KSk7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3QgdHJhbnNmb3JtZXIgPSAoaW5wdXQ6IGFueSkgPT4gZm5zLnJlZHVjZSgoYWNjLCBmbikgPT4gZm4oYWNjKSwgaW5wdXQpO1xyXG5cclxuICAgIHJldHVybiBwaXBlYWJsZShjb21wdXRlZCgoKSA9PiB0cmFuc2Zvcm1lcihpbnRlcm5hbCgpKSwgb3B0KSk7XHJcbiAgfTtcclxuXHJcbiAgY29uc3QgcGlwZUltcGwgPSAoLi4ub3BzOiBPcGVyYXRvcjxhbnksIGFueT5bXSkgPT4ge1xyXG4gICAgaWYgKG9wcy5sZW5ndGggPT09IDApIHJldHVybiBpbnRlcm5hbDtcclxuICAgIHJldHVybiBvcHMucmVkdWNlPFBpcGVhYmxlU2lnbmFsPGFueT4+KFxyXG4gICAgICAoc3JjLCBvcCkgPT4gcGlwZWFibGUob3Aoc3JjKSksXHJcbiAgICAgIGludGVybmFsIGFzIFBpcGVhYmxlU2lnbmFsPGFueT4sXHJcbiAgICApO1xyXG4gIH07XHJcblxyXG4gIE9iamVjdC5kZWZpbmVQcm9wZXJ0aWVzKGludGVybmFsLCB7XHJcbiAgICBtYXA6IHtcclxuICAgICAgdmFsdWU6IG1hcEltcGwsXHJcbiAgICAgIGNvbmZpZ3VyYWJsZTogdHJ1ZSxcclxuICAgICAgZW51bWVyYWJsZTogZmFsc2UsXHJcbiAgICAgIHdyaXRhYmxlOiBmYWxzZSxcclxuICAgIH0sXHJcblxyXG4gICAgcGlwZToge1xyXG4gICAgICB2YWx1ZTogcGlwZUltcGwsXHJcbiAgICAgIGNvbmZpZ3VyYWJsZTogdHJ1ZSxcclxuICAgICAgZW51bWVyYWJsZTogZmFsc2UsXHJcbiAgICAgIHdyaXRhYmxlOiBmYWxzZSxcclxuICAgIH0sXHJcbiAgfSk7XHJcblxyXG4gIHJldHVybiBpbnRlcm5hbDtcclxufVxyXG5cclxuLyoqXHJcbiAqIENyZWF0ZSBhIG5ldyAqKndyaXRhYmxlKiogc2lnbmFsIGFuZCByZXR1cm4gaXQgYXMgYSBgUGlwYWJsZVNpZ25hbGAuXHJcbiAqXHJcbiAqIFRoZSByZXR1cm5lZCB2YWx1ZSBpcyBhIGBXcml0YWJsZVNpZ25hbDxUPmAgd2l0aCBgLnNldGAsIGAudXBkYXRlYCwgYC5hc1JlYWRvbmx5YFxyXG4gKiBzdGlsbCBhdmFpbGFibGUgKHZpYSBpbnRlcnNlY3Rpb24gdHlwZSksIHBsdXMgYSBjaGFpbmFibGUgYC5waXBlKC4uLilgLlxyXG4gKlxyXG4gKiBAZXhhbXBsZVxyXG4gKiBjb25zdCBjb3VudCA9IHBpcGVkKDEpOyAvLyBXcml0YWJsZVNpZ25hbDxudW1iZXI+ICgrIHBpcGUpXHJcbiAqIGNvbnN0IGV2ZW4gPSBjb3VudC5waXBlKG4gPT4gbiAlIDIgPT09IDApOyAvLyBTaWduYWw8Ym9vbGVhbj4gKCsgcGlwZSlcclxuICogY291bnQudXBkYXRlKG4gPT4gbiArIDEpO1xyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIHBpcGVkPFQ+KFxyXG4gIGluaXRpYWw6IFQsXHJcbiAgb3B0PzogQ3JlYXRlU2lnbmFsT3B0aW9uczxUPixcclxuKTogUGlwZWFibGVTaWduYWw8VCwgV3JpdGFibGVTaWduYWw8VD4+IHtcclxuICByZXR1cm4gcGlwZWFibGUoc2lnbmFsKGluaXRpYWwsIG9wdCkpO1xyXG59XHJcbiJdfQ==","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, inject, PLATFORM_ID, signal, } from '@angular/core';\n/**\n * Creates a read-only signal that reactively tracks whether a CSS media query\n * string currently matches.\n *\n * It uses `window.matchMedia` to evaluate the query and listen for changes.\n * The primitive is SSR-safe (defaults to `false` on the server) and automatically\n * cleans up its event listeners when the creating context is destroyed.\n *\n * @param query The CSS media query string to evaluate (e.g., `'(min-width: 768px)'`, `'(prefers-color-scheme: dark)'`).\n * @param debugName Optional debug name for the signal.\n * @returns A read-only `Signal<boolean>` which is `true` if the media query\n * currently matches, and `false` otherwise.\n *\n * @remarks\n * - On the server, this signal will always return `false` by default.\n * - It automatically updates if the match status of the media query changes in the browser.\n * - Event listeners are cleaned up automatically via `DestroyRef` if created in an injection context.\n *\n * @example\n * ```ts\n * import { Component, effect } from '@angular/core';\n * import { mediaQuery } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-responsive-layout',\n * template: `\n * @if (isDesktop()) {\n * <p>Showing desktop layout.</p>\n * } @else {\n * <p>Showing mobile layout.</p>\n * }\n * `\n * })\n * export class ResponsiveLayoutComponent {\n * readonly isDesktop = mediaQuery('(min-width: 1024px)');\n *\n * constructor() {\n * effect(() => {\n * console.log('Is desktop view:', this.isDesktop());\n * });\n * }\n * }\n * ```\n */\nexport function mediaQuery(query, debugName = 'mediaQuery') {\n if (isPlatformServer(inject(PLATFORM_ID)))\n return computed(() => false, { debugName });\n const mediaQueryList = window.matchMedia(query);\n const state = signal(mediaQueryList.matches, { debugName: debugName });\n const handleChange = (event) => {\n state.set(event.matches);\n };\n mediaQueryList.addEventListener('change', handleChange);\n inject(DestroyRef).onDestroy(() => {\n mediaQueryList.removeEventListener('change', handleChange);\n });\n return state.asReadonly();\n}\n/**\n * Creates a read-only signal that tracks the user's OS/browser preference\n * for a dark color scheme using the `(prefers-color-scheme: dark)` media query.\n *\n * This is a convenience wrapper around the generic `mediaQuery` primitive.\n * It's SSR-safe (defaults to `false` on the server) and automatically\n * cleans up its event listeners.\n *\n * @param debugName Optional debug name for the signal.\n * @returns A read-only `Signal<boolean>` which is `true` if a dark theme\n * is preferred, and `false` otherwise.\n * @see {mediaQuery} for the underlying implementation.\n *\n * @example\n * ```ts\n * const isDarkMode = prefersDarkMode();\n * effect(() => {\n * document.body.classList.toggle('dark-theme', isDarkMode());\n * });\n * ```\n */\nexport function prefersDarkMode(debugName) {\n return mediaQuery('(prefers-color-scheme: dark)', debugName);\n}\n/**\n * Creates a read-only signal that tracks the user's OS/browser preference\n * for reduced motion using the `(prefers-reduced-motion: reduce)` media query.\n *\n * This is a convenience wrapper around the generic `mediaQuery` primitive.\n * It's SSR-safe (defaults to `false` on the server) and automatically\n * cleans up its event listeners.\n *\n * @param debugName Optional debug name for the signal.\n * @returns A read-only `Signal<boolean>` which is `true` if reduced motion\n * is preferred, and `false` otherwise.\n * @see {mediaQuery} for the underlying implementation.\n *\n * @example\n * ```ts\n * const reduceMotion = prefersReducedMotion();\n * effect(() => {\n * if (reduceMotion()) {\n * // Apply simplified animations or disable them\n * } else {\n * // Apply full animations\n * }\n * });\n * ```\n */\nexport function prefersReducedMotion(debugName) {\n return mediaQuery('(prefers-reduced-motion: reduce)', debugName);\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVkaWEtcXVlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3NyYy9saWIvc2Vuc29ycy9tZWRpYS1xdWVyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQ0wsUUFBUSxFQUNSLFVBQVUsRUFDVixNQUFNLEVBQ04sV0FBVyxFQUNYLE1BQU0sR0FFUCxNQUFNLGVBQWUsQ0FBQztBQUV2Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTJDRztBQUNILE1BQU0sVUFBVSxVQUFVLENBQ3hCLEtBQWEsRUFDYixTQUFTLEdBQUcsWUFBWTtJQUV4QixJQUFJLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN2QyxPQUFPLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBRTlDLE1BQU0sY0FBYyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7SUFFaEQsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQztJQUV2RSxNQUFNLFlBQVksR0FBRyxDQUFDLEtBQTBCLEVBQUUsRUFBRTtRQUNsRCxLQUFLLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMzQixDQUFDLENBQUM7SUFFRixjQUFjLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBRXhELE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ2hDLGNBQWMsQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLEVBQUUsWUFBWSxDQUFDLENBQUM7SUFDN0QsQ0FBQyxDQUFDLENBQUM7SUFFSCxPQUFPLEtBQUssQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUM1QixDQUFDO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JHO0FBQ0gsTUFBTSxVQUFVLGVBQWUsQ0FBQyxTQUFrQjtJQUNoRCxPQUFPLFVBQVUsQ0FBQyw4QkFBOEIsRUFBRSxTQUFTLENBQUMsQ0FBQztBQUMvRCxDQUFDO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXdCRztBQUNILE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxTQUFrQjtJQUNyRCxPQUFPLFVBQVUsQ0FBQyxrQ0FBa0MsRUFBRSxTQUFTLENBQUMsQ0FBQztBQUNuRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNQbGF0Zm9ybVNlcnZlciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7XHJcbiAgY29tcHV0ZWQsXHJcbiAgRGVzdHJveVJlZixcclxuICBpbmplY3QsXHJcbiAgUExBVEZPUk1fSUQsXHJcbiAgc2lnbmFsLFxyXG4gIFNpZ25hbCxcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGVzIGEgcmVhZC1vbmx5IHNpZ25hbCB0aGF0IHJlYWN0aXZlbHkgdHJhY2tzIHdoZXRoZXIgYSBDU1MgbWVkaWEgcXVlcnlcclxuICogc3RyaW5nIGN1cnJlbnRseSBtYXRjaGVzLlxyXG4gKlxyXG4gKiBJdCB1c2VzIGB3aW5kb3cubWF0Y2hNZWRpYWAgdG8gZXZhbHVhdGUgdGhlIHF1ZXJ5IGFuZCBsaXN0ZW4gZm9yIGNoYW5nZXMuXHJcbiAqIFRoZSBwcmltaXRpdmUgaXMgU1NSLXNhZmUgKGRlZmF1bHRzIHRvIGBmYWxzZWAgb24gdGhlIHNlcnZlcikgYW5kIGF1dG9tYXRpY2FsbHlcclxuICogY2xlYW5zIHVwIGl0cyBldmVudCBsaXN0ZW5lcnMgd2hlbiB0aGUgY3JlYXRpbmcgY29udGV4dCBpcyBkZXN0cm95ZWQuXHJcbiAqXHJcbiAqIEBwYXJhbSBxdWVyeSBUaGUgQ1NTIG1lZGlhIHF1ZXJ5IHN0cmluZyB0byBldmFsdWF0ZSAoZS5nLiwgYCcobWluLXdpZHRoOiA3NjhweCknYCwgYCcocHJlZmVycy1jb2xvci1zY2hlbWU6IGRhcmspJ2ApLlxyXG4gKiBAcGFyYW0gZGVidWdOYW1lIE9wdGlvbmFsIGRlYnVnIG5hbWUgZm9yIHRoZSBzaWduYWwuXHJcbiAqIEByZXR1cm5zIEEgcmVhZC1vbmx5IGBTaWduYWw8Ym9vbGVhbj5gIHdoaWNoIGlzIGB0cnVlYCBpZiB0aGUgbWVkaWEgcXVlcnlcclxuICogY3VycmVudGx5IG1hdGNoZXMsIGFuZCBgZmFsc2VgIG90aGVyd2lzZS5cclxuICpcclxuICogQHJlbWFya3NcclxuICogLSBPbiB0aGUgc2VydmVyLCB0aGlzIHNpZ25hbCB3aWxsIGFsd2F5cyByZXR1cm4gYGZhbHNlYCBieSBkZWZhdWx0LlxyXG4gKiAtIEl0IGF1dG9tYXRpY2FsbHkgdXBkYXRlcyBpZiB0aGUgbWF0Y2ggc3RhdHVzIG9mIHRoZSBtZWRpYSBxdWVyeSBjaGFuZ2VzIGluIHRoZSBicm93c2VyLlxyXG4gKiAtIEV2ZW50IGxpc3RlbmVycyBhcmUgY2xlYW5lZCB1cCBhdXRvbWF0aWNhbGx5IHZpYSBgRGVzdHJveVJlZmAgaWYgY3JlYXRlZCBpbiBhbiBpbmplY3Rpb24gY29udGV4dC5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogYGBgdHNcclxuICogaW1wb3J0IHsgQ29tcG9uZW50LCBlZmZlY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuICogaW1wb3J0IHsgbWVkaWFRdWVyeSB9IGZyb20gJ0BtbXN0YWNrL3ByaW1pdGl2ZXMnO1xyXG4gKlxyXG4gKiBAQ29tcG9uZW50KHtcclxuICogc2VsZWN0b3I6ICdhcHAtcmVzcG9uc2l2ZS1sYXlvdXQnLFxyXG4gKiB0ZW1wbGF0ZTogYFxyXG4gKiBAaWYgKGlzRGVza3RvcCgpKSB7XHJcbiAqIDxwPlNob3dpbmcgZGVza3RvcCBsYXlvdXQuPC9wPlxyXG4gKiB9IEBlbHNlIHtcclxuICogPHA+U2hvd2luZyBtb2JpbGUgbGF5b3V0LjwvcD5cclxuICogfVxyXG4gKiBgXHJcbiAqIH0pXHJcbiAqIGV4cG9ydCBjbGFzcyBSZXNwb25zaXZlTGF5b3V0Q29tcG9uZW50IHtcclxuICogcmVhZG9ubHkgaXNEZXNrdG9wID0gbWVkaWFRdWVyeSgnKG1pbi13aWR0aDogMTAyNHB4KScpO1xyXG4gKlxyXG4gKiBjb25zdHJ1Y3RvcigpIHtcclxuICogZWZmZWN0KCgpID0+IHtcclxuICogY29uc29sZS5sb2coJ0lzIGRlc2t0b3AgdmlldzonLCB0aGlzLmlzRGVza3RvcCgpKTtcclxuICogfSk7XHJcbiAqIH1cclxuICogfVxyXG4gKiBgYGBcclxuICovXHJcbmV4cG9ydCBmdW5jdGlvbiBtZWRpYVF1ZXJ5KFxyXG4gIHF1ZXJ5OiBzdHJpbmcsXHJcbiAgZGVidWdOYW1lID0gJ21lZGlhUXVlcnknLFxyXG4pOiBTaWduYWw8Ym9vbGVhbj4ge1xyXG4gIGlmIChpc1BsYXRmb3JtU2VydmVyKGluamVjdChQTEFURk9STV9JRCkpKVxyXG4gICAgcmV0dXJuIGNvbXB1dGVkKCgpID0+IGZhbHNlLCB7IGRlYnVnTmFtZSB9KTtcclxuXHJcbiAgY29uc3QgbWVkaWFRdWVyeUxpc3QgPSB3aW5kb3cubWF0Y2hNZWRpYShxdWVyeSk7XHJcblxyXG4gIGNvbnN0IHN0YXRlID0gc2lnbmFsKG1lZGlhUXVlcnlMaXN0Lm1hdGNoZXMsIHsgZGVidWdOYW1lOiBkZWJ1Z05hbWUgfSk7XHJcblxyXG4gIGNvbnN0IGhhbmRsZUNoYW5nZSA9IChldmVudDogTWVkaWFRdWVyeUxpc3RFdmVudCkgPT4ge1xyXG4gICAgc3RhdGUuc2V0KGV2ZW50Lm1hdGNoZXMpO1xyXG4gIH07XHJcblxyXG4gIG1lZGlhUXVlcnlMaXN0LmFkZEV2ZW50TGlzdGVuZXIoJ2NoYW5nZScsIGhhbmRsZUNoYW5nZSk7XHJcblxyXG4gIGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT4ge1xyXG4gICAgbWVkaWFRdWVyeUxpc3QucmVtb3ZlRXZlbnRMaXN0ZW5lcignY2hhbmdlJywgaGFuZGxlQ2hhbmdlKTtcclxuICB9KTtcclxuXHJcbiAgcmV0dXJuIHN0YXRlLmFzUmVhZG9ubHkoKTtcclxufVxyXG5cclxuLyoqXHJcbiAqIENyZWF0ZXMgYSByZWFkLW9ubHkgc2lnbmFsIHRoYXQgdHJhY2tzIHRoZSB1c2VyJ3MgT1MvYnJvd3NlciBwcmVmZXJlbmNlXHJcbiAqIGZvciBhIGRhcmsgY29sb3Igc2NoZW1lIHVzaW5nIHRoZSBgKHByZWZlcnMtY29sb3Itc2NoZW1lOiBkYXJrKWAgbWVkaWEgcXVlcnkuXHJcbiAqXHJcbiAqIFRoaXMgaXMgYSBjb252ZW5pZW5jZSB3cmFwcGVyIGFyb3VuZCB0aGUgZ2VuZXJpYyBgbWVkaWFRdWVyeWAgcHJpbWl0aXZlLlxyXG4gKiBJdCdzIFNTUi1zYWZlIChkZWZhdWx0cyB0byBgZmFsc2VgIG9uIHRoZSBzZXJ2ZXIpIGFuZCBhdXRvbWF0aWNhbGx5XHJcbiAqIGNsZWFucyB1cCBpdHMgZXZlbnQgbGlzdGVuZXJzLlxyXG4gKlxyXG4gKiBAcGFyYW0gZGVidWdOYW1lIE9wdGlvbmFsIGRlYnVnIG5hbWUgZm9yIHRoZSBzaWduYWwuXHJcbiAqIEByZXR1cm5zIEEgcmVhZC1vbmx5IGBTaWduYWw8Ym9vbGVhbj5gIHdoaWNoIGlzIGB0cnVlYCBpZiBhIGRhcmsgdGhlbWVcclxuICogaXMgcHJlZmVycmVkLCBhbmQgYGZhbHNlYCBvdGhlcndpc2UuXHJcbiAqIEBzZWUge21lZGlhUXVlcnl9IGZvciB0aGUgdW5kZXJseWluZyBpbXBsZW1lbnRhdGlvbi5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogYGBgdHNcclxuICogY29uc3QgaXNEYXJrTW9kZSA9IHByZWZlcnNEYXJrTW9kZSgpO1xyXG4gKiBlZmZlY3QoKCkgPT4ge1xyXG4gKiBkb2N1bWVudC5ib2R5LmNsYXNzTGlzdC50b2dnbGUoJ2RhcmstdGhlbWUnLCBpc0RhcmtNb2RlKCkpO1xyXG4gKiB9KTtcclxuICogYGBgXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gcHJlZmVyc0RhcmtNb2RlKGRlYnVnTmFtZT86IHN0cmluZyk6IFNpZ25hbDxib29sZWFuPiB7XHJcbiAgcmV0dXJuIG1lZGlhUXVlcnkoJyhwcmVmZXJzLWNvbG9yLXNjaGVtZTogZGFyayknLCBkZWJ1Z05hbWUpO1xyXG59XHJcblxyXG4vKipcclxuICogQ3JlYXRlcyBhIHJlYWQtb25seSBzaWduYWwgdGhhdCB0cmFja3MgdGhlIHVzZXIncyBPUy9icm93c2VyIHByZWZlcmVuY2VcclxuICogZm9yIHJlZHVjZWQgbW90aW9uIHVzaW5nIHRoZSBgKHByZWZlcnMtcmVkdWNlZC1tb3Rpb246IHJlZHVjZSlgIG1lZGlhIHF1ZXJ5LlxyXG4gKlxyXG4gKiBUaGlzIGlzIGEgY29udmVuaWVuY2Ugd3JhcHBlciBhcm91bmQgdGhlIGdlbmVyaWMgYG1lZGlhUXVlcnlgIHByaW1pdGl2ZS5cclxuICogSXQncyBTU1Itc2FmZSAoZGVmYXVsdHMgdG8gYGZhbHNlYCBvbiB0aGUgc2VydmVyKSBhbmQgYXV0b21hdGljYWxseVxyXG4gKiBjbGVhbnMgdXAgaXRzIGV2ZW50IGxpc3RlbmVycy5cclxuICpcclxuICogQHBhcmFtIGRlYnVnTmFtZSBPcHRpb25hbCBkZWJ1ZyBuYW1lIGZvciB0aGUgc2lnbmFsLlxyXG4gKiBAcmV0dXJucyBBIHJlYWQtb25seSBgU2lnbmFsPGJvb2xlYW4+YCB3aGljaCBpcyBgdHJ1ZWAgaWYgcmVkdWNlZCBtb3Rpb25cclxuICogaXMgcHJlZmVycmVkLCBhbmQgYGZhbHNlYCBvdGhlcndpc2UuXHJcbiAqIEBzZWUge21lZGlhUXVlcnl9IGZvciB0aGUgdW5kZXJseWluZyBpbXBsZW1lbnRhdGlvbi5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogYGBgdHNcclxuICogY29uc3QgcmVkdWNlTW90aW9uID0gcHJlZmVyc1JlZHVjZWRNb3Rpb24oKTtcclxuICogZWZmZWN0KCgpID0+IHtcclxuICogaWYgKHJlZHVjZU1vdGlvbigpKSB7XHJcbiAqIC8vIEFwcGx5IHNpbXBsaWZpZWQgYW5pbWF0aW9ucyBvciBkaXNhYmxlIHRoZW1cclxuICogfSBlbHNlIHtcclxuICogLy8gQXBwbHkgZnVsbCBhbmltYXRpb25zXHJcbiAqIH1cclxuICogfSk7XHJcbiAqIGBgYFxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIHByZWZlcnNSZWR1Y2VkTW90aW9uKGRlYnVnTmFtZT86IHN0cmluZyk6IFNpZ25hbDxib29sZWFuPiB7XHJcbiAgcmV0dXJuIG1lZGlhUXVlcnkoJyhwcmVmZXJzLXJlZHVjZWQtbW90aW9uOiByZWR1Y2UpJywgZGVidWdOYW1lKTtcclxufVxyXG4iXX0=","import { computed, DestroyRef, inject, signal, untracked, } from '@angular/core';\nimport { toWritable } from './to-writable';\n/**\n * A convenience function that creates and throttles a new `WritableSignal` in one step.\n *\n * @see {throttle} for the core implementation details.\n *\n * @template T The type of value the signal holds.\n * @param initial The initial value of the signal.\n * @param opt Options for signal creation, including throttle time `ms`.\n * @returns A `ThrottledSignal<T>` instance.\n *\n * @example\n * const query = throttled('', { ms: 500 });\n * effect(() => console.log('Throttled Query:', query()));\n *\n * query.set('a');\n * query.set('b');\n * query.set('c');\n * // With a trailing-edge throttle, the final value 'c' would be set\n * // after the 500ms cooldown.\n */\nexport function throttled(initial, opt) {\n return throttle(signal(initial, opt), opt);\n}\n/**\n * Wraps an existing `WritableSignal` to create a new one whose readable value is throttled.\n *\n * This implementation avoids using `effect` by pairing a trigger signal with an `untracked`\n * read of the source signal to control when the throttled value is re-evaluated.\n *\n * @template T The type of value the signal holds.\n * @param source The source `WritableSignal` to wrap. Writes are applied to this signal immediately.\n * @param opt Options for throttling, including throttle time `ms` and an optional `DestroyRef`.\n * @returns A new `ThrottledSignal<T>` whose read value is throttled. The `.original` property\n * of the returned signal is a reference back to the provided `source` signal.\n *\n * @example\n * const query = throttled('', { ms: 500 });\n * effect(() => console.log('Throttled Query:', query()));\n *\n * query.set('a');\n * query.set('b');\n * query.set('c');\n * // With a trailing-edge throttle, the final value 'c' would be set\n * // after the 500ms cooldown.\n */\nexport function throttle(source, opt) {\n const ms = opt?.ms ?? 0;\n const trigger = signal(false, ...(ngDevMode ? [{ debugName: \"trigger\" }] : []));\n let timeout;\n try {\n const destroyRef = opt?.destroyRef ?? inject(DestroyRef, { optional: true });\n destroyRef?.onDestroy(() => {\n if (timeout)\n clearTimeout(timeout);\n timeout = undefined;\n });\n }\n catch {\n // not in injection context & no destroyRef provided opting out of cleanup\n }\n const triggerFn = (updateSourceAction) => {\n updateSourceAction();\n if (timeout)\n return;\n timeout = setTimeout(() => {\n trigger.update((c) => !c);\n timeout = undefined;\n }, ms);\n };\n const set = (value) => {\n triggerFn(() => source.set(value));\n };\n const update = (fn) => {\n triggerFn(() => source.update(fn));\n };\n const writable = toWritable(computed(() => {\n trigger();\n return untracked(source);\n }, opt), set, update);\n writable.original = source;\n return writable;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"throttled.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/throttled.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAER,UAAU,EACV,MAAM,EACN,MAAM,EACN,SAAS,GAEV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAiC3C;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,SAAS,CACvB,OAAU,EACV,GAA+B;IAE/B,OAAO,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;AAC7C,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAM,UAAU,QAAQ,CACtB,MAAyB,EACzB,GAA+B;IAE/B,MAAM,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,CAAC,CAAC;IAExB,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,mDAAC,CAAC;IAE9B,IAAI,OAAkD,CAAC;IAEvD,IAAI,CAAC;QACH,MAAM,UAAU,GACd,GAAG,EAAE,UAAU,IAAI,MAAM,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAE5D,UAAU,EAAE,SAAS,CAAC,GAAG,EAAE;YACzB,IAAI,OAAO;gBAAE,YAAY,CAAC,OAAO,CAAC,CAAC;YACnC,OAAO,GAAG,SAAS,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IAAC,MAAM,CAAC;QACP,0EAA0E;IAC5E,CAAC;IAED,MAAM,SAAS,GAAG,CAAC,kBAA8B,EAAE,EAAE;QACnD,kBAAkB,EAAE,CAAC;QACrB,IAAI,OAAO;YAAE,OAAO;QAEpB,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;YACxB,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1B,OAAO,GAAG,SAAS,CAAC;QACtB,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC,CAAC;IAEF,MAAM,GAAG,GAAG,CAAC,KAAQ,EAAE,EAAE;QACvB,SAAS,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC;IAEF,MAAM,MAAM,GAAG,CAAC,EAAkB,EAAE,EAAE;QACpC,SAAS,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC;IAEF,MAAM,QAAQ,GAAG,UAAU,CACzB,QAAQ,CAAC,GAAG,EAAE;QACZ,OAAO,EAAE,CAAC;QACV,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC,EAAE,GAAG,CAAC,EACP,GAAG,EACH,MAAM,CACe,CAAC;IACxB,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC;IAE3B,OAAO,QAAQ,CAAC;AAClB,CAAC","sourcesContent":["import {\r\n  computed,\r\n  type CreateSignalOptions,\r\n  DestroyRef,\r\n  inject,\r\n  signal,\r\n  untracked,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { DebouncedSignal } from './debounced';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * Options for creating a throttled writable signal.\r\n * Extends Angular's `CreateSignalOptions` with a throttle time setting.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type CreateThrottledOptions<T> = CreateSignalOptions<T> & {\r\n  /**\r\n   * The throttle delay in milliseconds. The minimum time\r\n   * in milliseconds that must pass between updates to the throttled signal's value.\r\n   */\r\n  ms?: number;\r\n  /**\r\n   * Optional `DestroyRef` to clean up the throttle timer when the signal is destroyed.\r\n   * If provided, the timer will be cleared when the signal is destroyed.\r\n   * If the signal is called within a reactive context a DestroyRef is injected automatically.\r\n   * If it is not provided or injected, the timer will not be cleared automatically...which is usually fine :)\r\n   */\r\n  destroyRef?: DestroyRef;\r\n};\r\n\r\n/**\r\n * A specialized `WritableSignal` whose publicly readable value updates are throttled.\r\n *\r\n * It provides access to the underlying, non-throttled signal via the `original` property.\r\n *\r\n * @template T The type of value held by the signal.\r\n * @see {DebouncedSignal} as the output type has the same structure.\r\n */\r\nexport type ThrottledSignal<T> = DebouncedSignal<T>;\r\n\r\n/**\r\n * A convenience function that creates and throttles a new `WritableSignal` in one step.\r\n *\r\n * @see {throttle} for the core implementation details.\r\n *\r\n * @template T The type of value the signal holds.\r\n * @param initial The initial value of the signal.\r\n * @param opt Options for signal creation, including throttle time `ms`.\r\n * @returns A `ThrottledSignal<T>` instance.\r\n *\r\n * @example\r\n * const query = throttled('', { ms: 500 });\r\n * effect(() => console.log('Throttled Query:', query()));\r\n *\r\n * query.set('a');\r\n * query.set('b');\r\n * query.set('c');\r\n * // With a trailing-edge throttle, the final value 'c' would be set\r\n * // after the 500ms cooldown.\r\n */\r\nexport function throttled<T>(\r\n  initial: T,\r\n  opt?: CreateThrottledOptions<T>,\r\n): DebouncedSignal<T> {\r\n  return throttle(signal(initial, opt), opt);\r\n}\r\n\r\n/**\r\n * Wraps an existing `WritableSignal` to create a new one whose readable value is throttled.\r\n *\r\n * This implementation avoids using `effect` by pairing a trigger signal with an `untracked`\r\n * read of the source signal to control when the throttled value is re-evaluated.\r\n *\r\n * @template T The type of value the signal holds.\r\n * @param source The source `WritableSignal` to wrap. Writes are applied to this signal immediately.\r\n * @param opt Options for throttling, including throttle time `ms` and an optional `DestroyRef`.\r\n * @returns A new `ThrottledSignal<T>` whose read value is throttled. The `.original` property\r\n * of the returned signal is a reference back to the provided `source` signal.\r\n *\r\n * @example\r\n * const query = throttled('', { ms: 500 });\r\n * effect(() => console.log('Throttled Query:', query()));\r\n *\r\n * query.set('a');\r\n * query.set('b');\r\n * query.set('c');\r\n * // With a trailing-edge throttle, the final value 'c' would be set\r\n * // after the 500ms cooldown.\r\n */\r\nexport function throttle<T>(\r\n  source: WritableSignal<T>,\r\n  opt?: CreateThrottledOptions<T>,\r\n): ThrottledSignal<T> {\r\n  const ms = opt?.ms ?? 0;\r\n\r\n  const trigger = signal(false);\r\n\r\n  let timeout: ReturnType<typeof setTimeout> | undefined;\r\n\r\n  try {\r\n    const destroyRef =\r\n      opt?.destroyRef ?? inject(DestroyRef, { optional: true });\r\n\r\n    destroyRef?.onDestroy(() => {\r\n      if (timeout) clearTimeout(timeout);\r\n      timeout = undefined;\r\n    });\r\n  } catch {\r\n    // not in injection context & no destroyRef provided opting out of cleanup\r\n  }\r\n\r\n  const triggerFn = (updateSourceAction: () => void) => {\r\n    updateSourceAction();\r\n    if (timeout) return;\r\n\r\n    timeout = setTimeout(() => {\r\n      trigger.update((c) => !c);\r\n      timeout = undefined;\r\n    }, ms);\r\n  };\r\n\r\n  const set = (value: T) => {\r\n    triggerFn(() => source.set(value));\r\n  };\r\n\r\n  const update = (fn: (prev: T) => T) => {\r\n    triggerFn(() => source.update(fn));\r\n  };\r\n\r\n  const writable = toWritable(\r\n    computed(() => {\r\n      trigger();\r\n      return untracked(source);\r\n    }, opt),\r\n    set,\r\n    update,\r\n  ) as ThrottledSignal<T>;\r\n  writable.original = source;\r\n\r\n  return writable;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, ElementRef, inject, isDevMode, PLATFORM_ID, } from '@angular/core';\nimport { throttled } from '../throttled';\n/**\n * Creates a read-only signal that tracks the mouse cursor's position.\n *\n * It can track mouse movements on a specific target (window, document, or element)\n * and optionally include touch movements. The coordinate space ('client' or 'page')\n * can also be configured.\n * The primitive is SSR-safe and automatically cleans up its event listeners.\n *\n * @param options Optional configuration for the sensor.\n * @returns A read-only `Signal<MousePosition>`. On the server, it returns a static\n * signal with `{ x: 0, y: 0 }`.\n *\n * @example\n * ```ts\n * import { Component, effect } from '@angular/core';\n * import { mousePosition } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-mouse-tracker',\n * template: `<p>Mouse Position: X: {{ pos().x }}, Y: {{ pos().y }}</p>`\n * })\n * export class MouseTrackerComponent {\n * readonly pos = mousePosition({ coordinateSpace: 'page' });\n *\n * constructor() {\n * effect(() => {\n * console.log('Mouse moved to:', this.pos());\n * });\n * }\n * }\n * ```\n */\nexport function mousePosition(opt) {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n const base = computed(() => ({\n x: 0,\n y: 0,\n }), {\n debugName: opt?.debugName ?? 'mousePosition',\n });\n base.unthrottled = base;\n return base;\n }\n const { target = window, coordinateSpace = 'client', touch = false, debugName = 'mousePosition', throttle = 100, } = opt ?? {};\n const eventTarget = target instanceof ElementRef ? target.nativeElement : target;\n if (!eventTarget) {\n if (isDevMode())\n console.warn('mousePosition: Target element not found.');\n const base = computed(() => ({\n x: 0,\n y: 0,\n }), {\n debugName,\n });\n base.unthrottled = base;\n return base;\n }\n const pos = throttled({ x: 0, y: 0 }, {\n ms: throttle,\n equal: (a, b) => a.x === b.x && a.y === b.y,\n debugName,\n });\n const updatePosition = (event) => {\n let x, y;\n if (event instanceof MouseEvent) {\n x = coordinateSpace === 'page' ? event.pageX : event.clientX;\n y = coordinateSpace === 'page' ? event.pageY : event.clientY;\n }\n else if (event.touches.length > 0) {\n const firstTouch = event.touches[0];\n x = coordinateSpace === 'page' ? firstTouch.pageX : firstTouch.clientX;\n y = coordinateSpace === 'page' ? firstTouch.pageY : firstTouch.clientY;\n }\n else {\n return;\n }\n pos.set({ x, y });\n };\n eventTarget.addEventListener('mousemove', updatePosition);\n if (touch) {\n eventTarget.addEventListener('touchmove', updatePosition);\n }\n inject(DestroyRef).onDestroy(() => {\n eventTarget.removeEventListener('mousemove', updatePosition);\n if (touch) {\n eventTarget.removeEventListener('touchmove', updatePosition);\n }\n });\n const base = pos.asReadonly();\n base.unthrottled = pos.original;\n return base;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mouse-position.js","sourceRoot":"","sources":["../../../../../../packages/primitives/src/lib/sensors/mouse-position.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common';\r\nimport {\r\n  computed,\r\n  DestroyRef,\r\n  ElementRef,\r\n  inject,\r\n  isDevMode,\r\n  PLATFORM_ID,\r\n  Signal,\r\n} from '@angular/core';\r\nimport { throttled } from '../throttled';\r\n\r\ntype MousePosition = {\r\n  x: number;\r\n  y: number;\r\n};\r\n\r\n/**\r\n * Options for configuring the `mousePosition` sensor.\r\n */\r\nexport type MousePositionOptions = {\r\n  /**\r\n   * The target element to listen for mouse movements on.\r\n   * Can be `window`, `document`, an `HTMLElement`, or an `ElementRef<HTMLElement>`.\r\n   * @default window\r\n   */\r\n  target?: Window | Document | HTMLElement | ElementRef<HTMLElement>;\r\n  /**\r\n   * Defines the coordinate system for the reported position.\r\n   * - `'client'`: Coordinates relative to the viewport (`clientX`, `clientY`).\r\n   * - `'page'`: Coordinates relative to the entire document (`pageX`, `pageY`).\r\n   * @default 'client'\r\n   */\r\n  coordinateSpace?: 'client' | 'page';\r\n  /**\r\n   * If `true`, the sensor will also listen to `touchmove` events and report\r\n   * the coordinates of the first touch point.\r\n   * @default false\r\n   */\r\n  touch?: boolean;\r\n  /**\r\n   * Optional debug name for the internal signal.\r\n   */\r\n  debugName?: string;\r\n  /**\r\n   * Optional delay in milliseconds to throttle the updates.\r\n   * @default 100\r\n   */\r\n  throttle?: number;\r\n};\r\n\r\n/**\r\n * @internal used for setting the since signal\r\n */\r\ntype InternalMousePositionSignal = Signal<MousePosition> & {\r\n  unthrottled: Signal<MousePosition>;\r\n};\r\n\r\n/**\r\n * A specialized Signal that tracks mouse position within an element.\r\n * It's a throttled signal of the mouse coordinates with an attached `unthrottled` signal.\r\n */\r\nexport type MousePositionSignal = Signal<MousePosition> & {\r\n  /** A signal providing the raw, unthrottled mouse position. */\r\n  readonly unthrottled: Signal<MousePosition>;\r\n};\r\n\r\n/**\r\n * Creates a read-only signal that tracks the mouse cursor's position.\r\n *\r\n * It can track mouse movements on a specific target (window, document, or element)\r\n * and optionally include touch movements. The coordinate space ('client' or 'page')\r\n * can also be configured.\r\n * The primitive is SSR-safe and automatically cleans up its event listeners.\r\n *\r\n * @param options Optional configuration for the sensor.\r\n * @returns A read-only `Signal<MousePosition>`. On the server, it returns a static\r\n * signal with `{ x: 0, y: 0 }`.\r\n *\r\n * @example\r\n * ```ts\r\n * import { Component, effect } from '@angular/core';\r\n * import { mousePosition } from '@mmstack/primitives';\r\n *\r\n * @Component({\r\n * selector: 'app-mouse-tracker',\r\n * template: `<p>Mouse Position: X: {{ pos().x }}, Y: {{ pos().y }}</p>`\r\n * })\r\n * export class MouseTrackerComponent {\r\n * readonly pos = mousePosition({ coordinateSpace: 'page' });\r\n *\r\n * constructor() {\r\n * effect(() => {\r\n * console.log('Mouse moved to:', this.pos());\r\n * });\r\n * }\r\n * }\r\n * ```\r\n */\r\nexport function mousePosition(opt?: MousePositionOptions): MousePositionSignal {\r\n  if (isPlatformServer(inject(PLATFORM_ID))) {\r\n    const base = computed(\r\n      () => ({\r\n        x: 0,\r\n        y: 0,\r\n      }),\r\n      {\r\n        debugName: opt?.debugName ?? 'mousePosition',\r\n      },\r\n    ) as InternalMousePositionSignal;\r\n    base.unthrottled = base;\r\n    return base;\r\n  }\r\n\r\n  const {\r\n    target = window,\r\n    coordinateSpace = 'client',\r\n    touch = false,\r\n    debugName = 'mousePosition',\r\n    throttle = 100,\r\n  } = opt ?? {};\r\n\r\n  const eventTarget =\r\n    target instanceof ElementRef ? target.nativeElement : target;\r\n\r\n  if (!eventTarget) {\r\n    if (isDevMode()) console.warn('mousePosition: Target element not found.');\r\n\r\n    const base = computed(\r\n      () => ({\r\n        x: 0,\r\n        y: 0,\r\n      }),\r\n      {\r\n        debugName,\r\n      },\r\n    ) as InternalMousePositionSignal;\r\n    base.unthrottled = base;\r\n    return base;\r\n  }\r\n\r\n  const pos = throttled(\r\n    { x: 0, y: 0 },\r\n    {\r\n      ms: throttle,\r\n      equal: (a, b) => a.x === b.x && a.y === b.y,\r\n      debugName,\r\n    },\r\n  );\r\n\r\n  const updatePosition = (event: MouseEvent | TouchEvent) => {\r\n    let x: number, y: number;\r\n\r\n    if (event instanceof MouseEvent) {\r\n      x = coordinateSpace === 'page' ? event.pageX : event.clientX;\r\n      y = coordinateSpace === 'page' ? event.pageY : event.clientY;\r\n    } else if (event.touches.length > 0) {\r\n      const firstTouch = event.touches[0];\r\n      x = coordinateSpace === 'page' ? firstTouch.pageX : firstTouch.clientX;\r\n      y = coordinateSpace === 'page' ? firstTouch.pageY : firstTouch.clientY;\r\n    } else {\r\n      return;\r\n    }\r\n    pos.set({ x, y });\r\n  };\r\n\r\n  eventTarget.addEventListener('mousemove', updatePosition as EventListener);\r\n  if (touch) {\r\n    eventTarget.addEventListener('touchmove', updatePosition as EventListener);\r\n  }\r\n\r\n  inject(DestroyRef).onDestroy(() => {\r\n    eventTarget.removeEventListener(\r\n      'mousemove',\r\n      updatePosition as EventListener,\r\n    );\r\n    if (touch) {\r\n      eventTarget.removeEventListener(\r\n        'touchmove',\r\n        updatePosition as EventListener,\r\n      );\r\n    }\r\n  });\r\n\r\n  const base = pos.asReadonly() as InternalMousePositionSignal;\r\n  base.unthrottled = pos.original;\r\n  return base;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, inject, PLATFORM_ID, signal, } from '@angular/core';\nconst serverDate = new Date();\n/**\n * Creates a read-only signal that tracks the browser's online status.\n *\n * The main signal returns a boolean (`true` for online, `false` for offline).\n * An additional `since` signal is attached, tracking when the status last changed.\n * It's SSR-safe and automatically cleans up its event listeners.\n *\n * @param debugName Optional debug name for the signal.\n * @returns A `NetworkStatusSignal` instance.\n */\nexport function networkStatus(debugName = 'networkStatus') {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n const sig = computed(() => true, {\n debugName,\n });\n sig.since = computed(() => serverDate, ...(ngDevMode ? [{ debugName: \"since\" }] : []));\n return sig;\n }\n const state = signal(navigator.onLine, ...(ngDevMode ? [{ debugName: \"state\", debugName }] : [{\n debugName,\n }]));\n const since = signal(new Date(), ...(ngDevMode ? [{ debugName: \"since\" }] : []));\n const goOnline = () => {\n state.set(true);\n since.set(new Date());\n };\n const goOffline = () => {\n state.set(false);\n since.set(new Date());\n };\n window.addEventListener('online', goOnline);\n window.addEventListener('offline', goOffline);\n inject(DestroyRef).onDestroy(() => {\n window.removeEventListener('online', goOnline);\n window.removeEventListener('offline', goOffline);\n });\n const sig = state.asReadonly();\n sig.since = since.asReadonly();\n return sig;\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV0d29yay1zdGF0dXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3NyYy9saWIvc2Vuc29ycy9uZXR3b3JrLXN0YXR1cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQ0wsUUFBUSxFQUNSLFVBQVUsRUFDVixNQUFNLEVBQ04sV0FBVyxFQUVYLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQztBQWtCdkIsTUFBTSxVQUFVLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQztBQUU5Qjs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLFVBQVUsYUFBYSxDQUMzQixTQUFTLEdBQUcsZUFBZTtJQUUzQixJQUFJLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDMUMsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksRUFBRTtZQUMvQixTQUFTO1NBQ1YsQ0FBZ0MsQ0FBQztRQUNsQyxHQUFHLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLGlEQUFDLENBQUM7UUFDdkMsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDO0lBRUQsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLHlDQUNuQyxTQUFTLE9BRDRCO1lBQ3JDLFNBQVM7U0FDVixHQUFDLENBQUM7SUFDSCxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsSUFBSSxJQUFJLEVBQUUsaURBQUMsQ0FBQztJQUVqQyxNQUFNLFFBQVEsR0FBRyxHQUFHLEVBQUU7UUFDcEIsS0FBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNoQixLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN4QixDQUFDLENBQUM7SUFDRixNQUFNLFNBQVMsR0FBRyxHQUFHLEVBQUU7UUFDckIsS0FBSyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNqQixLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN4QixDQUFDLENBQUM7SUFFRixNQUFNLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQzVDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFFOUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDaEMsTUFBTSxDQUFDLG1CQUFtQixDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUMvQyxNQUFNLENBQUMsbUJBQW1CLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELENBQUMsQ0FBQyxDQUFDO0lBRUgsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLFVBQVUsRUFBaUMsQ0FBQztJQUM5RCxHQUFHLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUUvQixPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1BsYXRmb3JtU2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHtcclxuICBjb21wdXRlZCxcclxuICBEZXN0cm95UmVmLFxyXG4gIGluamVjdCxcclxuICBQTEFURk9STV9JRCxcclxuICBTaWduYWwsXHJcbiAgc2lnbmFsLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIEBpbnRlcm5hbCB1c2VkIGZvciBzZXR0aW5nIHRoZSBzaW5jZSBzaWduYWxcclxuICovXHJcbnR5cGUgSW50ZXJuYWxOZXR3b3JrU3RhdHVzU2lnbmFsID0gU2lnbmFsPGJvb2xlYW4+ICYge1xyXG4gIHNpbmNlOiBTaWduYWw8RGF0ZT47XHJcbn07XHJcblxyXG4vKipcclxuICogQSBzcGVjaWFsaXplZCBTaWduYWwgdGhhdCB0cmFja3MgbmV0d29yayBzdGF0dXMuXHJcbiAqIEl0J3MgYSBib29sZWFuIHNpZ25hbCB3aXRoIGFuIGF0dGFjaGVkIGBzaW5jZWAgc2lnbmFsLlxyXG4gKi9cclxuZXhwb3J0IHR5cGUgTmV0d29ya1N0YXR1c1NpZ25hbCA9IFNpZ25hbDxib29sZWFuPiAmIHtcclxuICAvKiogQSBzaWduYWwgdHJhY2tpbmcgdGhlIHRpbWVzdGFtcCBvZiB0aGUgbGFzdCBzdGF0dXMgY2hhbmdlLiAqL1xyXG4gIHJlYWRvbmx5IHNpbmNlOiBTaWduYWw8RGF0ZT47XHJcbn07XHJcblxyXG5jb25zdCBzZXJ2ZXJEYXRlID0gbmV3IERhdGUoKTtcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGVzIGEgcmVhZC1vbmx5IHNpZ25hbCB0aGF0IHRyYWNrcyB0aGUgYnJvd3NlcidzIG9ubGluZSBzdGF0dXMuXHJcbiAqXHJcbiAqIFRoZSBtYWluIHNpZ25hbCByZXR1cm5zIGEgYm9vbGVhbiAoYHRydWVgIGZvciBvbmxpbmUsIGBmYWxzZWAgZm9yIG9mZmxpbmUpLlxyXG4gKiBBbiBhZGRpdGlvbmFsIGBzaW5jZWAgc2lnbmFsIGlzIGF0dGFjaGVkLCB0cmFja2luZyB3aGVuIHRoZSBzdGF0dXMgbGFzdCBjaGFuZ2VkLlxyXG4gKiBJdCdzIFNTUi1zYWZlIGFuZCBhdXRvbWF0aWNhbGx5IGNsZWFucyB1cCBpdHMgZXZlbnQgbGlzdGVuZXJzLlxyXG4gKlxyXG4gKiBAcGFyYW0gZGVidWdOYW1lIE9wdGlvbmFsIGRlYnVnIG5hbWUgZm9yIHRoZSBzaWduYWwuXHJcbiAqIEByZXR1cm5zIEEgYE5ldHdvcmtTdGF0dXNTaWduYWxgIGluc3RhbmNlLlxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIG5ldHdvcmtTdGF0dXMoXHJcbiAgZGVidWdOYW1lID0gJ25ldHdvcmtTdGF0dXMnLFxyXG4pOiBOZXR3b3JrU3RhdHVzU2lnbmFsIHtcclxuICBpZiAoaXNQbGF0Zm9ybVNlcnZlcihpbmplY3QoUExBVEZPUk1fSUQpKSkge1xyXG4gICAgY29uc3Qgc2lnID0gY29tcHV0ZWQoKCkgPT4gdHJ1ZSwge1xyXG4gICAgICBkZWJ1Z05hbWUsXHJcbiAgICB9KSBhcyBJbnRlcm5hbE5ldHdvcmtTdGF0dXNTaWduYWw7XHJcbiAgICBzaWcuc2luY2UgPSBjb21wdXRlZCgoKSA9PiBzZXJ2ZXJEYXRlKTtcclxuICAgIHJldHVybiBzaWc7XHJcbiAgfVxyXG5cclxuICBjb25zdCBzdGF0ZSA9IHNpZ25hbChuYXZpZ2F0b3Iub25MaW5lLCB7XHJcbiAgICBkZWJ1Z05hbWUsXHJcbiAgfSk7XHJcbiAgY29uc3Qgc2luY2UgPSBzaWduYWwobmV3IERhdGUoKSk7XHJcblxyXG4gIGNvbnN0IGdvT25saW5lID0gKCkgPT4ge1xyXG4gICAgc3RhdGUuc2V0KHRydWUpO1xyXG4gICAgc2luY2Uuc2V0KG5ldyBEYXRlKCkpO1xyXG4gIH07XHJcbiAgY29uc3QgZ29PZmZsaW5lID0gKCkgPT4ge1xyXG4gICAgc3RhdGUuc2V0KGZhbHNlKTtcclxuICAgIHNpbmNlLnNldChuZXcgRGF0ZSgpKTtcclxuICB9O1xyXG5cclxuICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcignb25saW5lJywgZ29PbmxpbmUpO1xyXG4gIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdvZmZsaW5lJywgZ29PZmZsaW5lKTtcclxuXHJcbiAgaW5qZWN0KERlc3Ryb3lSZWYpLm9uRGVzdHJveSgoKSA9PiB7XHJcbiAgICB3aW5kb3cucmVtb3ZlRXZlbnRMaXN0ZW5lcignb25saW5lJywgZ29PbmxpbmUpO1xyXG4gICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ29mZmxpbmUnLCBnb09mZmxpbmUpO1xyXG4gIH0pO1xyXG5cclxuICBjb25zdCBzaWcgPSBzdGF0ZS5hc1JlYWRvbmx5KCkgYXMgSW50ZXJuYWxOZXR3b3JrU3RhdHVzU2lnbmFsO1xyXG4gIHNpZy5zaW5jZSA9IHNpbmNlLmFzUmVhZG9ubHkoKTtcclxuXHJcbiAgcmV0dXJuIHNpZztcclxufVxyXG4iXX0=","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, inject, PLATFORM_ID, signal, } from '@angular/core';\n/**\n * Creates a read-only signal that tracks the page's visibility state.\n *\n * It uses the browser's Page Visibility API to reactively report if the\n * current document is `'visible'`, `'hidden'`, or in another state.\n * The primitive is SSR-safe and automatically cleans up its event listeners\n * when the creating context is destroyed.\n *\n * @param debugName Optional debug name for the signal.\n * @returns A read-only `Signal<DocumentVisibilityState>`. On the server,\n * it returns a static signal with a value of `'visible'`.\n *\n * @example\n * ```ts\n * import { Component, effect } from '@angular/core';\n * import { pageVisibility } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-visibility-tracker',\n * template: `<p>Page is currently: {{ visibilityState() }}</p>`\n * })\n * export class VisibilityTrackerComponent {\n * readonly visibilityState = pageVisibility();\n *\n * constructor() {\n * effect(() => {\n * if (this.visibilityState() === 'hidden') {\n * console.log('Page is hidden, pausing expensive animations...');\n * } else {\n * console.log('Page is visible, resuming activity.');\n * }\n * });\n * }\n * }\n * ```\n */\nexport function pageVisibility(debugName = 'pageVisibility') {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n return computed(() => 'visible', { debugName });\n }\n const visibility = signal(document.visibilityState, ...(ngDevMode ? [{ debugName: \"visibility\", debugName }] : [{ debugName }]));\n const onVisibilityChange = () => visibility.set(document.visibilityState);\n document.addEventListener('visibilitychange', onVisibilityChange);\n inject(DestroyRef).onDestroy(() => document.removeEventListener('visibilitychange', onVisibilityChange));\n return visibility.asReadonly();\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS12aXNpYmlsaXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9zcmMvbGliL3NlbnNvcnMvcGFnZS12aXNpYmlsaXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sRUFDTCxRQUFRLEVBQ1IsVUFBVSxFQUNWLE1BQU0sRUFDTixXQUFXLEVBRVgsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBRXZCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW1DRztBQUNILE1BQU0sVUFBVSxjQUFjLENBQzVCLFNBQVMsR0FBRyxnQkFBZ0I7SUFFNUIsSUFBSSxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQzFDLE9BQU8sUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLFNBQVMsRUFBRSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVELE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsZUFBZSw4Q0FBSSxTQUFTLE9BQVgsRUFBRSxTQUFTLEVBQUUsR0FBQyxDQUFDO0lBRW5FLE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLENBQUM7SUFFMUUsUUFBUSxDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixFQUFFLGtCQUFrQixDQUFDLENBQUM7SUFFbEUsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FDaEMsUUFBUSxDQUFDLG1CQUFtQixDQUFDLGtCQUFrQixFQUFFLGtCQUFrQixDQUFDLENBQ3JFLENBQUM7SUFFRixPQUFPLFVBQVUsQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUNqQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNQbGF0Zm9ybVNlcnZlciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7XHJcbiAgY29tcHV0ZWQsXHJcbiAgRGVzdHJveVJlZixcclxuICBpbmplY3QsXHJcbiAgUExBVEZPUk1fSUQsXHJcbiAgU2lnbmFsLFxyXG4gIHNpZ25hbCxcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGVzIGEgcmVhZC1vbmx5IHNpZ25hbCB0aGF0IHRyYWNrcyB0aGUgcGFnZSdzIHZpc2liaWxpdHkgc3RhdGUuXHJcbiAqXHJcbiAqIEl0IHVzZXMgdGhlIGJyb3dzZXIncyBQYWdlIFZpc2liaWxpdHkgQVBJIHRvIHJlYWN0aXZlbHkgcmVwb3J0IGlmIHRoZVxyXG4gKiBjdXJyZW50IGRvY3VtZW50IGlzIGAndmlzaWJsZSdgLCBgJ2hpZGRlbidgLCBvciBpbiBhbm90aGVyIHN0YXRlLlxyXG4gKiBUaGUgcHJpbWl0aXZlIGlzIFNTUi1zYWZlIGFuZCBhdXRvbWF0aWNhbGx5IGNsZWFucyB1cCBpdHMgZXZlbnQgbGlzdGVuZXJzXHJcbiAqIHdoZW4gdGhlIGNyZWF0aW5nIGNvbnRleHQgaXMgZGVzdHJveWVkLlxyXG4gKlxyXG4gKiBAcGFyYW0gZGVidWdOYW1lIE9wdGlvbmFsIGRlYnVnIG5hbWUgZm9yIHRoZSBzaWduYWwuXHJcbiAqIEByZXR1cm5zIEEgcmVhZC1vbmx5IGBTaWduYWw8RG9jdW1lbnRWaXNpYmlsaXR5U3RhdGU+YC4gT24gdGhlIHNlcnZlcixcclxuICogaXQgcmV0dXJucyBhIHN0YXRpYyBzaWduYWwgd2l0aCBhIHZhbHVlIG9mIGAndmlzaWJsZSdgLlxyXG4gKlxyXG4gKiBAZXhhbXBsZVxyXG4gKiBgYGB0c1xyXG4gKiBpbXBvcnQgeyBDb21wb25lbnQsIGVmZmVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG4gKiBpbXBvcnQgeyBwYWdlVmlzaWJpbGl0eSB9IGZyb20gJ0BtbXN0YWNrL3ByaW1pdGl2ZXMnO1xyXG4gKlxyXG4gKiBAQ29tcG9uZW50KHtcclxuICogc2VsZWN0b3I6ICdhcHAtdmlzaWJpbGl0eS10cmFja2VyJyxcclxuICogdGVtcGxhdGU6IGA8cD5QYWdlIGlzIGN1cnJlbnRseToge3sgdmlzaWJpbGl0eVN0YXRlKCkgfX08L3A+YFxyXG4gKiB9KVxyXG4gKiBleHBvcnQgY2xhc3MgVmlzaWJpbGl0eVRyYWNrZXJDb21wb25lbnQge1xyXG4gKiByZWFkb25seSB2aXNpYmlsaXR5U3RhdGUgPSBwYWdlVmlzaWJpbGl0eSgpO1xyXG4gKlxyXG4gKiBjb25zdHJ1Y3RvcigpIHtcclxuICogZWZmZWN0KCgpID0+IHtcclxuICogaWYgKHRoaXMudmlzaWJpbGl0eVN0YXRlKCkgPT09ICdoaWRkZW4nKSB7XHJcbiAqIGNvbnNvbGUubG9nKCdQYWdlIGlzIGhpZGRlbiwgcGF1c2luZyBleHBlbnNpdmUgYW5pbWF0aW9ucy4uLicpO1xyXG4gKiB9IGVsc2Uge1xyXG4gKiBjb25zb2xlLmxvZygnUGFnZSBpcyB2aXNpYmxlLCByZXN1bWluZyBhY3Rpdml0eS4nKTtcclxuICogfVxyXG4gKiB9KTtcclxuICogfVxyXG4gKiB9XHJcbiAqIGBgYFxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIHBhZ2VWaXNpYmlsaXR5KFxyXG4gIGRlYnVnTmFtZSA9ICdwYWdlVmlzaWJpbGl0eScsXHJcbik6IFNpZ25hbDxEb2N1bWVudFZpc2liaWxpdHlTdGF0ZT4ge1xyXG4gIGlmIChpc1BsYXRmb3JtU2VydmVyKGluamVjdChQTEFURk9STV9JRCkpKSB7XHJcbiAgICByZXR1cm4gY29tcHV0ZWQoKCkgPT4gJ3Zpc2libGUnLCB7IGRlYnVnTmFtZSB9KTtcclxuICB9XHJcblxyXG4gIGNvbnN0IHZpc2liaWxpdHkgPSBzaWduYWwoZG9jdW1lbnQudmlzaWJpbGl0eVN0YXRlLCB7IGRlYnVnTmFtZSB9KTtcclxuXHJcbiAgY29uc3Qgb25WaXNpYmlsaXR5Q2hhbmdlID0gKCkgPT4gdmlzaWJpbGl0eS5zZXQoZG9jdW1lbnQudmlzaWJpbGl0eVN0YXRlKTtcclxuXHJcbiAgZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcigndmlzaWJpbGl0eWNoYW5nZScsIG9uVmlzaWJpbGl0eUNoYW5nZSk7XHJcblxyXG4gIGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT5cclxuICAgIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3Zpc2liaWxpdHljaGFuZ2UnLCBvblZpc2liaWxpdHlDaGFuZ2UpLFxyXG4gICk7XHJcblxyXG4gIHJldHVybiB2aXNpYmlsaXR5LmFzUmVhZG9ubHkoKTtcclxufVxyXG4iXX0=","import { isPlatformServer } from '@angular/common'; // Corrected import\nimport { computed, DestroyRef, ElementRef, inject, PLATFORM_ID, // Used for SSR fallback\n } from '@angular/core';\nimport { throttled } from '../throttled';\n/**\n * Creates a read-only signal that tracks the scroll position (x, y) of the window\n * or a specified HTML element.\n *\n * Updates are throttled by default to optimize performance. An `unthrottled`\n * property is available on the returned signal for direct access to raw updates.\n * The primitive is SSR-safe and automatically cleans up its event listeners.\n *\n * @param options Optional configuration for the scroll sensor.\n * @returns A `ScrollPositionSignal`. On the server, it returns a static\n * signal with `{ x: 0, y: 0 }`.\n *\n * @example\n * ```ts\n * import { Component, effect, ElementRef, viewChild } from '@angular/core';\n * import { scrollPosition } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-scroll-tracker',\n * template: `\n * <p>Window Scroll: X: {{ windowScroll().x }}, Y: {{ windowScroll().y }}</p>\n * <div #scrollableDiv style=\"height: 200px; width: 200px; overflow: auto; border: 1px solid black;\">\n * <div style=\"height: 400px; width: 400px;\">Scroll me!</div>\n * </div>\n * @if (divScroll()) {\n * <p>Div Scroll: X: {{ divScroll().x }}, Y: {{ divScroll().y }}</p>\n * }\n * `\n * })\n * export class ScrollTrackerComponent {\n * readonly windowScroll = scrollPosition(); // Defaults to window\n * readonly scrollableDiv = viewChild<ElementRef<HTMLDivElement>>('scrollableDiv');\n * readonly divScroll = scrollPosition({ target: this.scrollableDiv() }); // Example with element target\n *\n * constructor() {\n * effect(() => {\n * console.log('Window scrolled to:', this.windowScroll());\n * if (this.divScroll()) {\n * console.log('Div scrolled to:', this.divScroll());\n * }\n * });\n * }\n * }\n * ```\n */\nexport function scrollPosition(opt) {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n const base = computed(() => ({\n x: 0,\n y: 0,\n }), {\n debugName: opt?.debugName ?? 'scrollPosition',\n });\n base.unthrottled = base;\n return base;\n }\n const { target = window, throttle = 100, debugName = 'scrollPosition', } = opt || {};\n let element;\n let getScrollPosition;\n if (target instanceof Window) {\n element = target;\n getScrollPosition = () => {\n return { x: target.scrollX, y: target.scrollY };\n };\n }\n else if (target instanceof ElementRef) {\n element = target.nativeElement;\n getScrollPosition = () => {\n return {\n x: target.nativeElement.scrollLeft,\n y: target.nativeElement.scrollTop,\n };\n };\n }\n else {\n element = target;\n getScrollPosition = () => {\n return {\n x: target.scrollLeft,\n y: target.scrollTop,\n };\n };\n }\n const state = throttled(getScrollPosition(), {\n debugName,\n equal: (a, b) => a.x === b.x && a.y === b.y,\n ms: throttle,\n });\n const onScroll = () => state.set(getScrollPosition());\n element.addEventListener('scroll', onScroll, { passive: true });\n inject(DestroyRef).onDestroy(() => element.removeEventListener('scroll', onScroll));\n const base = state.asReadonly();\n base.unthrottled = state.original;\n return base;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroll-position.js","sourceRoot":"","sources":["../../../../../../packages/primitives/src/lib/sensors/scroll-position.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC,CAAC,mBAAmB;AACvE,OAAO,EACL,QAAQ,EACR,UAAU,EACV,UAAU,EACV,MAAM,EACN,WAAW,EAAE,wBAAwB;EAEtC,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAgDzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CG;AACH,MAAM,UAAU,cAAc,CAC5B,GAA2B;IAE3B,IAAI,gBAAgB,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC;QAC1C,MAAM,IAAI,GAAG,QAAQ,CACnB,GAAG,EAAE,CAAC,CAAC;YACL,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;SACL,CAAC,EACF;YACE,SAAS,EAAE,GAAG,EAAE,SAAS,IAAI,gBAAgB;SAC9C,CAC8B,CAAC;QAClC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,EACJ,MAAM,GAAG,MAAM,EACf,QAAQ,GAAG,GAAG,EACd,SAAS,GAAG,gBAAgB,GAC7B,GAAG,GAAG,IAAI,EAAE,CAAC;IAEd,IAAI,OAA6B,CAAC;IAElC,IAAI,iBAAuC,CAAC;IAE5C,IAAI,MAAM,YAAY,MAAM,EAAE,CAAC;QAC7B,OAAO,GAAG,MAAM,CAAC;QAEjB,iBAAiB,GAAG,GAAG,EAAE;YACvB,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC;QAClD,CAAC,CAAC;IACJ,CAAC;SAAM,IAAI,MAAM,YAAY,UAAU,EAAE,CAAC;QACxC,OAAO,GAAG,MAAM,CAAC,aAAa,CAAC;QAC/B,iBAAiB,GAAG,GAAG,EAAE;YACvB,OAAO;gBACL,CAAC,EAAE,MAAM,CAAC,aAAa,CAAC,UAAU;gBAClC,CAAC,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS;aAClC,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;SAAM,CAAC;QACN,OAAO,GAAG,MAAM,CAAC;QACjB,iBAAiB,GAAG,GAAG,EAAE;YACvB,OAAO;gBACL,CAAC,EAAE,MAAM,CAAC,UAAU;gBACpB,CAAC,EAAE,MAAM,CAAC,SAAS;aACpB,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,GAAG,SAAS,CAAiB,iBAAiB,EAAE,EAAE;QAC3D,SAAS;QACT,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3C,EAAE,EAAE,QAAQ;KACb,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,iBAAiB,EAAE,CAAC,CAAC;IACtD,OAAO,CAAC,gBAAgB,CAAC,QAAQ,EAAE,QAAQ,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IAEhE,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAChC,OAAO,CAAC,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAChD,CAAC;IAEF,MAAM,IAAI,GAAG,KAAK,CAAC,UAAU,EAAkC,CAAC;IAChE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,QAAQ,CAAC;IAClC,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["import { isPlatformServer } from '@angular/common'; // Corrected import\r\nimport {\r\n  computed,\r\n  DestroyRef,\r\n  ElementRef,\r\n  inject,\r\n  PLATFORM_ID, // Used for SSR fallback\r\n  type Signal,\r\n} from '@angular/core';\r\nimport { throttled } from '../throttled';\r\n\r\n/**\r\n * Represents the scroll position.\r\n */\r\nexport type ScrollPosition = {\r\n  /** The horizontal scroll position (pixels from the left). */\r\n  readonly x: number;\r\n  /** The vertical scroll position (pixels from the top). */\r\n  readonly y: number;\r\n};\r\n\r\n/**\r\n * Options for configuring the `scrollPosition` sensor.\r\n */\r\nexport type ScrollPositionOptions = {\r\n  /**\r\n   * The target to listen for scroll events on.\r\n   * Can be `window` (for page scroll) or an `HTMLElement`/`ElementRef<HTMLElement>`.\r\n   * @default window\r\n   */\r\n  target?: Window | HTMLElement | ElementRef<HTMLElement>;\r\n  /**\r\n   * Optional delay in milliseconds to throttle the updates.\r\n   * Scroll events can fire very rapidly.\r\n   * @default 100 // A common default for scroll throttling\r\n   */\r\n  throttle?: number;\r\n  /** Optional debug name for the internal signal. */\r\n  debugName?: string;\r\n};\r\n\r\n/**\r\n * @internal used for setting the unthrottled signal\r\n */\r\ntype InternalScrollPositionSignal = Signal<ScrollPosition> & {\r\n  unthrottled: Signal<ScrollPosition>;\r\n};\r\n\r\n/**\r\n * A specialized Signal that tracks scroll position.\r\n * It's a throttled signal of the scroll coordinates with an attached `unthrottled` signal.\r\n */\r\nexport type ScrollPositionSignal = Signal<ScrollPosition> & {\r\n  /** A signal providing the raw, unthrottled scroll position. */\r\n  readonly unthrottled: Signal<ScrollPosition>;\r\n};\r\n\r\n/**\r\n * Creates a read-only signal that tracks the scroll position (x, y) of the window\r\n * or a specified HTML element.\r\n *\r\n * Updates are throttled by default to optimize performance. An `unthrottled`\r\n * property is available on the returned signal for direct access to raw updates.\r\n * The primitive is SSR-safe and automatically cleans up its event listeners.\r\n *\r\n * @param options Optional configuration for the scroll sensor.\r\n * @returns A `ScrollPositionSignal`. On the server, it returns a static\r\n * signal with `{ x: 0, y: 0 }`.\r\n *\r\n * @example\r\n * ```ts\r\n * import { Component, effect, ElementRef, viewChild } from '@angular/core';\r\n * import { scrollPosition } from '@mmstack/primitives';\r\n *\r\n * @Component({\r\n * selector: 'app-scroll-tracker',\r\n * template: `\r\n * <p>Window Scroll: X: {{ windowScroll().x }}, Y: {{ windowScroll().y }}</p>\r\n * <div #scrollableDiv style=\"height: 200px; width: 200px; overflow: auto; border: 1px solid black;\">\r\n * <div style=\"height: 400px; width: 400px;\">Scroll me!</div>\r\n * </div>\r\n * @if (divScroll()) {\r\n * <p>Div Scroll: X: {{ divScroll().x }}, Y: {{ divScroll().y }}</p>\r\n * }\r\n * `\r\n * })\r\n * export class ScrollTrackerComponent {\r\n * readonly windowScroll = scrollPosition(); // Defaults to window\r\n * readonly scrollableDiv = viewChild<ElementRef<HTMLDivElement>>('scrollableDiv');\r\n * readonly divScroll = scrollPosition({ target: this.scrollableDiv() }); // Example with element target\r\n *\r\n * constructor() {\r\n * effect(() => {\r\n * console.log('Window scrolled to:', this.windowScroll());\r\n * if (this.divScroll()) {\r\n * console.log('Div scrolled to:', this.divScroll());\r\n * }\r\n * });\r\n * }\r\n * }\r\n * ```\r\n */\r\nexport function scrollPosition(\r\n  opt?: ScrollPositionOptions,\r\n): ScrollPositionSignal {\r\n  if (isPlatformServer(inject(PLATFORM_ID))) {\r\n    const base = computed(\r\n      () => ({\r\n        x: 0,\r\n        y: 0,\r\n      }),\r\n      {\r\n        debugName: opt?.debugName ?? 'scrollPosition',\r\n      },\r\n    ) as InternalScrollPositionSignal;\r\n    base.unthrottled = base;\r\n    return base;\r\n  }\r\n\r\n  const {\r\n    target = window,\r\n    throttle = 100,\r\n    debugName = 'scrollPosition',\r\n  } = opt || {};\r\n\r\n  let element: Window | HTMLElement;\r\n\r\n  let getScrollPosition: () => ScrollPosition;\r\n\r\n  if (target instanceof Window) {\r\n    element = target;\r\n\r\n    getScrollPosition = () => {\r\n      return { x: target.scrollX, y: target.scrollY };\r\n    };\r\n  } else if (target instanceof ElementRef) {\r\n    element = target.nativeElement;\r\n    getScrollPosition = () => {\r\n      return {\r\n        x: target.nativeElement.scrollLeft,\r\n        y: target.nativeElement.scrollTop,\r\n      };\r\n    };\r\n  } else {\r\n    element = target;\r\n    getScrollPosition = () => {\r\n      return {\r\n        x: target.scrollLeft,\r\n        y: target.scrollTop,\r\n      };\r\n    };\r\n  }\r\n\r\n  const state = throttled<ScrollPosition>(getScrollPosition(), {\r\n    debugName,\r\n    equal: (a, b) => a.x === b.x && a.y === b.y,\r\n    ms: throttle,\r\n  });\r\n\r\n  const onScroll = () => state.set(getScrollPosition());\r\n  element.addEventListener('scroll', onScroll, { passive: true });\r\n\r\n  inject(DestroyRef).onDestroy(() =>\r\n    element.removeEventListener('scroll', onScroll),\r\n  );\r\n\r\n  const base = state.asReadonly() as InternalScrollPositionSignal;\r\n  base.unthrottled = state.original;\r\n  return base;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, inject, PLATFORM_ID, } from '@angular/core';\nimport { throttled } from '../throttled';\n/**\n * Creates a read-only signal that tracks the browser window's inner dimensions (width and height).\n *\n * Updates are throttled by default (100ms) to optimize performance during resize events.\n * An `unthrottled` property is available on the returned signal for direct access to raw updates.\n * The primitive is SSR-safe (returns a default size on the server) and automatically\n * cleans up its event listeners.\n *\n * @param opt Optional configuration, including `throttle` (ms) and `debugName`.\n * @returns A `WindowSizeSignal` (a `Signal<WindowSize>` with an `unthrottled` property).\n *\n * @example\n * ```ts\n * import { Component, effect } from '@angular/core';\n * import { windowSize } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-responsive-header',\n * template: `\n * <header>\n * Current Window Size: {{ size().width }}px x {{ size().height }}px\n * @if (isMobile()) {\n * <p>Mobile Menu</p>\n * } @else {\n * <p>Desktop Menu</p>\n * }\n * </header>\n * `\n * })\n * export class ResponsiveHeaderComponent {\n * readonly size = windowSize();\n * readonly isMobile = computed(() => this.size().width < 768);\n *\n * constructor() {\n * effect(() => {\n * console.log('Window resized to:', this.size());\n * });\n * }\n * }\n * ```\n */\nexport function windowSize(opt) {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n const base = computed(() => ({\n width: 1024,\n height: 768,\n }), { debugName: opt?.debugName ?? 'windowSize' });\n base.unthrottled = base;\n return base;\n }\n const sizeSignal = throttled({ width: window.innerWidth, height: window.innerHeight }, {\n debugName: opt?.debugName ?? 'windowSize',\n equal: (a, b) => a.width === b.width && a.height === b.height,\n ms: opt?.throttle ?? 100,\n });\n const onResize = () => {\n sizeSignal.set({ width: window.innerWidth, height: window.innerHeight });\n };\n window.addEventListener('resize', onResize);\n inject(DestroyRef).onDestroy(() => {\n window.removeEventListener('resize', onResize);\n });\n const base = sizeSignal.asReadonly();\n base.unthrottled = sizeSignal.original;\n return base;\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2luZG93LXNpemUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3NyYy9saWIvc2Vuc29ycy93aW5kb3ctc2l6ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQ0wsUUFBUSxFQUNSLFVBQVUsRUFDVixNQUFNLEVBQ04sV0FBVyxHQUVaLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxjQUFjLENBQUM7QUE0Q3pDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBd0NHO0FBQ0gsTUFBTSxVQUFVLFVBQVUsQ0FBQyxHQUF1QjtJQUNoRCxJQUFJLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDMUMsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUNuQixHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQ0wsS0FBSyxFQUFFLElBQUk7WUFDWCxNQUFNLEVBQUUsR0FBRztTQUNaLENBQUMsRUFDRixFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsU0FBUyxJQUFJLFlBQVksRUFBRSxDQUNsQixDQUFDO1FBRTlCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELE1BQU0sVUFBVSxHQUFHLFNBQVMsQ0FDMUIsRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxDQUFDLFdBQVcsRUFBRSxFQUN4RDtRQUNFLFNBQVMsRUFBRSxHQUFHLEVBQUUsU0FBUyxJQUFJLFlBQVk7UUFDekMsS0FBSyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEtBQUssS0FBSyxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLE1BQU07UUFDN0QsRUFBRSxFQUFFLEdBQUcsRUFBRSxRQUFRLElBQUksR0FBRztLQUN6QixDQUNGLENBQUM7SUFFRixNQUFNLFFBQVEsR0FBRyxHQUFHLEVBQUU7UUFDcEIsVUFBVSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUMzRSxDQUFDLENBQUM7SUFFRixNQUFNLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBRTVDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ2hDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDakQsQ0FBQyxDQUFDLENBQUM7SUFFSCxNQUFNLElBQUksR0FBRyxVQUFVLENBQUMsVUFBVSxFQUE4QixDQUFDO0lBQ2pFLElBQUksQ0FBQyxXQUFXLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQztJQUN2QyxPQUFPLElBQUksQ0FBQztBQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1BsYXRmb3JtU2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHtcclxuICBjb21wdXRlZCxcclxuICBEZXN0cm95UmVmLFxyXG4gIGluamVjdCxcclxuICBQTEFURk9STV9JRCxcclxuICBTaWduYWwsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IHRocm90dGxlZCB9IGZyb20gJy4uL3Rocm90dGxlZCc7XHJcblxyXG4vKipcclxuICogUmVwcmVzZW50cyB0aGUgZGltZW5zaW9ucyBvZiB0aGUgd2luZG93LlxyXG4gKi9cclxuZXhwb3J0IHR5cGUgV2luZG93U2l6ZSA9IHtcclxuICAvKiogVGhlIGN1cnJlbnQgaW5uZXIgd2lkdGggb2YgdGhlIHdpbmRvdyBpbiBwaXhlbHMuICovXHJcbiAgcmVhZG9ubHkgd2lkdGg6IG51bWJlcjtcclxuICAvKiogVGhlIGN1cnJlbnQgaW5uZXIgaGVpZ2h0IG9mIHRoZSB3aW5kb3cgaW4gcGl4ZWxzLiAqL1xyXG4gIHJlYWRvbmx5IGhlaWdodDogbnVtYmVyO1xyXG59O1xyXG5cclxuLyoqXHJcbiAqIE9wdGlvbnMgZm9yIGNvbmZpZ3VyaW5nIHRoZSBgbW91c2VQb3NpdGlvbmAgc2Vuc29yLlxyXG4gKi9cclxuZXhwb3J0IHR5cGUgV2luZG93U2l6ZU9wdGlvbnMgPSB7XHJcbiAgLyoqXHJcbiAgICogT3B0aW9uYWwgZGVidWcgbmFtZSBmb3IgdGhlIGludGVybmFsIHNpZ25hbC5cclxuICAgKi9cclxuICBkZWJ1Z05hbWU/OiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogT3B0aW9uYWwgZGVsYXkgaW4gbWlsbGlzZWNvbmRzIHRvIHRocm90dGxlIHRoZSB1cGRhdGVzLlxyXG4gICAqIEBkZWZhdWx0IDEwMFxyXG4gICAqL1xyXG4gIHRocm90dGxlPzogbnVtYmVyO1xyXG59O1xyXG5cclxuLyoqXHJcbiAqIEBpbnRlcm5hbCB1c2VkIGZvciBzZXR0aW5nIHRoZSBzaW5jZSBzaWduYWxcclxuICovXHJcbnR5cGUgSW50ZXJuYWxXaW5kb3dTaXplU2lnbmFsID0gU2lnbmFsPFdpbmRvd1NpemU+ICYge1xyXG4gIHVudGhyb3R0bGVkOiBTaWduYWw8V2luZG93U2l6ZT47XHJcbn07XHJcblxyXG4vKipcclxuICogQSBzcGVjaWFsaXplZCBTaWduYWwgdGhhdCB0cmFja3Mgd2luZG93IHNpemUuXHJcbiAqIEl0J3MgYSB0aHJvdHRsZWQgc2lnbmFsIG9mIHRoZSB3aW5kb3cuaW5uZXJIZWlnaHQvaW5uZXJXaWR0aCBwcm9wZXJ0aWVzXHJcbiAqIHdpdGggYW4gYXR0YWNoZWQgYHVudGhyb3R0bGVkYCBzaWduYWwuXHJcbiAqL1xyXG5leHBvcnQgdHlwZSBXaW5kb3dTaXplU2lnbmFsID0gU2lnbmFsPFdpbmRvd1NpemU+ICYge1xyXG4gIC8qKiBBIHNpZ25hbCBwcm92aWRpbmcgdGhlIHJhdywgdW50aHJvdHRsZWQgd2luZG93IHNpemUuICovXHJcbiAgcmVhZG9ubHkgdW50aHJvdHRsZWQ6IFNpZ25hbDxXaW5kb3dTaXplPjtcclxufTtcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGVzIGEgcmVhZC1vbmx5IHNpZ25hbCB0aGF0IHRyYWNrcyB0aGUgYnJvd3NlciB3aW5kb3cncyBpbm5lciBkaW1lbnNpb25zICh3aWR0aCBhbmQgaGVpZ2h0KS5cclxuICpcclxuICogVXBkYXRlcyBhcmUgdGhyb3R0bGVkIGJ5IGRlZmF1bHQgKDEwMG1zKSB0byBvcHRpbWl6ZSBwZXJmb3JtYW5jZSBkdXJpbmcgcmVzaXplIGV2ZW50cy5cclxuICogQW4gYHVudGhyb3R0bGVkYCBwcm9wZXJ0eSBpcyBhdmFpbGFibGUgb24gdGhlIHJldHVybmVkIHNpZ25hbCBmb3IgZGlyZWN0IGFjY2VzcyB0byByYXcgdXBkYXRlcy5cclxuICogVGhlIHByaW1pdGl2ZSBpcyBTU1Itc2FmZSAocmV0dXJucyBhIGRlZmF1bHQgc2l6ZSBvbiB0aGUgc2VydmVyKSBhbmQgYXV0b21hdGljYWxseVxyXG4gKiBjbGVhbnMgdXAgaXRzIGV2ZW50IGxpc3RlbmVycy5cclxuICpcclxuICogQHBhcmFtIG9wdCBPcHRpb25hbCBjb25maWd1cmF0aW9uLCBpbmNsdWRpbmcgYHRocm90dGxlYCAobXMpIGFuZCBgZGVidWdOYW1lYC5cclxuICogQHJldHVybnMgQSBgV2luZG93U2l6ZVNpZ25hbGAgKGEgYFNpZ25hbDxXaW5kb3dTaXplPmAgd2l0aCBhbiBgdW50aHJvdHRsZWRgIHByb3BlcnR5KS5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogYGBgdHNcclxuICogaW1wb3J0IHsgQ29tcG9uZW50LCBlZmZlY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuICogaW1wb3J0IHsgd2luZG93U2l6ZSB9IGZyb20gJ0BtbXN0YWNrL3ByaW1pdGl2ZXMnO1xyXG4gKlxyXG4gKiBAQ29tcG9uZW50KHtcclxuICogc2VsZWN0b3I6ICdhcHAtcmVzcG9uc2l2ZS1oZWFkZXInLFxyXG4gKiB0ZW1wbGF0ZTogYFxyXG4gKiA8aGVhZGVyPlxyXG4gKiBDdXJyZW50IFdpbmRvdyBTaXplOiB7eyBzaXplKCkud2lkdGggfX1weCB4IHt7IHNpemUoKS5oZWlnaHQgfX1weFxyXG4gKiBAaWYgKGlzTW9iaWxlKCkpIHtcclxuICogPHA+TW9iaWxlIE1lbnU8L3A+XHJcbiAqIH0gQGVsc2Uge1xyXG4gKiA8cD5EZXNrdG9wIE1lbnU8L3A+XHJcbiAqIH1cclxuICogPC9oZWFkZXI+XHJcbiAqIGBcclxuICogfSlcclxuICogZXhwb3J0IGNsYXNzIFJlc3BvbnNpdmVIZWFkZXJDb21wb25lbnQge1xyXG4gKiByZWFkb25seSBzaXplID0gd2luZG93U2l6ZSgpO1xyXG4gKiByZWFkb25seSBpc01vYmlsZSA9IGNvbXB1dGVkKCgpID0+IHRoaXMuc2l6ZSgpLndpZHRoIDwgNzY4KTtcclxuICpcclxuICogY29uc3RydWN0b3IoKSB7XHJcbiAqIGVmZmVjdCgoKSA9PiB7XHJcbiAqIGNvbnNvbGUubG9nKCdXaW5kb3cgcmVzaXplZCB0bzonLCB0aGlzLnNpemUoKSk7XHJcbiAqIH0pO1xyXG4gKiB9XHJcbiAqIH1cclxuICogYGBgXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gd2luZG93U2l6ZShvcHQ/OiBXaW5kb3dTaXplT3B0aW9ucyk6IFdpbmRvd1NpemVTaWduYWwge1xyXG4gIGlmIChpc1BsYXRmb3JtU2VydmVyKGluamVjdChQTEFURk9STV9JRCkpKSB7XHJcbiAgICBjb25zdCBiYXNlID0gY29tcHV0ZWQoXHJcbiAgICAgICgpID0+ICh7XHJcbiAgICAgICAgd2lkdGg6IDEwMjQsXHJcbiAgICAgICAgaGVpZ2h0OiA3NjgsXHJcbiAgICAgIH0pLFxyXG4gICAgICB7IGRlYnVnTmFtZTogb3B0Py5kZWJ1Z05hbWUgPz8gJ3dpbmRvd1NpemUnIH0sXHJcbiAgICApIGFzIEludGVybmFsV2luZG93U2l6ZVNpZ25hbDtcclxuXHJcbiAgICBiYXNlLnVudGhyb3R0bGVkID0gYmFzZTtcclxuICAgIHJldHVybiBiYXNlO1xyXG4gIH1cclxuXHJcbiAgY29uc3Qgc2l6ZVNpZ25hbCA9IHRocm90dGxlZDxXaW5kb3dTaXplPihcclxuICAgIHsgd2lkdGg6IHdpbmRvdy5pbm5lcldpZHRoLCBoZWlnaHQ6IHdpbmRvdy5pbm5lckhlaWdodCB9LFxyXG4gICAge1xyXG4gICAgICBkZWJ1Z05hbWU6IG9wdD8uZGVidWdOYW1lID8/ICd3aW5kb3dTaXplJyxcclxuICAgICAgZXF1YWw6IChhLCBiKSA9PiBhLndpZHRoID09PSBiLndpZHRoICYmIGEuaGVpZ2h0ID09PSBiLmhlaWdodCxcclxuICAgICAgbXM6IG9wdD8udGhyb3R0bGUgPz8gMTAwLFxyXG4gICAgfSxcclxuICApO1xyXG5cclxuICBjb25zdCBvblJlc2l6ZSA9ICgpID0+IHtcclxuICAgIHNpemVTaWduYWwuc2V0KHsgd2lkdGg6IHdpbmRvdy5pbm5lcldpZHRoLCBoZWlnaHQ6IHdpbmRvdy5pbm5lckhlaWdodCB9KTtcclxuICB9O1xyXG5cclxuICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcigncmVzaXplJywgb25SZXNpemUpO1xyXG5cclxuICBpbmplY3QoRGVzdHJveVJlZikub25EZXN0cm95KCgpID0+IHtcclxuICAgIHdpbmRvdy5yZW1vdmVFdmVudExpc3RlbmVyKCdyZXNpemUnLCBvblJlc2l6ZSk7XHJcbiAgfSk7XHJcblxyXG4gIGNvbnN0IGJhc2UgPSBzaXplU2lnbmFsLmFzUmVhZG9ubHkoKSBhcyBJbnRlcm5hbFdpbmRvd1NpemVTaWduYWw7XHJcbiAgYmFzZS51bnRocm90dGxlZCA9IHNpemVTaWduYWwub3JpZ2luYWw7XHJcbiAgcmV0dXJuIGJhc2U7XHJcbn1cclxuIl19","import { prefersDarkMode, prefersReducedMotion } from './media-query';\nimport { mousePosition, } from './mouse-position';\nimport { networkStatus } from './network-status';\nimport { pageVisibility } from './page-visibility';\nimport { scrollPosition, } from './scroll-position';\nimport { windowSize } from './window-size';\n/**\n * Implementation for sensor overloads.\n * Users should refer to the specific overloads for detailed documentation.\n * @internal\n */\nexport function sensor(type, options) {\n switch (type) {\n case 'mousePosition':\n return mousePosition(options);\n case 'networkStatus':\n return networkStatus(options?.debugName);\n case 'pageVisibility':\n return pageVisibility(options?.debugName);\n case 'dark-mode':\n return prefersDarkMode(options?.debugName);\n case 'reduced-motion':\n return prefersReducedMotion(options?.debugName);\n case 'windowSize':\n return windowSize(options);\n case 'scrollPosition':\n return scrollPosition(options);\n default:\n throw new Error(`Unknown sensor type: ${type}`);\n }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sensor.js","sourceRoot":"","sources":["../../../../../../packages/primitives/src/lib/sensors/sensor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACtE,OAAO,EAGL,aAAa,GACd,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAuB,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAGL,cAAc,GACf,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAuC,UAAU,EAAE,MAAM,eAAe,CAAC;AA6FhF;;;;GAIG;AACH,MAAM,UAAU,MAAM,CACpB,IAOoB,EACpB,OAMyB;IASzB,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,eAAe;YAClB,OAAO,aAAa,CAAC,OAAO,CAAC,CAAC;QAChC,KAAK,eAAe;YAClB,OAAO,aAAa,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC3C,KAAK,gBAAgB;YACnB,OAAO,cAAc,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC5C,KAAK,WAAW;YACd,OAAO,eAAe,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC7C,KAAK,gBAAgB;YACnB,OAAO,oBAAoB,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAClD,KAAK,YAAY;YACf,OAAO,UAAU,CAAC,OAAO,CAAC,CAAC;QAC7B,KAAK,gBAAgB;YACnB,OAAO,cAAc,CAAC,OAAgC,CAAC,CAAC;QAC1D;YACE,MAAM,IAAI,KAAK,CAAC,wBAAwB,IAAI,EAAE,CAAC,CAAC;IACpD,CAAC;AACH,CAAC","sourcesContent":["import { Signal } from '@angular/core';\r\nimport { prefersDarkMode, prefersReducedMotion } from './media-query';\r\nimport {\r\n  MousePositionOptions,\r\n  MousePositionSignal,\r\n  mousePosition,\r\n} from './mouse-position';\r\nimport { NetworkStatusSignal, networkStatus } from './network-status';\r\nimport { pageVisibility } from './page-visibility';\r\nimport {\r\n  ScrollPositionOptions,\r\n  ScrollPositionSignal,\r\n  scrollPosition,\r\n} from './scroll-position';\r\nimport { WindowSizeOptions, WindowSizeSignal, windowSize } from './window-size';\r\n\r\n/**\r\n * Creates a sensor signal that tracks the mouse cursor's position.\r\n * @param type Must be `'mousePosition'`.\r\n * @param options Optional configuration for the mouse position sensor.\r\n * @returns A `MousePositionSignal` that tracks mouse coordinates and provides an unthrottled version.\r\n * @see {mousePosition} for detailed documentation and examples.\r\n * @example const pos = sensor('mousePosition', { coordinateSpace: 'page', throttle: 50 });\r\n */\r\nexport function sensor(\r\n  type: 'mousePosition',\r\n  options?: MousePositionOptions,\r\n): MousePositionSignal;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the browser's online/offline status.\r\n * @param type Must be `'networkStatus'`.\r\n * @param options Optional configuration, currently only `debugName`.\r\n * @returns A `NetworkStatusSignal` which is a boolean indicating online status, with an attached `since` signal.\r\n * @see {networkStatus} for detailed documentation and examples.\r\n * @example const onlineStatus = sensor('networkStatus');\r\n */\r\nexport function sensor(\r\n  type: 'networkStatus',\r\n  options?: { debugName?: string },\r\n): NetworkStatusSignal;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the page's visibility state (e.g., 'visible', 'hidden').\r\n * @param type Must be `'pageVisibility'`.\r\n * @param options Optional configuration, currently only `debugName`.\r\n * @returns A `Signal<DocumentVisibilityState>` indicating the page's current visibility.\r\n * @see {pageVisibility} for detailed documentation and examples.\r\n * @example const visibility = sensor('pageVisibility');\r\n */\r\nexport function sensor(\r\n  type: 'pageVisibility',\r\n  options?: { debugName?: string },\r\n): Signal<DocumentVisibilityState>;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the user's OS/browser preference for a dark color scheme.\r\n * @param type Must be `'dark-mode'`.\r\n * @param options Optional configuration, currently only `debugName`.\r\n * @returns A `Signal<boolean>` which is `true` if a dark theme is preferred.\r\n * @see {prefersDarkMode} for detailed documentation and examples.\r\n * @example const isDarkMode = sensor('dark-mode');\r\n */\r\nexport function sensor(\r\n  type: 'dark-mode',\r\n  options?: { debugName?: string },\r\n): Signal<boolean>;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the user's OS/browser preference for reduced motion.\r\n * @param type Must be `'reduced-motion'`.\r\n * @param options Optional configuration, currently only `debugName`.\r\n * @returns A `Signal<boolean>` which is `true` if reduced motion is preferred.\r\n * @see {prefersReducedMotion} for detailed documentation and examples.\r\n * @example const wantsReducedMotion = sensor('reduced-motion');\r\n */\r\nexport function sensor(\r\n  type: 'reduced-motion',\r\n  options?: { debugName?: string },\r\n): Signal<boolean>;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the browser window's inner dimensions (width and height).\r\n * @param type Must be `'windowSize'`.\r\n * @param options Optional configuration for the window size sensor, including `throttle` and `debugName`.\r\n * @returns A `WindowSizeSignal` that tracks window dimensions and provides an unthrottled version.\r\n * @see {windowSize} for detailed documentation and examples.\r\n * @example const size = sensor('windowSize', { throttle: 200 });\r\n */\r\nexport function sensor(\r\n  type: 'windowSize',\r\n  options?: WindowSizeOptions,\r\n): WindowSizeSignal;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the scroll position (x, y) of the window or a specified element.\r\n * @param type Must be `'scrollPosition'`.\r\n * @param options Optional configuration for the scroll position sensor, including `target`, `throttle`, and `debugName`.\r\n * @returns A `ScrollPositionSignal` that tracks scroll coordinates and provides an unthrottled version.\r\n * @see {scrollPosition} for detailed documentation and examples.\r\n * @example const pageScroll = sensor('scrollPosition', { throttle: 150 });\r\n */\r\nexport function sensor(\r\n  type: 'scrollPosition',\r\n  options?: ScrollPositionOptions,\r\n): ScrollPositionSignal;\r\n\r\n/**\r\n * Implementation for sensor overloads.\r\n * Users should refer to the specific overloads for detailed documentation.\r\n * @internal\r\n */\r\nexport function sensor(\r\n  type:\r\n    | 'mousePosition'\r\n    | 'networkStatus'\r\n    | 'pageVisibility'\r\n    | 'dark-mode'\r\n    | 'reduced-motion'\r\n    | 'windowSize'\r\n    | 'scrollPosition',\r\n  options?:\r\n    | {\r\n        debugName?: string;\r\n      }\r\n    | MousePositionOptions\r\n    | WindowSizeOptions\r\n    | ScrollPositionOptions,\r\n):\r\n  | MousePositionSignal\r\n  | NetworkStatusSignal\r\n  | Signal<DocumentVisibilityState>\r\n  | Signal<boolean>\r\n  | WindowSizeSignal\r\n  | ScrollPositionSignal\r\n  | Signal<IntersectionObserverEntry | undefined> {\r\n  switch (type) {\r\n    case 'mousePosition':\r\n      return mousePosition(options);\r\n    case 'networkStatus':\r\n      return networkStatus(options?.debugName);\r\n    case 'pageVisibility':\r\n      return pageVisibility(options?.debugName);\r\n    case 'dark-mode':\r\n      return prefersDarkMode(options?.debugName);\r\n    case 'reduced-motion':\r\n      return prefersReducedMotion(options?.debugName);\r\n    case 'windowSize':\r\n      return windowSize(options);\r\n    case 'scrollPosition':\r\n      return scrollPosition(options as ScrollPositionOptions);\r\n    default:\r\n      throw new Error(`Unknown sensor type: ${type}`);\r\n  }\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, effect, inject, isDevMode, isSignal, PLATFORM_ID, signal, untracked, } from '@angular/core';\nimport { toWritable } from './to-writable';\n// Internal dummy store for server-side rendering\nconst noopStore = {\n getItem: () => null,\n setItem: () => {\n /* noop */\n },\n removeItem: () => {\n /* noop */\n },\n};\n/**\n * Creates a `WritableSignal` whose state is automatically synchronized with persistent storage\n * (like `localStorage` or `sessionStorage`).\n *\n * It handles Server-Side Rendering (SSR) gracefully, allows dynamic storage keys,\n * custom serialization/deserialization, custom storage providers, and optional\n * synchronization across browser tabs.\n *\n * @template T The type of value held by the signal and stored (after serialization).\n * @param fallback The default value of type `T` to use when no value is found in storage\n * or when deserialization fails. The signal's value will never be `null` or `undefined`\n * publicly, it will always revert to this fallback.\n * @param options Configuration options (`CreateStoredOptions<T>`). Requires at least the `key`.\n * @returns A `StoredSignal<T>` instance. This signal behaves like a standard `WritableSignal<T>`,\n * but its value is persisted. It includes a `.clear()` method to remove the item from storage\n * and a `.key` signal providing the current storage key.\n *\n * @remarks\n * - **Persistence:** The signal automatically saves its value to storage whenever the signal's\n * value or its configured `key` changes. This is managed internally using `effect`.\n * - **SSR Safety:** Detects server environments and uses a no-op storage, preventing errors.\n * - **Error Handling:** Catches and logs errors during serialization/deserialization in dev mode.\n * - **Tab Sync:** If `syncTabs` is true, listens to `storage` events to keep the signal value\n * consistent across browser tabs using the same key. Cleanup is handled automatically\n * using `DestroyRef`.\n * - **Removal:** Use the `.clear()` method on the returned signal to remove the item from storage.\n * Setting the signal to the fallback value will store the fallback value, not remove the item.\n *\n * @example\n * ```ts\n * import { Component, effect, signal } from '@angular/core';\n * import { stored } from '@mmstack/primitives'; // Adjust import path\n *\n * @Component({\n * selector: 'app-settings',\n * standalone: true,\n * template: `\n * Theme:\n * <select [ngModel]=\"theme()\" (ngModelChange)=\"theme.set($event)\">\n * <option value=\"light\">Light</option>\n * <option value=\"dark\">Dark</option>\n * </select>\n * <button (click)=\"theme.clear()\">Clear Theme Setting</button>\n * <p>Storage Key Used: {{ theme.key() }}</p>\n * ` // Requires FormsModule for ngModel\n * })\n * export class SettingsComponent {\n * theme = stored<'light' | 'dark'>('light', { key: 'app-theme', syncTabs: true });\n * }\n * ```\n */\nexport function stored(fallback, { key, store: providedStore, serialize = JSON.stringify, deserialize = JSON.parse, syncTabs = false, equal = Object.is, onKeyChange = 'load', cleanupOldKey = false, ...rest }) {\n const isServer = isPlatformServer(inject(PLATFORM_ID));\n const fallbackStore = isServer ? noopStore : localStorage;\n const store = providedStore ?? fallbackStore;\n const keySig = typeof key === 'string'\n ? computed(() => key)\n : isSignal(key)\n ? key\n : computed(key);\n const getValue = (key) => {\n const found = store.getItem(key);\n if (found === null)\n return null;\n try {\n return deserialize(found);\n }\n catch (err) {\n if (isDevMode())\n console.error(`Failed to parse stored value for key \"${key}\":`, err);\n return null;\n }\n };\n const storeValue = (key, value) => {\n try {\n if (value === null)\n return store.removeItem(key);\n const serialized = serialize(value);\n store.setItem(key, serialized);\n }\n catch (err) {\n if (isDevMode())\n console.error(`Failed to store value for key \"${key}\":`, err);\n }\n };\n const opt = {\n ...rest,\n equal,\n };\n const initialKey = untracked(keySig);\n const internal = signal(getValue(initialKey), ...(ngDevMode ? [{ debugName: \"internal\", ...opt,\n equal: (a, b) => {\n if (a === null && b === null)\n return true;\n if (a === null || b === null)\n return false;\n return equal(a, b);\n } }] : [{\n ...opt,\n equal: (a, b) => {\n if (a === null && b === null)\n return true;\n if (a === null || b === null)\n return false;\n return equal(a, b);\n },\n }]));\n let prevKey = initialKey;\n if (onKeyChange === 'store') {\n effect(() => {\n const k = keySig();\n storeValue(k, internal());\n if (prevKey !== k) {\n if (cleanupOldKey)\n store.removeItem(prevKey);\n prevKey = k;\n }\n });\n }\n else {\n effect(() => {\n const k = keySig();\n const internalValue = internal();\n if (k === prevKey) {\n return storeValue(k, internalValue); // normal operation\n }\n else {\n if (cleanupOldKey)\n store.removeItem(prevKey);\n const value = getValue(k);\n prevKey = k;\n internal.set(value); // load new value\n }\n });\n }\n if (syncTabs && !isServer) {\n const destroyRef = inject(DestroyRef);\n const sync = (e) => {\n if (e.key !== untracked(keySig))\n return;\n if (e.newValue === null)\n internal.set(null);\n else\n internal.set(getValue(e.key));\n };\n window.addEventListener('storage', sync);\n destroyRef.onDestroy(() => window.removeEventListener('storage', sync));\n }\n const writable = toWritable(computed(() => internal() ?? fallback, opt), internal.set);\n writable.clear = () => {\n internal.set(null);\n };\n writable.key = keySig;\n return writable;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stored.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/stored.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACL,QAAQ,EACR,UAAU,EACV,MAAM,EACN,MAAM,EACN,SAAS,EACT,QAAQ,EACR,WAAW,EAEX,MAAM,EACN,SAAS,GAGV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAe3C,iDAAiD;AACjD,MAAM,SAAS,GAAU;IACvB,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI;IACnB,OAAO,EAAE,GAAG,EAAE;QACZ,UAAU;IACZ,CAAC;IACD,UAAU,EAAE,GAAG,EAAE;QACf,UAAU;IACZ,CAAC;CACF,CAAC;AA0EF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkDG;AACH,MAAM,UAAU,MAAM,CACpB,QAAW,EACX,EACE,GAAG,EACH,KAAK,EAAE,aAAa,EACpB,SAAS,GAAG,IAAI,CAAC,SAAS,EAC1B,WAAW,GAAG,IAAI,CAAC,KAAK,EACxB,QAAQ,GAAG,KAAK,EAChB,KAAK,GAAG,MAAM,CAAC,EAAE,EACjB,WAAW,GAAG,MAAM,EACpB,aAAa,GAAG,KAAK,EACrB,GAAG,IAAI,EACgB;IAEzB,MAAM,QAAQ,GAAG,gBAAgB,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;IAEvD,MAAM,aAAa,GAAG,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC;IAC1D,MAAM,KAAK,GAAG,aAAa,IAAI,aAAa,CAAC;IAE7C,MAAM,MAAM,GACV,OAAO,GAAG,KAAK,QAAQ;QACrB,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC;QACrB,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC;YACb,CAAC,CAAC,GAAG;YACL,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IAEtB,MAAM,QAAQ,GAAG,CAAC,GAAW,EAAY,EAAE;QACzC,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,KAAK,KAAK,IAAI;YAAE,OAAO,IAAI,CAAC;QAChC,IAAI,CAAC;YACH,OAAO,WAAW,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,SAAS,EAAE;gBACb,OAAO,CAAC,KAAK,CAAC,yCAAyC,GAAG,IAAI,EAAE,GAAG,CAAC,CAAC;YACvE,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,UAAU,GAAG,CAAC,GAAW,EAAE,KAAe,EAAE,EAAE;QAClD,IAAI,CAAC;YACH,IAAI,KAAK,KAAK,IAAI;gBAAE,OAAO,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YACjD,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;YACpC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;QACjC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,SAAS,EAAE;gBACb,OAAO,CAAC,KAAK,CAAC,kCAAkC,GAAG,IAAI,EAAE,GAAG,CAAC,CAAC;QAClE,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,GAAG,GAAG;QACV,GAAG,IAAI;QACP,KAAK;KACN,CAAC;IAEF,MAAM,UAAU,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IACrC,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,4CAC1C,GAAG,GAAG;YACN,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBACd,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,IAAI;oBAAE,OAAO,IAAI,CAAC;gBAC1C,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,IAAI;oBAAE,OAAO,KAAK,CAAC;gBAC3C,OAAO,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACrB,CAAC,OAN2C;YAC5C,GAAG,GAAG;YACN,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBACd,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,IAAI;oBAAE,OAAO,IAAI,CAAC;gBAC1C,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,IAAI;oBAAE,OAAO,KAAK,CAAC;gBAC3C,OAAO,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACrB,CAAC;SACF,GAAC,CAAC;IAEH,IAAI,OAAO,GAAG,UAAU,CAAC;IAEzB,IAAI,WAAW,KAAK,OAAO,EAAE,CAAC;QAC5B,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,CAAC,GAAG,MAAM,EAAE,CAAC;YACnB,UAAU,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;YAC1B,IAAI,OAAO,KAAK,CAAC,EAAE,CAAC;gBAClB,IAAI,aAAa;oBAAE,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;gBAC7C,OAAO,GAAG,CAAC,CAAC;YACd,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;SAAM,CAAC;QACN,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,CAAC,GAAG,MAAM,EAAE,CAAC;YACnB,MAAM,aAAa,GAAG,QAAQ,EAAE,CAAC;YACjC,IAAI,CAAC,KAAK,OAAO,EAAE,CAAC;gBAClB,OAAO,UAAU,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,mBAAmB;YAC1D,CAAC;iBAAM,CAAC;gBACN,IAAI,aAAa;oBAAE,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;gBAC7C,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;gBAE1B,OAAO,GAAG,CAAC,CAAC;gBACZ,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,iBAAiB;YACxC,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,QAAQ,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC1B,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QACtC,MAAM,IAAI,GAAG,CAAC,CAAe,EAAE,EAAE;YAC/B,IAAI,CAAC,CAAC,GAAG,KAAK,SAAS,CAAC,MAAM,CAAC;gBAAE,OAAO;YAExC,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI;gBAAE,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;;gBACvC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACrC,CAAC,CAAC;QAEF,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAEzC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC;IAC1E,CAAC;IAED,MAAM,QAAQ,GAAG,UAAU,CACzB,QAAQ,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,IAAI,QAAQ,EAAE,GAAG,CAAC,EAC3C,QAAQ,CAAC,GAAG,CACM,CAAC;IAErB,QAAQ,CAAC,KAAK,GAAG,GAAG,EAAE;QACpB,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC,CAAC;IACF,QAAQ,CAAC,GAAG,GAAG,MAAM,CAAC;IACtB,OAAO,QAAQ,CAAC;AAClB,CAAC","sourcesContent":["import { isPlatformServer } from '@angular/common';\r\nimport {\r\n  computed,\r\n  DestroyRef,\r\n  effect,\r\n  inject,\r\n  isDevMode,\r\n  isSignal,\r\n  PLATFORM_ID,\r\n  Signal,\r\n  signal,\r\n  untracked,\r\n  type CreateSignalOptions,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * Interface for storage mechanisms compatible with the `stored` signal.\r\n * Matches the essential parts of the `Storage` interface (`localStorage`, `sessionStorage`).\r\n */\r\ntype Store = {\r\n  /** Retrieves an item from storage for a given key. */\r\n  getItem: (key: string) => string | null;\r\n  /** Sets an item in storage for a given key. */\r\n  setItem: (key: string, value: string) => void;\r\n  /** Removes an item from storage for a given key. */\r\n  removeItem: (key: string) => void;\r\n};\r\n\r\n// Internal dummy store for server-side rendering\r\nconst noopStore: Store = {\r\n  getItem: () => null,\r\n  setItem: () => {\r\n    /* noop */\r\n  },\r\n  removeItem: () => {\r\n    /* noop */\r\n  },\r\n};\r\n\r\n/**\r\n * Options for creating a signal synchronized with persistent storage using `stored()`.\r\n * Extends Angular's `CreateSignalOptions`.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type CreateStoredOptions<T> = CreateSignalOptions<T> & {\r\n  /**\r\n   * The key used to identify the item in storage.\r\n   * Can be a static string or a function/signal returning a string for dynamic keys\r\n   * (e.g., based on user ID or other application state).\r\n   */\r\n  key: string | (() => string);\r\n  /**\r\n   * Optional custom storage implementation (e.g., `sessionStorage` or a custom adapter).\r\n   * Must conform to the `Store` interface (`getItem`, `setItem`, `removeItem`).\r\n   * Defaults to `localStorage` in browser environments and a no-op store on the server.\r\n   */\r\n  store?: Store;\r\n  /**\r\n   * Optional function to serialize the value (type `T`) into a string before storing.\r\n   * Defaults to `JSON.stringify`.\r\n   * @param {T} value The value to serialize.\r\n   * @returns {string} The serialized string representation.\r\n   */\r\n  serialize?: (value: T) => string;\r\n  /**\r\n   * Optional function to deserialize the string retrieved from storage back into the value (type `T`).\r\n   * Defaults to `JSON.parse`.\r\n   * @param {string} value The string retrieved from storage.\r\n   * @returns {T} The deserialized value.\r\n   */\r\n  deserialize?: (value: string) => T;\r\n  /**\r\n   * If `true`, the signal will attempt to synchronize its state across multiple browser tabs\r\n   * using the `storage` event. Changes made in one tab (set, update, clear) will be\r\n   * reflected in other tabs using the same storage key.\r\n   * Requires a browser environment. Defaults to `false`.\r\n   */\r\n  syncTabs?: boolean;\r\n  /**\r\n   * Optional parameter to specify how key changes should be handled, load is the default.\r\n   * - `load`: The signal will load the value from storage when the key changes & replace the signal's value.\r\n   * - `store`: The signal will store the current value to the new key when the key changes.\r\n   */\r\n  onKeyChange?: 'load' | 'store';\r\n  /**\r\n   * If 'true', the signal will remove the old key from storage when the key changes, defaults to `false`.\r\n   */\r\n  cleanupOldKey?: boolean;\r\n};\r\n\r\n/**\r\n * A specialized `WritableSignal` returned by the `stored()` function.\r\n * It synchronizes its value with persistent storage and provides additional methods.\r\n *\r\n * @template T The type of value held by the signal (matches the fallback type).\r\n */\r\nexport type StoredSignal<T> = WritableSignal<T> & {\r\n  /**\r\n   * Removes the item associated with the signal's key from the configured storage.\r\n   * After clearing, reading the signal will return the fallback value until it's set again.\r\n   */\r\n  clear: () => void;\r\n  /**\r\n   * A `Signal<string>` containing the current storage key being used by this stored signal.\r\n   * This is particularly useful if the key was configured dynamically. You can read or react\r\n   * to this signal to know the active key.\r\n   */\r\n  key: Signal<string>;\r\n};\r\n\r\n/**\r\n * Creates a `WritableSignal` whose state is automatically synchronized with persistent storage\r\n * (like `localStorage` or `sessionStorage`).\r\n *\r\n * It handles Server-Side Rendering (SSR) gracefully, allows dynamic storage keys,\r\n * custom serialization/deserialization, custom storage providers, and optional\r\n * synchronization across browser tabs.\r\n *\r\n * @template T The type of value held by the signal and stored (after serialization).\r\n * @param fallback The default value of type `T` to use when no value is found in storage\r\n * or when deserialization fails. The signal's value will never be `null` or `undefined`\r\n * publicly, it will always revert to this fallback.\r\n * @param options Configuration options (`CreateStoredOptions<T>`). Requires at least the `key`.\r\n * @returns A `StoredSignal<T>` instance. This signal behaves like a standard `WritableSignal<T>`,\r\n * but its value is persisted. It includes a `.clear()` method to remove the item from storage\r\n * and a `.key` signal providing the current storage key.\r\n *\r\n * @remarks\r\n * - **Persistence:** The signal automatically saves its value to storage whenever the signal's\r\n * value or its configured `key` changes. This is managed internally using `effect`.\r\n * - **SSR Safety:** Detects server environments and uses a no-op storage, preventing errors.\r\n * - **Error Handling:** Catches and logs errors during serialization/deserialization in dev mode.\r\n * - **Tab Sync:** If `syncTabs` is true, listens to `storage` events to keep the signal value\r\n * consistent across browser tabs using the same key. Cleanup is handled automatically\r\n * using `DestroyRef`.\r\n * - **Removal:** Use the `.clear()` method on the returned signal to remove the item from storage.\r\n * Setting the signal to the fallback value will store the fallback value, not remove the item.\r\n *\r\n * @example\r\n * ```ts\r\n * import { Component, effect, signal } from '@angular/core';\r\n * import { stored } from '@mmstack/primitives'; // Adjust import path\r\n *\r\n * @Component({\r\n * selector: 'app-settings',\r\n * standalone: true,\r\n * template: `\r\n * Theme:\r\n * <select [ngModel]=\"theme()\" (ngModelChange)=\"theme.set($event)\">\r\n * <option value=\"light\">Light</option>\r\n * <option value=\"dark\">Dark</option>\r\n * </select>\r\n * <button (click)=\"theme.clear()\">Clear Theme Setting</button>\r\n * <p>Storage Key Used: {{ theme.key() }}</p>\r\n * ` // Requires FormsModule for ngModel\r\n * })\r\n * export class SettingsComponent {\r\n *  theme = stored<'light' | 'dark'>('light', { key: 'app-theme', syncTabs: true });\r\n * }\r\n * ```\r\n */\r\nexport function stored<T>(\r\n  fallback: T,\r\n  {\r\n    key,\r\n    store: providedStore,\r\n    serialize = JSON.stringify,\r\n    deserialize = JSON.parse,\r\n    syncTabs = false,\r\n    equal = Object.is,\r\n    onKeyChange = 'load',\r\n    cleanupOldKey = false,\r\n    ...rest\r\n  }: CreateStoredOptions<T>,\r\n): StoredSignal<T> {\r\n  const isServer = isPlatformServer(inject(PLATFORM_ID));\r\n\r\n  const fallbackStore = isServer ? noopStore : localStorage;\r\n  const store = providedStore ?? fallbackStore;\r\n\r\n  const keySig =\r\n    typeof key === 'string'\r\n      ? computed(() => key)\r\n      : isSignal(key)\r\n        ? key\r\n        : computed(key);\r\n\r\n  const getValue = (key: string): T | null => {\r\n    const found = store.getItem(key);\r\n    if (found === null) return null;\r\n    try {\r\n      return deserialize(found);\r\n    } catch (err) {\r\n      if (isDevMode())\r\n        console.error(`Failed to parse stored value for key \"${key}\":`, err);\r\n      return null;\r\n    }\r\n  };\r\n\r\n  const storeValue = (key: string, value: T | null) => {\r\n    try {\r\n      if (value === null) return store.removeItem(key);\r\n      const serialized = serialize(value);\r\n      store.setItem(key, serialized);\r\n    } catch (err) {\r\n      if (isDevMode())\r\n        console.error(`Failed to store value for key \"${key}\":`, err);\r\n    }\r\n  };\r\n\r\n  const opt = {\r\n    ...rest,\r\n    equal,\r\n  };\r\n\r\n  const initialKey = untracked(keySig);\r\n  const internal = signal(getValue(initialKey), {\r\n    ...opt,\r\n    equal: (a, b) => {\r\n      if (a === null && b === null) return true;\r\n      if (a === null || b === null) return false;\r\n      return equal(a, b);\r\n    },\r\n  });\r\n\r\n  let prevKey = initialKey;\r\n\r\n  if (onKeyChange === 'store') {\r\n    effect(() => {\r\n      const k = keySig();\r\n      storeValue(k, internal());\r\n      if (prevKey !== k) {\r\n        if (cleanupOldKey) store.removeItem(prevKey);\r\n        prevKey = k;\r\n      }\r\n    });\r\n  } else {\r\n    effect(() => {\r\n      const k = keySig();\r\n      const internalValue = internal();\r\n      if (k === prevKey) {\r\n        return storeValue(k, internalValue); // normal operation\r\n      } else {\r\n        if (cleanupOldKey) store.removeItem(prevKey);\r\n        const value = getValue(k);\r\n\r\n        prevKey = k;\r\n        internal.set(value); // load new value\r\n      }\r\n    });\r\n  }\r\n\r\n  if (syncTabs && !isServer) {\r\n    const destroyRef = inject(DestroyRef);\r\n    const sync = (e: StorageEvent) => {\r\n      if (e.key !== untracked(keySig)) return;\r\n\r\n      if (e.newValue === null) internal.set(null);\r\n      else internal.set(getValue(e.key));\r\n    };\r\n\r\n    window.addEventListener('storage', sync);\r\n\r\n    destroyRef.onDestroy(() => window.removeEventListener('storage', sync));\r\n  }\r\n\r\n  const writable = toWritable<T>(\r\n    computed(() => internal() ?? fallback, opt),\r\n    internal.set,\r\n  ) as StoredSignal<T>;\r\n\r\n  writable.clear = () => {\r\n    internal.set(null);\r\n  };\r\n  writable.key = keySig;\r\n  return writable;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { DestroyRef, effect, inject, Injectable, PLATFORM_ID, } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class MessageBus {\n channel = new BroadcastChannel('mmstack-tab-sync-bus');\n listeners = new Map();\n subscribe(id, listener) {\n this.unsubscribe(id); // Ensure no duplicate listeners\n const wrapped = (ev) => {\n try {\n if (ev.data?.id === id)\n listener(ev.data?.value);\n }\n catch {\n // noop\n }\n };\n this.channel.addEventListener('message', wrapped);\n this.listeners.set(id, wrapped);\n return {\n unsub: (() => this.unsubscribe(id)).bind(this),\n post: ((value) => this.channel.postMessage({ id, value })).bind(this),\n };\n }\n unsubscribe(id) {\n const listener = this.listeners.get(id);\n if (!listener)\n return;\n this.channel.removeEventListener('message', listener);\n this.listeners.delete(id);\n }\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.1\", ngImport: i0, type: MessageBus, deps: [], target: i0.ɵɵFactoryTarget.Injectable });\n static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.1\", ngImport: i0, type: MessageBus, providedIn: 'root' });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.1\", ngImport: i0, type: MessageBus, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\nexport function generateDeterministicID() {\n const stack = new Error().stack;\n if (stack) {\n // Look for the actual caller (first non-internal frame)\n const lines = stack.split('\\n');\n for (let i = 2; i < lines.length; i++) {\n const line = lines[i];\n if (line && !line.includes('tabSync') && !line.includes('MessageBus')) {\n let hash = 0;\n for (let j = 0; j < line.length; j++) {\n const char = line.charCodeAt(j);\n hash = (hash << 5) - hash + char;\n hash = hash & hash;\n }\n return `auto-${Math.abs(hash)}`;\n }\n }\n }\n throw new Error('Could not generate deterministic ID, please provide one manually.');\n}\n/**\n * Synchronizes a WritableSignal across browser tabs using BroadcastChannel API.\n *\n * Creates a shared signal that automatically syncs its value between all tabs\n * of the same application. When the signal is updated in one tab, all other\n * tabs will receive the new value automatically.\n *\n * @template T - The type of the WritableSignal\n * @param sig - The WritableSignal to synchronize across tabs\n * @param opt - Optional configuration object\n * @param opt.id - Explicit channel ID for synchronization. If not provided,\n * a deterministic ID is generated based on the call site.\n * Use explicit IDs in production for reliability.\n *\n * @returns The same WritableSignal instance, now synchronized across tabs\n *\n * @throws {Error} When deterministic ID generation fails and no explicit ID is provided\n *\n * @example\n * ```typescript\n * // Basic usage - auto-generates channel ID from call site\n * const theme = tabSync(signal('dark'));\n *\n * // With explicit ID (recommended for production)\n * const userPrefs = tabSync(signal({ lang: 'en' }), { id: 'user-preferences' });\n *\n * // Changes in one tab will sync to all other tabs\n * theme.set('light'); // All tabs will update to 'light'\n * ```\n *\n * @remarks\n * - Only works in browser environments (returns original signal on server)\n * - Uses a single BroadcastChannel for all synchronized signals\n * - Automatically cleans up listeners when the injection context is destroyed\n * - Initial signal value after sync setup is not broadcasted to prevent loops\n *\n */\nexport function tabSync(sig, opt) {\n if (isPlatformServer(inject(PLATFORM_ID)))\n return sig;\n const id = opt?.id || generateDeterministicID();\n const bus = inject(MessageBus);\n const { unsub, post } = bus.subscribe(id, (next) => sig.set(next));\n let first = false;\n const effectRef = effect(() => {\n const val = sig();\n if (!first) {\n first = true;\n return;\n }\n post(val);\n }, ...(ngDevMode ? [{ debugName: \"effectRef\" }] : []));\n inject(DestroyRef).onDestroy(() => {\n effectRef.destroy();\n unsub();\n });\n return sig;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabSync.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/tabSync.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common';\nimport {\n  DestroyRef,\n  effect,\n  inject,\n  Injectable,\n  PLATFORM_ID,\n  WritableSignal,\n} from '@angular/core';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class MessageBus {\n  private readonly channel = new BroadcastChannel('mmstack-tab-sync-bus');\n  private readonly listeners = new Map<string, (ev: MessageEvent) => void>();\n\n  subscribe<T>(id: string, listener: (data: T) => void) {\n    this.unsubscribe(id); // Ensure no duplicate listeners\n    const wrapped = (ev: MessageEvent) => {\n      try {\n        if (ev.data?.id === id) listener(ev.data?.value);\n      } catch {\n        // noop\n      }\n    };\n    this.channel.addEventListener('message', wrapped);\n    this.listeners.set(id, wrapped);\n\n    return {\n      unsub: (() => this.unsubscribe(id)).bind(this),\n      post: ((value: T) => this.channel.postMessage({ id, value })).bind(this),\n    };\n  }\n\n  private unsubscribe(id: string) {\n    const listener = this.listeners.get(id);\n    if (!listener) return;\n    this.channel.removeEventListener('message', listener);\n    this.listeners.delete(id);\n  }\n}\n\nexport function generateDeterministicID(): string {\n  const stack = new Error().stack;\n  if (stack) {\n    // Look for the actual caller (first non-internal frame)\n    const lines = stack.split('\\n');\n    for (let i = 2; i < lines.length; i++) {\n      const line = lines[i];\n      if (line && !line.includes('tabSync') && !line.includes('MessageBus')) {\n        let hash = 0;\n        for (let j = 0; j < line.length; j++) {\n          const char = line.charCodeAt(j);\n          hash = (hash << 5) - hash + char;\n          hash = hash & hash;\n        }\n        return `auto-${Math.abs(hash)}`;\n      }\n    }\n  }\n  throw new Error(\n    'Could not generate deterministic ID, please provide one manually.',\n  );\n}\n\ntype SyncSignalOptions = {\n  id?: string;\n};\n\n/**\n * Synchronizes a WritableSignal across browser tabs using BroadcastChannel API.\n *\n * Creates a shared signal that automatically syncs its value between all tabs\n * of the same application. When the signal is updated in one tab, all other\n * tabs will receive the new value automatically.\n *\n * @template T - The type of the WritableSignal\n * @param sig - The WritableSignal to synchronize across tabs\n * @param opt - Optional configuration object\n * @param opt.id - Explicit channel ID for synchronization. If not provided,\n *                 a deterministic ID is generated based on the call site.\n *                 Use explicit IDs in production for reliability.\n *\n * @returns The same WritableSignal instance, now synchronized across tabs\n *\n * @throws {Error} When deterministic ID generation fails and no explicit ID is provided\n *\n * @example\n * ```typescript\n * // Basic usage - auto-generates channel ID from call site\n * const theme = tabSync(signal('dark'));\n *\n * // With explicit ID (recommended for production)\n * const userPrefs = tabSync(signal({ lang: 'en' }), { id: 'user-preferences' });\n *\n * // Changes in one tab will sync to all other tabs\n * theme.set('light'); // All tabs will update to 'light'\n * ```\n *\n * @remarks\n * - Only works in browser environments (returns original signal on server)\n * - Uses a single BroadcastChannel for all synchronized signals\n * - Automatically cleans up listeners when the injection context is destroyed\n * - Initial signal value after sync setup is not broadcasted to prevent loops\n *\n */\nexport function tabSync<T extends WritableSignal<any>>(\n  sig: T,\n  opt?: SyncSignalOptions,\n): T {\n  if (isPlatformServer(inject(PLATFORM_ID))) return sig;\n\n  const id = opt?.id || generateDeterministicID();\n\n  const bus = inject(MessageBus);\n\n  const { unsub, post } = bus.subscribe(id, (next) => sig.set(next));\n\n  let first = false;\n\n  const effectRef = effect(() => {\n    const val = sig();\n    if (!first) {\n      first = true;\n      return;\n    }\n    post(val);\n  });\n\n  inject(DestroyRef).onDestroy(() => {\n    effectRef.destroy();\n    unsub();\n  });\n\n  return sig;\n}\n"]}","import { DestroyRef, effect, inject, Injector, runInInjectionContext, untracked, } from '@angular/core';\nexport function until(sourceSignal, predicate, options = {}) {\n const injector = options.injector ?? inject(Injector);\n return new Promise((resolve, reject) => {\n let effectRef;\n let timeoutId;\n let settled = false;\n const cleanupAndReject = (reason) => {\n if (!settled) {\n settled = true;\n if (timeoutId)\n clearTimeout(timeoutId);\n effectRef?.destroy();\n reject(new Error(reason));\n }\n };\n const cleanupAndResolve = (value) => {\n if (!settled) {\n settled = true;\n if (timeoutId)\n clearTimeout(timeoutId);\n effectRef?.destroy();\n resolve(value);\n }\n };\n try {\n const destroyRef = options.destroyRef ?? inject(DestroyRef, { optional: true });\n destroyRef?.onDestroy(() => {\n cleanupAndReject('until: Operation cancelled due to context destruction.');\n });\n }\n catch {\n // noop\n }\n const initialValue = untracked(sourceSignal);\n if (predicate(initialValue)) {\n cleanupAndResolve(initialValue);\n return;\n }\n if (options?.timeout !== undefined) {\n timeoutId = setTimeout(() => cleanupAndReject(`until: Timeout after ${options.timeout}ms.`), options.timeout);\n }\n runInInjectionContext(injector, () => {\n effectRef = effect(() => {\n if (settled) {\n return effectRef?.destroy();\n }\n const currentValue = sourceSignal();\n if (predicate(currentValue)) {\n cleanupAndResolve(currentValue);\n }\n });\n });\n });\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"until.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/until.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EACV,MAAM,EAEN,MAAM,EACN,QAAQ,EACR,qBAAqB,EAErB,SAAS,GACV,MAAM,eAAe,CAAC;AAmEvB,MAAM,UAAU,KAAK,CACnB,YAAuB,EACvB,SAAgC,EAChC,UAAwB,EAAE;IAE1B,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,CAAC;IACtD,OAAO,IAAI,OAAO,CAAI,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACxC,IAAI,SAAgC,CAAC;QACrC,IAAI,SAAoD,CAAC;QACzD,IAAI,OAAO,GAAG,KAAK,CAAC;QAEpB,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAE,EAAE;YAC1C,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,OAAO,GAAG,IAAI,CAAC;gBACf,IAAI,SAAS;oBAAE,YAAY,CAAC,SAAS,CAAC,CAAC;gBACvC,SAAS,EAAE,OAAO,EAAE,CAAC;gBACrB,MAAM,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC,CAAC;QAEF,MAAM,iBAAiB,GAAG,CAAC,KAAQ,EAAE,EAAE;YACrC,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,OAAO,GAAG,IAAI,CAAC;gBACf,IAAI,SAAS;oBAAE,YAAY,CAAC,SAAS,CAAC,CAAC;gBACvC,SAAS,EAAE,OAAO,EAAE,CAAC;gBACrB,OAAO,CAAC,KAAK,CAAC,CAAC;YACjB,CAAC;QACH,CAAC,CAAC;QAEF,IAAI,CAAC;YACH,MAAM,UAAU,GACd,OAAO,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;YAE/D,UAAU,EAAE,SAAS,CAAC,GAAG,EAAE;gBACzB,gBAAgB,CACd,wDAAwD,CACzD,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC;QAAC,MAAM,CAAC;YACP,OAAO;QACT,CAAC;QAED,MAAM,YAAY,GAAG,SAAS,CAAC,YAAY,CAAC,CAAC;QAC7C,IAAI,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC;YAC5B,iBAAiB,CAAC,YAAY,CAAC,CAAC;YAChC,OAAO;QACT,CAAC;QAED,IAAI,OAAO,EAAE,OAAO,KAAK,SAAS,EAAE,CAAC;YACnC,SAAS,GAAG,UAAU,CACpB,GAAG,EAAE,CAAC,gBAAgB,CAAC,wBAAwB,OAAO,CAAC,OAAO,KAAK,CAAC,EACpE,OAAO,CAAC,OAAO,CAChB,CAAC;QACJ,CAAC;QAED,qBAAqB,CAAC,QAAQ,EAAE,GAAG,EAAE;YACnC,SAAS,GAAG,MAAM,CAAC,GAAG,EAAE;gBACtB,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,SAAS,EAAE,OAAO,EAAE,CAAC;gBAC9B,CAAC;gBAED,MAAM,YAAY,GAAG,YAAY,EAAE,CAAC;gBACpC,IAAI,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC;oBAC5B,iBAAiB,CAAC,YAAY,CAAC,CAAC;gBAClC,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["import {\r\n  DestroyRef,\r\n  effect,\r\n  EffectRef,\r\n  inject,\r\n  Injector,\r\n  runInInjectionContext,\r\n  Signal,\r\n  untracked,\r\n} from '@angular/core';\r\n\r\nexport type UntilOptions = {\r\n  /**\r\n   * Optional timeout in milliseconds. If the condition is not met\r\n   * within this period, the promise will reject.\r\n   */\r\n  timeout?: number;\r\n  /**\r\n   * Optional DestroyRef. If provided and the component/context is destroyed\r\n   * before the condition is met or timeout occurs, the promise will reject.\r\n   * If not provided, it will attempt to inject one if called in an injection context.\r\n   */\r\n  destroyRef?: DestroyRef;\r\n  injector?: Injector;\r\n};\r\n\r\n/**\r\n * Creates a Promise that resolves when a signal's value satisfies a type predicate.\r\n *\r\n * This overload is used when the predicate function is a type guard (e.g., `(v): v is MyType`).\r\n * The returned promise will resolve with the narrowed type.\r\n *\r\n * @template T The base type of the signal's value.\r\n * @template U The narrowed type asserted by the predicate.\r\n * @param sourceSignal The signal to observe.\r\n * @param predicate A type guard function that returns `true` if the value is of type `U`.\r\n * @param options Optional configuration for timeout and explicit destruction.\r\n * @returns A Promise that resolves with the signal's value, narrowed to type `U`.\r\n *\r\n * @example\r\n * ```ts\r\n * const event = signal<Event | null>(null);\r\n *\r\n * // The returned promise is `Promise<MouseEvent>`\r\n * const mouseEventPromise = until(event, (e): e is MouseEvent => e instanceof MouseEvent);\r\n *\r\n * async function logMouseEvent() {\r\n * const me = await mouseEventPromise;\r\n * console.log(me.clientX); // `me` is correctly typed as MouseEvent\r\n * }\r\n * ```\r\n */\r\nexport function until<T, U extends T>(\r\n  sourceSignal: Signal<T>,\r\n  predicate: (value: T) => value is U,\r\n  options?: UntilOptions,\r\n): Promise<U>;\r\n\r\n/**\r\n * Creates a Promise that resolves when a signal's value satisfies a given predicate.\r\n *\r\n * This is useful for imperatively waiting for a reactive state to change,\r\n * for example, in tests or to orchestrate complex asynchronous operations.\r\n *\r\n * @template T The type of the signal's value.\r\n * @param sourceSignal The signal to observe.\r\n * @param predicate A function that takes the signal's value and returns `true` if the condition is met.\r\n * @param options Optional configuration for timeout and explicit destruction.\r\n * @returns A Promise that resolves with the signal's value when the predicate is true,\r\n * or rejects on timeout or context destruction.\r\n */\r\nexport function until<T>(\r\n  sourceSignal: Signal<T>,\r\n  predicate: (value: T) => boolean,\r\n  options?: UntilOptions,\r\n): Promise<T>;\r\nexport function until<T>(\r\n  sourceSignal: Signal<T>,\r\n  predicate: (value: T) => boolean,\r\n  options: UntilOptions = {},\r\n): Promise<T> {\r\n  const injector = options.injector ?? inject(Injector);\r\n  return new Promise<T>((resolve, reject) => {\r\n    let effectRef: EffectRef | undefined;\r\n    let timeoutId: ReturnType<typeof setTimeout> | undefined;\r\n    let settled = false;\r\n\r\n    const cleanupAndReject = (reason: string) => {\r\n      if (!settled) {\r\n        settled = true;\r\n        if (timeoutId) clearTimeout(timeoutId);\r\n        effectRef?.destroy();\r\n        reject(new Error(reason));\r\n      }\r\n    };\r\n\r\n    const cleanupAndResolve = (value: T) => {\r\n      if (!settled) {\r\n        settled = true;\r\n        if (timeoutId) clearTimeout(timeoutId);\r\n        effectRef?.destroy();\r\n        resolve(value);\r\n      }\r\n    };\r\n\r\n    try {\r\n      const destroyRef =\r\n        options.destroyRef ?? inject(DestroyRef, { optional: true });\r\n\r\n      destroyRef?.onDestroy(() => {\r\n        cleanupAndReject(\r\n          'until: Operation cancelled due to context destruction.',\r\n        );\r\n      });\r\n    } catch {\r\n      // noop\r\n    }\r\n\r\n    const initialValue = untracked(sourceSignal);\r\n    if (predicate(initialValue)) {\r\n      cleanupAndResolve(initialValue);\r\n      return;\r\n    }\r\n\r\n    if (options?.timeout !== undefined) {\r\n      timeoutId = setTimeout(\r\n        () => cleanupAndReject(`until: Timeout after ${options.timeout}ms.`),\r\n        options.timeout,\r\n      );\r\n    }\r\n\r\n    runInInjectionContext(injector, () => {\r\n      effectRef = effect(() => {\r\n        if (settled) {\r\n          return effectRef?.destroy();\r\n        }\r\n\r\n        const currentValue = sourceSignal();\r\n        if (predicate(currentValue)) {\r\n          cleanupAndResolve(currentValue);\r\n        }\r\n      });\r\n    });\r\n  });\r\n}\r\n"]}","import { SIGNAL } from '@angular/core/primitives/signals';\n/**\n * @interal\n */\nexport function getSignalEquality(sig) {\n const internal = sig[SIGNAL];\n if (internal && typeof internal.equal === 'function') {\n return internal.equal;\n }\n return Object.is; // Default equality check\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LXNpZ25hbC1lcXVhbGl0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc3JjL2xpYi9nZXQtc2lnbmFsLWVxdWFsaXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUUxRDs7R0FFRztBQUNILE1BQU0sVUFBVSxpQkFBaUIsQ0FBSSxHQUFjO0lBQ2pELE1BQU0sUUFBUSxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBRTFCLENBQUM7SUFDRixJQUFJLFFBQVEsSUFBSSxPQUFPLFFBQVEsQ0FBQyxLQUFLLEtBQUssVUFBVSxFQUFFLENBQUM7UUFDckQsT0FBTyxRQUFRLENBQUMsS0FBSyxDQUFDO0lBQ3hCLENBQUM7SUFDRCxPQUFPLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQyx5QkFBeUI7QUFDN0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNpZ25hbCwgVmFsdWVFcXVhbGl0eUZuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNJR05BTCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcHJpbWl0aXZlcy9zaWduYWxzJztcclxuXHJcbi8qKlxyXG4gKiBAaW50ZXJhbFxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIGdldFNpZ25hbEVxdWFsaXR5PFQ+KHNpZzogU2lnbmFsPFQ+KTogVmFsdWVFcXVhbGl0eUZuPFQ+IHtcclxuICBjb25zdCBpbnRlcm5hbCA9IHNpZ1tTSUdOQUxdIGFzIHtcclxuICAgIGVxdWFsPzogVmFsdWVFcXVhbGl0eUZuPFQ+O1xyXG4gIH07XHJcbiAgaWYgKGludGVybmFsICYmIHR5cGVvZiBpbnRlcm5hbC5lcXVhbCA9PT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgcmV0dXJuIGludGVybmFsLmVxdWFsO1xyXG4gIH1cclxuICByZXR1cm4gT2JqZWN0LmlzOyAvLyBEZWZhdWx0IGVxdWFsaXR5IGNoZWNrXHJcbn1cclxuIl19","import { computed, untracked, } from '@angular/core';\nimport { getSignalEquality } from './get-signal-equality';\nimport { mutable } from './mutable';\nimport { toWritable } from './to-writable';\n/**\n * Enhances an existing `WritableSignal` by adding a complete undo/redo history\n * stack and an API to control it.\n *\n * @template T The type of value held by the signal.\n * @param source The source `WritableSignal` to add history tracking to.\n * @param options Optional configuration for the history behavior.\n * @returns A `SignalWithHistory<T>` instance, augmenting the source signal with history APIs.\n *\n * @remarks\n * - Any new `.set()` or `.update()` call on the signal will clear the entire redo stack.\n * - The primitive attempts to automatically use the source signal's own `equal` function,\n * but this relies on an internal Angular API. For maximum stability across Angular\n * versions, it is recommended to provide an explicit `equal` function in the options.\n *\n * @example\n * ```ts\n * import { signal } from '@angular/core';\n * import { withHistory } from '@mmstack/primitives';\n *\n * const name = withHistory(signal('John'), { maxSize: 5 });\n *\n * console.log('Initial value:', name()); // \"John\"\n *\n * name.set('John Doe');\n * name.set('Jane Doe');\n *\n * console.log('Current value:', name()); // \"Jane Doe\"\n * console.log('History:', name.history()); // [\"John\", \"John Doe\"]\n * console.log('Can undo:', name.canUndo()); // true\n * console.log('Can redo:', name.canRedo()); // false\n *\n * name.undo();\n * console.log('After undo:', name()); // \"John Doe\"\n * console.log('Can redo:', name.canRedo()); // true\n *\n * name.redo();\n * console.log('After redo:', name()); // \"Jane Doe\"\n *\n * // A new change will clear the redo history\n * name.set('Janine Doe');\n * console.log('Can redo:', name.canRedo()); // false\n *\n * name.clear();\n * console.log('Can undo:', name.canUndo()); // false\n * ```\n */\nexport function withHistory(source, opt) {\n const equal = opt?.equal ?? getSignalEquality(source);\n const maxSize = opt?.maxSize ?? Infinity;\n const history = mutable([], {\n ...opt,\n equal: undefined,\n });\n const redoArray = mutable([]);\n const originalSet = source.set;\n const set = (value) => {\n const current = untracked(source);\n if (equal(value, current))\n return;\n source.set(value);\n history.mutate((c) => {\n if (c.length >= maxSize) {\n if (opt?.cleanupStrategy === 'shift') {\n c.shift();\n }\n else {\n c = c.slice(Math.floor(maxSize / 2));\n }\n }\n c.push(current);\n return c;\n });\n redoArray.set([]);\n };\n const update = (updater) => {\n set(updater(untracked(source)));\n };\n const internal = toWritable(computed(() => source(), {\n equal,\n debugName: opt?.debugName,\n }), set, update);\n internal.history = history;\n internal.undo = () => {\n const historyStack = untracked(history);\n if (historyStack.length === 0)\n return;\n const valueForRedo = untracked(source);\n const valueToRestore = historyStack.at(-1);\n if (valueToRestore === undefined)\n return;\n originalSet.call(source, valueToRestore);\n history.inline((h) => h.pop());\n redoArray.inline((r) => r.push(valueForRedo));\n };\n internal.redo = () => {\n const redoStack = untracked(redoArray);\n if (redoStack.length === 0)\n return;\n const valueForUndo = untracked(source);\n const valueToRestore = redoStack.at(-1);\n if (valueToRestore === undefined)\n return;\n originalSet.call(source, valueToRestore);\n redoArray.inline((r) => r.pop());\n history.mutate((h) => {\n if (h.length >= maxSize) {\n if (opt?.cleanupStrategy === 'shift') {\n h.shift();\n }\n else {\n h = h.slice(Math.floor(maxSize / 2));\n }\n }\n h.push(valueForUndo);\n return h;\n });\n };\n internal.clear = () => {\n history.set([]);\n redoArray.set([]);\n };\n internal.canUndo = computed(() => history().length > 0, ...(ngDevMode ? [{ debugName: \"canUndo\" }] : []));\n internal.canRedo = computed(() => redoArray().length > 0, ...(ngDevMode ? [{ debugName: \"canRedo\" }] : []));\n internal.canClear = computed(() => internal.canUndo() || internal.canRedo(), ...(ngDevMode ? [{ debugName: \"canClear\" }] : []));\n return internal;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-history.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/with-history.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  type CreateSignalOptions,\r\n  type Signal,\r\n  untracked,\r\n  type ValueEqualityFn,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { getSignalEquality } from './get-signal-equality';\r\nimport { mutable } from './mutable';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * A WritableSignal enhanced with undo/redo capabilities and history tracking.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type SignalWithHistory<T> = WritableSignal<T> & {\r\n  /** A read-only signal of the undo history stack. The oldest changes are at the start of the array. */\r\n  history: Signal<T[]>;\r\n  /** Reverts the signal to its most recent previous state in the history. */\r\n  undo: () => void;\r\n  /** Re-applies the last state that was undone. */\r\n  redo: () => void;\r\n  /** A signal that is `true` if there are states in the redo stack. */\r\n  canRedo: Signal<boolean>;\r\n  /** A signal that is `true` if there are states in the undo history. */\r\n  canUndo: Signal<boolean>;\r\n  /** Clears both the undo and redo history stacks. */\r\n  clear: () => void;\r\n  /** A signal that is `true` if there is any history that can be cleared. */\r\n  canClear: Signal<boolean>;\r\n};\r\n\r\n/**\r\n * Options for creating a signal with history tracking.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type CreateHistoryOptions<T> = Omit<\r\n  CreateSignalOptions<T[]>,\r\n  'equal'\r\n> & {\r\n  /**\r\n   * Optional custom equality function to determine if a value has changed before\r\n   * adding it to history. Defaults to the source signal's equality function or `Object.is`.\r\n   */\r\n  equal?: ValueEqualityFn<T>;\r\n  /**\r\n   * The maximum number of undo states to keep in the history.\r\n   * @default Infinity\r\n   */\r\n  maxSize?: number;\r\n  /**\r\n   * The strategy for trimming the history when `maxSize` is reached.\r\n   * - `shift`: Removes the single oldest entry from the history.\r\n   * - `halve`: Removes the oldest half of the history stack.\r\n   * @default 'halve'\r\n   */\r\n  cleanupStrategy?: 'shift' | 'halve';\r\n};\r\n\r\n/**\r\n * Enhances an existing `WritableSignal` by adding a complete undo/redo history\r\n * stack and an API to control it.\r\n *\r\n * @template T The type of value held by the signal.\r\n * @param source The source `WritableSignal` to add history tracking to.\r\n * @param options Optional configuration for the history behavior.\r\n * @returns A `SignalWithHistory<T>` instance, augmenting the source signal with history APIs.\r\n *\r\n * @remarks\r\n * - Any new `.set()` or `.update()` call on the signal will clear the entire redo stack.\r\n * - The primitive attempts to automatically use the source signal's own `equal` function,\r\n * but this relies on an internal Angular API. For maximum stability across Angular\r\n * versions, it is recommended to provide an explicit `equal` function in the options.\r\n *\r\n * @example\r\n * ```ts\r\n * import { signal } from '@angular/core';\r\n * import { withHistory } from '@mmstack/primitives';\r\n *\r\n * const name = withHistory(signal('John'), { maxSize: 5 });\r\n *\r\n * console.log('Initial value:', name()); // \"John\"\r\n *\r\n * name.set('John Doe');\r\n * name.set('Jane Doe');\r\n *\r\n * console.log('Current value:', name()); // \"Jane Doe\"\r\n * console.log('History:', name.history()); // [\"John\", \"John Doe\"]\r\n * console.log('Can undo:', name.canUndo()); // true\r\n * console.log('Can redo:', name.canRedo()); // false\r\n *\r\n * name.undo();\r\n * console.log('After undo:', name()); // \"John Doe\"\r\n * console.log('Can redo:', name.canRedo()); // true\r\n *\r\n * name.redo();\r\n * console.log('After redo:', name()); // \"Jane Doe\"\r\n *\r\n * // A new change will clear the redo history\r\n * name.set('Janine Doe');\r\n * console.log('Can redo:', name.canRedo()); // false\r\n *\r\n * name.clear();\r\n * console.log('Can undo:', name.canUndo()); // false\r\n * ```\r\n */\r\nexport function withHistory<T>(\r\n  source: WritableSignal<T>,\r\n  opt?: CreateHistoryOptions<T>,\r\n): SignalWithHistory<T> {\r\n  const equal = opt?.equal ?? getSignalEquality(source);\r\n  const maxSize = opt?.maxSize ?? Infinity;\r\n\r\n  const history = mutable<T[]>([], {\r\n    ...opt,\r\n    equal: undefined,\r\n  });\r\n\r\n  const redoArray = mutable<T[]>([]);\r\n\r\n  const originalSet = source.set;\r\n\r\n  const set = (value: T) => {\r\n    const current = untracked(source);\r\n    if (equal(value, current)) return;\r\n\r\n    source.set(value);\r\n\r\n    history.mutate((c) => {\r\n      if (c.length >= maxSize) {\r\n        if (opt?.cleanupStrategy === 'shift') {\r\n          c.shift();\r\n        } else {\r\n          c = c.slice(Math.floor(maxSize / 2));\r\n        }\r\n      }\r\n      c.push(current);\r\n      return c;\r\n    });\r\n    redoArray.set([]);\r\n  };\r\n\r\n  const update = (updater: (prev: T) => T) => {\r\n    set(updater(untracked(source)));\r\n  };\r\n\r\n  const internal = toWritable(\r\n    computed(() => source(), {\r\n      equal,\r\n      debugName: opt?.debugName,\r\n    }),\r\n    set,\r\n    update,\r\n  ) as SignalWithHistory<T>;\r\n  internal.history = history;\r\n\r\n  internal.undo = () => {\r\n    const historyStack = untracked(history);\r\n    if (historyStack.length === 0) return;\r\n\r\n    const valueForRedo = untracked(source);\r\n    const valueToRestore = historyStack.at(-1);\r\n    if (valueToRestore === undefined) return;\r\n\r\n    originalSet.call(source, valueToRestore);\r\n\r\n    history.inline((h) => h.pop());\r\n    redoArray.inline((r) => r.push(valueForRedo));\r\n  };\r\n\r\n  internal.redo = () => {\r\n    const redoStack = untracked(redoArray);\r\n    if (redoStack.length === 0) return;\r\n\r\n    const valueForUndo = untracked(source);\r\n    const valueToRestore = redoStack.at(-1);\r\n    if (valueToRestore === undefined) return;\r\n\r\n    originalSet.call(source, valueToRestore);\r\n\r\n    redoArray.inline((r) => r.pop());\r\n    history.mutate((h) => {\r\n      if (h.length >= maxSize) {\r\n        if (opt?.cleanupStrategy === 'shift') {\r\n          h.shift();\r\n        } else {\r\n          h = h.slice(Math.floor(maxSize / 2));\r\n        }\r\n      }\r\n      h.push(valueForUndo);\r\n      return h;\r\n    });\r\n  };\r\n\r\n  internal.clear = () => {\r\n    history.set([]);\r\n    redoArray.set([]);\r\n  };\r\n\r\n  internal.canUndo = computed(() => history().length > 0);\r\n  internal.canRedo = computed(() => redoArray().length > 0);\r\n  internal.canClear = computed(() => internal.canUndo() || internal.canRedo());\r\n\r\n  return internal;\r\n}\r\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW1zdGFjay1wcmltaXRpdmVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9zcmMvbW1zdGFjay1wcmltaXRpdmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"mmstack-primitives.mjs","sources":["../tmp-esm2022/lib/to-writable.js","../tmp-esm2022/lib/debounced.js","../tmp-esm2022/lib/mutable.js","../tmp-esm2022/lib/derived.js","../tmp-esm2022/lib/element-visibility.js","../tmp-esm2022/lib/map-array.js","../tmp-esm2022/lib/nested-effect.js","../tmp-esm2022/lib/pipeable/operators.js","../tmp-esm2022/lib/pipeable/pipeble.js","../tmp-esm2022/lib/sensors/media-query.js","../tmp-esm2022/lib/throttled.js","../tmp-esm2022/lib/sensors/mouse-position.js","../tmp-esm2022/lib/sensors/network-status.js","../tmp-esm2022/lib/sensors/page-visibility.js","../tmp-esm2022/lib/sensors/scroll-position.js","../tmp-esm2022/lib/sensors/window-size.js","../tmp-esm2022/lib/sensors/sensor.js","../tmp-esm2022/lib/stored.js","../tmp-esm2022/lib/tabSync.js","../tmp-esm2022/lib/until.js","../tmp-esm2022/lib/get-signal-equality.js","../tmp-esm2022/lib/with-history.js","../tmp-esm2022/mmstack-primitives.js"],"sourcesContent":["import { untracked } from '@angular/core';\n/**\n * Converts a read-only `Signal` into a `WritableSignal` by providing custom `set` and, optionally, `update` functions.\n * This can be useful for creating controlled write access to a signal that is otherwise read-only.\n *\n * @typeParam T - The type of value held by the signal.\n *\n * @param signal - The read-only `Signal` to be made writable.\n * @param set - A function that will be used to set the signal's value. This function *must* handle\n * the actual update mechanism (e.g., updating a backing store, emitting an event, etc.).\n * @param update - (Optional) A function that will be used to update the signal's value based on its\n * previous value. If not provided, a default `update` implementation is used that\n * calls the provided `set` function with the result of the updater function. The\n * default implementation uses `untracked` to avoid creating unnecessary dependencies\n * within the updater function.\n *\n * @returns A `WritableSignal` that uses the provided `set` and `update` functions. The `asReadonly`\n * method of the returned signal will still return the original read-only signal.\n *\n * @example\n * // Basic usage: Making a read-only signal writable with a custom set function.\n * const originalValue = signal({a: 0});\n * const readOnlySignal = computed(() => originalValue().a);\n * const writableSignal = toWritable(readOnlySignal, (newValue) => {\n * originalValue.update((prev) => { ...prev, a: newValue });\n * });\n *\n * writableSignal.set(5); // sets value of originalValue.a to 5 & triggers all signals\n */\nexport function toWritable(signal, set, update) {\n const internal = signal;\n internal.asReadonly = () => signal;\n internal.set = set;\n internal.update = update ?? ((updater) => set(updater(untracked(internal))));\n return internal;\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG8td3JpdGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3NyYy9saWIvdG8td3JpdGFibGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFVLFNBQVMsRUFBa0IsTUFBTSxlQUFlLENBQUM7QUFFbEU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTJCRztBQUNILE1BQU0sVUFBVSxVQUFVLENBQ3hCLE1BQWlCLEVBQ2pCLEdBQXVCLEVBQ3ZCLE1BQTJDO0lBRTNDLE1BQU0sUUFBUSxHQUFHLE1BQTJCLENBQUM7SUFDN0MsUUFBUSxDQUFDLFVBQVUsR0FBRyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUM7SUFDbkMsUUFBUSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7SUFDbkIsUUFBUSxDQUFDLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFFN0UsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNpZ25hbCwgdW50cmFja2VkLCBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIENvbnZlcnRzIGEgcmVhZC1vbmx5IGBTaWduYWxgIGludG8gYSBgV3JpdGFibGVTaWduYWxgIGJ5IHByb3ZpZGluZyBjdXN0b20gYHNldGAgYW5kLCBvcHRpb25hbGx5LCBgdXBkYXRlYCBmdW5jdGlvbnMuXHJcbiAqIFRoaXMgY2FuIGJlIHVzZWZ1bCBmb3IgY3JlYXRpbmcgY29udHJvbGxlZCB3cml0ZSBhY2Nlc3MgdG8gYSBzaWduYWwgdGhhdCBpcyBvdGhlcndpc2UgcmVhZC1vbmx5LlxyXG4gKlxyXG4gKiBAdHlwZVBhcmFtIFQgLSBUaGUgdHlwZSBvZiB2YWx1ZSBoZWxkIGJ5IHRoZSBzaWduYWwuXHJcbiAqXHJcbiAqIEBwYXJhbSBzaWduYWwgLSBUaGUgcmVhZC1vbmx5IGBTaWduYWxgIHRvIGJlIG1hZGUgd3JpdGFibGUuXHJcbiAqIEBwYXJhbSBzZXQgLSBBIGZ1bmN0aW9uIHRoYXQgd2lsbCBiZSB1c2VkIHRvIHNldCB0aGUgc2lnbmFsJ3MgdmFsdWUuICBUaGlzIGZ1bmN0aW9uICptdXN0KiBoYW5kbGVcclxuICogICAgICAgICAgICAgIHRoZSBhY3R1YWwgdXBkYXRlIG1lY2hhbmlzbSAoZS5nLiwgdXBkYXRpbmcgYSBiYWNraW5nIHN0b3JlLCBlbWl0dGluZyBhbiBldmVudCwgZXRjLikuXHJcbiAqIEBwYXJhbSB1cGRhdGUgLSAoT3B0aW9uYWwpIEEgZnVuY3Rpb24gdGhhdCB3aWxsIGJlIHVzZWQgdG8gdXBkYXRlIHRoZSBzaWduYWwncyB2YWx1ZSBiYXNlZCBvbiBpdHNcclxuICogICAgICAgICAgICAgICAgIHByZXZpb3VzIHZhbHVlLiAgSWYgbm90IHByb3ZpZGVkLCBhIGRlZmF1bHQgYHVwZGF0ZWAgaW1wbGVtZW50YXRpb24gaXMgdXNlZCB0aGF0XHJcbiAqICAgICAgICAgICAgICAgICBjYWxscyB0aGUgcHJvdmlkZWQgYHNldGAgZnVuY3Rpb24gd2l0aCB0aGUgcmVzdWx0IG9mIHRoZSB1cGRhdGVyIGZ1bmN0aW9uLiBUaGVcclxuICogICAgICAgICAgICAgICAgIGRlZmF1bHQgaW1wbGVtZW50YXRpb24gdXNlcyBgdW50cmFja2VkYCB0byBhdm9pZCBjcmVhdGluZyB1bm5lY2Vzc2FyeSBkZXBlbmRlbmNpZXNcclxuICogICAgICAgICAgICAgICAgIHdpdGhpbiB0aGUgdXBkYXRlciBmdW5jdGlvbi5cclxuICpcclxuICogQHJldHVybnMgQSBgV3JpdGFibGVTaWduYWxgIHRoYXQgdXNlcyB0aGUgcHJvdmlkZWQgYHNldGAgYW5kIGB1cGRhdGVgIGZ1bmN0aW9ucy4gIFRoZSBgYXNSZWFkb25seWBcclxuICogICAgICAgICAgbWV0aG9kIG9mIHRoZSByZXR1cm5lZCBzaWduYWwgd2lsbCBzdGlsbCByZXR1cm4gdGhlIG9yaWdpbmFsIHJlYWQtb25seSBzaWduYWwuXHJcbiAqXHJcbiAqIEBleGFtcGxlXHJcbiAqIC8vIEJhc2ljIHVzYWdlOiBNYWtpbmcgYSByZWFkLW9ubHkgc2lnbmFsIHdyaXRhYmxlIHdpdGggYSBjdXN0b20gc2V0IGZ1bmN0aW9uLlxyXG4gKiBjb25zdCBvcmlnaW5hbFZhbHVlID0gc2lnbmFsKHthOiAwfSk7XHJcbiAqIGNvbnN0IHJlYWRPbmx5U2lnbmFsID0gY29tcHV0ZWQoKCkgPT4gb3JpZ2luYWxWYWx1ZSgpLmEpO1xyXG4gKiBjb25zdCB3cml0YWJsZVNpZ25hbCA9IHRvV3JpdGFibGUocmVhZE9ubHlTaWduYWwsIChuZXdWYWx1ZSkgPT4ge1xyXG4gKiAgb3JpZ2luYWxWYWx1ZS51cGRhdGUoKHByZXYpID0+IHsgLi4ucHJldiwgYTogbmV3VmFsdWUgfSk7XHJcbiAqIH0pO1xyXG4gKlxyXG4gKiB3cml0YWJsZVNpZ25hbC5zZXQoNSk7IC8vIHNldHMgdmFsdWUgb2Ygb3JpZ2luYWxWYWx1ZS5hIHRvIDUgJiB0cmlnZ2VycyBhbGwgc2lnbmFsc1xyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIHRvV3JpdGFibGU8VD4oXHJcbiAgc2lnbmFsOiBTaWduYWw8VD4sXHJcbiAgc2V0OiAodmFsdWU6IFQpID0+IHZvaWQsXHJcbiAgdXBkYXRlPzogKHVwZGF0ZXI6ICh2YWx1ZTogVCkgPT4gVCkgPT4gdm9pZCxcclxuKTogV3JpdGFibGVTaWduYWw8VD4ge1xyXG4gIGNvbnN0IGludGVybmFsID0gc2lnbmFsIGFzIFdyaXRhYmxlU2lnbmFsPFQ+O1xyXG4gIGludGVybmFsLmFzUmVhZG9ubHkgPSAoKSA9PiBzaWduYWw7XHJcbiAgaW50ZXJuYWwuc2V0ID0gc2V0O1xyXG4gIGludGVybmFsLnVwZGF0ZSA9IHVwZGF0ZSA/PyAoKHVwZGF0ZXIpID0+IHNldCh1cGRhdGVyKHVudHJhY2tlZChpbnRlcm5hbCkpKSk7XHJcblxyXG4gIHJldHVybiBpbnRlcm5hbDtcclxufVxyXG4iXX0=","import { computed, DestroyRef, inject, signal, untracked, } from '@angular/core';\nimport { toWritable } from './to-writable';\n/**\n * A convenience function that creates and debounces a new `WritableSignal` in one step.\n *\n * @see {debounce} for the core implementation details.\n *\n * @template T The type of value the signal holds.\n * @param initial The initial value of the signal.\n * @param opt Options for signal creation, including debounce time `ms`.\n * @returns A `DebouncedSignal<T>` instance.\n *\n * @example\n * // The existing example remains perfect here.\n * const query = debounced('', { ms: 500 });\n * effect(() => console.log('Debounced Query:', query()));\n * query.set('abc');\n * // ...500ms later...\n * // Output: Debounced Query: abc\n */\nexport function debounced(initial, opt) {\n return debounce(signal(initial, opt), opt);\n}\n/**\n * Wraps an existing `WritableSignal` to create a new one whose readable value is debounced.\n *\n * This implementation avoids using `effect` by pairing a trigger signal with an `untracked`\n * read of the source signal to control when the debounced value is re-evaluated.\n *\n * @template T The type of value the signal holds.\n * @param source The source `WritableSignal` to wrap. Writes are applied to this signal immediately.\n * @param opt Options for debouncing, including debounce time `ms` and an optional `DestroyRef`.\n * @returns A new `DebouncedSignal<T>` whose read value is debounced. The `.original` property\n * of the returned signal is a reference back to the provided `source` signal.\n *\n * @example\n * ```ts\n * import { signal, effect } from '@angular/core';\n *\n * // 1. Create a standard source signal.\n * const sourceQuery = signal('');\n *\n * // 2. Create a debounced version of it.\n * const debouncedQuery = debounce(sourceQuery, { ms: 500 });\n *\n * // This effect tracks the original signal and runs immediately.\n * effect(() => {\n * console.log('Original Query:', debouncedQuery.original());\n * });\n *\n * // This effect tracks the debounced signal and runs after the delay.\n * effect(() => {\n * console.log('Debounced Query:', debouncedQuery());\n * });\n *\n * console.log('Setting query to \"a\"');\n * debouncedQuery.set('a');\n * // Output: Original Query: a\n *\n * // ...500ms later...\n * // Output: Debounced Query: a\n * ```\n */\nexport function debounce(source, opt) {\n const ms = opt?.ms ?? 0;\n const trigger = signal(false, ...(ngDevMode ? [{ debugName: \"trigger\" }] : []));\n let timeout;\n try {\n const destroyRef = opt?.destroyRef ?? inject(DestroyRef, { optional: true });\n destroyRef?.onDestroy(() => {\n if (timeout)\n clearTimeout(timeout);\n timeout = undefined;\n });\n }\n catch {\n // not in injection context & no destroyRef provided opting out of cleanup\n }\n const triggerFn = (afterClean) => {\n if (timeout)\n clearTimeout(timeout);\n afterClean();\n timeout = setTimeout(() => {\n trigger.update((c) => !c);\n }, ms);\n };\n const set = (value) => {\n triggerFn(() => source.set(value));\n };\n const update = (fn) => {\n triggerFn(() => source.update(fn));\n };\n const writable = toWritable(computed(() => {\n trigger();\n return untracked(source);\n }, opt), set, update);\n writable.original = source;\n return writable;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"debounced.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/debounced.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAER,UAAU,EACV,MAAM,EAEN,MAAM,EACN,SAAS,GAEV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAwC3C;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,UAAU,SAAS,CACvB,OAAU,EACV,GAA+B;IAE/B,OAAO,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;AAC7C,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,MAAM,UAAU,QAAQ,CACtB,MAAyB,EACzB,GAA+B;IAE/B,MAAM,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,CAAC,CAAC;IAExB,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,mDAAC,CAAC;IAE9B,IAAI,OAAkD,CAAC;IAEvD,IAAI,CAAC;QACH,MAAM,UAAU,GACd,GAAG,EAAE,UAAU,IAAI,MAAM,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAE5D,UAAU,EAAE,SAAS,CAAC,GAAG,EAAE;YACzB,IAAI,OAAO;gBAAE,YAAY,CAAC,OAAO,CAAC,CAAC;YACnC,OAAO,GAAG,SAAS,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IAAC,MAAM,CAAC;QACP,0EAA0E;IAC5E,CAAC;IAED,MAAM,SAAS,GAAG,CAAC,UAAsB,EAAE,EAAE;QAC3C,IAAI,OAAO;YAAE,YAAY,CAAC,OAAO,CAAC,CAAC;QACnC,UAAU,EAAE,CAAC;QACb,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;YACxB,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5B,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC,CAAC;IAEF,MAAM,GAAG,GAAG,CAAC,KAAQ,EAAE,EAAE;QACvB,SAAS,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC;IAEF,MAAM,MAAM,GAAG,CAAC,EAAkB,EAAE,EAAE;QACpC,SAAS,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC;IAEF,MAAM,QAAQ,GAAG,UAAU,CACzB,QAAQ,CAAC,GAAG,EAAE;QACZ,OAAO,EAAE,CAAC;QACV,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC,EAAE,GAAG,CAAC,EACP,GAAG,EACH,MAAM,CACe,CAAC;IACxB,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC;IAE3B,OAAO,QAAQ,CAAC;AAClB,CAAC","sourcesContent":["import {\r\n  computed,\r\n  type CreateSignalOptions,\r\n  DestroyRef,\r\n  inject,\r\n  type Signal,\r\n  signal,\r\n  untracked,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * Options for creating a debounced writable signal.\r\n * Extends Angular's `CreateSignalOptions` with a debounce time setting.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type CreateDebouncedOptions<T> = CreateSignalOptions<T> & {\r\n  /**\r\n   * The debounce delay in milliseconds. Specifies how long to wait after the\r\n   * last `set` or `update` call before the debounced signal reflects the new value.\r\n   */\r\n  ms?: number;\r\n  /**\r\n   * Optional `DestroyRef` to clean up the debounce timer when the signal is destroyed.\r\n   * If provided, the timer will be cleared when the signal is destroyed.\r\n   * If the signal is called within a reactive context a DestroyRef is injected automatically.\r\n   * If it is not provided or injected, the timer will not be cleared automatically...which is usually fine :)\r\n   */\r\n  destroyRef?: DestroyRef;\r\n};\r\n\r\n/**\r\n * A specialized `WritableSignal` whose publicly readable value updates are debounced.\r\n *\r\n * It provides access to the underlying, non-debounced signal via the `original` property.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type DebouncedSignal<T> = WritableSignal<T> & {\r\n  /**\r\n   * A reference to the original, inner `WritableSignal`.\r\n   * This signal's value is updated *immediately* upon calls to `set` or `update`\r\n   * on the parent `DebouncedSignal`. Useful for accessing the latest value\r\n   * without the debounce delay.\r\n   */\r\n  original: Signal<T>;\r\n};\r\n\r\n/**\r\n * A convenience function that creates and debounces a new `WritableSignal` in one step.\r\n *\r\n * @see {debounce} for the core implementation details.\r\n *\r\n * @template T The type of value the signal holds.\r\n * @param initial The initial value of the signal.\r\n * @param opt Options for signal creation, including debounce time `ms`.\r\n * @returns A `DebouncedSignal<T>` instance.\r\n *\r\n * @example\r\n * // The existing example remains perfect here.\r\n * const query = debounced('', { ms: 500 });\r\n * effect(() => console.log('Debounced Query:', query()));\r\n * query.set('abc');\r\n * // ...500ms later...\r\n * // Output: Debounced Query: abc\r\n */\r\nexport function debounced<T>(\r\n  initial: T,\r\n  opt?: CreateDebouncedOptions<T>,\r\n): DebouncedSignal<T> {\r\n  return debounce(signal(initial, opt), opt);\r\n}\r\n\r\n/**\r\n * Wraps an existing `WritableSignal` to create a new one whose readable value is debounced.\r\n *\r\n * This implementation avoids using `effect` by pairing a trigger signal with an `untracked`\r\n * read of the source signal to control when the debounced value is re-evaluated.\r\n *\r\n * @template T The type of value the signal holds.\r\n * @param source The source `WritableSignal` to wrap. Writes are applied to this signal immediately.\r\n * @param opt Options for debouncing, including debounce time `ms` and an optional `DestroyRef`.\r\n * @returns A new `DebouncedSignal<T>` whose read value is debounced. The `.original` property\r\n * of the returned signal is a reference back to the provided `source` signal.\r\n *\r\n * @example\r\n * ```ts\r\n * import { signal, effect } from '@angular/core';\r\n *\r\n * // 1. Create a standard source signal.\r\n * const sourceQuery = signal('');\r\n *\r\n * // 2. Create a debounced version of it.\r\n * const debouncedQuery = debounce(sourceQuery, { ms: 500 });\r\n *\r\n * // This effect tracks the original signal and runs immediately.\r\n * effect(() => {\r\n * console.log('Original Query:', debouncedQuery.original());\r\n * });\r\n *\r\n * // This effect tracks the debounced signal and runs after the delay.\r\n * effect(() => {\r\n * console.log('Debounced Query:', debouncedQuery());\r\n * });\r\n *\r\n * console.log('Setting query to \"a\"');\r\n * debouncedQuery.set('a');\r\n * // Output: Original Query: a\r\n *\r\n * // ...500ms later...\r\n * // Output: Debounced Query: a\r\n * ```\r\n */\r\nexport function debounce<T>(\r\n  source: WritableSignal<T>,\r\n  opt?: CreateDebouncedOptions<T>,\r\n): DebouncedSignal<T> {\r\n  const ms = opt?.ms ?? 0;\r\n\r\n  const trigger = signal(false);\r\n\r\n  let timeout: ReturnType<typeof setTimeout> | undefined;\r\n\r\n  try {\r\n    const destroyRef =\r\n      opt?.destroyRef ?? inject(DestroyRef, { optional: true });\r\n\r\n    destroyRef?.onDestroy(() => {\r\n      if (timeout) clearTimeout(timeout);\r\n      timeout = undefined;\r\n    });\r\n  } catch {\r\n    // not in injection context & no destroyRef provided opting out of cleanup\r\n  }\r\n\r\n  const triggerFn = (afterClean: () => void) => {\r\n    if (timeout) clearTimeout(timeout);\r\n    afterClean();\r\n    timeout = setTimeout(() => {\r\n      trigger.update((c) => !c);\r\n    }, ms);\r\n  };\r\n\r\n  const set = (value: T) => {\r\n    triggerFn(() => source.set(value));\r\n  };\r\n\r\n  const update = (fn: (prev: T) => T) => {\r\n    triggerFn(() => source.update(fn));\r\n  };\r\n\r\n  const writable = toWritable(\r\n    computed(() => {\r\n      trigger();\r\n      return untracked(source);\r\n    }, opt),\r\n    set,\r\n    update,\r\n  ) as DebouncedSignal<T>;\r\n  writable.original = source;\r\n\r\n  return writable;\r\n}\r\n"]}","import { signal, } from '@angular/core';\nconst { is } = Object;\nexport function mutable(initial, opt) {\n const baseEqual = opt?.equal ?? is;\n let trigger = false;\n const equal = (a, b) => {\n if (trigger)\n return false;\n return baseEqual(a, b);\n };\n const sig = signal(initial, {\n ...opt,\n equal,\n });\n const internalUpdate = sig.update;\n sig.mutate = (updater) => {\n trigger = true;\n internalUpdate(updater);\n trigger = false;\n };\n sig.inline = (updater) => {\n sig.mutate((prev) => {\n updater(prev);\n return prev;\n });\n };\n return sig;\n}\n/**\n * Type guard function to check if a given `WritableSignal` is a `MutableSignal`. This is useful\n * for situations where you need to conditionally use the `mutate` or `inline` methods.\n *\n * @typeParam T - The type of the signal's value (optional, defaults to `any`).\n * @param value - The `WritableSignal` to check.\n * @returns `true` if the signal is a `MutableSignal`, `false` otherwise.\n *\n * @example\n * const mySignal = signal(0);\n * const myMutableSignal = mutable(0);\n *\n * if (isMutable(mySignal)) {\n * mySignal.mutate(x => x + 1); // This would cause a type error, as mySignal is not a MutableSignal.\n * }\n *\n * if (isMutable(myMutableSignal)) {\n * myMutableSignal.mutate(x => x + 1); // This is safe.\n * }\n */\nexport function isMutable(value) {\n return 'mutate' in value && typeof value.mutate === 'function';\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mutable.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/mutable.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,MAAM,GAIP,MAAM,eAAe,CAAC;AAEvB,MAAM,EAAE,EAAE,EAAE,GAAG,MAAM,CAAC;AAiFtB,MAAM,UAAU,OAAO,CACrB,OAAW,EACX,GAA4B;IAE5B,MAAM,SAAS,GAAG,GAAG,EAAE,KAAK,IAAI,EAAE,CAAC;IACnC,IAAI,OAAO,GAAG,KAAK,CAAC;IAEpB,MAAM,KAAK,GAAmC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACrD,IAAI,OAAO;YAAE,OAAO,KAAK,CAAC;QAC1B,OAAO,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzB,CAAC,CAAC;IAEF,MAAM,GAAG,GAAG,MAAM,CAAgB,OAAO,EAAE;QACzC,GAAG,GAAG;QACN,KAAK;KACN,CAAqB,CAAC;IAEvB,MAAM,cAAc,GAAG,GAAG,CAAC,MAAM,CAAC;IAElC,GAAG,CAAC,MAAM,GAAG,CAAC,OAAO,EAAE,EAAE;QACvB,OAAO,GAAG,IAAI,CAAC;QACf,cAAc,CAAC,OAAO,CAAC,CAAC;QACxB,OAAO,GAAG,KAAK,CAAC;IAClB,CAAC,CAAC;IAEF,GAAG,CAAC,MAAM,GAAG,CAAC,OAAO,EAAE,EAAE;QACvB,GAAG,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YAClB,OAAO,CAAC,IAAI,CAAC,CAAC;YACd,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,OAAO,GAAG,CAAC;AACb,CAAC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,SAAS,CACvB,KAAwB;IAExB,OAAO,QAAQ,IAAI,KAAK,IAAI,OAAO,KAAK,CAAC,MAAM,KAAK,UAAU,CAAC;AACjE,CAAC","sourcesContent":["import {\r\n  signal,\r\n  type CreateSignalOptions,\r\n  type ValueEqualityFn,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\n\r\nconst { is } = Object;\r\n\r\n/**\r\n * A `MutableSignal` is a special type of `WritableSignal` that allows for in-place mutation of its value.\r\n * In addition to the standard `set` and `update` methods, it provides a `mutate` method.  This is useful\r\n * for performance optimization when dealing with complex objects or arrays, as it avoids unnecessary\r\n * object copying.\r\n *\r\n * @typeParam T - The type of value held by the signal.\r\n */\r\nexport type MutableSignal<T> = WritableSignal<T> & {\r\n  /**\r\n   * Mutates the signal's value in-place.  This is similar to `update`, but it's optimized for\r\n   * scenarios where you want to modify the existing object directly rather than creating a new one.\r\n   *\r\n   * @param updater - A function that takes the current value as input and modifies it directly.\r\n   *\r\n   * @example\r\n   * const myArray = mutable([1, 2, 3]);\r\n   * myArray.mutate((arr) => {\r\n   *  arr.push(4);\r\n   *  return arr;\r\n   * }); // myArray() now returns [1, 2, 3, 4]\r\n   */\r\n  mutate: WritableSignal<T>['update'];\r\n\r\n  /**\r\n   * Mutates the signal's value in-place, similar to `mutate`, but with a void-returning value in updater\r\n   * function. This further emphasizes that the mutation is happening inline, improving readability\r\n   * in some cases.\r\n   * @param updater - Function to change to the current value\r\n   * @example\r\n   * const myObject = mutable({ a: 1, b: 2 });\r\n   * myObject.inline((obj) => (obj.a = 3)); // myObject() now returns { a: 3, b: 2 }\r\n   */\r\n  inline: (updater: (value: T) => void) => void;\r\n};\r\n\r\n/**\r\n * Creates a `MutableSignal`. This function overloads the standard `signal` function to provide\r\n * the additional `mutate` and `inline` methods.\r\n *\r\n * @typeParam T The type of value held by the signal.\r\n * @param initial The initial value of the signal.\r\n * @param options Optional signal options, including a custom `equal` function.\r\n * @returns A `MutableSignal` instance.\r\n *\r\n * ### Important Note on `computed` Signals\r\n *\r\n * When creating a `computed` signal that derives a non-primitive value (e.g., an object or array)\r\n * from a `mutable` signal, you **must** provide the `{ equal: false }` option to the `computed`\r\n * function.\r\n *\r\n * This is because a `.mutate()` call notifies its dependents that it has changed, but if the\r\n * reference to a derived object hasn't changed, the `computed` signal will not trigger its\r\n * own dependents by default.\r\n *\r\n * @example\r\n * ```ts\r\n * const state = mutable({ user: { name: 'John' }, lastUpdated: new Date() });\r\n *\r\n * // ✅ CORRECT: Deriving a primitive value works as expected.\r\n * const name = computed(() => state().user.name);\r\n *\r\n * // ❌ INCORRECT: This will not update reliably after the first change.\r\n * const userObject = computed(() => state().user);\r\n *\r\n * // ✅ CORRECT: For object derivations, `equal: false` is required.\r\n * const userObjectFixed = computed(() => state().user, { equal: false });\r\n *\r\n * // This mutation will now correctly trigger effects depending on `userObjectFixed`.\r\n * state.mutate(s => s.lastUpdated = new Date());\r\n * ```\r\n */\r\nexport function mutable<T>(): MutableSignal<T | undefined>;\r\nexport function mutable<T>(initial: T): MutableSignal<T>;\r\nexport function mutable<T>(\r\n  initial: T,\r\n  opt?: CreateSignalOptions<T>,\r\n): MutableSignal<T>;\r\n\r\nexport function mutable<T>(\r\n  initial?: T,\r\n  opt?: CreateSignalOptions<T>,\r\n): MutableSignal<T> {\r\n  const baseEqual = opt?.equal ?? is;\r\n  let trigger = false;\r\n\r\n  const equal: ValueEqualityFn<T | undefined> = (a, b) => {\r\n    if (trigger) return false;\r\n    return baseEqual(a, b);\r\n  };\r\n\r\n  const sig = signal<T | undefined>(initial, {\r\n    ...opt,\r\n    equal,\r\n  }) as MutableSignal<T>;\r\n\r\n  const internalUpdate = sig.update;\r\n\r\n  sig.mutate = (updater) => {\r\n    trigger = true;\r\n    internalUpdate(updater);\r\n    trigger = false;\r\n  };\r\n\r\n  sig.inline = (updater) => {\r\n    sig.mutate((prev) => {\r\n      updater(prev);\r\n      return prev;\r\n    });\r\n  };\r\n\r\n  return sig;\r\n}\r\n\r\n/**\r\n * Type guard function to check if a given `WritableSignal` is a `MutableSignal`.  This is useful\r\n * for situations where you need to conditionally use the `mutate` or `inline` methods.\r\n *\r\n * @typeParam T - The type of the signal's value (optional, defaults to `any`).\r\n * @param value - The `WritableSignal` to check.\r\n * @returns `true` if the signal is a `MutableSignal`, `false` otherwise.\r\n *\r\n * @example\r\n * const mySignal = signal(0);\r\n * const myMutableSignal = mutable(0);\r\n *\r\n * if (isMutable(mySignal)) {\r\n *   mySignal.mutate(x => x + 1); // This would cause a type error, as mySignal is not a MutableSignal.\r\n * }\r\n *\r\n * if (isMutable(myMutableSignal)) {\r\n *   myMutableSignal.mutate(x => x + 1); // This is safe.\r\n * }\r\n */\r\nexport function isMutable<T = any>(\r\n  value: WritableSignal<T>,\r\n): value is MutableSignal<T> {\r\n  return 'mutate' in value && typeof value.mutate === 'function';\r\n}\r\n"]}","import { computed, signal, untracked, } from '@angular/core';\nimport { isMutable } from './mutable';\nimport { toWritable } from './to-writable';\nexport function derived(source, optOrKey, opt) {\n const isArray = Array.isArray(untracked(source)) && typeof optOrKey === 'number';\n const from = typeof optOrKey === 'object' ? optOrKey.from : (v) => v[optOrKey];\n const onChange = typeof optOrKey === 'object'\n ? optOrKey.onChange\n : isArray\n ? isMutable(source)\n ? (next) => {\n source.mutate((cur) => {\n cur[optOrKey] = next;\n return cur;\n });\n }\n : (next) => {\n source.update((cur) => {\n const newArray = [...cur];\n newArray[optOrKey] = next;\n return newArray;\n });\n }\n : isMutable(source)\n ? (next) => {\n source.mutate((cur) => {\n cur[optOrKey] = next;\n return cur;\n });\n }\n : (next) => {\n source.update((cur) => ({ ...cur, [optOrKey]: next }));\n };\n const rest = typeof optOrKey === 'object' ? optOrKey : opt;\n const baseEqual = rest?.equal ?? Object.is;\n let trigger = false;\n const equal = isMutable(source)\n ? (a, b) => {\n if (trigger)\n return false;\n return baseEqual(a, b);\n }\n : baseEqual;\n const sig = toWritable(computed(() => from(source()), { ...rest, equal }), (newVal) => onChange(newVal));\n sig.from = from;\n if (isMutable(source)) {\n sig.mutate = (updater) => {\n trigger = true;\n sig.update(updater);\n trigger = false;\n };\n sig.inline = (updater) => {\n sig.mutate((prev) => {\n updater(prev);\n return prev;\n });\n };\n }\n return sig;\n}\n/**\n * Creates a \"fake\" `DerivedSignal` from a simple value. This is useful for creating\n * `FormControlSignal` instances that are not directly derived from another signal.\n * The returned signal's `from` function will always return the initial value.\n *\n * @typeParam T - This type parameter is not used in the implementation but is kept for type compatibility with `DerivedSignal`.\n * @typeParam U - The type of the signal's value.\n * @param initial - The initial value of the signal.\n * @returns A `DerivedSignal` instance.\n * @internal\n */\nexport function toFakeDerivation(initial) {\n const sig = signal(initial);\n sig.from = () => initial;\n return sig;\n}\n/**\n * Creates a \"fake\" `DerivedSignal` from an existing `WritableSignal`. This is useful\n * for treating a regular `WritableSignal` as a `DerivedSignal` without changing its behavior.\n * The returned signal's `from` function returns the current value of signal, using `untracked`.\n *\n * @typeParam T - This type parameter is not used in the implementation but is kept for type compatibility with `DerivedSignal`.\n * @typeParam U - The type of the signal's value.\n * @param initial - The existing `WritableSignal`.\n * @returns A `DerivedSignal` instance.\n * @internal\n */\nexport function toFakeSignalDerivation(initial) {\n const sig = initial;\n sig.from = () => untracked(initial);\n return sig;\n}\n/**\n * Type guard function to check if a given `WritableSignal` is a `DerivedSignal`.\n *\n * @typeParam T - The type of the source signal's value (optional, defaults to `any`).\n * @typeParam U - The type of the derived signal's value (optional, defaults to `any`).\n * @param sig - The `WritableSignal` to check.\n * @returns `true` if the signal is a `DerivedSignal`, `false` otherwise.\n */\nexport function isDerivation(sig) {\n return 'from' in sig;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"derived.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/derived.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  CreateSignalOptions,\r\n  signal,\r\n  untracked,\r\n  ValueEqualityFn,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { isMutable, MutableSignal } from './mutable';\r\nimport { toWritable } from './to-writable';\r\n\r\ntype UnknownObject = Record<PropertyKey, unknown>;\r\n\r\n/**\r\n * Options for creating a derived signal using the full `derived` function signature.\r\n * @typeParam T - The type of the source signal's value (parent).\r\n * @typeParam U - The type of the derived signal's value (child).\r\n */\r\ntype CreateDerivedOptions<T, U> = CreateSignalOptions<U> & {\r\n  /**\r\n   * A function that extracts the derived value (`U`) from the source signal's value (`T`).\r\n   */\r\n  from: (v: T) => U;\r\n  /**\r\n   * A function that updates the source signal's value (`T`) when the derived signal's value (`U`) changes.\r\n   * This establishes the two-way binding.\r\n   */\r\n  onChange: (newValue: U) => void;\r\n};\r\n\r\n/**\r\n * A `WritableSignal` that derives its value from another `WritableSignal` (the \"source\" signal).\r\n * It provides two-way binding: changes to the source signal update the derived signal, and\r\n * changes to the derived signal update the source signal.\r\n *\r\n * @typeParam T - The type of the source signal's value (parent).\r\n * @typeParam U - The type of the derived signal's value (child).\r\n */\r\nexport type DerivedSignal<T, U> = WritableSignal<U> & {\r\n  /**\r\n   * The function used to derive the derived signal's value from the source signal's value.\r\n   * This is primarily for internal use and introspection.\r\n   */\r\n  from: (v: T) => U;\r\n};\r\n\r\n/**\r\n * Creates a `DerivedSignal` that derives its value from another `WritableSignal`.\r\n * This overload provides the most flexibility, allowing you to specify custom `from` and `onChange` functions.\r\n *\r\n * @typeParam T The type of the source signal's value.\r\n * @typeParam U The type of the derived signal's value.\r\n * @param source The source `WritableSignal`.\r\n * @param options An object containing the `from` and `onChange` functions, and optional signal options.\r\n * @returns A `DerivedSignal` instance.\r\n *\r\n * @example\r\n * ```ts\r\n * const user = signal({ name: 'John', age: 30 });\r\n * const name = derived(user, {\r\n * from: (u) => u.name,\r\n * onChange: (newName) => user.update((u) => ({ ...u, name: newName })),\r\n * });\r\n *\r\n * name.set('Jane'); // Updates the original signal\r\n * console.log(user().name); // Outputs: Jane\r\n * ```\r\n */\r\nexport function derived<T, U>(\r\n  source: WritableSignal<T>,\r\n  opt: CreateDerivedOptions<T, U>,\r\n): DerivedSignal<T, U>;\r\n\r\n/**\r\n * Creates a `DerivedSignal` that derives a property from an object held by the source signal.\r\n * This overload is a convenient shorthand for accessing object properties.\r\n *\r\n * @typeParam T The type of the source signal's value (must be an object).\r\n * @typeParam TKey The key of the property to derive.\r\n * @param source The source `WritableSignal` (holding an object).\r\n * @param key The key of the property to derive.\r\n * @param options Optional signal options for the derived signal.\r\n * @returns A `DerivedSignal` instance.\r\n *\r\n * @example\r\n * ```ts\r\n * const user = signal({ name: 'John', age: 30 });\r\n * const name = derived(user, 'name');\r\n *\r\n * console.log(name()); // Outputs: John\r\n *\r\n * // Update the derived signal, which also updates the source\r\n * name.set('Jane');\r\n *\r\n * console.log(user().name); // Outputs: Jane\r\n * ```\r\n */\r\nexport function derived<T extends UnknownObject, TKey extends keyof T>(\r\n  source: WritableSignal<T>,\r\n  key: TKey,\r\n  opt?: CreateSignalOptions<T[TKey]>,\r\n): DerivedSignal<T, T[TKey]>;\r\n\r\n/**\r\n * Creates a `DerivedSignal` from an array, deriving an element by its index.\r\n * This overload is a convenient shorthand for accessing array elements.\r\n *\r\n * @typeParam T The type of the source signal's value (must be an array).\r\n * @param source The source `WritableSignal` (holding an array).\r\n * @param index The index of the element to derive.\r\n * @param options Optional signal options for the derived signal.\r\n * @returns A `DerivedSignal` instance.\r\n *\r\n * @example\r\n * ```ts\r\n * const numbers = signal([1, 2, 3]);\r\n * const secondNumber = derived(numbers, 1);\r\n *\r\n * console.log(secondNumber()); // Outputs: 2\r\n *\r\n * // Update the derived signal, which also updates the source\r\n * secondNumber.set(5);\r\n *\r\n * console.log(numbers()); // Outputs: [1, 5, 3]\r\n * ```\r\n */\r\nexport function derived<T extends any[]>(\r\n  source: WritableSignal<T>,\r\n  index: number,\r\n  opt?: CreateSignalOptions<T[number]>,\r\n): DerivedSignal<T, T[number]>;\r\n\r\n/**\r\n * Creates a `DerivedSignal` that derives its value from another `MutableSignal`.\r\n * Use mutuable signals with caution, but very useful for deeply nested structures.\r\n *\r\n * @typeParam T The type of the source signal's value.\r\n * @typeParam U The type of the derived signal's value.\r\n * @param source The source `WritableSignal`.\r\n * @param options An object containing the `from` and `onChange` functions, and optional signal options.\r\n * @returns A `DerivedSignal & MutableSignal` instance.\r\n *\r\n * @example\r\n * ```ts\r\n * const user = signal({ name: 'John', age: 30 });\r\n * const name = derived(user, {\r\n * from: (u) => u.name,\r\n * onChange: (newName) => user.update((u) => ({ ...u, name: newName })),\r\n * });\r\n *\r\n * name.set('Jane'); // Updates the original signal\r\n * console.log(user().name); // Outputs: Jane\r\n * ```\r\n */\r\nexport function derived<T, U>(\r\n  source: MutableSignal<T>,\r\n  optOrKey: CreateDerivedOptions<T, U> | keyof T,\r\n  opt?: CreateSignalOptions<U>,\r\n): DerivedSignal<T, U> & MutableSignal<U>;\r\n\r\nexport function derived<T, U>(\r\n  source: WritableSignal<T> | MutableSignal<T>,\r\n  optOrKey: CreateDerivedOptions<T, U> | keyof T,\r\n  opt?: CreateSignalOptions<U>,\r\n): DerivedSignal<T, U> | (DerivedSignal<T, U> & MutableSignal<U>) {\r\n  const isArray =\r\n    Array.isArray(untracked(source)) && typeof optOrKey === 'number';\r\n\r\n  const from =\r\n    typeof optOrKey === 'object' ? optOrKey.from : (v: T) => v[optOrKey] as U;\r\n\r\n  const onChange =\r\n    typeof optOrKey === 'object'\r\n      ? optOrKey.onChange\r\n      : isArray\r\n        ? isMutable(source)\r\n          ? (next: U) => {\r\n              source.mutate((cur) => {\r\n                (cur as any[])[optOrKey] = next;\r\n                return cur as T;\r\n              });\r\n            }\r\n          : (next: U) => {\r\n              source.update((cur) => {\r\n                const newArray = [...(cur as unknown as any[])];\r\n                newArray[optOrKey] = next;\r\n                return newArray as T;\r\n              });\r\n            }\r\n        : isMutable(source)\r\n          ? (next: U) => {\r\n              source.mutate((cur) => {\r\n                (cur as UnknownObject)[optOrKey] = next as T[keyof T];\r\n                return cur;\r\n              });\r\n            }\r\n          : (next: U) => {\r\n              source.update((cur) => ({ ...cur, [optOrKey]: next }));\r\n            };\r\n\r\n  const rest = typeof optOrKey === 'object' ? optOrKey : opt;\r\n\r\n  const baseEqual = rest?.equal ?? Object.is;\r\n  let trigger = false;\r\n\r\n  const equal: ValueEqualityFn<U> = isMutable(source)\r\n    ? (a: U, b: U) => {\r\n        if (trigger) return false;\r\n        return baseEqual(a, b);\r\n      }\r\n    : baseEqual;\r\n\r\n  const sig = toWritable<U>(\r\n    computed(() => from(source()), { ...rest, equal }),\r\n    (newVal) => onChange(newVal),\r\n  ) as DerivedSignal<T, U> & MutableSignal<U>;\r\n\r\n  sig.from = from;\r\n\r\n  if (isMutable(source)) {\r\n    sig.mutate = (updater) => {\r\n      trigger = true;\r\n      sig.update(updater);\r\n      trigger = false;\r\n    };\r\n\r\n    sig.inline = (updater) => {\r\n      sig.mutate((prev) => {\r\n        updater(prev);\r\n        return prev;\r\n      });\r\n    };\r\n  }\r\n\r\n  return sig;\r\n}\r\n\r\n/**\r\n * Creates a \"fake\" `DerivedSignal` from a simple value. This is useful for creating\r\n * `FormControlSignal` instances that are not directly derived from another signal.\r\n * The returned signal's `from` function will always return the initial value.\r\n *\r\n * @typeParam T -  This type parameter is not used in the implementation but is kept for type compatibility with `DerivedSignal`.\r\n * @typeParam U - The type of the signal's value.\r\n * @param initial - The initial value of the signal.\r\n * @returns A `DerivedSignal` instance.\r\n * @internal\r\n */\r\nexport function toFakeDerivation<T, U>(initial: U): DerivedSignal<T, U> {\r\n  const sig = signal(initial) as DerivedSignal<T, U>;\r\n  sig.from = () => initial;\r\n\r\n  return sig;\r\n}\r\n\r\n/**\r\n * Creates a \"fake\" `DerivedSignal` from an existing `WritableSignal`. This is useful\r\n * for treating a regular `WritableSignal` as a `DerivedSignal` without changing its behavior.\r\n *  The returned signal's `from` function returns the current value of signal, using `untracked`.\r\n *\r\n * @typeParam T - This type parameter is not used in the implementation but is kept for type compatibility with `DerivedSignal`.\r\n * @typeParam U - The type of the signal's value.\r\n * @param initial - The existing `WritableSignal`.\r\n * @returns A `DerivedSignal` instance.\r\n * @internal\r\n */\r\nexport function toFakeSignalDerivation<T, U>(\r\n  initial: WritableSignal<U>,\r\n): DerivedSignal<T, U> {\r\n  const sig = initial as DerivedSignal<T, U>;\r\n  sig.from = () => untracked(initial);\r\n  return sig;\r\n}\r\n\r\n/**\r\n * Type guard function to check if a given `WritableSignal` is a `DerivedSignal`.\r\n *\r\n * @typeParam T - The type of the source signal's value (optional, defaults to `any`).\r\n * @typeParam U - The type of the derived signal's value (optional, defaults to `any`).\r\n * @param sig - The `WritableSignal` to check.\r\n * @returns `true` if the signal is a `DerivedSignal`, `false` otherwise.\r\n */\r\nexport function isDerivation<T, U>(\r\n  sig: WritableSignal<U>,\r\n): sig is DerivedSignal<T, U> {\r\n  return 'from' in sig;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, effect, ElementRef, inject, isSignal, PLATFORM_ID, signal, } from '@angular/core';\nfunction observerSupported() {\n return typeof IntersectionObserver !== 'undefined';\n}\n/**\n * Creates a read-only signal that tracks the intersection status of a target DOM element\n * with the viewport or a specified root element, using the `IntersectionObserver` API.\n *\n * It can observe a static `ElementRef`/`Element` or a `Signal` that resolves to one,\n * allowing for dynamic targets.\n *\n * @param target The DOM element (or `ElementRef`, or a `Signal` resolving to one) to observe.\n * If the signal resolves to `null`, observation stops.\n * @param options Optional `IntersectionObserverInit` options (e.g., `root`, `rootMargin`, `threshold`)\n * and an optional `debugName`.\n * @returns A `Signal<IntersectionObserverEntry | undefined>`. It emits `undefined` initially,\n * on the server, or if the target is `null`. Otherwise, it emits the latest\n * `IntersectionObserverEntry`. Consumers can derive a boolean `isVisible` from\n * this entry's `isIntersecting` property.\n *\n * @example\n * ```ts\n * import { Component, effect, ElementRef, viewChild } from '@angular/core';\n * import { elementVisibility } from '@mmstack/primitives';\n * import { computed } from '@angular/core'; // For derived boolean\n *\n * @Component({\n * selector: 'app-lazy-image',\n * template: `\n * <div #imageContainer style=\"height: 200px; border: 1px dashed grey;\">\n * @if (isVisible()) {\n * <img src=\"your-image-url.jpg\" alt=\"Lazy loaded image\" />\n * <p>Image is VISIBLE!</p>\n * } @else {\n * <p>Scroll down to see the image...</p>\n * }\n * </div>\n * `\n * })\n * export class LazyImageComponent {\n * readonly imageContainer = viewChild.required<ElementRef<HTMLDivElement>>('imageContainer');\n *\n * // Observe the element, get the full IntersectionObserverEntry\n * readonly intersectionEntry = elementVisibility(this.imageContainer);\n *\n * // Derive a simple boolean for visibility\n * readonly isVisible = computed(() => this.intersectionEntry()?.isIntersecting ?? false);\n *\n * constructor() {\n * effect(() => {\n * console.log('Intersection Entry:', this.intersectionEntry());\n * console.log('Is Visible:', this.isVisible());\n * });\n * }\n * }\n * ```\n */\nexport function elementVisibility(target = inject(ElementRef), opt) {\n if (isPlatformServer(inject(PLATFORM_ID)) || !observerSupported()) {\n const base = computed(() => undefined, {\n debugName: opt?.debugName,\n });\n base.visible = computed(() => false, ...(ngDevMode ? [{ debugName: \"visible\" }] : []));\n return base;\n }\n const state = signal(undefined, {\n debugName: opt?.debugName,\n equal: (a, b) => {\n if (!a && !b)\n return true;\n if (!a || !b)\n return false;\n return (a.target === b.target &&\n a.isIntersecting === b.isIntersecting &&\n a.intersectionRatio === b.intersectionRatio &&\n a.boundingClientRect.top === b.boundingClientRect.top &&\n a.boundingClientRect.left === b.boundingClientRect.left &&\n a.boundingClientRect.width === b.boundingClientRect.width &&\n a.boundingClientRect.height === b.boundingClientRect.height);\n },\n });\n const targetSignal = isSignal(target) ? target : computed(() => target);\n effect((cleanup) => {\n const el = targetSignal();\n if (!el)\n return state.set(undefined);\n let observer = null;\n observer = new IntersectionObserver(([entry]) => state.set(entry), opt);\n observer.observe(el instanceof ElementRef ? el.nativeElement : el);\n cleanup(() => {\n observer?.disconnect();\n });\n });\n const base = state.asReadonly();\n base.visible = computed(() => {\n const s = state();\n if (!s)\n return false;\n return s.isIntersecting;\n }, ...(ngDevMode ? [{ debugName: \"visible\" }] : []));\n return base;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element-visibility.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/element-visibility.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACL,QAAQ,EACR,MAAM,EACN,UAAU,EACV,MAAM,EACN,QAAQ,EACR,WAAW,EACX,MAAM,GAEP,MAAM,eAAe,CAAC;AAWvB,SAAS,iBAAiB;IACxB,OAAO,OAAO,oBAAoB,KAAK,WAAW,CAAC;AACrD,CAAC;AAcD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoDG;AACH,MAAM,UAAU,iBAAiB,CAC/B,SAGmD,MAAM,CAAC,UAAU,CAAC,EACrE,GAA8B;IAE9B,IAAI,gBAAgB,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;QAClE,MAAM,IAAI,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,SAAS,EAAE;YACrC,SAAS,EAAE,GAAG,EAAE,SAAS;SAC1B,CAAoC,CAAC;QACtC,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,mDAAC,CAAC;QACrC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,KAAK,GAAG,MAAM,CAAwC,SAAS,EAAE;QACrE,SAAS,EAAE,GAAG,EAAE,SAAS;QACzB,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACd,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBAAE,OAAO,IAAI,CAAC;YAC1B,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;gBAAE,OAAO,KAAK,CAAC;YAC3B,OAAO,CACL,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM;gBACrB,CAAC,CAAC,cAAc,KAAK,CAAC,CAAC,cAAc;gBACrC,CAAC,CAAC,iBAAiB,KAAK,CAAC,CAAC,iBAAiB;gBAC3C,CAAC,CAAC,kBAAkB,CAAC,GAAG,KAAK,CAAC,CAAC,kBAAkB,CAAC,GAAG;gBACrD,CAAC,CAAC,kBAAkB,CAAC,IAAI,KAAK,CAAC,CAAC,kBAAkB,CAAC,IAAI;gBACvD,CAAC,CAAC,kBAAkB,CAAC,KAAK,KAAK,CAAC,CAAC,kBAAkB,CAAC,KAAK;gBACzD,CAAC,CAAC,kBAAkB,CAAC,MAAM,KAAK,CAAC,CAAC,kBAAkB,CAAC,MAAM,CAC5D,CAAC;QACJ,CAAC;KACF,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC;IAExE,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE;QACjB,MAAM,EAAE,GAAG,YAAY,EAAE,CAAC;QAE1B,IAAI,CAAC,EAAE;YAAE,OAAO,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAErC,IAAI,QAAQ,GAAgC,IAAI,CAAC;QACjD,QAAQ,GAAG,IAAI,oBAAoB,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,CAAC;QACxE,QAAQ,CAAC,OAAO,CAAC,EAAE,YAAY,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEnE,OAAO,CAAC,GAAG,EAAE;YACX,QAAQ,EAAE,UAAU,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,MAAM,IAAI,GAAG,KAAK,CAAC,UAAU,EAAqC,CAAC;IACnE,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,GAAG,EAAE;QAC3B,MAAM,CAAC,GAAG,KAAK,EAAE,CAAC;QAClB,IAAI,CAAC,CAAC;YAAE,OAAO,KAAK,CAAC;QACrB,OAAO,CAAC,CAAC,cAAc,CAAC;IAC1B,CAAC,mDAAC,CAAC;IACH,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["import { isPlatformServer } from '@angular/common';\r\nimport {\r\n  computed,\r\n  effect,\r\n  ElementRef,\r\n  inject,\r\n  isSignal,\r\n  PLATFORM_ID,\r\n  signal,\r\n  Signal,\r\n} from '@angular/core';\r\n\r\n/**\r\n * Options for configuring the `elementVisibility` sensor, extending\r\n * standard `IntersectionObserverInit` options.\r\n */\r\nexport type ElementVisibilityOptions = IntersectionObserverInit & {\r\n  /** Optional debug name for the internal signal. */\r\n  debugName?: string;\r\n};\r\n\r\nfunction observerSupported() {\r\n  return typeof IntersectionObserver !== 'undefined';\r\n}\r\n\r\ntype InternalElementVisibilitySignal = Signal<\r\n  IntersectionObserverEntry | undefined\r\n> & {\r\n  visible: Signal<boolean>;\r\n};\r\n\r\nexport type ElementVisibilitySignal = Signal<\r\n  IntersectionObserverEntry | undefined\r\n> & {\r\n  readonly visible: Signal<boolean>;\r\n};\r\n\r\n/**\r\n * Creates a read-only signal that tracks the intersection status of a target DOM element\r\n * with the viewport or a specified root element, using the `IntersectionObserver` API.\r\n *\r\n * It can observe a static `ElementRef`/`Element` or a `Signal` that resolves to one,\r\n * allowing for dynamic targets.\r\n *\r\n * @param target The DOM element (or `ElementRef`, or a `Signal` resolving to one) to observe.\r\n * If the signal resolves to `null`, observation stops.\r\n * @param options Optional `IntersectionObserverInit` options (e.g., `root`, `rootMargin`, `threshold`)\r\n * and an optional `debugName`.\r\n * @returns A `Signal<IntersectionObserverEntry | undefined>`. It emits `undefined` initially,\r\n * on the server, or if the target is `null`. Otherwise, it emits the latest\r\n * `IntersectionObserverEntry`. Consumers can derive a boolean `isVisible` from\r\n * this entry's `isIntersecting` property.\r\n *\r\n * @example\r\n * ```ts\r\n * import { Component, effect, ElementRef, viewChild } from '@angular/core';\r\n * import { elementVisibility } from '@mmstack/primitives';\r\n * import { computed } from '@angular/core'; // For derived boolean\r\n *\r\n * @Component({\r\n * selector: 'app-lazy-image',\r\n * template: `\r\n * <div #imageContainer style=\"height: 200px; border: 1px dashed grey;\">\r\n * @if (isVisible()) {\r\n * <img src=\"your-image-url.jpg\" alt=\"Lazy loaded image\" />\r\n * <p>Image is VISIBLE!</p>\r\n * } @else {\r\n * <p>Scroll down to see the image...</p>\r\n * }\r\n * </div>\r\n * `\r\n * })\r\n * export class LazyImageComponent {\r\n * readonly imageContainer = viewChild.required<ElementRef<HTMLDivElement>>('imageContainer');\r\n *\r\n * // Observe the element, get the full IntersectionObserverEntry\r\n * readonly intersectionEntry = elementVisibility(this.imageContainer);\r\n *\r\n * // Derive a simple boolean for visibility\r\n * readonly isVisible = computed(() => this.intersectionEntry()?.isIntersecting ?? false);\r\n *\r\n * constructor() {\r\n * effect(() => {\r\n * console.log('Intersection Entry:', this.intersectionEntry());\r\n * console.log('Is Visible:', this.isVisible());\r\n * });\r\n * }\r\n * }\r\n * ```\r\n */\r\nexport function elementVisibility(\r\n  target:\r\n    | ElementRef<Element>\r\n    | Element\r\n    | Signal<ElementRef<Element> | Element | null> = inject(ElementRef),\r\n  opt?: ElementVisibilityOptions,\r\n): ElementVisibilitySignal {\r\n  if (isPlatformServer(inject(PLATFORM_ID)) || !observerSupported()) {\r\n    const base = computed(() => undefined, {\r\n      debugName: opt?.debugName,\r\n    }) as InternalElementVisibilitySignal;\r\n    base.visible = computed(() => false);\r\n    return base;\r\n  }\r\n\r\n  const state = signal<IntersectionObserverEntry | undefined>(undefined, {\r\n    debugName: opt?.debugName,\r\n    equal: (a, b) => {\r\n      if (!a && !b) return true;\r\n      if (!a || !b) return false;\r\n      return (\r\n        a.target === b.target &&\r\n        a.isIntersecting === b.isIntersecting &&\r\n        a.intersectionRatio === b.intersectionRatio &&\r\n        a.boundingClientRect.top === b.boundingClientRect.top &&\r\n        a.boundingClientRect.left === b.boundingClientRect.left &&\r\n        a.boundingClientRect.width === b.boundingClientRect.width &&\r\n        a.boundingClientRect.height === b.boundingClientRect.height\r\n      );\r\n    },\r\n  });\r\n\r\n  const targetSignal = isSignal(target) ? target : computed(() => target);\r\n\r\n  effect((cleanup) => {\r\n    const el = targetSignal();\r\n\r\n    if (!el) return state.set(undefined);\r\n\r\n    let observer: IntersectionObserver | null = null;\r\n    observer = new IntersectionObserver(([entry]) => state.set(entry), opt);\r\n    observer.observe(el instanceof ElementRef ? el.nativeElement : el);\r\n\r\n    cleanup(() => {\r\n      observer?.disconnect();\r\n    });\r\n  });\r\n\r\n  const base = state.asReadonly() as InternalElementVisibilitySignal;\r\n  base.visible = computed(() => {\r\n    const s = state();\r\n    if (!s) return false;\r\n    return s.isIntersecting;\r\n  });\r\n  return base;\r\n}\r\n"]}","import { computed, isSignal, linkedSignal, } from '@angular/core';\nimport { derived } from './derived';\nimport { isMutable } from './mutable';\nimport { toWritable } from './to-writable';\n/**\n * @internal\n * Checks if a signal is a WritableSignal.\n * @param sig The signal to check.\n */\nfunction isWritable(sig) {\n // We just need to check for the presence of a 'set' method.\n return 'set' in sig;\n}\n/**\n * @internal\n * Creates a setter function for a source signal of type `Signal<T[]>` or a function returning `T[]`.\n * @param source The source signal of type `Signal<T[]>` or a function returning `T[]`.\n * @returns\n */\nfunction createSetter(source) {\n if (!isWritable(source))\n return () => {\n // noop;\n };\n if (isMutable(source))\n return (value, index) => {\n source.inline((arr) => {\n arr[index] = value;\n });\n };\n return (value, index) => {\n source.update((arr) => arr.map((v, i) => (i === index ? value : v)));\n };\n}\nexport function mapArray(source, map, options) {\n const data = isSignal(source) ? source : computed(source);\n const len = computed(() => data().length, ...(ngDevMode ? [{ debugName: \"len\" }] : []));\n const setter = createSetter(data);\n const opt = { ...options };\n const writableData = isWritable(data)\n ? data\n : toWritable(data, () => {\n // noop\n });\n if (isWritable(data) && isMutable(data) && !opt.equal) {\n opt.equal = (a, b) => {\n if (a !== b)\n return false; // actually check primitives and references\n return false; // opt out for same refs\n };\n }\n return linkedSignal({\n source: () => len(),\n computation: (len, prev) => {\n if (!prev)\n return Array.from({ length: len }, (_, i) => {\n const derivation = derived(writableData, // typcase to largest type\n {\n from: (src) => src[i],\n onChange: (value) => setter(value, i),\n }, opt);\n return map(derivation, i);\n });\n if (len === prev.value.length)\n return prev.value;\n if (len < prev.value.length) {\n const slice = prev.value.slice(0, len);\n if (opt.onDestroy) {\n for (let i = len; i < prev.value.length; i++) {\n opt.onDestroy?.(prev.value[i]);\n }\n }\n return slice;\n }\n else {\n const next = [...prev.value];\n for (let i = prev.value.length; i < len; i++) {\n const derivation = derived(writableData, // typcase to largest type\n {\n from: (src) => src[i],\n onChange: (value) => setter(value, i),\n }, opt);\n next[i] = map(derivation, i);\n }\n return next;\n }\n },\n equal: (a, b) => a.length === b.length,\n });\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-array.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/map-array.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  type CreateSignalOptions,\r\n  isSignal,\r\n  linkedSignal,\r\n  type Signal,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { derived } from './derived';\r\nimport { isMutable, MutableSignal } from './mutable';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * @internal\r\n * Checks if a signal is a WritableSignal.\r\n * @param sig The signal to check.\r\n */\r\nfunction isWritable<T>(sig: Signal<T>): sig is WritableSignal<T> {\r\n  // We just need to check for the presence of a 'set' method.\r\n  return 'set' in sig;\r\n}\r\n\r\n/**\r\n * @internal\r\n * Creates a setter function for a source signal of type `Signal<T[]>` or a function returning `T[]`.\r\n * @param source The source signal of type `Signal<T[]>` or a function returning `T[]`.\r\n * @returns\r\n */\r\nfunction createSetter<T>(\r\n  source: Signal<T[]>,\r\n): (value: T, index: number) => void {\r\n  if (!isWritable(source))\r\n    return () => {\r\n      // noop;\r\n    };\r\n\r\n  if (isMutable(source))\r\n    return (value, index) => {\r\n      source.inline((arr) => {\r\n        arr[index] = value;\r\n      });\r\n    };\r\n\r\n  return (value, index) => {\r\n    source.update((arr) => arr.map((v, i) => (i === index ? value : v)));\r\n  };\r\n}\r\n\r\n/**\r\n * Reactively maps items from a source array to a new array, creating stable signals for each item.\r\n *\r\n * This function is highly optimized for performance, similar to SolidJS's `mapArray`.\r\n * For each item in the source array, it creates a stable signal that is passed to the mapping function.\r\n * This ensures that downstream consumers only re-evaluate for items that have actually changed,\r\n * or when items are added or removed from the list.\r\n *\r\n * The type of signal passed to the `map` function depends on the source:\r\n * - **Readonly `Signal`**: `map` receives a readonly `Signal<T>`.\r\n * - **`WritableSignal`**: `map` receives a `WritableSignal<T>`, allowing two-way binding.\r\n * - **`MutableSignal`**: `map` receives a `MutableSignal<T>`, allowing in-place mutation for performance.\r\n *\r\n * @template T The type of items in the source array.\r\n * @template U The type of items in the resulting mapped array.\r\n *\r\n * @param source A `Signal<T[]>` or a function returning `T[]`.\r\n * @param map The mapping function. It receives a stable signal for the item and its index.\r\n * @param options Optional configuration, including `CreateSignalOptions` for the item signals\r\n * (e.g., a custom `equal` function) and an `onDestroy` callback for cleanup.\r\n * @returns A `Signal<U[]>` containing the mapped array.\r\n *\r\n * @example\r\n * // Writable example\r\n * const sourceItems = signal([\r\n * { id: 1, name: 'Apple' },\r\n * { id: 2, name: 'Banana' }\r\n * ]);\r\n *\r\n * // The `itemSignal` is writable because `sourceItems` is a WritableSignal.\r\n * const mappedItems = mapArray(sourceItems, (itemSignal, index) => ({\r\n * label: computed(() => `${index}: ${itemSignal().name.toUpperCase()}`),\r\n * setName: (newName: string) => itemSignal.update(item => ({ ...item, name: newName }))\r\n * }));\r\n *\r\n * // This will update the original source signal.\r\n * mappedItems()[0].setName('Avocado');\r\n * // sourceItems() is now: [{ id: 1, name: 'Avocado' }, { id: 2, name: 'Banana' }]\r\n */\r\nexport function mapArray<T, U>(\r\n  source: MutableSignal<T[]>,\r\n  map: (value: MutableSignal<T>, index: number) => U,\r\n  options?: CreateSignalOptions<T> & {\r\n    onDestroy?: (value: U) => void;\r\n  },\r\n): Signal<U[]>;\r\n\r\nexport function mapArray<T, U>(\r\n  source: WritableSignal<T[]>,\r\n  map: (value: WritableSignal<T>, index: number) => U,\r\n  options?: CreateSignalOptions<T> & {\r\n    onDestroy?: (value: U) => void;\r\n  },\r\n): Signal<U[]>;\r\n\r\nexport function mapArray<T, U>(\r\n  source: Signal<T[]> | (() => T[]),\r\n  map: (value: Signal<T>, index: number) => U,\r\n  options?: CreateSignalOptions<T> & {\r\n    onDestroy?: (value: U) => void;\r\n  },\r\n): Signal<U[]>;\r\n\r\nexport function mapArray<T, U>(\r\n  source: Signal<T[]> | (() => T[]),\r\n  map:\r\n    | ((value: Signal<T>, index: number) => U)\r\n    | ((value: WritableSignal<T>, index: number) => U)\r\n    | ((value: MutableSignal<T>, index: number) => U),\r\n  options?: CreateSignalOptions<T> & {\r\n    onDestroy?: (value: U) => void;\r\n  },\r\n): Signal<U[]> {\r\n  const data = isSignal(source) ? source : computed(source);\r\n  const len = computed(() => data().length);\r\n\r\n  const setter = createSetter(data);\r\n\r\n  const opt = { ...options };\r\n\r\n  const writableData = isWritable(data)\r\n    ? data\r\n    : toWritable(data, () => {\r\n        // noop\r\n      });\r\n\r\n  if (isWritable(data) && isMutable(data) && !opt.equal) {\r\n    opt.equal = (a: T, b: T) => {\r\n      if (a !== b) return false; // actually check primitives and references\r\n      return false; // opt out for same refs\r\n    };\r\n  }\r\n\r\n  return linkedSignal<number, U[]>({\r\n    source: () => len(),\r\n    computation: (len, prev) => {\r\n      if (!prev)\r\n        return Array.from({ length: len }, (_, i) => {\r\n          const derivation = derived(\r\n            writableData as MutableSignal<T[]>, // typcase to largest type\r\n            {\r\n              from: (src) => src[i],\r\n              onChange: (value) => setter(value, i),\r\n            },\r\n            opt,\r\n          );\r\n\r\n          return map(derivation, i);\r\n        });\r\n\r\n      if (len === prev.value.length) return prev.value;\r\n\r\n      if (len < prev.value.length) {\r\n        const slice = prev.value.slice(0, len);\r\n\r\n        if (opt.onDestroy) {\r\n          for (let i = len; i < prev.value.length; i++) {\r\n            opt.onDestroy?.(prev.value[i]);\r\n          }\r\n        }\r\n\r\n        return slice;\r\n      } else {\r\n        const next = [...prev.value];\r\n        for (let i = prev.value.length; i < len; i++) {\r\n          const derivation = derived(\r\n            writableData as MutableSignal<T[]>, // typcase to largest type\r\n            {\r\n              from: (src) => src[i],\r\n              onChange: (value) => setter(value, i),\r\n            },\r\n            opt,\r\n          );\r\n          next[i] = map(derivation, i);\r\n        }\r\n        return next;\r\n      }\r\n    },\r\n    equal: (a, b) => a.length === b.length,\r\n  });\r\n}\r\n"]}","import { effect, inject, Injector, isDevMode, untracked, } from '@angular/core';\nconst frameStack = [];\nfunction current() {\n return frameStack.at(-1) ?? null;\n}\nfunction clearFrame(frame, userCleanups) {\n for (const child of frame.children) {\n try {\n child.destroy();\n }\n catch (e) {\n if (isDevMode())\n console.error('Error destroying nested effect:', e);\n }\n }\n frame.children.clear();\n for (const fn of userCleanups) {\n try {\n fn();\n }\n catch (e) {\n if (isDevMode())\n console.error('Error destroying nested effect:', e);\n }\n }\n userCleanups.length = 0;\n}\n/**\n * Creates an effect that can be nested, similar to SolidJS's `createEffect`.\n *\n * This primitive enables true hierarchical reactivity. A `nestedEffect` created\n * within another `nestedEffect` is automatically destroyed and recreated when\n * the parent re-runs.\n *\n * It automatically handles injector propagation and lifetime management, allowing\n * you to create fine-grained, conditional side-effects that only track\n * dependencies when they are \"live\".\n *\n * @param effectFn The side-effect function, which receives a cleanup register function.\n * @param options (Optional) Angular's `CreateEffectOptions`.\n * @returns An `EffectRef` for the created effect.\n *\n * @example\n * ```ts\n * // Assume `coldGuard` changes rarely, but `hotSignal` changes often.\n * const coldGuard = signal(false);\n * const hotSignal = signal(0);\n *\n * nestedEffect(() => {\n * // This outer effect only tracks `coldGuard`.\n * if (coldGuard()) {\n *\n * // This inner effect is CREATED when coldGuard is true\n * // and DESTROYED when it becomes false.\n * nestedEffect(() => {\n * // It only tracks `hotSignal` while it exists.\n * console.log('Hot signal is:', hotSignal());\n * });\n * }\n * // If `coldGuard` is false, this outer effect does not track `hotSignal`.\n * });\n * ```\n * @example\n * ```ts\n * const users = signal([\n { id: 1, name: 'Alice' },\n { id: 2, name: 'Bob' }\n]);\n\n// The fine-grained mapped list\nconst mappedUsers = mapArray(\n users,\n (userSignal, index) => {\n // 1. Create a fine-grained SIDE EFFECT for *this item*\n // This effect's lifetime is now tied to this specific item. created once on init of this index.\n const effectRef = nestedEffect(() => {\n // This only runs if *this* userSignal changes,\n // not if the whole list changes.\n console.log(`User ${index} updated:`, userSignal().name);\n });\n\n // 2. Return the data AND the cleanup logic\n return {\n // The mapped data\n label: computed(() => `User: ${userSignal().name}`),\n \n // The cleanup function\n destroyEffect: () => effectRef.destroy()\n };\n },\n {\n // 3. Tell mapArray HOW to clean up when an item is removed, this needs to be manual as it's not a nestedEffect itself\n onDestroy: (mappedItem) => {\n mappedItem.destroyEffect();\n }\n }\n);\n * ```\n */\nexport function nestedEffect(effectFn, options) {\n const parent = current();\n const injector = options?.injector ?? parent?.injector ?? inject(Injector);\n const srcRef = untracked(() => {\n return effect((cleanup) => {\n const frame = {\n injector,\n children: new Set(),\n };\n const userCleanups = [];\n frameStack.push(frame);\n try {\n effectFn((fn) => {\n userCleanups.push(fn);\n });\n }\n finally {\n frameStack.pop();\n }\n return cleanup(() => clearFrame(frame, userCleanups));\n }, {\n ...options,\n injector,\n manualCleanup: !!parent,\n });\n });\n const ref = {\n ...srcRef,\n destroy: () => {\n parent?.children.delete(ref);\n srcRef.destroy();\n },\n };\n parent?.children.add(ref);\n return ref;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-effect.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/nested-effect.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,MAAM,EAGN,MAAM,EACN,QAAQ,EACR,SAAS,EACT,SAAS,GACV,MAAM,eAAe,CAAC;AAOvB,MAAM,UAAU,GAAY,EAAE,CAAC;AAE/B,SAAS,OAAO;IACd,OAAO,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;AACnC,CAAC;AAED,SAAS,UAAU,CAAC,KAAY,EAAE,YAA4B;IAC5D,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;QACnC,IAAI,CAAC;YACH,KAAK,CAAC,OAAO,EAAE,CAAC;QAClB,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,IAAI,SAAS,EAAE;gBAAE,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,CAAC,CAAC,CAAC;QACvE,CAAC;IACH,CAAC;IACD,KAAK,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IACvB,KAAK,MAAM,EAAE,IAAI,YAAY,EAAE,CAAC;QAC9B,IAAI,CAAC;YACH,EAAE,EAAE,CAAC;QACP,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,IAAI,SAAS,EAAE;gBAAE,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,CAAC,CAAC,CAAC;QACvE,CAAC;IACH,CAAC;IACD,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;AAC1B,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuEG;AACH,MAAM,UAAU,YAAY,CAC1B,QAA4D,EAC5D,OAA6B;IAE7B,MAAM,MAAM,GAAG,OAAO,EAAE,CAAC;IACzB,MAAM,QAAQ,GAAG,OAAO,EAAE,QAAQ,IAAI,MAAM,EAAE,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,CAAC;IAE3E,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,EAAE;QAC5B,OAAO,MAAM,CACX,CAAC,OAAO,EAAE,EAAE;YACV,MAAM,KAAK,GAAU;gBACnB,QAAQ;gBACR,QAAQ,EAAE,IAAI,GAAG,EAAa;aAC/B,CAAC;YAEF,MAAM,YAAY,GAAmB,EAAE,CAAC;YAExC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAEvB,IAAI,CAAC;gBACH,QAAQ,CAAC,CAAC,EAAE,EAAE,EAAE;oBACd,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACxB,CAAC,CAAC,CAAC;YACL,CAAC;oBAAS,CAAC;gBACT,UAAU,CAAC,GAAG,EAAE,CAAC;YACnB,CAAC;YAED,OAAO,OAAO,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC;QACxD,CAAC,EACD;YACE,GAAG,OAAO;YACV,QAAQ;YACR,aAAa,EAAE,CAAC,CAAC,MAAM;SACxB,CACF,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,MAAM,GAAG,GAAG;QACV,GAAG,MAAM;QACT,OAAO,EAAE,GAAG,EAAE;YACZ,MAAM,EAAE,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAC7B,MAAM,CAAC,OAAO,EAAE,CAAC;QACnB,CAAC;KACF,CAAC;IACF,MAAM,EAAE,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAE1B,OAAO,GAAG,CAAC;AACb,CAAC","sourcesContent":["import {\r\n  type CreateEffectOptions,\r\n  effect,\r\n  type EffectCleanupRegisterFn,\r\n  type EffectRef,\r\n  inject,\r\n  Injector,\r\n  isDevMode,\r\n  untracked,\r\n} from '@angular/core';\r\n\r\ntype Frame = {\r\n  injector: Injector;\r\n  children: Set<EffectRef>;\r\n};\r\n\r\nconst frameStack: Frame[] = [];\r\n\r\nfunction current() {\r\n  return frameStack.at(-1) ?? null;\r\n}\r\n\r\nfunction clearFrame(frame: Frame, userCleanups: (() => void)[]) {\r\n  for (const child of frame.children) {\r\n    try {\r\n      child.destroy();\r\n    } catch (e) {\r\n      if (isDevMode()) console.error('Error destroying nested effect:', e);\r\n    }\r\n  }\r\n  frame.children.clear();\r\n  for (const fn of userCleanups) {\r\n    try {\r\n      fn();\r\n    } catch (e) {\r\n      if (isDevMode()) console.error('Error destroying nested effect:', e);\r\n    }\r\n  }\r\n  userCleanups.length = 0;\r\n}\r\n\r\n/**\r\n * Creates an effect that can be nested, similar to SolidJS's `createEffect`.\r\n *\r\n * This primitive enables true hierarchical reactivity. A `nestedEffect` created\r\n * within another `nestedEffect` is automatically destroyed and recreated when\r\n * the parent re-runs.\r\n *\r\n * It automatically handles injector propagation and lifetime management, allowing\r\n * you to create fine-grained, conditional side-effects that only track\r\n * dependencies when they are \"live\".\r\n *\r\n * @param effectFn The side-effect function, which receives a cleanup register function.\r\n * @param options (Optional) Angular's `CreateEffectOptions`.\r\n * @returns An `EffectRef` for the created effect.\r\n *\r\n * @example\r\n * ```ts\r\n * // Assume `coldGuard` changes rarely, but `hotSignal` changes often.\r\n * const coldGuard = signal(false);\r\n * const hotSignal = signal(0);\r\n *\r\n * nestedEffect(() => {\r\n * // This outer effect only tracks `coldGuard`.\r\n * if (coldGuard()) {\r\n *\r\n * // This inner effect is CREATED when coldGuard is true\r\n * // and DESTROYED when it becomes false.\r\n * nestedEffect(() => {\r\n * // It only tracks `hotSignal` while it exists.\r\n * console.log('Hot signal is:', hotSignal());\r\n * });\r\n * }\r\n * // If `coldGuard` is false, this outer effect does not track `hotSignal`.\r\n * });\r\n * ```\r\n * @example\r\n * ```ts\r\n * const users = signal([\r\n  { id: 1, name: 'Alice' },\r\n  { id: 2, name: 'Bob' }\r\n]);\r\n\r\n// The fine-grained mapped list\r\nconst mappedUsers = mapArray(\r\n  users,\r\n  (userSignal, index) => {\r\n    // 1. Create a fine-grained SIDE EFFECT for *this item*\r\n    // This effect's lifetime is now tied to this specific item. created once on init of this index.\r\n    const effectRef = nestedEffect(() => {\r\n      // This only runs if *this* userSignal changes,\r\n      // not if the whole list changes.\r\n      console.log(`User ${index} updated:`, userSignal().name);\r\n    });\r\n\r\n    // 2. Return the data AND the cleanup logic\r\n    return {\r\n      // The mapped data\r\n      label: computed(() => `User: ${userSignal().name}`),\r\n      \r\n      // The cleanup function\r\n      destroyEffect: () => effectRef.destroy()\r\n    };\r\n  },\r\n  {\r\n    // 3. Tell mapArray HOW to clean up when an item is removed, this needs to be manual as it's not a nestedEffect itself\r\n    onDestroy: (mappedItem) => {\r\n      mappedItem.destroyEffect();\r\n    }\r\n  }\r\n);\r\n * ```\r\n */\r\nexport function nestedEffect(\r\n  effectFn: (registerCleanup: EffectCleanupRegisterFn) => void,\r\n  options?: CreateEffectOptions,\r\n) {\r\n  const parent = current();\r\n  const injector = options?.injector ?? parent?.injector ?? inject(Injector);\r\n\r\n  const srcRef = untracked(() => {\r\n    return effect(\r\n      (cleanup) => {\r\n        const frame: Frame = {\r\n          injector,\r\n          children: new Set<EffectRef>(),\r\n        };\r\n\r\n        const userCleanups: (() => void)[] = [];\r\n\r\n        frameStack.push(frame);\r\n\r\n        try {\r\n          effectFn((fn) => {\r\n            userCleanups.push(fn);\r\n          });\r\n        } finally {\r\n          frameStack.pop();\r\n        }\r\n\r\n        return cleanup(() => clearFrame(frame, userCleanups));\r\n      },\r\n      {\r\n        ...options,\r\n        injector,\r\n        manualCleanup: !!parent,\r\n      },\r\n    );\r\n  });\r\n\r\n  const ref = {\r\n    ...srcRef,\r\n    destroy: () => {\r\n      parent?.children.delete(ref);\r\n      srcRef.destroy();\r\n    },\r\n  };\r\n  parent?.children.add(ref);\r\n\r\n  return ref;\r\n}\r\n"]}","import { computed, effect, linkedSignal, } from '@angular/core';\n/** Project with optional equality. Pure & sync. */\nexport const select = (projector, opt) => (src) => computed(() => projector(src()), opt);\n/** Combine with another signal using a projector. */\nexport const combineWith = (other, project, opt) => (src) => computed(() => project(src(), other()), opt);\n/** Only re-emit when equal(prev, next) is false. */\nexport const distinct = (equal = Object.is) => (src) => computed(() => src(), { equal });\n/** map to new value */\nexport const map = (fn) => (src) => computed(() => fn(src()));\n/** filter values, keeping the last value if it was ever available, if first value is filtered will return undefined */\nexport const filter = (predicate) => (src) => linkedSignal({\n source: src,\n computation: (next, prev) => {\n if (predicate(next))\n return next;\n return prev?.source;\n },\n});\n/** tap into the value */\nexport const tap = (fn) => (src) => {\n effect(() => fn(src()));\n return src;\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3BlcmF0b3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9zcmMvbGliL3BpcGVhYmxlL29wZXJhdG9ycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsUUFBUSxFQUVSLE1BQU0sRUFDTixZQUFZLEdBRWIsTUFBTSxlQUFlLENBQUM7QUFHdkIsbURBQW1EO0FBQ25ELE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FDakIsQ0FDRSxTQUFzQixFQUN0QixHQUE0QixFQUNaLEVBQUUsQ0FDcEIsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUNOLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQztBQUUxQyxxREFBcUQ7QUFDckQsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUN0QixDQUNFLEtBQWdCLEVBQ2hCLE9BQTBCLEVBQzFCLEdBQTRCLEVBQ1osRUFBRSxDQUNwQixDQUFDLEdBQUcsRUFBRSxFQUFFLENBQ04sUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBRWpELG9EQUFvRDtBQUNwRCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQ25CLENBQUksUUFBaUMsTUFBTSxDQUFDLEVBQUUsRUFBa0IsRUFBRSxDQUNsRSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQ04sUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztBQUVyQyx1QkFBdUI7QUFDdkIsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUNkLENBQU8sRUFBZSxFQUFrQixFQUFFLENBQzFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FDTixRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUU5Qix1SEFBdUg7QUFDdkgsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUNqQixDQUFJLFNBQTRCLEVBQThCLEVBQUUsQ0FDaEUsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUNOLFlBQVksQ0FBQztJQUNYLE1BQU0sRUFBRSxHQUFHO0lBQ1gsV0FBVyxFQUFFLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxFQUFFO1FBQzFCLElBQUksU0FBUyxDQUFDLElBQUksQ0FBQztZQUFFLE9BQU8sSUFBSSxDQUFDO1FBQ2pDLE9BQU8sSUFBSSxFQUFFLE1BQU0sQ0FBQztJQUN0QixDQUFDO0NBQ0YsQ0FBQyxDQUFDO0FBRVAseUJBQXlCO0FBQ3pCLE1BQU0sQ0FBQyxNQUFNLEdBQUcsR0FDZCxDQUFJLEVBQWtCLEVBQWtCLEVBQUUsQ0FDMUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtJQUNOLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBRXhCLE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgY29tcHV0ZWQsXG4gIENyZWF0ZVNpZ25hbE9wdGlvbnMsXG4gIGVmZmVjdCxcbiAgbGlua2VkU2lnbmFsLFxuICBTaWduYWwsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT3BlcmF0b3IgfSBmcm9tICcuL3R5cGVzJztcblxuLyoqIFByb2plY3Qgd2l0aCBvcHRpb25hbCBlcXVhbGl0eS4gUHVyZSAmIHN5bmMuICovXG5leHBvcnQgY29uc3Qgc2VsZWN0ID1cbiAgPEksIE8+KFxuICAgIHByb2plY3RvcjogKHY6IEkpID0+IE8sXG4gICAgb3B0PzogQ3JlYXRlU2lnbmFsT3B0aW9uczxPPixcbiAgKTogT3BlcmF0b3I8SSwgTz4gPT5cbiAgKHNyYykgPT5cbiAgICBjb21wdXRlZCgoKSA9PiBwcm9qZWN0b3Ioc3JjKCkpLCBvcHQpO1xuXG4vKiogQ29tYmluZSB3aXRoIGFub3RoZXIgc2lnbmFsIHVzaW5nIGEgcHJvamVjdG9yLiAqL1xuZXhwb3J0IGNvbnN0IGNvbWJpbmVXaXRoID1cbiAgPEEsIEIsIFI+KFxuICAgIG90aGVyOiBTaWduYWw8Qj4sXG4gICAgcHJvamVjdDogKGE6IEEsIGI6IEIpID0+IFIsXG4gICAgb3B0PzogQ3JlYXRlU2lnbmFsT3B0aW9uczxSPixcbiAgKTogT3BlcmF0b3I8QSwgUj4gPT5cbiAgKHNyYykgPT5cbiAgICBjb21wdXRlZCgoKSA9PiBwcm9qZWN0KHNyYygpLCBvdGhlcigpKSwgb3B0KTtcblxuLyoqIE9ubHkgcmUtZW1pdCB3aGVuIGVxdWFsKHByZXYsIG5leHQpIGlzIGZhbHNlLiAqL1xuZXhwb3J0IGNvbnN0IGRpc3RpbmN0ID1cbiAgPFQ+KGVxdWFsOiAoYTogVCwgYjogVCkgPT4gYm9vbGVhbiA9IE9iamVjdC5pcyk6IE9wZXJhdG9yPFQsIFQ+ID0+XG4gIChzcmMpID0+XG4gICAgY29tcHV0ZWQoKCkgPT4gc3JjKCksIHsgZXF1YWwgfSk7XG5cbi8qKiBtYXAgdG8gbmV3IHZhbHVlICovXG5leHBvcnQgY29uc3QgbWFwID1cbiAgPEksIE8+KGZuOiAodjogSSkgPT4gTyk6IE9wZXJhdG9yPEksIE8+ID0+XG4gIChzcmMpID0+XG4gICAgY29tcHV0ZWQoKCkgPT4gZm4oc3JjKCkpKTtcblxuLyoqIGZpbHRlciB2YWx1ZXMsIGtlZXBpbmcgdGhlIGxhc3QgdmFsdWUgaWYgaXQgd2FzIGV2ZXIgYXZhaWxhYmxlLCBpZiBmaXJzdCB2YWx1ZSBpcyBmaWx0ZXJlZCB3aWxsIHJldHVybiB1bmRlZmluZWQgKi9cbmV4cG9ydCBjb25zdCBmaWx0ZXIgPVxuICA8VD4ocHJlZGljYXRlOiAodjogVCkgPT4gYm9vbGVhbik6IE9wZXJhdG9yPFQsIFQgfCB1bmRlZmluZWQ+ID0+XG4gIChzcmMpID0+XG4gICAgbGlua2VkU2lnbmFsKHtcbiAgICAgIHNvdXJjZTogc3JjLFxuICAgICAgY29tcHV0YXRpb246IChuZXh0LCBwcmV2KSA9PiB7XG4gICAgICAgIGlmIChwcmVkaWNhdGUobmV4dCkpIHJldHVybiBuZXh0O1xuICAgICAgICByZXR1cm4gcHJldj8uc291cmNlO1xuICAgICAgfSxcbiAgICB9KTtcblxuLyoqIHRhcCBpbnRvIHRoZSB2YWx1ZSAqL1xuZXhwb3J0IGNvbnN0IHRhcCA9XG4gIDxUPihmbjogKHY6IFQpID0+IHZvaWQpOiBPcGVyYXRvcjxULCBUPiA9PlxuICAoc3JjKSA9PiB7XG4gICAgZWZmZWN0KCgpID0+IGZuKHNyYygpKSk7XG5cbiAgICByZXR1cm4gc3JjO1xuICB9O1xuIl19","import { computed, signal, } from '@angular/core';\n/**\n * Decorate any `Signal<T>` with a chainable `.pipe(...)` method.\n *\n * @example\n * const s = pipeable(signal(1)); // WritableSignal<number> (+ pipe)\n * const label = s.pipe(n => n * 2, n => `#${n}`); // Signal<string> (+ pipe)\n * label(); // \"#2\"\n */\nexport function pipeable(signal) {\n const internal = signal;\n const mapImpl = (...fns) => {\n const last = fns.at(-1);\n let opt;\n if (last && typeof last !== 'function') {\n fns = fns.slice(0, -1);\n opt = last;\n }\n if (fns.length === 0)\n return internal;\n if (fns.length === 1) {\n const fn = fns[0];\n return pipeable(computed(() => fn(internal()), opt));\n }\n const transformer = (input) => fns.reduce((acc, fn) => fn(acc), input);\n return pipeable(computed(() => transformer(internal()), opt));\n };\n const pipeImpl = (...ops) => {\n if (ops.length === 0)\n return internal;\n return ops.reduce((src, op) => pipeable(op(src)), internal);\n };\n Object.defineProperties(internal, {\n map: {\n value: mapImpl,\n configurable: true,\n enumerable: false,\n writable: false,\n },\n pipe: {\n value: pipeImpl,\n configurable: true,\n enumerable: false,\n writable: false,\n },\n });\n return internal;\n}\n/**\n * Create a new **writable** signal and return it as a `PipableSignal`.\n *\n * The returned value is a `WritableSignal<T>` with `.set`, `.update`, `.asReadonly`\n * still available (via intersection type), plus a chainable `.pipe(...)`.\n *\n * @example\n * const count = piped(1); // WritableSignal<number> (+ pipe)\n * const even = count.pipe(n => n % 2 === 0); // Signal<boolean> (+ pipe)\n * count.update(n => n + 1);\n */\nexport function piped(initial, opt) {\n return pipeable(signal(initial, opt));\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlwZWJsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc3JjL2xpYi9waXBlYWJsZS9waXBlYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxRQUFRLEVBQ1IsTUFBTSxHQUlQLE1BQU0sZUFBZSxDQUFDO0FBUXZCOzs7Ozs7O0dBT0c7QUFDSCxNQUFNLFVBQVUsUUFBUSxDQUN0QixNQUFZO0lBRVosTUFBTSxRQUFRLEdBQUcsTUFBaUQsQ0FBQztJQUVuRSxNQUFNLE9BQU8sR0FBRyxDQUFDLEdBQUcsR0FBOEIsRUFBRSxFQUFFO1FBQ3BELE1BQU0sSUFBSSxHQUFHLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4QixJQUFJLEdBQXlDLENBQUM7UUFDOUMsSUFBSSxJQUFJLElBQUksT0FBTyxJQUFJLEtBQUssVUFBVSxFQUFFLENBQUM7WUFDdkMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdkIsR0FBRyxHQUFHLElBQUksQ0FBQztRQUNiLENBQUM7UUFFRCxJQUFJLEdBQUcsQ0FBQyxNQUFNLEtBQUssQ0FBQztZQUFFLE9BQU8sUUFBUSxDQUFDO1FBRXRDLElBQUksR0FBRyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUNyQixNQUFNLEVBQUUsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDbEIsT0FBTyxRQUFRLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDdkQsQ0FBQztRQUVELE1BQU0sV0FBVyxHQUFHLENBQUMsS0FBVSxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBRTVFLE9BQU8sUUFBUSxDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxXQUFXLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ2hFLENBQUMsQ0FBQztJQUVGLE1BQU0sUUFBUSxHQUFHLENBQUMsR0FBRyxHQUF5QixFQUFFLEVBQUU7UUFDaEQsSUFBSSxHQUFHLENBQUMsTUFBTSxLQUFLLENBQUM7WUFBRSxPQUFPLFFBQVEsQ0FBQztRQUN0QyxPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQ2YsQ0FBQyxHQUFHLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQzlCLFFBQStCLENBQ2hDLENBQUM7SUFDSixDQUFDLENBQUM7SUFFRixNQUFNLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFO1FBQ2hDLEdBQUcsRUFBRTtZQUNILEtBQUssRUFBRSxPQUFPO1lBQ2QsWUFBWSxFQUFFLElBQUk7WUFDbEIsVUFBVSxFQUFFLEtBQUs7WUFDakIsUUFBUSxFQUFFLEtBQUs7U0FDaEI7UUFFRCxJQUFJLEVBQUU7WUFDSixLQUFLLEVBQUUsUUFBUTtZQUNmLFlBQVksRUFBRSxJQUFJO1lBQ2xCLFVBQVUsRUFBRSxLQUFLO1lBQ2pCLFFBQVEsRUFBRSxLQUFLO1NBQ2hCO0tBQ0YsQ0FBQyxDQUFDO0lBRUgsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQztBQUVEOzs7Ozs7Ozs7O0dBVUc7QUFDSCxNQUFNLFVBQVUsS0FBSyxDQUNuQixPQUFVLEVBQ1YsR0FBNEI7SUFFNUIsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO0FBQ3hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIGNvbXB1dGVkLFxyXG4gIHNpZ25hbCxcclxuICB0eXBlIENyZWF0ZVNpZ25hbE9wdGlvbnMsXHJcbiAgdHlwZSBTaWduYWwsXHJcbiAgdHlwZSBXcml0YWJsZVNpZ25hbCxcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHR5cGUge1xyXG4gIE9wZXJhdG9yLFxyXG4gIFBpcGVhYmxlU2lnbmFsLFxyXG4gIFNpZ25hbFZhbHVlLFxyXG4gIFVuYXJ5RnVuY3Rpb24sXHJcbn0gZnJvbSAnLi90eXBlcyc7XHJcblxyXG4vKipcclxuICogRGVjb3JhdGUgYW55IGBTaWduYWw8VD5gIHdpdGggYSBjaGFpbmFibGUgYC5waXBlKC4uLilgIG1ldGhvZC5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogY29uc3QgcyA9IHBpcGVhYmxlKHNpZ25hbCgxKSk7IC8vIFdyaXRhYmxlU2lnbmFsPG51bWJlcj4gKCsgcGlwZSlcclxuICogY29uc3QgbGFiZWwgPSBzLnBpcGUobiA9PiBuICogMiwgbiA9PiBgIyR7bn1gKTsgLy8gU2lnbmFsPHN0cmluZz4gKCsgcGlwZSlcclxuICogbGFiZWwoKTsgLy8gXCIjMlwiXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gcGlwZWFibGU8VFNpZyBleHRlbmRzIFNpZ25hbDxhbnk+PihcclxuICBzaWduYWw6IFRTaWcsXHJcbik6IFBpcGVhYmxlU2lnbmFsPFNpZ25hbFZhbHVlPFRTaWc+LCBUU2lnPiB7XHJcbiAgY29uc3QgaW50ZXJuYWwgPSBzaWduYWwgYXMgUGlwZWFibGVTaWduYWw8U2lnbmFsVmFsdWU8VFNpZz4sIFRTaWc+O1xyXG5cclxuICBjb25zdCBtYXBJbXBsID0gKC4uLmZuczogVW5hcnlGdW5jdGlvbjxhbnksIGFueT5bXSkgPT4ge1xyXG4gICAgY29uc3QgbGFzdCA9IGZucy5hdCgtMSk7XHJcbiAgICBsZXQgb3B0OiBDcmVhdGVTaWduYWxPcHRpb25zPGFueT4gfCB1bmRlZmluZWQ7XHJcbiAgICBpZiAobGFzdCAmJiB0eXBlb2YgbGFzdCAhPT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgICBmbnMgPSBmbnMuc2xpY2UoMCwgLTEpO1xyXG4gICAgICBvcHQgPSBsYXN0O1xyXG4gICAgfVxyXG5cclxuICAgIGlmIChmbnMubGVuZ3RoID09PSAwKSByZXR1cm4gaW50ZXJuYWw7XHJcblxyXG4gICAgaWYgKGZucy5sZW5ndGggPT09IDEpIHtcclxuICAgICAgY29uc3QgZm4gPSBmbnNbMF07XHJcbiAgICAgIHJldHVybiBwaXBlYWJsZShjb21wdXRlZCgoKSA9PiBmbihpbnRlcm5hbCgpKSwgb3B0KSk7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3QgdHJhbnNmb3JtZXIgPSAoaW5wdXQ6IGFueSkgPT4gZm5zLnJlZHVjZSgoYWNjLCBmbikgPT4gZm4oYWNjKSwgaW5wdXQpO1xyXG5cclxuICAgIHJldHVybiBwaXBlYWJsZShjb21wdXRlZCgoKSA9PiB0cmFuc2Zvcm1lcihpbnRlcm5hbCgpKSwgb3B0KSk7XHJcbiAgfTtcclxuXHJcbiAgY29uc3QgcGlwZUltcGwgPSAoLi4ub3BzOiBPcGVyYXRvcjxhbnksIGFueT5bXSkgPT4ge1xyXG4gICAgaWYgKG9wcy5sZW5ndGggPT09IDApIHJldHVybiBpbnRlcm5hbDtcclxuICAgIHJldHVybiBvcHMucmVkdWNlPFBpcGVhYmxlU2lnbmFsPGFueT4+KFxyXG4gICAgICAoc3JjLCBvcCkgPT4gcGlwZWFibGUob3Aoc3JjKSksXHJcbiAgICAgIGludGVybmFsIGFzIFBpcGVhYmxlU2lnbmFsPGFueT4sXHJcbiAgICApO1xyXG4gIH07XHJcblxyXG4gIE9iamVjdC5kZWZpbmVQcm9wZXJ0aWVzKGludGVybmFsLCB7XHJcbiAgICBtYXA6IHtcclxuICAgICAgdmFsdWU6IG1hcEltcGwsXHJcbiAgICAgIGNvbmZpZ3VyYWJsZTogdHJ1ZSxcclxuICAgICAgZW51bWVyYWJsZTogZmFsc2UsXHJcbiAgICAgIHdyaXRhYmxlOiBmYWxzZSxcclxuICAgIH0sXHJcblxyXG4gICAgcGlwZToge1xyXG4gICAgICB2YWx1ZTogcGlwZUltcGwsXHJcbiAgICAgIGNvbmZpZ3VyYWJsZTogdHJ1ZSxcclxuICAgICAgZW51bWVyYWJsZTogZmFsc2UsXHJcbiAgICAgIHdyaXRhYmxlOiBmYWxzZSxcclxuICAgIH0sXHJcbiAgfSk7XHJcblxyXG4gIHJldHVybiBpbnRlcm5hbDtcclxufVxyXG5cclxuLyoqXHJcbiAqIENyZWF0ZSBhIG5ldyAqKndyaXRhYmxlKiogc2lnbmFsIGFuZCByZXR1cm4gaXQgYXMgYSBgUGlwYWJsZVNpZ25hbGAuXHJcbiAqXHJcbiAqIFRoZSByZXR1cm5lZCB2YWx1ZSBpcyBhIGBXcml0YWJsZVNpZ25hbDxUPmAgd2l0aCBgLnNldGAsIGAudXBkYXRlYCwgYC5hc1JlYWRvbmx5YFxyXG4gKiBzdGlsbCBhdmFpbGFibGUgKHZpYSBpbnRlcnNlY3Rpb24gdHlwZSksIHBsdXMgYSBjaGFpbmFibGUgYC5waXBlKC4uLilgLlxyXG4gKlxyXG4gKiBAZXhhbXBsZVxyXG4gKiBjb25zdCBjb3VudCA9IHBpcGVkKDEpOyAvLyBXcml0YWJsZVNpZ25hbDxudW1iZXI+ICgrIHBpcGUpXHJcbiAqIGNvbnN0IGV2ZW4gPSBjb3VudC5waXBlKG4gPT4gbiAlIDIgPT09IDApOyAvLyBTaWduYWw8Ym9vbGVhbj4gKCsgcGlwZSlcclxuICogY291bnQudXBkYXRlKG4gPT4gbiArIDEpO1xyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIHBpcGVkPFQ+KFxyXG4gIGluaXRpYWw6IFQsXHJcbiAgb3B0PzogQ3JlYXRlU2lnbmFsT3B0aW9uczxUPixcclxuKTogUGlwZWFibGVTaWduYWw8VCwgV3JpdGFibGVTaWduYWw8VD4+IHtcclxuICByZXR1cm4gcGlwZWFibGUoc2lnbmFsKGluaXRpYWwsIG9wdCkpO1xyXG59XHJcbiJdfQ==","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, inject, PLATFORM_ID, signal, } from '@angular/core';\n/**\n * Creates a read-only signal that reactively tracks whether a CSS media query\n * string currently matches.\n *\n * It uses `window.matchMedia` to evaluate the query and listen for changes.\n * The primitive is SSR-safe (defaults to `false` on the server) and automatically\n * cleans up its event listeners when the creating context is destroyed.\n *\n * @param query The CSS media query string to evaluate (e.g., `'(min-width: 768px)'`, `'(prefers-color-scheme: dark)'`).\n * @param debugName Optional debug name for the signal.\n * @returns A read-only `Signal<boolean>` which is `true` if the media query\n * currently matches, and `false` otherwise.\n *\n * @remarks\n * - On the server, this signal will always return `false` by default.\n * - It automatically updates if the match status of the media query changes in the browser.\n * - Event listeners are cleaned up automatically via `DestroyRef` if created in an injection context.\n *\n * @example\n * ```ts\n * import { Component, effect } from '@angular/core';\n * import { mediaQuery } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-responsive-layout',\n * template: `\n * @if (isDesktop()) {\n * <p>Showing desktop layout.</p>\n * } @else {\n * <p>Showing mobile layout.</p>\n * }\n * `\n * })\n * export class ResponsiveLayoutComponent {\n * readonly isDesktop = mediaQuery('(min-width: 1024px)');\n *\n * constructor() {\n * effect(() => {\n * console.log('Is desktop view:', this.isDesktop());\n * });\n * }\n * }\n * ```\n */\nexport function mediaQuery(query, debugName = 'mediaQuery') {\n if (isPlatformServer(inject(PLATFORM_ID)))\n return computed(() => false, { debugName });\n const mediaQueryList = window.matchMedia(query);\n const state = signal(mediaQueryList.matches, { debugName: debugName });\n const handleChange = (event) => {\n state.set(event.matches);\n };\n mediaQueryList.addEventListener('change', handleChange);\n inject(DestroyRef).onDestroy(() => {\n mediaQueryList.removeEventListener('change', handleChange);\n });\n return state.asReadonly();\n}\n/**\n * Creates a read-only signal that tracks the user's OS/browser preference\n * for a dark color scheme using the `(prefers-color-scheme: dark)` media query.\n *\n * This is a convenience wrapper around the generic `mediaQuery` primitive.\n * It's SSR-safe (defaults to `false` on the server) and automatically\n * cleans up its event listeners.\n *\n * @param debugName Optional debug name for the signal.\n * @returns A read-only `Signal<boolean>` which is `true` if a dark theme\n * is preferred, and `false` otherwise.\n * @see {mediaQuery} for the underlying implementation.\n *\n * @example\n * ```ts\n * const isDarkMode = prefersDarkMode();\n * effect(() => {\n * document.body.classList.toggle('dark-theme', isDarkMode());\n * });\n * ```\n */\nexport function prefersDarkMode(debugName) {\n return mediaQuery('(prefers-color-scheme: dark)', debugName);\n}\n/**\n * Creates a read-only signal that tracks the user's OS/browser preference\n * for reduced motion using the `(prefers-reduced-motion: reduce)` media query.\n *\n * This is a convenience wrapper around the generic `mediaQuery` primitive.\n * It's SSR-safe (defaults to `false` on the server) and automatically\n * cleans up its event listeners.\n *\n * @param debugName Optional debug name for the signal.\n * @returns A read-only `Signal<boolean>` which is `true` if reduced motion\n * is preferred, and `false` otherwise.\n * @see {mediaQuery} for the underlying implementation.\n *\n * @example\n * ```ts\n * const reduceMotion = prefersReducedMotion();\n * effect(() => {\n * if (reduceMotion()) {\n * // Apply simplified animations or disable them\n * } else {\n * // Apply full animations\n * }\n * });\n * ```\n */\nexport function prefersReducedMotion(debugName) {\n return mediaQuery('(prefers-reduced-motion: reduce)', debugName);\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVkaWEtcXVlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3NyYy9saWIvc2Vuc29ycy9tZWRpYS1xdWVyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQ0wsUUFBUSxFQUNSLFVBQVUsRUFDVixNQUFNLEVBQ04sV0FBVyxFQUNYLE1BQU0sR0FFUCxNQUFNLGVBQWUsQ0FBQztBQUV2Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTJDRztBQUNILE1BQU0sVUFBVSxVQUFVLENBQ3hCLEtBQWEsRUFDYixTQUFTLEdBQUcsWUFBWTtJQUV4QixJQUFJLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN2QyxPQUFPLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBRTlDLE1BQU0sY0FBYyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7SUFFaEQsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQztJQUV2RSxNQUFNLFlBQVksR0FBRyxDQUFDLEtBQTBCLEVBQUUsRUFBRTtRQUNsRCxLQUFLLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMzQixDQUFDLENBQUM7SUFFRixjQUFjLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBRXhELE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ2hDLGNBQWMsQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLEVBQUUsWUFBWSxDQUFDLENBQUM7SUFDN0QsQ0FBQyxDQUFDLENBQUM7SUFFSCxPQUFPLEtBQUssQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUM1QixDQUFDO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JHO0FBQ0gsTUFBTSxVQUFVLGVBQWUsQ0FBQyxTQUFrQjtJQUNoRCxPQUFPLFVBQVUsQ0FBQyw4QkFBOEIsRUFBRSxTQUFTLENBQUMsQ0FBQztBQUMvRCxDQUFDO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXdCRztBQUNILE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxTQUFrQjtJQUNyRCxPQUFPLFVBQVUsQ0FBQyxrQ0FBa0MsRUFBRSxTQUFTLENBQUMsQ0FBQztBQUNuRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNQbGF0Zm9ybVNlcnZlciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7XHJcbiAgY29tcHV0ZWQsXHJcbiAgRGVzdHJveVJlZixcclxuICBpbmplY3QsXHJcbiAgUExBVEZPUk1fSUQsXHJcbiAgc2lnbmFsLFxyXG4gIFNpZ25hbCxcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGVzIGEgcmVhZC1vbmx5IHNpZ25hbCB0aGF0IHJlYWN0aXZlbHkgdHJhY2tzIHdoZXRoZXIgYSBDU1MgbWVkaWEgcXVlcnlcclxuICogc3RyaW5nIGN1cnJlbnRseSBtYXRjaGVzLlxyXG4gKlxyXG4gKiBJdCB1c2VzIGB3aW5kb3cubWF0Y2hNZWRpYWAgdG8gZXZhbHVhdGUgdGhlIHF1ZXJ5IGFuZCBsaXN0ZW4gZm9yIGNoYW5nZXMuXHJcbiAqIFRoZSBwcmltaXRpdmUgaXMgU1NSLXNhZmUgKGRlZmF1bHRzIHRvIGBmYWxzZWAgb24gdGhlIHNlcnZlcikgYW5kIGF1dG9tYXRpY2FsbHlcclxuICogY2xlYW5zIHVwIGl0cyBldmVudCBsaXN0ZW5lcnMgd2hlbiB0aGUgY3JlYXRpbmcgY29udGV4dCBpcyBkZXN0cm95ZWQuXHJcbiAqXHJcbiAqIEBwYXJhbSBxdWVyeSBUaGUgQ1NTIG1lZGlhIHF1ZXJ5IHN0cmluZyB0byBldmFsdWF0ZSAoZS5nLiwgYCcobWluLXdpZHRoOiA3NjhweCknYCwgYCcocHJlZmVycy1jb2xvci1zY2hlbWU6IGRhcmspJ2ApLlxyXG4gKiBAcGFyYW0gZGVidWdOYW1lIE9wdGlvbmFsIGRlYnVnIG5hbWUgZm9yIHRoZSBzaWduYWwuXHJcbiAqIEByZXR1cm5zIEEgcmVhZC1vbmx5IGBTaWduYWw8Ym9vbGVhbj5gIHdoaWNoIGlzIGB0cnVlYCBpZiB0aGUgbWVkaWEgcXVlcnlcclxuICogY3VycmVudGx5IG1hdGNoZXMsIGFuZCBgZmFsc2VgIG90aGVyd2lzZS5cclxuICpcclxuICogQHJlbWFya3NcclxuICogLSBPbiB0aGUgc2VydmVyLCB0aGlzIHNpZ25hbCB3aWxsIGFsd2F5cyByZXR1cm4gYGZhbHNlYCBieSBkZWZhdWx0LlxyXG4gKiAtIEl0IGF1dG9tYXRpY2FsbHkgdXBkYXRlcyBpZiB0aGUgbWF0Y2ggc3RhdHVzIG9mIHRoZSBtZWRpYSBxdWVyeSBjaGFuZ2VzIGluIHRoZSBicm93c2VyLlxyXG4gKiAtIEV2ZW50IGxpc3RlbmVycyBhcmUgY2xlYW5lZCB1cCBhdXRvbWF0aWNhbGx5IHZpYSBgRGVzdHJveVJlZmAgaWYgY3JlYXRlZCBpbiBhbiBpbmplY3Rpb24gY29udGV4dC5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogYGBgdHNcclxuICogaW1wb3J0IHsgQ29tcG9uZW50LCBlZmZlY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuICogaW1wb3J0IHsgbWVkaWFRdWVyeSB9IGZyb20gJ0BtbXN0YWNrL3ByaW1pdGl2ZXMnO1xyXG4gKlxyXG4gKiBAQ29tcG9uZW50KHtcclxuICogc2VsZWN0b3I6ICdhcHAtcmVzcG9uc2l2ZS1sYXlvdXQnLFxyXG4gKiB0ZW1wbGF0ZTogYFxyXG4gKiBAaWYgKGlzRGVza3RvcCgpKSB7XHJcbiAqIDxwPlNob3dpbmcgZGVza3RvcCBsYXlvdXQuPC9wPlxyXG4gKiB9IEBlbHNlIHtcclxuICogPHA+U2hvd2luZyBtb2JpbGUgbGF5b3V0LjwvcD5cclxuICogfVxyXG4gKiBgXHJcbiAqIH0pXHJcbiAqIGV4cG9ydCBjbGFzcyBSZXNwb25zaXZlTGF5b3V0Q29tcG9uZW50IHtcclxuICogcmVhZG9ubHkgaXNEZXNrdG9wID0gbWVkaWFRdWVyeSgnKG1pbi13aWR0aDogMTAyNHB4KScpO1xyXG4gKlxyXG4gKiBjb25zdHJ1Y3RvcigpIHtcclxuICogZWZmZWN0KCgpID0+IHtcclxuICogY29uc29sZS5sb2coJ0lzIGRlc2t0b3AgdmlldzonLCB0aGlzLmlzRGVza3RvcCgpKTtcclxuICogfSk7XHJcbiAqIH1cclxuICogfVxyXG4gKiBgYGBcclxuICovXHJcbmV4cG9ydCBmdW5jdGlvbiBtZWRpYVF1ZXJ5KFxyXG4gIHF1ZXJ5OiBzdHJpbmcsXHJcbiAgZGVidWdOYW1lID0gJ21lZGlhUXVlcnknLFxyXG4pOiBTaWduYWw8Ym9vbGVhbj4ge1xyXG4gIGlmIChpc1BsYXRmb3JtU2VydmVyKGluamVjdChQTEFURk9STV9JRCkpKVxyXG4gICAgcmV0dXJuIGNvbXB1dGVkKCgpID0+IGZhbHNlLCB7IGRlYnVnTmFtZSB9KTtcclxuXHJcbiAgY29uc3QgbWVkaWFRdWVyeUxpc3QgPSB3aW5kb3cubWF0Y2hNZWRpYShxdWVyeSk7XHJcblxyXG4gIGNvbnN0IHN0YXRlID0gc2lnbmFsKG1lZGlhUXVlcnlMaXN0Lm1hdGNoZXMsIHsgZGVidWdOYW1lOiBkZWJ1Z05hbWUgfSk7XHJcblxyXG4gIGNvbnN0IGhhbmRsZUNoYW5nZSA9IChldmVudDogTWVkaWFRdWVyeUxpc3RFdmVudCkgPT4ge1xyXG4gICAgc3RhdGUuc2V0KGV2ZW50Lm1hdGNoZXMpO1xyXG4gIH07XHJcblxyXG4gIG1lZGlhUXVlcnlMaXN0LmFkZEV2ZW50TGlzdGVuZXIoJ2NoYW5nZScsIGhhbmRsZUNoYW5nZSk7XHJcblxyXG4gIGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT4ge1xyXG4gICAgbWVkaWFRdWVyeUxpc3QucmVtb3ZlRXZlbnRMaXN0ZW5lcignY2hhbmdlJywgaGFuZGxlQ2hhbmdlKTtcclxuICB9KTtcclxuXHJcbiAgcmV0dXJuIHN0YXRlLmFzUmVhZG9ubHkoKTtcclxufVxyXG5cclxuLyoqXHJcbiAqIENyZWF0ZXMgYSByZWFkLW9ubHkgc2lnbmFsIHRoYXQgdHJhY2tzIHRoZSB1c2VyJ3MgT1MvYnJvd3NlciBwcmVmZXJlbmNlXHJcbiAqIGZvciBhIGRhcmsgY29sb3Igc2NoZW1lIHVzaW5nIHRoZSBgKHByZWZlcnMtY29sb3Itc2NoZW1lOiBkYXJrKWAgbWVkaWEgcXVlcnkuXHJcbiAqXHJcbiAqIFRoaXMgaXMgYSBjb252ZW5pZW5jZSB3cmFwcGVyIGFyb3VuZCB0aGUgZ2VuZXJpYyBgbWVkaWFRdWVyeWAgcHJpbWl0aXZlLlxyXG4gKiBJdCdzIFNTUi1zYWZlIChkZWZhdWx0cyB0byBgZmFsc2VgIG9uIHRoZSBzZXJ2ZXIpIGFuZCBhdXRvbWF0aWNhbGx5XHJcbiAqIGNsZWFucyB1cCBpdHMgZXZlbnQgbGlzdGVuZXJzLlxyXG4gKlxyXG4gKiBAcGFyYW0gZGVidWdOYW1lIE9wdGlvbmFsIGRlYnVnIG5hbWUgZm9yIHRoZSBzaWduYWwuXHJcbiAqIEByZXR1cm5zIEEgcmVhZC1vbmx5IGBTaWduYWw8Ym9vbGVhbj5gIHdoaWNoIGlzIGB0cnVlYCBpZiBhIGRhcmsgdGhlbWVcclxuICogaXMgcHJlZmVycmVkLCBhbmQgYGZhbHNlYCBvdGhlcndpc2UuXHJcbiAqIEBzZWUge21lZGlhUXVlcnl9IGZvciB0aGUgdW5kZXJseWluZyBpbXBsZW1lbnRhdGlvbi5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogYGBgdHNcclxuICogY29uc3QgaXNEYXJrTW9kZSA9IHByZWZlcnNEYXJrTW9kZSgpO1xyXG4gKiBlZmZlY3QoKCkgPT4ge1xyXG4gKiBkb2N1bWVudC5ib2R5LmNsYXNzTGlzdC50b2dnbGUoJ2RhcmstdGhlbWUnLCBpc0RhcmtNb2RlKCkpO1xyXG4gKiB9KTtcclxuICogYGBgXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gcHJlZmVyc0RhcmtNb2RlKGRlYnVnTmFtZT86IHN0cmluZyk6IFNpZ25hbDxib29sZWFuPiB7XHJcbiAgcmV0dXJuIG1lZGlhUXVlcnkoJyhwcmVmZXJzLWNvbG9yLXNjaGVtZTogZGFyayknLCBkZWJ1Z05hbWUpO1xyXG59XHJcblxyXG4vKipcclxuICogQ3JlYXRlcyBhIHJlYWQtb25seSBzaWduYWwgdGhhdCB0cmFja3MgdGhlIHVzZXIncyBPUy9icm93c2VyIHByZWZlcmVuY2VcclxuICogZm9yIHJlZHVjZWQgbW90aW9uIHVzaW5nIHRoZSBgKHByZWZlcnMtcmVkdWNlZC1tb3Rpb246IHJlZHVjZSlgIG1lZGlhIHF1ZXJ5LlxyXG4gKlxyXG4gKiBUaGlzIGlzIGEgY29udmVuaWVuY2Ugd3JhcHBlciBhcm91bmQgdGhlIGdlbmVyaWMgYG1lZGlhUXVlcnlgIHByaW1pdGl2ZS5cclxuICogSXQncyBTU1Itc2FmZSAoZGVmYXVsdHMgdG8gYGZhbHNlYCBvbiB0aGUgc2VydmVyKSBhbmQgYXV0b21hdGljYWxseVxyXG4gKiBjbGVhbnMgdXAgaXRzIGV2ZW50IGxpc3RlbmVycy5cclxuICpcclxuICogQHBhcmFtIGRlYnVnTmFtZSBPcHRpb25hbCBkZWJ1ZyBuYW1lIGZvciB0aGUgc2lnbmFsLlxyXG4gKiBAcmV0dXJucyBBIHJlYWQtb25seSBgU2lnbmFsPGJvb2xlYW4+YCB3aGljaCBpcyBgdHJ1ZWAgaWYgcmVkdWNlZCBtb3Rpb25cclxuICogaXMgcHJlZmVycmVkLCBhbmQgYGZhbHNlYCBvdGhlcndpc2UuXHJcbiAqIEBzZWUge21lZGlhUXVlcnl9IGZvciB0aGUgdW5kZXJseWluZyBpbXBsZW1lbnRhdGlvbi5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogYGBgdHNcclxuICogY29uc3QgcmVkdWNlTW90aW9uID0gcHJlZmVyc1JlZHVjZWRNb3Rpb24oKTtcclxuICogZWZmZWN0KCgpID0+IHtcclxuICogaWYgKHJlZHVjZU1vdGlvbigpKSB7XHJcbiAqIC8vIEFwcGx5IHNpbXBsaWZpZWQgYW5pbWF0aW9ucyBvciBkaXNhYmxlIHRoZW1cclxuICogfSBlbHNlIHtcclxuICogLy8gQXBwbHkgZnVsbCBhbmltYXRpb25zXHJcbiAqIH1cclxuICogfSk7XHJcbiAqIGBgYFxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIHByZWZlcnNSZWR1Y2VkTW90aW9uKGRlYnVnTmFtZT86IHN0cmluZyk6IFNpZ25hbDxib29sZWFuPiB7XHJcbiAgcmV0dXJuIG1lZGlhUXVlcnkoJyhwcmVmZXJzLXJlZHVjZWQtbW90aW9uOiByZWR1Y2UpJywgZGVidWdOYW1lKTtcclxufVxyXG4iXX0=","import { computed, DestroyRef, inject, signal, untracked, } from '@angular/core';\nimport { toWritable } from './to-writable';\n/**\n * A convenience function that creates and throttles a new `WritableSignal` in one step.\n *\n * @see {throttle} for the core implementation details.\n *\n * @template T The type of value the signal holds.\n * @param initial The initial value of the signal.\n * @param opt Options for signal creation, including throttle time `ms`.\n * @returns A `ThrottledSignal<T>` instance.\n *\n * @example\n * const query = throttled('', { ms: 500 });\n * effect(() => console.log('Throttled Query:', query()));\n *\n * query.set('a');\n * query.set('b');\n * query.set('c');\n * // With a trailing-edge throttle, the final value 'c' would be set\n * // after the 500ms cooldown.\n */\nexport function throttled(initial, opt) {\n return throttle(signal(initial, opt), opt);\n}\n/**\n * Wraps an existing `WritableSignal` to create a new one whose readable value is throttled.\n *\n * This implementation avoids using `effect` by pairing a trigger signal with an `untracked`\n * read of the source signal to control when the throttled value is re-evaluated.\n *\n * @template T The type of value the signal holds.\n * @param source The source `WritableSignal` to wrap. Writes are applied to this signal immediately.\n * @param opt Options for throttling, including throttle time `ms` and an optional `DestroyRef`.\n * @returns A new `ThrottledSignal<T>` whose read value is throttled. The `.original` property\n * of the returned signal is a reference back to the provided `source` signal.\n *\n * @example\n * const query = throttled('', { ms: 500 });\n * effect(() => console.log('Throttled Query:', query()));\n *\n * query.set('a');\n * query.set('b');\n * query.set('c');\n * // With a trailing-edge throttle, the final value 'c' would be set\n * // after the 500ms cooldown.\n */\nexport function throttle(source, opt) {\n const ms = opt?.ms ?? 0;\n const trigger = signal(false, ...(ngDevMode ? [{ debugName: \"trigger\" }] : []));\n let timeout;\n try {\n const destroyRef = opt?.destroyRef ?? inject(DestroyRef, { optional: true });\n destroyRef?.onDestroy(() => {\n if (timeout)\n clearTimeout(timeout);\n timeout = undefined;\n });\n }\n catch {\n // not in injection context & no destroyRef provided opting out of cleanup\n }\n const triggerFn = (updateSourceAction) => {\n updateSourceAction();\n if (timeout)\n return;\n timeout = setTimeout(() => {\n trigger.update((c) => !c);\n timeout = undefined;\n }, ms);\n };\n const set = (value) => {\n triggerFn(() => source.set(value));\n };\n const update = (fn) => {\n triggerFn(() => source.update(fn));\n };\n const writable = toWritable(computed(() => {\n trigger();\n return untracked(source);\n }, opt), set, update);\n writable.original = source;\n return writable;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"throttled.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/throttled.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAER,UAAU,EACV,MAAM,EACN,MAAM,EACN,SAAS,GAEV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAiC3C;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,SAAS,CACvB,OAAU,EACV,GAA+B;IAE/B,OAAO,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;AAC7C,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAM,UAAU,QAAQ,CACtB,MAAyB,EACzB,GAA+B;IAE/B,MAAM,EAAE,GAAG,GAAG,EAAE,EAAE,IAAI,CAAC,CAAC;IAExB,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,mDAAC,CAAC;IAE9B,IAAI,OAAkD,CAAC;IAEvD,IAAI,CAAC;QACH,MAAM,UAAU,GACd,GAAG,EAAE,UAAU,IAAI,MAAM,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAE5D,UAAU,EAAE,SAAS,CAAC,GAAG,EAAE;YACzB,IAAI,OAAO;gBAAE,YAAY,CAAC,OAAO,CAAC,CAAC;YACnC,OAAO,GAAG,SAAS,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IAAC,MAAM,CAAC;QACP,0EAA0E;IAC5E,CAAC;IAED,MAAM,SAAS,GAAG,CAAC,kBAA8B,EAAE,EAAE;QACnD,kBAAkB,EAAE,CAAC;QACrB,IAAI,OAAO;YAAE,OAAO;QAEpB,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;YACxB,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1B,OAAO,GAAG,SAAS,CAAC;QACtB,CAAC,EAAE,EAAE,CAAC,CAAC;IACT,CAAC,CAAC;IAEF,MAAM,GAAG,GAAG,CAAC,KAAQ,EAAE,EAAE;QACvB,SAAS,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC;IAEF,MAAM,MAAM,GAAG,CAAC,EAAkB,EAAE,EAAE;QACpC,SAAS,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IACrC,CAAC,CAAC;IAEF,MAAM,QAAQ,GAAG,UAAU,CACzB,QAAQ,CAAC,GAAG,EAAE;QACZ,OAAO,EAAE,CAAC;QACV,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC,EAAE,GAAG,CAAC,EACP,GAAG,EACH,MAAM,CACe,CAAC;IACxB,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC;IAE3B,OAAO,QAAQ,CAAC;AAClB,CAAC","sourcesContent":["import {\r\n  computed,\r\n  type CreateSignalOptions,\r\n  DestroyRef,\r\n  inject,\r\n  signal,\r\n  untracked,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { DebouncedSignal } from './debounced';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * Options for creating a throttled writable signal.\r\n * Extends Angular's `CreateSignalOptions` with a throttle time setting.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type CreateThrottledOptions<T> = CreateSignalOptions<T> & {\r\n  /**\r\n   * The throttle delay in milliseconds. The minimum time\r\n   * in milliseconds that must pass between updates to the throttled signal's value.\r\n   */\r\n  ms?: number;\r\n  /**\r\n   * Optional `DestroyRef` to clean up the throttle timer when the signal is destroyed.\r\n   * If provided, the timer will be cleared when the signal is destroyed.\r\n   * If the signal is called within a reactive context a DestroyRef is injected automatically.\r\n   * If it is not provided or injected, the timer will not be cleared automatically...which is usually fine :)\r\n   */\r\n  destroyRef?: DestroyRef;\r\n};\r\n\r\n/**\r\n * A specialized `WritableSignal` whose publicly readable value updates are throttled.\r\n *\r\n * It provides access to the underlying, non-throttled signal via the `original` property.\r\n *\r\n * @template T The type of value held by the signal.\r\n * @see {DebouncedSignal} as the output type has the same structure.\r\n */\r\nexport type ThrottledSignal<T> = DebouncedSignal<T>;\r\n\r\n/**\r\n * A convenience function that creates and throttles a new `WritableSignal` in one step.\r\n *\r\n * @see {throttle} for the core implementation details.\r\n *\r\n * @template T The type of value the signal holds.\r\n * @param initial The initial value of the signal.\r\n * @param opt Options for signal creation, including throttle time `ms`.\r\n * @returns A `ThrottledSignal<T>` instance.\r\n *\r\n * @example\r\n * const query = throttled('', { ms: 500 });\r\n * effect(() => console.log('Throttled Query:', query()));\r\n *\r\n * query.set('a');\r\n * query.set('b');\r\n * query.set('c');\r\n * // With a trailing-edge throttle, the final value 'c' would be set\r\n * // after the 500ms cooldown.\r\n */\r\nexport function throttled<T>(\r\n  initial: T,\r\n  opt?: CreateThrottledOptions<T>,\r\n): DebouncedSignal<T> {\r\n  return throttle(signal(initial, opt), opt);\r\n}\r\n\r\n/**\r\n * Wraps an existing `WritableSignal` to create a new one whose readable value is throttled.\r\n *\r\n * This implementation avoids using `effect` by pairing a trigger signal with an `untracked`\r\n * read of the source signal to control when the throttled value is re-evaluated.\r\n *\r\n * @template T The type of value the signal holds.\r\n * @param source The source `WritableSignal` to wrap. Writes are applied to this signal immediately.\r\n * @param opt Options for throttling, including throttle time `ms` and an optional `DestroyRef`.\r\n * @returns A new `ThrottledSignal<T>` whose read value is throttled. The `.original` property\r\n * of the returned signal is a reference back to the provided `source` signal.\r\n *\r\n * @example\r\n * const query = throttled('', { ms: 500 });\r\n * effect(() => console.log('Throttled Query:', query()));\r\n *\r\n * query.set('a');\r\n * query.set('b');\r\n * query.set('c');\r\n * // With a trailing-edge throttle, the final value 'c' would be set\r\n * // after the 500ms cooldown.\r\n */\r\nexport function throttle<T>(\r\n  source: WritableSignal<T>,\r\n  opt?: CreateThrottledOptions<T>,\r\n): ThrottledSignal<T> {\r\n  const ms = opt?.ms ?? 0;\r\n\r\n  const trigger = signal(false);\r\n\r\n  let timeout: ReturnType<typeof setTimeout> | undefined;\r\n\r\n  try {\r\n    const destroyRef =\r\n      opt?.destroyRef ?? inject(DestroyRef, { optional: true });\r\n\r\n    destroyRef?.onDestroy(() => {\r\n      if (timeout) clearTimeout(timeout);\r\n      timeout = undefined;\r\n    });\r\n  } catch {\r\n    // not in injection context & no destroyRef provided opting out of cleanup\r\n  }\r\n\r\n  const triggerFn = (updateSourceAction: () => void) => {\r\n    updateSourceAction();\r\n    if (timeout) return;\r\n\r\n    timeout = setTimeout(() => {\r\n      trigger.update((c) => !c);\r\n      timeout = undefined;\r\n    }, ms);\r\n  };\r\n\r\n  const set = (value: T) => {\r\n    triggerFn(() => source.set(value));\r\n  };\r\n\r\n  const update = (fn: (prev: T) => T) => {\r\n    triggerFn(() => source.update(fn));\r\n  };\r\n\r\n  const writable = toWritable(\r\n    computed(() => {\r\n      trigger();\r\n      return untracked(source);\r\n    }, opt),\r\n    set,\r\n    update,\r\n  ) as ThrottledSignal<T>;\r\n  writable.original = source;\r\n\r\n  return writable;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, ElementRef, inject, isDevMode, PLATFORM_ID, } from '@angular/core';\nimport { throttled } from '../throttled';\n/**\n * Creates a read-only signal that tracks the mouse cursor's position.\n *\n * It can track mouse movements on a specific target (window, document, or element)\n * and optionally include touch movements. The coordinate space ('client' or 'page')\n * can also be configured.\n * The primitive is SSR-safe and automatically cleans up its event listeners.\n *\n * @param options Optional configuration for the sensor.\n * @returns A read-only `Signal<MousePosition>`. On the server, it returns a static\n * signal with `{ x: 0, y: 0 }`.\n *\n * @example\n * ```ts\n * import { Component, effect } from '@angular/core';\n * import { mousePosition } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-mouse-tracker',\n * template: `<p>Mouse Position: X: {{ pos().x }}, Y: {{ pos().y }}</p>`\n * })\n * export class MouseTrackerComponent {\n * readonly pos = mousePosition({ coordinateSpace: 'page' });\n *\n * constructor() {\n * effect(() => {\n * console.log('Mouse moved to:', this.pos());\n * });\n * }\n * }\n * ```\n */\nexport function mousePosition(opt) {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n const base = computed(() => ({\n x: 0,\n y: 0,\n }), {\n debugName: opt?.debugName ?? 'mousePosition',\n });\n base.unthrottled = base;\n return base;\n }\n const { target = window, coordinateSpace = 'client', touch = false, debugName = 'mousePosition', throttle = 100, } = opt ?? {};\n const eventTarget = target instanceof ElementRef ? target.nativeElement : target;\n if (!eventTarget) {\n if (isDevMode())\n console.warn('mousePosition: Target element not found.');\n const base = computed(() => ({\n x: 0,\n y: 0,\n }), {\n debugName,\n });\n base.unthrottled = base;\n return base;\n }\n const pos = throttled({ x: 0, y: 0 }, {\n ms: throttle,\n equal: (a, b) => a.x === b.x && a.y === b.y,\n debugName,\n });\n const updatePosition = (event) => {\n let x, y;\n if (event instanceof MouseEvent) {\n x = coordinateSpace === 'page' ? event.pageX : event.clientX;\n y = coordinateSpace === 'page' ? event.pageY : event.clientY;\n }\n else if (event.touches.length > 0) {\n const firstTouch = event.touches[0];\n x = coordinateSpace === 'page' ? firstTouch.pageX : firstTouch.clientX;\n y = coordinateSpace === 'page' ? firstTouch.pageY : firstTouch.clientY;\n }\n else {\n return;\n }\n pos.set({ x, y });\n };\n eventTarget.addEventListener('mousemove', updatePosition);\n if (touch) {\n eventTarget.addEventListener('touchmove', updatePosition);\n }\n inject(DestroyRef).onDestroy(() => {\n eventTarget.removeEventListener('mousemove', updatePosition);\n if (touch) {\n eventTarget.removeEventListener('touchmove', updatePosition);\n }\n });\n const base = pos.asReadonly();\n base.unthrottled = pos.original;\n return base;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mouse-position.js","sourceRoot":"","sources":["../../../../../../packages/primitives/src/lib/sensors/mouse-position.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common';\r\nimport {\r\n  computed,\r\n  DestroyRef,\r\n  ElementRef,\r\n  inject,\r\n  isDevMode,\r\n  PLATFORM_ID,\r\n  Signal,\r\n} from '@angular/core';\r\nimport { throttled } from '../throttled';\r\n\r\ntype MousePosition = {\r\n  x: number;\r\n  y: number;\r\n};\r\n\r\n/**\r\n * Options for configuring the `mousePosition` sensor.\r\n */\r\nexport type MousePositionOptions = {\r\n  /**\r\n   * The target element to listen for mouse movements on.\r\n   * Can be `window`, `document`, an `HTMLElement`, or an `ElementRef<HTMLElement>`.\r\n   * @default window\r\n   */\r\n  target?: Window | Document | HTMLElement | ElementRef<HTMLElement>;\r\n  /**\r\n   * Defines the coordinate system for the reported position.\r\n   * - `'client'`: Coordinates relative to the viewport (`clientX`, `clientY`).\r\n   * - `'page'`: Coordinates relative to the entire document (`pageX`, `pageY`).\r\n   * @default 'client'\r\n   */\r\n  coordinateSpace?: 'client' | 'page';\r\n  /**\r\n   * If `true`, the sensor will also listen to `touchmove` events and report\r\n   * the coordinates of the first touch point.\r\n   * @default false\r\n   */\r\n  touch?: boolean;\r\n  /**\r\n   * Optional debug name for the internal signal.\r\n   */\r\n  debugName?: string;\r\n  /**\r\n   * Optional delay in milliseconds to throttle the updates.\r\n   * @default 100\r\n   */\r\n  throttle?: number;\r\n};\r\n\r\n/**\r\n * @internal used for setting the since signal\r\n */\r\ntype InternalMousePositionSignal = Signal<MousePosition> & {\r\n  unthrottled: Signal<MousePosition>;\r\n};\r\n\r\n/**\r\n * A specialized Signal that tracks mouse position within an element.\r\n * It's a throttled signal of the mouse coordinates with an attached `unthrottled` signal.\r\n */\r\nexport type MousePositionSignal = Signal<MousePosition> & {\r\n  /** A signal providing the raw, unthrottled mouse position. */\r\n  readonly unthrottled: Signal<MousePosition>;\r\n};\r\n\r\n/**\r\n * Creates a read-only signal that tracks the mouse cursor's position.\r\n *\r\n * It can track mouse movements on a specific target (window, document, or element)\r\n * and optionally include touch movements. The coordinate space ('client' or 'page')\r\n * can also be configured.\r\n * The primitive is SSR-safe and automatically cleans up its event listeners.\r\n *\r\n * @param options Optional configuration for the sensor.\r\n * @returns A read-only `Signal<MousePosition>`. On the server, it returns a static\r\n * signal with `{ x: 0, y: 0 }`.\r\n *\r\n * @example\r\n * ```ts\r\n * import { Component, effect } from '@angular/core';\r\n * import { mousePosition } from '@mmstack/primitives';\r\n *\r\n * @Component({\r\n * selector: 'app-mouse-tracker',\r\n * template: `<p>Mouse Position: X: {{ pos().x }}, Y: {{ pos().y }}</p>`\r\n * })\r\n * export class MouseTrackerComponent {\r\n * readonly pos = mousePosition({ coordinateSpace: 'page' });\r\n *\r\n * constructor() {\r\n * effect(() => {\r\n * console.log('Mouse moved to:', this.pos());\r\n * });\r\n * }\r\n * }\r\n * ```\r\n */\r\nexport function mousePosition(opt?: MousePositionOptions): MousePositionSignal {\r\n  if (isPlatformServer(inject(PLATFORM_ID))) {\r\n    const base = computed(\r\n      () => ({\r\n        x: 0,\r\n        y: 0,\r\n      }),\r\n      {\r\n        debugName: opt?.debugName ?? 'mousePosition',\r\n      },\r\n    ) as InternalMousePositionSignal;\r\n    base.unthrottled = base;\r\n    return base;\r\n  }\r\n\r\n  const {\r\n    target = window,\r\n    coordinateSpace = 'client',\r\n    touch = false,\r\n    debugName = 'mousePosition',\r\n    throttle = 100,\r\n  } = opt ?? {};\r\n\r\n  const eventTarget =\r\n    target instanceof ElementRef ? target.nativeElement : target;\r\n\r\n  if (!eventTarget) {\r\n    if (isDevMode()) console.warn('mousePosition: Target element not found.');\r\n\r\n    const base = computed(\r\n      () => ({\r\n        x: 0,\r\n        y: 0,\r\n      }),\r\n      {\r\n        debugName,\r\n      },\r\n    ) as InternalMousePositionSignal;\r\n    base.unthrottled = base;\r\n    return base;\r\n  }\r\n\r\n  const pos = throttled(\r\n    { x: 0, y: 0 },\r\n    {\r\n      ms: throttle,\r\n      equal: (a, b) => a.x === b.x && a.y === b.y,\r\n      debugName,\r\n    },\r\n  );\r\n\r\n  const updatePosition = (event: MouseEvent | TouchEvent) => {\r\n    let x: number, y: number;\r\n\r\n    if (event instanceof MouseEvent) {\r\n      x = coordinateSpace === 'page' ? event.pageX : event.clientX;\r\n      y = coordinateSpace === 'page' ? event.pageY : event.clientY;\r\n    } else if (event.touches.length > 0) {\r\n      const firstTouch = event.touches[0];\r\n      x = coordinateSpace === 'page' ? firstTouch.pageX : firstTouch.clientX;\r\n      y = coordinateSpace === 'page' ? firstTouch.pageY : firstTouch.clientY;\r\n    } else {\r\n      return;\r\n    }\r\n    pos.set({ x, y });\r\n  };\r\n\r\n  eventTarget.addEventListener('mousemove', updatePosition as EventListener);\r\n  if (touch) {\r\n    eventTarget.addEventListener('touchmove', updatePosition as EventListener);\r\n  }\r\n\r\n  inject(DestroyRef).onDestroy(() => {\r\n    eventTarget.removeEventListener(\r\n      'mousemove',\r\n      updatePosition as EventListener,\r\n    );\r\n    if (touch) {\r\n      eventTarget.removeEventListener(\r\n        'touchmove',\r\n        updatePosition as EventListener,\r\n      );\r\n    }\r\n  });\r\n\r\n  const base = pos.asReadonly() as InternalMousePositionSignal;\r\n  base.unthrottled = pos.original;\r\n  return base;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, inject, PLATFORM_ID, signal, } from '@angular/core';\nconst serverDate = new Date();\n/**\n * Creates a read-only signal that tracks the browser's online status.\n *\n * The main signal returns a boolean (`true` for online, `false` for offline).\n * An additional `since` signal is attached, tracking when the status last changed.\n * It's SSR-safe and automatically cleans up its event listeners.\n *\n * @param debugName Optional debug name for the signal.\n * @returns A `NetworkStatusSignal` instance.\n */\nexport function networkStatus(debugName = 'networkStatus') {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n const sig = computed(() => true, {\n debugName,\n });\n sig.since = computed(() => serverDate, ...(ngDevMode ? [{ debugName: \"since\" }] : []));\n return sig;\n }\n const state = signal(navigator.onLine, ...(ngDevMode ? [{ debugName: \"state\", debugName }] : [{\n debugName,\n }]));\n const since = signal(new Date(), ...(ngDevMode ? [{ debugName: \"since\" }] : []));\n const goOnline = () => {\n state.set(true);\n since.set(new Date());\n };\n const goOffline = () => {\n state.set(false);\n since.set(new Date());\n };\n window.addEventListener('online', goOnline);\n window.addEventListener('offline', goOffline);\n inject(DestroyRef).onDestroy(() => {\n window.removeEventListener('online', goOnline);\n window.removeEventListener('offline', goOffline);\n });\n const sig = state.asReadonly();\n sig.since = since.asReadonly();\n return sig;\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV0d29yay1zdGF0dXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3NyYy9saWIvc2Vuc29ycy9uZXR3b3JrLXN0YXR1cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQ0wsUUFBUSxFQUNSLFVBQVUsRUFDVixNQUFNLEVBQ04sV0FBVyxFQUVYLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQztBQWtCdkIsTUFBTSxVQUFVLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQztBQUU5Qjs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLFVBQVUsYUFBYSxDQUMzQixTQUFTLEdBQUcsZUFBZTtJQUUzQixJQUFJLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDMUMsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksRUFBRTtZQUMvQixTQUFTO1NBQ1YsQ0FBZ0MsQ0FBQztRQUNsQyxHQUFHLENBQUMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLGlEQUFDLENBQUM7UUFDdkMsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDO0lBRUQsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLHlDQUNuQyxTQUFTLE9BRDRCO1lBQ3JDLFNBQVM7U0FDVixHQUFDLENBQUM7SUFDSCxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsSUFBSSxJQUFJLEVBQUUsaURBQUMsQ0FBQztJQUVqQyxNQUFNLFFBQVEsR0FBRyxHQUFHLEVBQUU7UUFDcEIsS0FBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNoQixLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN4QixDQUFDLENBQUM7SUFDRixNQUFNLFNBQVMsR0FBRyxHQUFHLEVBQUU7UUFDckIsS0FBSyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNqQixLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN4QixDQUFDLENBQUM7SUFFRixNQUFNLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBQzVDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFFOUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7UUFDaEMsTUFBTSxDQUFDLG1CQUFtQixDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUMvQyxNQUFNLENBQUMsbUJBQW1CLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDO0lBQ25ELENBQUMsQ0FBQyxDQUFDO0lBRUgsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLFVBQVUsRUFBaUMsQ0FBQztJQUM5RCxHQUFHLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUUvQixPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1BsYXRmb3JtU2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHtcclxuICBjb21wdXRlZCxcclxuICBEZXN0cm95UmVmLFxyXG4gIGluamVjdCxcclxuICBQTEFURk9STV9JRCxcclxuICBTaWduYWwsXHJcbiAgc2lnbmFsLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuLyoqXHJcbiAqIEBpbnRlcm5hbCB1c2VkIGZvciBzZXR0aW5nIHRoZSBzaW5jZSBzaWduYWxcclxuICovXHJcbnR5cGUgSW50ZXJuYWxOZXR3b3JrU3RhdHVzU2lnbmFsID0gU2lnbmFsPGJvb2xlYW4+ICYge1xyXG4gIHNpbmNlOiBTaWduYWw8RGF0ZT47XHJcbn07XHJcblxyXG4vKipcclxuICogQSBzcGVjaWFsaXplZCBTaWduYWwgdGhhdCB0cmFja3MgbmV0d29yayBzdGF0dXMuXHJcbiAqIEl0J3MgYSBib29sZWFuIHNpZ25hbCB3aXRoIGFuIGF0dGFjaGVkIGBzaW5jZWAgc2lnbmFsLlxyXG4gKi9cclxuZXhwb3J0IHR5cGUgTmV0d29ya1N0YXR1c1NpZ25hbCA9IFNpZ25hbDxib29sZWFuPiAmIHtcclxuICAvKiogQSBzaWduYWwgdHJhY2tpbmcgdGhlIHRpbWVzdGFtcCBvZiB0aGUgbGFzdCBzdGF0dXMgY2hhbmdlLiAqL1xyXG4gIHJlYWRvbmx5IHNpbmNlOiBTaWduYWw8RGF0ZT47XHJcbn07XHJcblxyXG5jb25zdCBzZXJ2ZXJEYXRlID0gbmV3IERhdGUoKTtcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGVzIGEgcmVhZC1vbmx5IHNpZ25hbCB0aGF0IHRyYWNrcyB0aGUgYnJvd3NlcidzIG9ubGluZSBzdGF0dXMuXHJcbiAqXHJcbiAqIFRoZSBtYWluIHNpZ25hbCByZXR1cm5zIGEgYm9vbGVhbiAoYHRydWVgIGZvciBvbmxpbmUsIGBmYWxzZWAgZm9yIG9mZmxpbmUpLlxyXG4gKiBBbiBhZGRpdGlvbmFsIGBzaW5jZWAgc2lnbmFsIGlzIGF0dGFjaGVkLCB0cmFja2luZyB3aGVuIHRoZSBzdGF0dXMgbGFzdCBjaGFuZ2VkLlxyXG4gKiBJdCdzIFNTUi1zYWZlIGFuZCBhdXRvbWF0aWNhbGx5IGNsZWFucyB1cCBpdHMgZXZlbnQgbGlzdGVuZXJzLlxyXG4gKlxyXG4gKiBAcGFyYW0gZGVidWdOYW1lIE9wdGlvbmFsIGRlYnVnIG5hbWUgZm9yIHRoZSBzaWduYWwuXHJcbiAqIEByZXR1cm5zIEEgYE5ldHdvcmtTdGF0dXNTaWduYWxgIGluc3RhbmNlLlxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIG5ldHdvcmtTdGF0dXMoXHJcbiAgZGVidWdOYW1lID0gJ25ldHdvcmtTdGF0dXMnLFxyXG4pOiBOZXR3b3JrU3RhdHVzU2lnbmFsIHtcclxuICBpZiAoaXNQbGF0Zm9ybVNlcnZlcihpbmplY3QoUExBVEZPUk1fSUQpKSkge1xyXG4gICAgY29uc3Qgc2lnID0gY29tcHV0ZWQoKCkgPT4gdHJ1ZSwge1xyXG4gICAgICBkZWJ1Z05hbWUsXHJcbiAgICB9KSBhcyBJbnRlcm5hbE5ldHdvcmtTdGF0dXNTaWduYWw7XHJcbiAgICBzaWcuc2luY2UgPSBjb21wdXRlZCgoKSA9PiBzZXJ2ZXJEYXRlKTtcclxuICAgIHJldHVybiBzaWc7XHJcbiAgfVxyXG5cclxuICBjb25zdCBzdGF0ZSA9IHNpZ25hbChuYXZpZ2F0b3Iub25MaW5lLCB7XHJcbiAgICBkZWJ1Z05hbWUsXHJcbiAgfSk7XHJcbiAgY29uc3Qgc2luY2UgPSBzaWduYWwobmV3IERhdGUoKSk7XHJcblxyXG4gIGNvbnN0IGdvT25saW5lID0gKCkgPT4ge1xyXG4gICAgc3RhdGUuc2V0KHRydWUpO1xyXG4gICAgc2luY2Uuc2V0KG5ldyBEYXRlKCkpO1xyXG4gIH07XHJcbiAgY29uc3QgZ29PZmZsaW5lID0gKCkgPT4ge1xyXG4gICAgc3RhdGUuc2V0KGZhbHNlKTtcclxuICAgIHNpbmNlLnNldChuZXcgRGF0ZSgpKTtcclxuICB9O1xyXG5cclxuICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcignb25saW5lJywgZ29PbmxpbmUpO1xyXG4gIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdvZmZsaW5lJywgZ29PZmZsaW5lKTtcclxuXHJcbiAgaW5qZWN0KERlc3Ryb3lSZWYpLm9uRGVzdHJveSgoKSA9PiB7XHJcbiAgICB3aW5kb3cucmVtb3ZlRXZlbnRMaXN0ZW5lcignb25saW5lJywgZ29PbmxpbmUpO1xyXG4gICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ29mZmxpbmUnLCBnb09mZmxpbmUpO1xyXG4gIH0pO1xyXG5cclxuICBjb25zdCBzaWcgPSBzdGF0ZS5hc1JlYWRvbmx5KCkgYXMgSW50ZXJuYWxOZXR3b3JrU3RhdHVzU2lnbmFsO1xyXG4gIHNpZy5zaW5jZSA9IHNpbmNlLmFzUmVhZG9ubHkoKTtcclxuXHJcbiAgcmV0dXJuIHNpZztcclxufVxyXG4iXX0=","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, inject, PLATFORM_ID, signal, } from '@angular/core';\n/**\n * Creates a read-only signal that tracks the page's visibility state.\n *\n * It uses the browser's Page Visibility API to reactively report if the\n * current document is `'visible'`, `'hidden'`, or in another state.\n * The primitive is SSR-safe and automatically cleans up its event listeners\n * when the creating context is destroyed.\n *\n * @param debugName Optional debug name for the signal.\n * @returns A read-only `Signal<DocumentVisibilityState>`. On the server,\n * it returns a static signal with a value of `'visible'`.\n *\n * @example\n * ```ts\n * import { Component, effect } from '@angular/core';\n * import { pageVisibility } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-visibility-tracker',\n * template: `<p>Page is currently: {{ visibilityState() }}</p>`\n * })\n * export class VisibilityTrackerComponent {\n * readonly visibilityState = pageVisibility();\n *\n * constructor() {\n * effect(() => {\n * if (this.visibilityState() === 'hidden') {\n * console.log('Page is hidden, pausing expensive animations...');\n * } else {\n * console.log('Page is visible, resuming activity.');\n * }\n * });\n * }\n * }\n * ```\n */\nexport function pageVisibility(debugName = 'pageVisibility') {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n return computed(() => 'visible', { debugName });\n }\n const visibility = signal(document.visibilityState, ...(ngDevMode ? [{ debugName: \"visibility\", debugName }] : [{ debugName }]));\n const onVisibilityChange = () => visibility.set(document.visibilityState);\n document.addEventListener('visibilitychange', onVisibilityChange);\n inject(DestroyRef).onDestroy(() => document.removeEventListener('visibilitychange', onVisibilityChange));\n return visibility.asReadonly();\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS12aXNpYmlsaXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9zcmMvbGliL3NlbnNvcnMvcGFnZS12aXNpYmlsaXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sRUFDTCxRQUFRLEVBQ1IsVUFBVSxFQUNWLE1BQU0sRUFDTixXQUFXLEVBRVgsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBRXZCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW1DRztBQUNILE1BQU0sVUFBVSxjQUFjLENBQzVCLFNBQVMsR0FBRyxnQkFBZ0I7SUFFNUIsSUFBSSxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQzFDLE9BQU8sUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLFNBQVMsRUFBRSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVELE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsZUFBZSw4Q0FBSSxTQUFTLE9BQVgsRUFBRSxTQUFTLEVBQUUsR0FBQyxDQUFDO0lBRW5FLE1BQU0sa0JBQWtCLEdBQUcsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLENBQUM7SUFFMUUsUUFBUSxDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixFQUFFLGtCQUFrQixDQUFDLENBQUM7SUFFbEUsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FDaEMsUUFBUSxDQUFDLG1CQUFtQixDQUFDLGtCQUFrQixFQUFFLGtCQUFrQixDQUFDLENBQ3JFLENBQUM7SUFFRixPQUFPLFVBQVUsQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUNqQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNQbGF0Zm9ybVNlcnZlciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7XHJcbiAgY29tcHV0ZWQsXHJcbiAgRGVzdHJveVJlZixcclxuICBpbmplY3QsXHJcbiAgUExBVEZPUk1fSUQsXHJcbiAgU2lnbmFsLFxyXG4gIHNpZ25hbCxcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGVzIGEgcmVhZC1vbmx5IHNpZ25hbCB0aGF0IHRyYWNrcyB0aGUgcGFnZSdzIHZpc2liaWxpdHkgc3RhdGUuXHJcbiAqXHJcbiAqIEl0IHVzZXMgdGhlIGJyb3dzZXIncyBQYWdlIFZpc2liaWxpdHkgQVBJIHRvIHJlYWN0aXZlbHkgcmVwb3J0IGlmIHRoZVxyXG4gKiBjdXJyZW50IGRvY3VtZW50IGlzIGAndmlzaWJsZSdgLCBgJ2hpZGRlbidgLCBvciBpbiBhbm90aGVyIHN0YXRlLlxyXG4gKiBUaGUgcHJpbWl0aXZlIGlzIFNTUi1zYWZlIGFuZCBhdXRvbWF0aWNhbGx5IGNsZWFucyB1cCBpdHMgZXZlbnQgbGlzdGVuZXJzXHJcbiAqIHdoZW4gdGhlIGNyZWF0aW5nIGNvbnRleHQgaXMgZGVzdHJveWVkLlxyXG4gKlxyXG4gKiBAcGFyYW0gZGVidWdOYW1lIE9wdGlvbmFsIGRlYnVnIG5hbWUgZm9yIHRoZSBzaWduYWwuXHJcbiAqIEByZXR1cm5zIEEgcmVhZC1vbmx5IGBTaWduYWw8RG9jdW1lbnRWaXNpYmlsaXR5U3RhdGU+YC4gT24gdGhlIHNlcnZlcixcclxuICogaXQgcmV0dXJucyBhIHN0YXRpYyBzaWduYWwgd2l0aCBhIHZhbHVlIG9mIGAndmlzaWJsZSdgLlxyXG4gKlxyXG4gKiBAZXhhbXBsZVxyXG4gKiBgYGB0c1xyXG4gKiBpbXBvcnQgeyBDb21wb25lbnQsIGVmZmVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG4gKiBpbXBvcnQgeyBwYWdlVmlzaWJpbGl0eSB9IGZyb20gJ0BtbXN0YWNrL3ByaW1pdGl2ZXMnO1xyXG4gKlxyXG4gKiBAQ29tcG9uZW50KHtcclxuICogc2VsZWN0b3I6ICdhcHAtdmlzaWJpbGl0eS10cmFja2VyJyxcclxuICogdGVtcGxhdGU6IGA8cD5QYWdlIGlzIGN1cnJlbnRseToge3sgdmlzaWJpbGl0eVN0YXRlKCkgfX08L3A+YFxyXG4gKiB9KVxyXG4gKiBleHBvcnQgY2xhc3MgVmlzaWJpbGl0eVRyYWNrZXJDb21wb25lbnQge1xyXG4gKiByZWFkb25seSB2aXNpYmlsaXR5U3RhdGUgPSBwYWdlVmlzaWJpbGl0eSgpO1xyXG4gKlxyXG4gKiBjb25zdHJ1Y3RvcigpIHtcclxuICogZWZmZWN0KCgpID0+IHtcclxuICogaWYgKHRoaXMudmlzaWJpbGl0eVN0YXRlKCkgPT09ICdoaWRkZW4nKSB7XHJcbiAqIGNvbnNvbGUubG9nKCdQYWdlIGlzIGhpZGRlbiwgcGF1c2luZyBleHBlbnNpdmUgYW5pbWF0aW9ucy4uLicpO1xyXG4gKiB9IGVsc2Uge1xyXG4gKiBjb25zb2xlLmxvZygnUGFnZSBpcyB2aXNpYmxlLCByZXN1bWluZyBhY3Rpdml0eS4nKTtcclxuICogfVxyXG4gKiB9KTtcclxuICogfVxyXG4gKiB9XHJcbiAqIGBgYFxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIHBhZ2VWaXNpYmlsaXR5KFxyXG4gIGRlYnVnTmFtZSA9ICdwYWdlVmlzaWJpbGl0eScsXHJcbik6IFNpZ25hbDxEb2N1bWVudFZpc2liaWxpdHlTdGF0ZT4ge1xyXG4gIGlmIChpc1BsYXRmb3JtU2VydmVyKGluamVjdChQTEFURk9STV9JRCkpKSB7XHJcbiAgICByZXR1cm4gY29tcHV0ZWQoKCkgPT4gJ3Zpc2libGUnLCB7IGRlYnVnTmFtZSB9KTtcclxuICB9XHJcblxyXG4gIGNvbnN0IHZpc2liaWxpdHkgPSBzaWduYWwoZG9jdW1lbnQudmlzaWJpbGl0eVN0YXRlLCB7IGRlYnVnTmFtZSB9KTtcclxuXHJcbiAgY29uc3Qgb25WaXNpYmlsaXR5Q2hhbmdlID0gKCkgPT4gdmlzaWJpbGl0eS5zZXQoZG9jdW1lbnQudmlzaWJpbGl0eVN0YXRlKTtcclxuXHJcbiAgZG9jdW1lbnQuYWRkRXZlbnRMaXN0ZW5lcigndmlzaWJpbGl0eWNoYW5nZScsIG9uVmlzaWJpbGl0eUNoYW5nZSk7XHJcblxyXG4gIGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koKCkgPT5cclxuICAgIGRvY3VtZW50LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3Zpc2liaWxpdHljaGFuZ2UnLCBvblZpc2liaWxpdHlDaGFuZ2UpLFxyXG4gICk7XHJcblxyXG4gIHJldHVybiB2aXNpYmlsaXR5LmFzUmVhZG9ubHkoKTtcclxufVxyXG4iXX0=","import { isPlatformServer } from '@angular/common'; // Corrected import\nimport { computed, DestroyRef, ElementRef, inject, PLATFORM_ID, // Used for SSR fallback\n } from '@angular/core';\nimport { throttled } from '../throttled';\n/**\n * Creates a read-only signal that tracks the scroll position (x, y) of the window\n * or a specified HTML element.\n *\n * Updates are throttled by default to optimize performance. An `unthrottled`\n * property is available on the returned signal for direct access to raw updates.\n * The primitive is SSR-safe and automatically cleans up its event listeners.\n *\n * @param options Optional configuration for the scroll sensor.\n * @returns A `ScrollPositionSignal`. On the server, it returns a static\n * signal with `{ x: 0, y: 0 }`.\n *\n * @example\n * ```ts\n * import { Component, effect, ElementRef, viewChild } from '@angular/core';\n * import { scrollPosition } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-scroll-tracker',\n * template: `\n * <p>Window Scroll: X: {{ windowScroll().x }}, Y: {{ windowScroll().y }}</p>\n * <div #scrollableDiv style=\"height: 200px; width: 200px; overflow: auto; border: 1px solid black;\">\n * <div style=\"height: 400px; width: 400px;\">Scroll me!</div>\n * </div>\n * @if (divScroll()) {\n * <p>Div Scroll: X: {{ divScroll().x }}, Y: {{ divScroll().y }}</p>\n * }\n * `\n * })\n * export class ScrollTrackerComponent {\n * readonly windowScroll = scrollPosition(); // Defaults to window\n * readonly scrollableDiv = viewChild<ElementRef<HTMLDivElement>>('scrollableDiv');\n * readonly divScroll = scrollPosition({ target: this.scrollableDiv() }); // Example with element target\n *\n * constructor() {\n * effect(() => {\n * console.log('Window scrolled to:', this.windowScroll());\n * if (this.divScroll()) {\n * console.log('Div scrolled to:', this.divScroll());\n * }\n * });\n * }\n * }\n * ```\n */\nexport function scrollPosition(opt) {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n const base = computed(() => ({\n x: 0,\n y: 0,\n }), {\n debugName: opt?.debugName ?? 'scrollPosition',\n });\n base.unthrottled = base;\n return base;\n }\n const { target = window, throttle = 100, debugName = 'scrollPosition', } = opt || {};\n let element;\n let getScrollPosition;\n if (target instanceof Window) {\n element = target;\n getScrollPosition = () => {\n return { x: target.scrollX, y: target.scrollY };\n };\n }\n else if (target instanceof ElementRef) {\n element = target.nativeElement;\n getScrollPosition = () => {\n return {\n x: target.nativeElement.scrollLeft,\n y: target.nativeElement.scrollTop,\n };\n };\n }\n else {\n element = target;\n getScrollPosition = () => {\n return {\n x: target.scrollLeft,\n y: target.scrollTop,\n };\n };\n }\n const state = throttled(getScrollPosition(), {\n debugName,\n equal: (a, b) => a.x === b.x && a.y === b.y,\n ms: throttle,\n });\n const onScroll = () => state.set(getScrollPosition());\n element.addEventListener('scroll', onScroll, { passive: true });\n inject(DestroyRef).onDestroy(() => element.removeEventListener('scroll', onScroll));\n const base = state.asReadonly();\n base.unthrottled = state.original;\n return base;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroll-position.js","sourceRoot":"","sources":["../../../../../../packages/primitives/src/lib/sensors/scroll-position.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC,CAAC,mBAAmB;AACvE,OAAO,EACL,QAAQ,EACR,UAAU,EACV,UAAU,EACV,MAAM,EACN,WAAW,EAAE,wBAAwB;EAEtC,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAgDzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CG;AACH,MAAM,UAAU,cAAc,CAC5B,GAA2B;IAE3B,IAAI,gBAAgB,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC;QAC1C,MAAM,IAAI,GAAG,QAAQ,CACnB,GAAG,EAAE,CAAC,CAAC;YACL,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;SACL,CAAC,EACF;YACE,SAAS,EAAE,GAAG,EAAE,SAAS,IAAI,gBAAgB;SAC9C,CAC8B,CAAC;QAClC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,EACJ,MAAM,GAAG,MAAM,EACf,QAAQ,GAAG,GAAG,EACd,SAAS,GAAG,gBAAgB,GAC7B,GAAG,GAAG,IAAI,EAAE,CAAC;IAEd,IAAI,OAA6B,CAAC;IAElC,IAAI,iBAAuC,CAAC;IAE5C,IAAI,MAAM,YAAY,MAAM,EAAE,CAAC;QAC7B,OAAO,GAAG,MAAM,CAAC;QAEjB,iBAAiB,GAAG,GAAG,EAAE;YACvB,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC;QAClD,CAAC,CAAC;IACJ,CAAC;SAAM,IAAI,MAAM,YAAY,UAAU,EAAE,CAAC;QACxC,OAAO,GAAG,MAAM,CAAC,aAAa,CAAC;QAC/B,iBAAiB,GAAG,GAAG,EAAE;YACvB,OAAO;gBACL,CAAC,EAAE,MAAM,CAAC,aAAa,CAAC,UAAU;gBAClC,CAAC,EAAE,MAAM,CAAC,aAAa,CAAC,SAAS;aAClC,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;SAAM,CAAC;QACN,OAAO,GAAG,MAAM,CAAC;QACjB,iBAAiB,GAAG,GAAG,EAAE;YACvB,OAAO;gBACL,CAAC,EAAE,MAAM,CAAC,UAAU;gBACpB,CAAC,EAAE,MAAM,CAAC,SAAS;aACpB,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;IAED,MAAM,KAAK,GAAG,SAAS,CAAiB,iBAAiB,EAAE,EAAE;QAC3D,SAAS;QACT,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3C,EAAE,EAAE,QAAQ;KACb,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,iBAAiB,EAAE,CAAC,CAAC;IACtD,OAAO,CAAC,gBAAgB,CAAC,QAAQ,EAAE,QAAQ,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;IAEhE,MAAM,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAChC,OAAO,CAAC,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAChD,CAAC;IAEF,MAAM,IAAI,GAAG,KAAK,CAAC,UAAU,EAAkC,CAAC;IAChE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,QAAQ,CAAC;IAClC,OAAO,IAAI,CAAC;AACd,CAAC","sourcesContent":["import { isPlatformServer } from '@angular/common'; // Corrected import\r\nimport {\r\n  computed,\r\n  DestroyRef,\r\n  ElementRef,\r\n  inject,\r\n  PLATFORM_ID, // Used for SSR fallback\r\n  type Signal,\r\n} from '@angular/core';\r\nimport { throttled } from '../throttled';\r\n\r\n/**\r\n * Represents the scroll position.\r\n */\r\nexport type ScrollPosition = {\r\n  /** The horizontal scroll position (pixels from the left). */\r\n  readonly x: number;\r\n  /** The vertical scroll position (pixels from the top). */\r\n  readonly y: number;\r\n};\r\n\r\n/**\r\n * Options for configuring the `scrollPosition` sensor.\r\n */\r\nexport type ScrollPositionOptions = {\r\n  /**\r\n   * The target to listen for scroll events on.\r\n   * Can be `window` (for page scroll) or an `HTMLElement`/`ElementRef<HTMLElement>`.\r\n   * @default window\r\n   */\r\n  target?: Window | HTMLElement | ElementRef<HTMLElement>;\r\n  /**\r\n   * Optional delay in milliseconds to throttle the updates.\r\n   * Scroll events can fire very rapidly.\r\n   * @default 100 // A common default for scroll throttling\r\n   */\r\n  throttle?: number;\r\n  /** Optional debug name for the internal signal. */\r\n  debugName?: string;\r\n};\r\n\r\n/**\r\n * @internal used for setting the unthrottled signal\r\n */\r\ntype InternalScrollPositionSignal = Signal<ScrollPosition> & {\r\n  unthrottled: Signal<ScrollPosition>;\r\n};\r\n\r\n/**\r\n * A specialized Signal that tracks scroll position.\r\n * It's a throttled signal of the scroll coordinates with an attached `unthrottled` signal.\r\n */\r\nexport type ScrollPositionSignal = Signal<ScrollPosition> & {\r\n  /** A signal providing the raw, unthrottled scroll position. */\r\n  readonly unthrottled: Signal<ScrollPosition>;\r\n};\r\n\r\n/**\r\n * Creates a read-only signal that tracks the scroll position (x, y) of the window\r\n * or a specified HTML element.\r\n *\r\n * Updates are throttled by default to optimize performance. An `unthrottled`\r\n * property is available on the returned signal for direct access to raw updates.\r\n * The primitive is SSR-safe and automatically cleans up its event listeners.\r\n *\r\n * @param options Optional configuration for the scroll sensor.\r\n * @returns A `ScrollPositionSignal`. On the server, it returns a static\r\n * signal with `{ x: 0, y: 0 }`.\r\n *\r\n * @example\r\n * ```ts\r\n * import { Component, effect, ElementRef, viewChild } from '@angular/core';\r\n * import { scrollPosition } from '@mmstack/primitives';\r\n *\r\n * @Component({\r\n * selector: 'app-scroll-tracker',\r\n * template: `\r\n * <p>Window Scroll: X: {{ windowScroll().x }}, Y: {{ windowScroll().y }}</p>\r\n * <div #scrollableDiv style=\"height: 200px; width: 200px; overflow: auto; border: 1px solid black;\">\r\n * <div style=\"height: 400px; width: 400px;\">Scroll me!</div>\r\n * </div>\r\n * @if (divScroll()) {\r\n * <p>Div Scroll: X: {{ divScroll().x }}, Y: {{ divScroll().y }}</p>\r\n * }\r\n * `\r\n * })\r\n * export class ScrollTrackerComponent {\r\n * readonly windowScroll = scrollPosition(); // Defaults to window\r\n * readonly scrollableDiv = viewChild<ElementRef<HTMLDivElement>>('scrollableDiv');\r\n * readonly divScroll = scrollPosition({ target: this.scrollableDiv() }); // Example with element target\r\n *\r\n * constructor() {\r\n * effect(() => {\r\n * console.log('Window scrolled to:', this.windowScroll());\r\n * if (this.divScroll()) {\r\n * console.log('Div scrolled to:', this.divScroll());\r\n * }\r\n * });\r\n * }\r\n * }\r\n * ```\r\n */\r\nexport function scrollPosition(\r\n  opt?: ScrollPositionOptions,\r\n): ScrollPositionSignal {\r\n  if (isPlatformServer(inject(PLATFORM_ID))) {\r\n    const base = computed(\r\n      () => ({\r\n        x: 0,\r\n        y: 0,\r\n      }),\r\n      {\r\n        debugName: opt?.debugName ?? 'scrollPosition',\r\n      },\r\n    ) as InternalScrollPositionSignal;\r\n    base.unthrottled = base;\r\n    return base;\r\n  }\r\n\r\n  const {\r\n    target = window,\r\n    throttle = 100,\r\n    debugName = 'scrollPosition',\r\n  } = opt || {};\r\n\r\n  let element: Window | HTMLElement;\r\n\r\n  let getScrollPosition: () => ScrollPosition;\r\n\r\n  if (target instanceof Window) {\r\n    element = target;\r\n\r\n    getScrollPosition = () => {\r\n      return { x: target.scrollX, y: target.scrollY };\r\n    };\r\n  } else if (target instanceof ElementRef) {\r\n    element = target.nativeElement;\r\n    getScrollPosition = () => {\r\n      return {\r\n        x: target.nativeElement.scrollLeft,\r\n        y: target.nativeElement.scrollTop,\r\n      };\r\n    };\r\n  } else {\r\n    element = target;\r\n    getScrollPosition = () => {\r\n      return {\r\n        x: target.scrollLeft,\r\n        y: target.scrollTop,\r\n      };\r\n    };\r\n  }\r\n\r\n  const state = throttled<ScrollPosition>(getScrollPosition(), {\r\n    debugName,\r\n    equal: (a, b) => a.x === b.x && a.y === b.y,\r\n    ms: throttle,\r\n  });\r\n\r\n  const onScroll = () => state.set(getScrollPosition());\r\n  element.addEventListener('scroll', onScroll, { passive: true });\r\n\r\n  inject(DestroyRef).onDestroy(() =>\r\n    element.removeEventListener('scroll', onScroll),\r\n  );\r\n\r\n  const base = state.asReadonly() as InternalScrollPositionSignal;\r\n  base.unthrottled = state.original;\r\n  return base;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, inject, PLATFORM_ID, } from '@angular/core';\nimport { throttled } from '../throttled';\n/**\n * Creates a read-only signal that tracks the browser window's inner dimensions (width and height).\n *\n * Updates are throttled by default (100ms) to optimize performance during resize events.\n * An `unthrottled` property is available on the returned signal for direct access to raw updates.\n * The primitive is SSR-safe (returns a default size on the server) and automatically\n * cleans up its event listeners.\n *\n * @param opt Optional configuration, including `throttle` (ms) and `debugName`.\n * @returns A `WindowSizeSignal` (a `Signal<WindowSize>` with an `unthrottled` property).\n *\n * @example\n * ```ts\n * import { Component, effect } from '@angular/core';\n * import { windowSize } from '@mmstack/primitives';\n *\n * @Component({\n * selector: 'app-responsive-header',\n * template: `\n * <header>\n * Current Window Size: {{ size().width }}px x {{ size().height }}px\n * @if (isMobile()) {\n * <p>Mobile Menu</p>\n * } @else {\n * <p>Desktop Menu</p>\n * }\n * </header>\n * `\n * })\n * export class ResponsiveHeaderComponent {\n * readonly size = windowSize();\n * readonly isMobile = computed(() => this.size().width < 768);\n *\n * constructor() {\n * effect(() => {\n * console.log('Window resized to:', this.size());\n * });\n * }\n * }\n * ```\n */\nexport function windowSize(opt) {\n if (isPlatformServer(inject(PLATFORM_ID))) {\n const base = computed(() => ({\n width: 1024,\n height: 768,\n }), { debugName: opt?.debugName ?? 'windowSize' });\n base.unthrottled = base;\n return base;\n }\n const sizeSignal = throttled({ width: window.innerWidth, height: window.innerHeight }, {\n debugName: opt?.debugName ?? 'windowSize',\n equal: (a, b) => a.width === b.width && a.height === b.height,\n ms: opt?.throttle ?? 100,\n });\n const onResize = () => {\n sizeSignal.set({ width: window.innerWidth, height: window.innerHeight });\n };\n window.addEventListener('resize', onResize);\n inject(DestroyRef).onDestroy(() => {\n window.removeEventListener('resize', onResize);\n });\n const base = sizeSignal.asReadonly();\n base.unthrottled = sizeSignal.original;\n return base;\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2luZG93LXNpemUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3NyYy9saWIvc2Vuc29ycy93aW5kb3ctc2l6ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNuRCxPQUFPLEVBQ0wsUUFBUSxFQUNSLFVBQVUsRUFDVixNQUFNLEVBQ04sV0FBVyxHQUVaLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxjQUFjLENBQUM7QUE0Q3pDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBd0NHO0FBQ0gsTUFBTSxVQUFVLFVBQVUsQ0FBQyxHQUF1QjtJQUNoRCxJQUFJLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDMUMsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUNuQixHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQ0wsS0FBSyxFQUFFLElBQUk7WUFDWCxNQUFNLEVBQUUsR0FBRztTQUNaLENBQUMsRUFDRixFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsU0FBUyxJQUFJLFlBQVksRUFBRSxDQUNsQixDQUFDO1FBRTlCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1FBQ3hCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELE1BQU0sVUFBVSxHQUFHLFNBQVMsQ0FDMUIsRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxDQUFDLFdBQVcsRUFBRSxFQUN4RDtRQUNFLFNBQVMsRUFBRSxHQUFHLEVBQUUsU0FBUyxJQUFJLFlBQVk7UUFDekMsS0FBSyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEtBQUssS0FBSyxDQUFDLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLE1BQU07UUFDN0QsRUFBRSxFQUFFLEdBQUcsRUFBRSxRQUFRLElBQUksR0FBRztLQUN6QixDQUNGLENBQUM7SUFFRixNQUFNLFFBQVEsR0FBRyxHQUFHLEVBQUU7UUFDcEIsVUFBVSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUMzRSxDQUFDLENBQUM7SUFFRixNQUFNLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBRTVDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ2hDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDakQsQ0FBQyxDQUFDLENBQUM7SUFFSCxNQUFNLElBQUksR0FBRyxVQUFVLENBQUMsVUFBVSxFQUE4QixDQUFDO0lBQ2pFLElBQUksQ0FBQyxXQUFXLEdBQUcsVUFBVSxDQUFDLFFBQVEsQ0FBQztJQUN2QyxPQUFPLElBQUksQ0FBQztBQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1BsYXRmb3JtU2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHtcclxuICBjb21wdXRlZCxcclxuICBEZXN0cm95UmVmLFxyXG4gIGluamVjdCxcclxuICBQTEFURk9STV9JRCxcclxuICBTaWduYWwsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IHRocm90dGxlZCB9IGZyb20gJy4uL3Rocm90dGxlZCc7XHJcblxyXG4vKipcclxuICogUmVwcmVzZW50cyB0aGUgZGltZW5zaW9ucyBvZiB0aGUgd2luZG93LlxyXG4gKi9cclxuZXhwb3J0IHR5cGUgV2luZG93U2l6ZSA9IHtcclxuICAvKiogVGhlIGN1cnJlbnQgaW5uZXIgd2lkdGggb2YgdGhlIHdpbmRvdyBpbiBwaXhlbHMuICovXHJcbiAgcmVhZG9ubHkgd2lkdGg6IG51bWJlcjtcclxuICAvKiogVGhlIGN1cnJlbnQgaW5uZXIgaGVpZ2h0IG9mIHRoZSB3aW5kb3cgaW4gcGl4ZWxzLiAqL1xyXG4gIHJlYWRvbmx5IGhlaWdodDogbnVtYmVyO1xyXG59O1xyXG5cclxuLyoqXHJcbiAqIE9wdGlvbnMgZm9yIGNvbmZpZ3VyaW5nIHRoZSBgbW91c2VQb3NpdGlvbmAgc2Vuc29yLlxyXG4gKi9cclxuZXhwb3J0IHR5cGUgV2luZG93U2l6ZU9wdGlvbnMgPSB7XHJcbiAgLyoqXHJcbiAgICogT3B0aW9uYWwgZGVidWcgbmFtZSBmb3IgdGhlIGludGVybmFsIHNpZ25hbC5cclxuICAgKi9cclxuICBkZWJ1Z05hbWU/OiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogT3B0aW9uYWwgZGVsYXkgaW4gbWlsbGlzZWNvbmRzIHRvIHRocm90dGxlIHRoZSB1cGRhdGVzLlxyXG4gICAqIEBkZWZhdWx0IDEwMFxyXG4gICAqL1xyXG4gIHRocm90dGxlPzogbnVtYmVyO1xyXG59O1xyXG5cclxuLyoqXHJcbiAqIEBpbnRlcm5hbCB1c2VkIGZvciBzZXR0aW5nIHRoZSBzaW5jZSBzaWduYWxcclxuICovXHJcbnR5cGUgSW50ZXJuYWxXaW5kb3dTaXplU2lnbmFsID0gU2lnbmFsPFdpbmRvd1NpemU+ICYge1xyXG4gIHVudGhyb3R0bGVkOiBTaWduYWw8V2luZG93U2l6ZT47XHJcbn07XHJcblxyXG4vKipcclxuICogQSBzcGVjaWFsaXplZCBTaWduYWwgdGhhdCB0cmFja3Mgd2luZG93IHNpemUuXHJcbiAqIEl0J3MgYSB0aHJvdHRsZWQgc2lnbmFsIG9mIHRoZSB3aW5kb3cuaW5uZXJIZWlnaHQvaW5uZXJXaWR0aCBwcm9wZXJ0aWVzXHJcbiAqIHdpdGggYW4gYXR0YWNoZWQgYHVudGhyb3R0bGVkYCBzaWduYWwuXHJcbiAqL1xyXG5leHBvcnQgdHlwZSBXaW5kb3dTaXplU2lnbmFsID0gU2lnbmFsPFdpbmRvd1NpemU+ICYge1xyXG4gIC8qKiBBIHNpZ25hbCBwcm92aWRpbmcgdGhlIHJhdywgdW50aHJvdHRsZWQgd2luZG93IHNpemUuICovXHJcbiAgcmVhZG9ubHkgdW50aHJvdHRsZWQ6IFNpZ25hbDxXaW5kb3dTaXplPjtcclxufTtcclxuXHJcbi8qKlxyXG4gKiBDcmVhdGVzIGEgcmVhZC1vbmx5IHNpZ25hbCB0aGF0IHRyYWNrcyB0aGUgYnJvd3NlciB3aW5kb3cncyBpbm5lciBkaW1lbnNpb25zICh3aWR0aCBhbmQgaGVpZ2h0KS5cclxuICpcclxuICogVXBkYXRlcyBhcmUgdGhyb3R0bGVkIGJ5IGRlZmF1bHQgKDEwMG1zKSB0byBvcHRpbWl6ZSBwZXJmb3JtYW5jZSBkdXJpbmcgcmVzaXplIGV2ZW50cy5cclxuICogQW4gYHVudGhyb3R0bGVkYCBwcm9wZXJ0eSBpcyBhdmFpbGFibGUgb24gdGhlIHJldHVybmVkIHNpZ25hbCBmb3IgZGlyZWN0IGFjY2VzcyB0byByYXcgdXBkYXRlcy5cclxuICogVGhlIHByaW1pdGl2ZSBpcyBTU1Itc2FmZSAocmV0dXJucyBhIGRlZmF1bHQgc2l6ZSBvbiB0aGUgc2VydmVyKSBhbmQgYXV0b21hdGljYWxseVxyXG4gKiBjbGVhbnMgdXAgaXRzIGV2ZW50IGxpc3RlbmVycy5cclxuICpcclxuICogQHBhcmFtIG9wdCBPcHRpb25hbCBjb25maWd1cmF0aW9uLCBpbmNsdWRpbmcgYHRocm90dGxlYCAobXMpIGFuZCBgZGVidWdOYW1lYC5cclxuICogQHJldHVybnMgQSBgV2luZG93U2l6ZVNpZ25hbGAgKGEgYFNpZ25hbDxXaW5kb3dTaXplPmAgd2l0aCBhbiBgdW50aHJvdHRsZWRgIHByb3BlcnR5KS5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogYGBgdHNcclxuICogaW1wb3J0IHsgQ29tcG9uZW50LCBlZmZlY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuICogaW1wb3J0IHsgd2luZG93U2l6ZSB9IGZyb20gJ0BtbXN0YWNrL3ByaW1pdGl2ZXMnO1xyXG4gKlxyXG4gKiBAQ29tcG9uZW50KHtcclxuICogc2VsZWN0b3I6ICdhcHAtcmVzcG9uc2l2ZS1oZWFkZXInLFxyXG4gKiB0ZW1wbGF0ZTogYFxyXG4gKiA8aGVhZGVyPlxyXG4gKiBDdXJyZW50IFdpbmRvdyBTaXplOiB7eyBzaXplKCkud2lkdGggfX1weCB4IHt7IHNpemUoKS5oZWlnaHQgfX1weFxyXG4gKiBAaWYgKGlzTW9iaWxlKCkpIHtcclxuICogPHA+TW9iaWxlIE1lbnU8L3A+XHJcbiAqIH0gQGVsc2Uge1xyXG4gKiA8cD5EZXNrdG9wIE1lbnU8L3A+XHJcbiAqIH1cclxuICogPC9oZWFkZXI+XHJcbiAqIGBcclxuICogfSlcclxuICogZXhwb3J0IGNsYXNzIFJlc3BvbnNpdmVIZWFkZXJDb21wb25lbnQge1xyXG4gKiByZWFkb25seSBzaXplID0gd2luZG93U2l6ZSgpO1xyXG4gKiByZWFkb25seSBpc01vYmlsZSA9IGNvbXB1dGVkKCgpID0+IHRoaXMuc2l6ZSgpLndpZHRoIDwgNzY4KTtcclxuICpcclxuICogY29uc3RydWN0b3IoKSB7XHJcbiAqIGVmZmVjdCgoKSA9PiB7XHJcbiAqIGNvbnNvbGUubG9nKCdXaW5kb3cgcmVzaXplZCB0bzonLCB0aGlzLnNpemUoKSk7XHJcbiAqIH0pO1xyXG4gKiB9XHJcbiAqIH1cclxuICogYGBgXHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gd2luZG93U2l6ZShvcHQ/OiBXaW5kb3dTaXplT3B0aW9ucyk6IFdpbmRvd1NpemVTaWduYWwge1xyXG4gIGlmIChpc1BsYXRmb3JtU2VydmVyKGluamVjdChQTEFURk9STV9JRCkpKSB7XHJcbiAgICBjb25zdCBiYXNlID0gY29tcHV0ZWQoXHJcbiAgICAgICgpID0+ICh7XHJcbiAgICAgICAgd2lkdGg6IDEwMjQsXHJcbiAgICAgICAgaGVpZ2h0OiA3NjgsXHJcbiAgICAgIH0pLFxyXG4gICAgICB7IGRlYnVnTmFtZTogb3B0Py5kZWJ1Z05hbWUgPz8gJ3dpbmRvd1NpemUnIH0sXHJcbiAgICApIGFzIEludGVybmFsV2luZG93U2l6ZVNpZ25hbDtcclxuXHJcbiAgICBiYXNlLnVudGhyb3R0bGVkID0gYmFzZTtcclxuICAgIHJldHVybiBiYXNlO1xyXG4gIH1cclxuXHJcbiAgY29uc3Qgc2l6ZVNpZ25hbCA9IHRocm90dGxlZDxXaW5kb3dTaXplPihcclxuICAgIHsgd2lkdGg6IHdpbmRvdy5pbm5lcldpZHRoLCBoZWlnaHQ6IHdpbmRvdy5pbm5lckhlaWdodCB9LFxyXG4gICAge1xyXG4gICAgICBkZWJ1Z05hbWU6IG9wdD8uZGVidWdOYW1lID8/ICd3aW5kb3dTaXplJyxcclxuICAgICAgZXF1YWw6IChhLCBiKSA9PiBhLndpZHRoID09PSBiLndpZHRoICYmIGEuaGVpZ2h0ID09PSBiLmhlaWdodCxcclxuICAgICAgbXM6IG9wdD8udGhyb3R0bGUgPz8gMTAwLFxyXG4gICAgfSxcclxuICApO1xyXG5cclxuICBjb25zdCBvblJlc2l6ZSA9ICgpID0+IHtcclxuICAgIHNpemVTaWduYWwuc2V0KHsgd2lkdGg6IHdpbmRvdy5pbm5lcldpZHRoLCBoZWlnaHQ6IHdpbmRvdy5pbm5lckhlaWdodCB9KTtcclxuICB9O1xyXG5cclxuICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcigncmVzaXplJywgb25SZXNpemUpO1xyXG5cclxuICBpbmplY3QoRGVzdHJveVJlZikub25EZXN0cm95KCgpID0+IHtcclxuICAgIHdpbmRvdy5yZW1vdmVFdmVudExpc3RlbmVyKCdyZXNpemUnLCBvblJlc2l6ZSk7XHJcbiAgfSk7XHJcblxyXG4gIGNvbnN0IGJhc2UgPSBzaXplU2lnbmFsLmFzUmVhZG9ubHkoKSBhcyBJbnRlcm5hbFdpbmRvd1NpemVTaWduYWw7XHJcbiAgYmFzZS51bnRocm90dGxlZCA9IHNpemVTaWduYWwub3JpZ2luYWw7XHJcbiAgcmV0dXJuIGJhc2U7XHJcbn1cclxuIl19","import { prefersDarkMode, prefersReducedMotion } from './media-query';\nimport { mousePosition, } from './mouse-position';\nimport { networkStatus } from './network-status';\nimport { pageVisibility } from './page-visibility';\nimport { scrollPosition, } from './scroll-position';\nimport { windowSize } from './window-size';\n/**\n * Implementation for sensor overloads.\n * Users should refer to the specific overloads for detailed documentation.\n * @internal\n */\nexport function sensor(type, options) {\n switch (type) {\n case 'mousePosition':\n return mousePosition(options);\n case 'networkStatus':\n return networkStatus(options?.debugName);\n case 'pageVisibility':\n return pageVisibility(options?.debugName);\n case 'dark-mode':\n return prefersDarkMode(options?.debugName);\n case 'reduced-motion':\n return prefersReducedMotion(options?.debugName);\n case 'windowSize':\n return windowSize(options);\n case 'scrollPosition':\n return scrollPosition(options);\n default:\n throw new Error(`Unknown sensor type: ${type}`);\n }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sensor.js","sourceRoot":"","sources":["../../../../../../packages/primitives/src/lib/sensors/sensor.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACtE,OAAO,EAGL,aAAa,GACd,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAuB,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAGL,cAAc,GACf,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAuC,UAAU,EAAE,MAAM,eAAe,CAAC;AA6FhF;;;;GAIG;AACH,MAAM,UAAU,MAAM,CACpB,IAOoB,EACpB,OAMyB;IASzB,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,eAAe;YAClB,OAAO,aAAa,CAAC,OAAO,CAAC,CAAC;QAChC,KAAK,eAAe;YAClB,OAAO,aAAa,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC3C,KAAK,gBAAgB;YACnB,OAAO,cAAc,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC5C,KAAK,WAAW;YACd,OAAO,eAAe,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC7C,KAAK,gBAAgB;YACnB,OAAO,oBAAoB,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAClD,KAAK,YAAY;YACf,OAAO,UAAU,CAAC,OAAO,CAAC,CAAC;QAC7B,KAAK,gBAAgB;YACnB,OAAO,cAAc,CAAC,OAAgC,CAAC,CAAC;QAC1D;YACE,MAAM,IAAI,KAAK,CAAC,wBAAwB,IAAI,EAAE,CAAC,CAAC;IACpD,CAAC;AACH,CAAC","sourcesContent":["import { Signal } from '@angular/core';\r\nimport { prefersDarkMode, prefersReducedMotion } from './media-query';\r\nimport {\r\n  MousePositionOptions,\r\n  MousePositionSignal,\r\n  mousePosition,\r\n} from './mouse-position';\r\nimport { NetworkStatusSignal, networkStatus } from './network-status';\r\nimport { pageVisibility } from './page-visibility';\r\nimport {\r\n  ScrollPositionOptions,\r\n  ScrollPositionSignal,\r\n  scrollPosition,\r\n} from './scroll-position';\r\nimport { WindowSizeOptions, WindowSizeSignal, windowSize } from './window-size';\r\n\r\n/**\r\n * Creates a sensor signal that tracks the mouse cursor's position.\r\n * @param type Must be `'mousePosition'`.\r\n * @param options Optional configuration for the mouse position sensor.\r\n * @returns A `MousePositionSignal` that tracks mouse coordinates and provides an unthrottled version.\r\n * @see {mousePosition} for detailed documentation and examples.\r\n * @example const pos = sensor('mousePosition', { coordinateSpace: 'page', throttle: 50 });\r\n */\r\nexport function sensor(\r\n  type: 'mousePosition',\r\n  options?: MousePositionOptions,\r\n): MousePositionSignal;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the browser's online/offline status.\r\n * @param type Must be `'networkStatus'`.\r\n * @param options Optional configuration, currently only `debugName`.\r\n * @returns A `NetworkStatusSignal` which is a boolean indicating online status, with an attached `since` signal.\r\n * @see {networkStatus} for detailed documentation and examples.\r\n * @example const onlineStatus = sensor('networkStatus');\r\n */\r\nexport function sensor(\r\n  type: 'networkStatus',\r\n  options?: { debugName?: string },\r\n): NetworkStatusSignal;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the page's visibility state (e.g., 'visible', 'hidden').\r\n * @param type Must be `'pageVisibility'`.\r\n * @param options Optional configuration, currently only `debugName`.\r\n * @returns A `Signal<DocumentVisibilityState>` indicating the page's current visibility.\r\n * @see {pageVisibility} for detailed documentation and examples.\r\n * @example const visibility = sensor('pageVisibility');\r\n */\r\nexport function sensor(\r\n  type: 'pageVisibility',\r\n  options?: { debugName?: string },\r\n): Signal<DocumentVisibilityState>;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the user's OS/browser preference for a dark color scheme.\r\n * @param type Must be `'dark-mode'`.\r\n * @param options Optional configuration, currently only `debugName`.\r\n * @returns A `Signal<boolean>` which is `true` if a dark theme is preferred.\r\n * @see {prefersDarkMode} for detailed documentation and examples.\r\n * @example const isDarkMode = sensor('dark-mode');\r\n */\r\nexport function sensor(\r\n  type: 'dark-mode',\r\n  options?: { debugName?: string },\r\n): Signal<boolean>;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the user's OS/browser preference for reduced motion.\r\n * @param type Must be `'reduced-motion'`.\r\n * @param options Optional configuration, currently only `debugName`.\r\n * @returns A `Signal<boolean>` which is `true` if reduced motion is preferred.\r\n * @see {prefersReducedMotion} for detailed documentation and examples.\r\n * @example const wantsReducedMotion = sensor('reduced-motion');\r\n */\r\nexport function sensor(\r\n  type: 'reduced-motion',\r\n  options?: { debugName?: string },\r\n): Signal<boolean>;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the browser window's inner dimensions (width and height).\r\n * @param type Must be `'windowSize'`.\r\n * @param options Optional configuration for the window size sensor, including `throttle` and `debugName`.\r\n * @returns A `WindowSizeSignal` that tracks window dimensions and provides an unthrottled version.\r\n * @see {windowSize} for detailed documentation and examples.\r\n * @example const size = sensor('windowSize', { throttle: 200 });\r\n */\r\nexport function sensor(\r\n  type: 'windowSize',\r\n  options?: WindowSizeOptions,\r\n): WindowSizeSignal;\r\n\r\n/**\r\n * Creates a sensor signal that tracks the scroll position (x, y) of the window or a specified element.\r\n * @param type Must be `'scrollPosition'`.\r\n * @param options Optional configuration for the scroll position sensor, including `target`, `throttle`, and `debugName`.\r\n * @returns A `ScrollPositionSignal` that tracks scroll coordinates and provides an unthrottled version.\r\n * @see {scrollPosition} for detailed documentation and examples.\r\n * @example const pageScroll = sensor('scrollPosition', { throttle: 150 });\r\n */\r\nexport function sensor(\r\n  type: 'scrollPosition',\r\n  options?: ScrollPositionOptions,\r\n): ScrollPositionSignal;\r\n\r\n/**\r\n * Implementation for sensor overloads.\r\n * Users should refer to the specific overloads for detailed documentation.\r\n * @internal\r\n */\r\nexport function sensor(\r\n  type:\r\n    | 'mousePosition'\r\n    | 'networkStatus'\r\n    | 'pageVisibility'\r\n    | 'dark-mode'\r\n    | 'reduced-motion'\r\n    | 'windowSize'\r\n    | 'scrollPosition',\r\n  options?:\r\n    | {\r\n        debugName?: string;\r\n      }\r\n    | MousePositionOptions\r\n    | WindowSizeOptions\r\n    | ScrollPositionOptions,\r\n):\r\n  | MousePositionSignal\r\n  | NetworkStatusSignal\r\n  | Signal<DocumentVisibilityState>\r\n  | Signal<boolean>\r\n  | WindowSizeSignal\r\n  | ScrollPositionSignal\r\n  | Signal<IntersectionObserverEntry | undefined> {\r\n  switch (type) {\r\n    case 'mousePosition':\r\n      return mousePosition(options);\r\n    case 'networkStatus':\r\n      return networkStatus(options?.debugName);\r\n    case 'pageVisibility':\r\n      return pageVisibility(options?.debugName);\r\n    case 'dark-mode':\r\n      return prefersDarkMode(options?.debugName);\r\n    case 'reduced-motion':\r\n      return prefersReducedMotion(options?.debugName);\r\n    case 'windowSize':\r\n      return windowSize(options);\r\n    case 'scrollPosition':\r\n      return scrollPosition(options as ScrollPositionOptions);\r\n    default:\r\n      throw new Error(`Unknown sensor type: ${type}`);\r\n  }\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { computed, DestroyRef, effect, inject, isDevMode, isSignal, PLATFORM_ID, signal, untracked, } from '@angular/core';\nimport { toWritable } from './to-writable';\n// Internal dummy store for server-side rendering\nconst noopStore = {\n getItem: () => null,\n setItem: () => {\n /* noop */\n },\n removeItem: () => {\n /* noop */\n },\n};\n/**\n * Creates a `WritableSignal` whose state is automatically synchronized with persistent storage\n * (like `localStorage` or `sessionStorage`).\n *\n * It handles Server-Side Rendering (SSR) gracefully, allows dynamic storage keys,\n * custom serialization/deserialization, custom storage providers, and optional\n * synchronization across browser tabs.\n *\n * @template T The type of value held by the signal and stored (after serialization).\n * @param fallback The default value of type `T` to use when no value is found in storage\n * or when deserialization fails. The signal's value will never be `null` or `undefined`\n * publicly, it will always revert to this fallback.\n * @param options Configuration options (`CreateStoredOptions<T>`). Requires at least the `key`.\n * @returns A `StoredSignal<T>` instance. This signal behaves like a standard `WritableSignal<T>`,\n * but its value is persisted. It includes a `.clear()` method to remove the item from storage\n * and a `.key` signal providing the current storage key.\n *\n * @remarks\n * - **Persistence:** The signal automatically saves its value to storage whenever the signal's\n * value or its configured `key` changes. This is managed internally using `effect`.\n * - **SSR Safety:** Detects server environments and uses a no-op storage, preventing errors.\n * - **Error Handling:** Catches and logs errors during serialization/deserialization in dev mode.\n * - **Tab Sync:** If `syncTabs` is true, listens to `storage` events to keep the signal value\n * consistent across browser tabs using the same key. Cleanup is handled automatically\n * using `DestroyRef`.\n * - **Removal:** Use the `.clear()` method on the returned signal to remove the item from storage.\n * Setting the signal to the fallback value will store the fallback value, not remove the item.\n *\n * @example\n * ```ts\n * import { Component, effect, signal } from '@angular/core';\n * import { stored } from '@mmstack/primitives'; // Adjust import path\n *\n * @Component({\n * selector: 'app-settings',\n * standalone: true,\n * template: `\n * Theme:\n * <select [ngModel]=\"theme()\" (ngModelChange)=\"theme.set($event)\">\n * <option value=\"light\">Light</option>\n * <option value=\"dark\">Dark</option>\n * </select>\n * <button (click)=\"theme.clear()\">Clear Theme Setting</button>\n * <p>Storage Key Used: {{ theme.key() }}</p>\n * ` // Requires FormsModule for ngModel\n * })\n * export class SettingsComponent {\n * theme = stored<'light' | 'dark'>('light', { key: 'app-theme', syncTabs: true });\n * }\n * ```\n */\nexport function stored(fallback, { key, store: providedStore, serialize = JSON.stringify, deserialize = JSON.parse, syncTabs = false, equal = Object.is, onKeyChange = 'load', cleanupOldKey = false, ...rest }) {\n const isServer = isPlatformServer(inject(PLATFORM_ID));\n const fallbackStore = isServer ? noopStore : localStorage;\n const store = providedStore ?? fallbackStore;\n const keySig = typeof key === 'string'\n ? computed(() => key)\n : isSignal(key)\n ? key\n : computed(key);\n const getValue = (key) => {\n const found = store.getItem(key);\n if (found === null)\n return null;\n try {\n return deserialize(found);\n }\n catch (err) {\n if (isDevMode())\n console.error(`Failed to parse stored value for key \"${key}\":`, err);\n return null;\n }\n };\n const storeValue = (key, value) => {\n try {\n if (value === null)\n return store.removeItem(key);\n const serialized = serialize(value);\n store.setItem(key, serialized);\n }\n catch (err) {\n if (isDevMode())\n console.error(`Failed to store value for key \"${key}\":`, err);\n }\n };\n const opt = {\n ...rest,\n equal,\n };\n const initialKey = untracked(keySig);\n const internal = signal(getValue(initialKey), ...(ngDevMode ? [{ debugName: \"internal\", ...opt,\n equal: (a, b) => {\n if (a === null && b === null)\n return true;\n if (a === null || b === null)\n return false;\n return equal(a, b);\n } }] : [{\n ...opt,\n equal: (a, b) => {\n if (a === null && b === null)\n return true;\n if (a === null || b === null)\n return false;\n return equal(a, b);\n },\n }]));\n let prevKey = initialKey;\n if (onKeyChange === 'store') {\n effect(() => {\n const k = keySig();\n storeValue(k, internal());\n if (prevKey !== k) {\n if (cleanupOldKey)\n store.removeItem(prevKey);\n prevKey = k;\n }\n });\n }\n else {\n effect(() => {\n const k = keySig();\n const internalValue = internal();\n if (k === prevKey) {\n return storeValue(k, internalValue); // normal operation\n }\n else {\n if (cleanupOldKey)\n store.removeItem(prevKey);\n const value = getValue(k);\n prevKey = k;\n internal.set(value); // load new value\n }\n });\n }\n if (syncTabs && !isServer) {\n const destroyRef = inject(DestroyRef);\n const sync = (e) => {\n if (e.key !== untracked(keySig))\n return;\n if (e.newValue === null)\n internal.set(null);\n else\n internal.set(getValue(e.key));\n };\n window.addEventListener('storage', sync);\n destroyRef.onDestroy(() => window.removeEventListener('storage', sync));\n }\n const writable = toWritable(computed(() => internal() ?? fallback, opt), internal.set);\n writable.clear = () => {\n internal.set(null);\n };\n writable.key = keySig;\n return writable;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stored.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/stored.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common';\r\nimport {\r\n  computed,\r\n  DestroyRef,\r\n  effect,\r\n  inject,\r\n  isDevMode,\r\n  isSignal,\r\n  PLATFORM_ID,\r\n  Signal,\r\n  signal,\r\n  untracked,\r\n  type CreateSignalOptions,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * Interface for storage mechanisms compatible with the `stored` signal.\r\n * Matches the essential parts of the `Storage` interface (`localStorage`, `sessionStorage`).\r\n */\r\ntype Store = {\r\n  /** Retrieves an item from storage for a given key. */\r\n  getItem: (key: string) => string | null;\r\n  /** Sets an item in storage for a given key. */\r\n  setItem: (key: string, value: string) => void;\r\n  /** Removes an item from storage for a given key. */\r\n  removeItem: (key: string) => void;\r\n};\r\n\r\n// Internal dummy store for server-side rendering\r\nconst noopStore: Store = {\r\n  getItem: () => null,\r\n  setItem: () => {\r\n    /* noop */\r\n  },\r\n  removeItem: () => {\r\n    /* noop */\r\n  },\r\n};\r\n\r\n/**\r\n * Options for creating a signal synchronized with persistent storage using `stored()`.\r\n * Extends Angular's `CreateSignalOptions`.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type CreateStoredOptions<T> = CreateSignalOptions<T> & {\r\n  /**\r\n   * The key used to identify the item in storage.\r\n   * Can be a static string or a function/signal returning a string for dynamic keys\r\n   * (e.g., based on user ID or other application state).\r\n   */\r\n  key: string | (() => string);\r\n  /**\r\n   * Optional custom storage implementation (e.g., `sessionStorage` or a custom adapter).\r\n   * Must conform to the `Store` interface (`getItem`, `setItem`, `removeItem`).\r\n   * Defaults to `localStorage` in browser environments and a no-op store on the server.\r\n   */\r\n  store?: Store;\r\n  /**\r\n   * Optional function to serialize the value (type `T`) into a string before storing.\r\n   * Defaults to `JSON.stringify`.\r\n   * @param {T} value The value to serialize.\r\n   * @returns {string} The serialized string representation.\r\n   */\r\n  serialize?: (value: T) => string;\r\n  /**\r\n   * Optional function to deserialize the string retrieved from storage back into the value (type `T`).\r\n   * Defaults to `JSON.parse`.\r\n   * @param {string} value The string retrieved from storage.\r\n   * @returns {T} The deserialized value.\r\n   */\r\n  deserialize?: (value: string) => T;\r\n  /**\r\n   * If `true`, the signal will attempt to synchronize its state across multiple browser tabs\r\n   * using the `storage` event. Changes made in one tab (set, update, clear) will be\r\n   * reflected in other tabs using the same storage key.\r\n   * Requires a browser environment. Defaults to `false`.\r\n   */\r\n  syncTabs?: boolean;\r\n  /**\r\n   * Optional parameter to specify how key changes should be handled, load is the default.\r\n   * - `load`: The signal will load the value from storage when the key changes & replace the signal's value.\r\n   * - `store`: The signal will store the current value to the new key when the key changes.\r\n   */\r\n  onKeyChange?: 'load' | 'store';\r\n  /**\r\n   * If 'true', the signal will remove the old key from storage when the key changes, defaults to `false`.\r\n   */\r\n  cleanupOldKey?: boolean;\r\n};\r\n\r\n/**\r\n * A specialized `WritableSignal` returned by the `stored()` function.\r\n * It synchronizes its value with persistent storage and provides additional methods.\r\n *\r\n * @template T The type of value held by the signal (matches the fallback type).\r\n */\r\nexport type StoredSignal<T> = WritableSignal<T> & {\r\n  /**\r\n   * Removes the item associated with the signal's key from the configured storage.\r\n   * After clearing, reading the signal will return the fallback value until it's set again.\r\n   */\r\n  clear: () => void;\r\n  /**\r\n   * A `Signal<string>` containing the current storage key being used by this stored signal.\r\n   * This is particularly useful if the key was configured dynamically. You can read or react\r\n   * to this signal to know the active key.\r\n   */\r\n  key: Signal<string>;\r\n};\r\n\r\n/**\r\n * Creates a `WritableSignal` whose state is automatically synchronized with persistent storage\r\n * (like `localStorage` or `sessionStorage`).\r\n *\r\n * It handles Server-Side Rendering (SSR) gracefully, allows dynamic storage keys,\r\n * custom serialization/deserialization, custom storage providers, and optional\r\n * synchronization across browser tabs.\r\n *\r\n * @template T The type of value held by the signal and stored (after serialization).\r\n * @param fallback The default value of type `T` to use when no value is found in storage\r\n * or when deserialization fails. The signal's value will never be `null` or `undefined`\r\n * publicly, it will always revert to this fallback.\r\n * @param options Configuration options (`CreateStoredOptions<T>`). Requires at least the `key`.\r\n * @returns A `StoredSignal<T>` instance. This signal behaves like a standard `WritableSignal<T>`,\r\n * but its value is persisted. It includes a `.clear()` method to remove the item from storage\r\n * and a `.key` signal providing the current storage key.\r\n *\r\n * @remarks\r\n * - **Persistence:** The signal automatically saves its value to storage whenever the signal's\r\n * value or its configured `key` changes. This is managed internally using `effect`.\r\n * - **SSR Safety:** Detects server environments and uses a no-op storage, preventing errors.\r\n * - **Error Handling:** Catches and logs errors during serialization/deserialization in dev mode.\r\n * - **Tab Sync:** If `syncTabs` is true, listens to `storage` events to keep the signal value\r\n * consistent across browser tabs using the same key. Cleanup is handled automatically\r\n * using `DestroyRef`.\r\n * - **Removal:** Use the `.clear()` method on the returned signal to remove the item from storage.\r\n * Setting the signal to the fallback value will store the fallback value, not remove the item.\r\n *\r\n * @example\r\n * ```ts\r\n * import { Component, effect, signal } from '@angular/core';\r\n * import { stored } from '@mmstack/primitives'; // Adjust import path\r\n *\r\n * @Component({\r\n * selector: 'app-settings',\r\n * standalone: true,\r\n * template: `\r\n * Theme:\r\n * <select [ngModel]=\"theme()\" (ngModelChange)=\"theme.set($event)\">\r\n * <option value=\"light\">Light</option>\r\n * <option value=\"dark\">Dark</option>\r\n * </select>\r\n * <button (click)=\"theme.clear()\">Clear Theme Setting</button>\r\n * <p>Storage Key Used: {{ theme.key() }}</p>\r\n * ` // Requires FormsModule for ngModel\r\n * })\r\n * export class SettingsComponent {\r\n *  theme = stored<'light' | 'dark'>('light', { key: 'app-theme', syncTabs: true });\r\n * }\r\n * ```\r\n */\r\nexport function stored<T>(\r\n  fallback: T,\r\n  {\r\n    key,\r\n    store: providedStore,\r\n    serialize = JSON.stringify,\r\n    deserialize = JSON.parse,\r\n    syncTabs = false,\r\n    equal = Object.is,\r\n    onKeyChange = 'load',\r\n    cleanupOldKey = false,\r\n    ...rest\r\n  }: CreateStoredOptions<T>,\r\n): StoredSignal<T> {\r\n  const isServer = isPlatformServer(inject(PLATFORM_ID));\r\n\r\n  const fallbackStore = isServer ? noopStore : localStorage;\r\n  const store = providedStore ?? fallbackStore;\r\n\r\n  const keySig =\r\n    typeof key === 'string'\r\n      ? computed(() => key)\r\n      : isSignal(key)\r\n        ? key\r\n        : computed(key);\r\n\r\n  const getValue = (key: string): T | null => {\r\n    const found = store.getItem(key);\r\n    if (found === null) return null;\r\n    try {\r\n      return deserialize(found);\r\n    } catch (err) {\r\n      if (isDevMode())\r\n        console.error(`Failed to parse stored value for key \"${key}\":`, err);\r\n      return null;\r\n    }\r\n  };\r\n\r\n  const storeValue = (key: string, value: T | null) => {\r\n    try {\r\n      if (value === null) return store.removeItem(key);\r\n      const serialized = serialize(value);\r\n      store.setItem(key, serialized);\r\n    } catch (err) {\r\n      if (isDevMode())\r\n        console.error(`Failed to store value for key \"${key}\":`, err);\r\n    }\r\n  };\r\n\r\n  const opt = {\r\n    ...rest,\r\n    equal,\r\n  };\r\n\r\n  const initialKey = untracked(keySig);\r\n  const internal = signal(getValue(initialKey), {\r\n    ...opt,\r\n    equal: (a, b) => {\r\n      if (a === null && b === null) return true;\r\n      if (a === null || b === null) return false;\r\n      return equal(a, b);\r\n    },\r\n  });\r\n\r\n  let prevKey = initialKey;\r\n\r\n  if (onKeyChange === 'store') {\r\n    effect(() => {\r\n      const k = keySig();\r\n      storeValue(k, internal());\r\n      if (prevKey !== k) {\r\n        if (cleanupOldKey) store.removeItem(prevKey);\r\n        prevKey = k;\r\n      }\r\n    });\r\n  } else {\r\n    effect(() => {\r\n      const k = keySig();\r\n      const internalValue = internal();\r\n      if (k === prevKey) {\r\n        return storeValue(k, internalValue); // normal operation\r\n      } else {\r\n        if (cleanupOldKey) store.removeItem(prevKey);\r\n        const value = getValue(k);\r\n\r\n        prevKey = k;\r\n        internal.set(value); // load new value\r\n      }\r\n    });\r\n  }\r\n\r\n  if (syncTabs && !isServer) {\r\n    const destroyRef = inject(DestroyRef);\r\n    const sync = (e: StorageEvent) => {\r\n      if (e.key !== untracked(keySig)) return;\r\n\r\n      if (e.newValue === null) internal.set(null);\r\n      else internal.set(getValue(e.key));\r\n    };\r\n\r\n    window.addEventListener('storage', sync);\r\n\r\n    destroyRef.onDestroy(() => window.removeEventListener('storage', sync));\r\n  }\r\n\r\n  const writable = toWritable<T>(\r\n    computed(() => internal() ?? fallback, opt),\r\n    internal.set,\r\n  ) as StoredSignal<T>;\r\n\r\n  writable.clear = () => {\r\n    internal.set(null);\r\n  };\r\n  writable.key = keySig;\r\n  return writable;\r\n}\r\n"]}","import { isPlatformServer } from '@angular/common';\nimport { DestroyRef, effect, inject, Injectable, PLATFORM_ID, } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class MessageBus {\n channel = new BroadcastChannel('mmstack-tab-sync-bus');\n listeners = new Map();\n subscribe(id, listener) {\n this.unsubscribe(id); // Ensure no duplicate listeners\n const wrapped = (ev) => {\n try {\n if (ev.data?.id === id)\n listener(ev.data?.value);\n }\n catch {\n // noop\n }\n };\n this.channel.addEventListener('message', wrapped);\n this.listeners.set(id, wrapped);\n return {\n unsub: (() => this.unsubscribe(id)).bind(this),\n post: ((value) => this.channel.postMessage({ id, value })).bind(this),\n };\n }\n unsubscribe(id) {\n const listener = this.listeners.get(id);\n if (!listener)\n return;\n this.channel.removeEventListener('message', listener);\n this.listeners.delete(id);\n }\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.1\", ngImport: i0, type: MessageBus, deps: [], target: i0.ɵɵFactoryTarget.Injectable });\n static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.1\", ngImport: i0, type: MessageBus, providedIn: 'root' });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.1\", ngImport: i0, type: MessageBus, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\nexport function generateDeterministicID() {\n const stack = new Error().stack;\n if (stack) {\n // Look for the actual caller (first non-internal frame)\n const lines = stack.split('\\n');\n for (let i = 2; i < lines.length; i++) {\n const line = lines[i];\n if (line && !line.includes('tabSync') && !line.includes('MessageBus')) {\n let hash = 0;\n for (let j = 0; j < line.length; j++) {\n const char = line.charCodeAt(j);\n hash = (hash << 5) - hash + char;\n hash = hash & hash;\n }\n return `auto-${Math.abs(hash)}`;\n }\n }\n }\n throw new Error('Could not generate deterministic ID, please provide one manually.');\n}\n/**\n * Synchronizes a WritableSignal across browser tabs using BroadcastChannel API.\n *\n * Creates a shared signal that automatically syncs its value between all tabs\n * of the same application. When the signal is updated in one tab, all other\n * tabs will receive the new value automatically.\n *\n * @template T - The type of the WritableSignal\n * @param sig - The WritableSignal to synchronize across tabs\n * @param opt - Optional configuration object\n * @param opt.id - Explicit channel ID for synchronization. If not provided,\n * a deterministic ID is generated based on the call site.\n * Use explicit IDs in production for reliability.\n *\n * @returns The same WritableSignal instance, now synchronized across tabs\n *\n * @throws {Error} When deterministic ID generation fails and no explicit ID is provided\n *\n * @example\n * ```typescript\n * // Basic usage - auto-generates channel ID from call site\n * const theme = tabSync(signal('dark'));\n *\n * // With explicit ID (recommended for production)\n * const userPrefs = tabSync(signal({ lang: 'en' }), { id: 'user-preferences' });\n *\n * // Changes in one tab will sync to all other tabs\n * theme.set('light'); // All tabs will update to 'light'\n * ```\n *\n * @remarks\n * - Only works in browser environments (returns original signal on server)\n * - Uses a single BroadcastChannel for all synchronized signals\n * - Automatically cleans up listeners when the injection context is destroyed\n * - Initial signal value after sync setup is not broadcasted to prevent loops\n *\n */\nexport function tabSync(sig, opt) {\n if (isPlatformServer(inject(PLATFORM_ID)))\n return sig;\n const id = opt?.id || generateDeterministicID();\n const bus = inject(MessageBus);\n const { unsub, post } = bus.subscribe(id, (next) => sig.set(next));\n let first = false;\n const effectRef = effect(() => {\n const val = sig();\n if (!first) {\n first = true;\n return;\n }\n post(val);\n }, ...(ngDevMode ? [{ debugName: \"effectRef\" }] : []));\n inject(DestroyRef).onDestroy(() => {\n effectRef.destroy();\n unsub();\n });\n return sig;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabSync.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/tabSync.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformServer } from '@angular/common';\nimport {\n  DestroyRef,\n  effect,\n  inject,\n  Injectable,\n  PLATFORM_ID,\n  WritableSignal,\n} from '@angular/core';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class MessageBus {\n  private readonly channel = new BroadcastChannel('mmstack-tab-sync-bus');\n  private readonly listeners = new Map<string, (ev: MessageEvent) => void>();\n\n  subscribe<T>(id: string, listener: (data: T) => void) {\n    this.unsubscribe(id); // Ensure no duplicate listeners\n    const wrapped = (ev: MessageEvent) => {\n      try {\n        if (ev.data?.id === id) listener(ev.data?.value);\n      } catch {\n        // noop\n      }\n    };\n    this.channel.addEventListener('message', wrapped);\n    this.listeners.set(id, wrapped);\n\n    return {\n      unsub: (() => this.unsubscribe(id)).bind(this),\n      post: ((value: T) => this.channel.postMessage({ id, value })).bind(this),\n    };\n  }\n\n  private unsubscribe(id: string) {\n    const listener = this.listeners.get(id);\n    if (!listener) return;\n    this.channel.removeEventListener('message', listener);\n    this.listeners.delete(id);\n  }\n}\n\nexport function generateDeterministicID(): string {\n  const stack = new Error().stack;\n  if (stack) {\n    // Look for the actual caller (first non-internal frame)\n    const lines = stack.split('\\n');\n    for (let i = 2; i < lines.length; i++) {\n      const line = lines[i];\n      if (line && !line.includes('tabSync') && !line.includes('MessageBus')) {\n        let hash = 0;\n        for (let j = 0; j < line.length; j++) {\n          const char = line.charCodeAt(j);\n          hash = (hash << 5) - hash + char;\n          hash = hash & hash;\n        }\n        return `auto-${Math.abs(hash)}`;\n      }\n    }\n  }\n  throw new Error(\n    'Could not generate deterministic ID, please provide one manually.',\n  );\n}\n\ntype SyncSignalOptions = {\n  id?: string;\n};\n\n/**\n * Synchronizes a WritableSignal across browser tabs using BroadcastChannel API.\n *\n * Creates a shared signal that automatically syncs its value between all tabs\n * of the same application. When the signal is updated in one tab, all other\n * tabs will receive the new value automatically.\n *\n * @template T - The type of the WritableSignal\n * @param sig - The WritableSignal to synchronize across tabs\n * @param opt - Optional configuration object\n * @param opt.id - Explicit channel ID for synchronization. If not provided,\n *                 a deterministic ID is generated based on the call site.\n *                 Use explicit IDs in production for reliability.\n *\n * @returns The same WritableSignal instance, now synchronized across tabs\n *\n * @throws {Error} When deterministic ID generation fails and no explicit ID is provided\n *\n * @example\n * ```typescript\n * // Basic usage - auto-generates channel ID from call site\n * const theme = tabSync(signal('dark'));\n *\n * // With explicit ID (recommended for production)\n * const userPrefs = tabSync(signal({ lang: 'en' }), { id: 'user-preferences' });\n *\n * // Changes in one tab will sync to all other tabs\n * theme.set('light'); // All tabs will update to 'light'\n * ```\n *\n * @remarks\n * - Only works in browser environments (returns original signal on server)\n * - Uses a single BroadcastChannel for all synchronized signals\n * - Automatically cleans up listeners when the injection context is destroyed\n * - Initial signal value after sync setup is not broadcasted to prevent loops\n *\n */\nexport function tabSync<T extends WritableSignal<any>>(\n  sig: T,\n  opt?: SyncSignalOptions,\n): T {\n  if (isPlatformServer(inject(PLATFORM_ID))) return sig;\n\n  const id = opt?.id || generateDeterministicID();\n\n  const bus = inject(MessageBus);\n\n  const { unsub, post } = bus.subscribe(id, (next) => sig.set(next));\n\n  let first = false;\n\n  const effectRef = effect(() => {\n    const val = sig();\n    if (!first) {\n      first = true;\n      return;\n    }\n    post(val);\n  });\n\n  inject(DestroyRef).onDestroy(() => {\n    effectRef.destroy();\n    unsub();\n  });\n\n  return sig;\n}\n"]}","import { DestroyRef, effect, inject, Injector, runInInjectionContext, untracked, } from '@angular/core';\nexport function until(sourceSignal, predicate, options = {}) {\n const injector = options.injector ?? inject(Injector);\n return new Promise((resolve, reject) => {\n let effectRef;\n let timeoutId;\n let settled = false;\n const cleanupAndReject = (reason) => {\n if (!settled) {\n settled = true;\n if (timeoutId)\n clearTimeout(timeoutId);\n effectRef?.destroy();\n reject(new Error(reason));\n }\n };\n const cleanupAndResolve = (value) => {\n if (!settled) {\n settled = true;\n if (timeoutId)\n clearTimeout(timeoutId);\n effectRef?.destroy();\n resolve(value);\n }\n };\n try {\n const destroyRef = options.destroyRef ?? inject(DestroyRef, { optional: true });\n destroyRef?.onDestroy(() => {\n cleanupAndReject('until: Operation cancelled due to context destruction.');\n });\n }\n catch {\n // noop\n }\n const initialValue = untracked(sourceSignal);\n if (predicate(initialValue)) {\n cleanupAndResolve(initialValue);\n return;\n }\n if (options?.timeout !== undefined) {\n timeoutId = setTimeout(() => cleanupAndReject(`until: Timeout after ${options.timeout}ms.`), options.timeout);\n }\n runInInjectionContext(injector, () => {\n effectRef = effect(() => {\n if (settled) {\n return effectRef?.destroy();\n }\n const currentValue = sourceSignal();\n if (predicate(currentValue)) {\n cleanupAndResolve(currentValue);\n }\n });\n });\n });\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"until.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/until.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EACV,MAAM,EAEN,MAAM,EACN,QAAQ,EACR,qBAAqB,EAErB,SAAS,GACV,MAAM,eAAe,CAAC;AAmEvB,MAAM,UAAU,KAAK,CACnB,YAAuB,EACvB,SAAgC,EAChC,UAAwB,EAAE;IAE1B,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,CAAC;IACtD,OAAO,IAAI,OAAO,CAAI,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACxC,IAAI,SAAgC,CAAC;QACrC,IAAI,SAAoD,CAAC;QACzD,IAAI,OAAO,GAAG,KAAK,CAAC;QAEpB,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAE,EAAE;YAC1C,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,OAAO,GAAG,IAAI,CAAC;gBACf,IAAI,SAAS;oBAAE,YAAY,CAAC,SAAS,CAAC,CAAC;gBACvC,SAAS,EAAE,OAAO,EAAE,CAAC;gBACrB,MAAM,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC,CAAC;QAEF,MAAM,iBAAiB,GAAG,CAAC,KAAQ,EAAE,EAAE;YACrC,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,OAAO,GAAG,IAAI,CAAC;gBACf,IAAI,SAAS;oBAAE,YAAY,CAAC,SAAS,CAAC,CAAC;gBACvC,SAAS,EAAE,OAAO,EAAE,CAAC;gBACrB,OAAO,CAAC,KAAK,CAAC,CAAC;YACjB,CAAC;QACH,CAAC,CAAC;QAEF,IAAI,CAAC;YACH,MAAM,UAAU,GACd,OAAO,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;YAE/D,UAAU,EAAE,SAAS,CAAC,GAAG,EAAE;gBACzB,gBAAgB,CACd,wDAAwD,CACzD,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC;QAAC,MAAM,CAAC;YACP,OAAO;QACT,CAAC;QAED,MAAM,YAAY,GAAG,SAAS,CAAC,YAAY,CAAC,CAAC;QAC7C,IAAI,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC;YAC5B,iBAAiB,CAAC,YAAY,CAAC,CAAC;YAChC,OAAO;QACT,CAAC;QAED,IAAI,OAAO,EAAE,OAAO,KAAK,SAAS,EAAE,CAAC;YACnC,SAAS,GAAG,UAAU,CACpB,GAAG,EAAE,CAAC,gBAAgB,CAAC,wBAAwB,OAAO,CAAC,OAAO,KAAK,CAAC,EACpE,OAAO,CAAC,OAAO,CAChB,CAAC;QACJ,CAAC;QAED,qBAAqB,CAAC,QAAQ,EAAE,GAAG,EAAE;YACnC,SAAS,GAAG,MAAM,CAAC,GAAG,EAAE;gBACtB,IAAI,OAAO,EAAE,CAAC;oBACZ,OAAO,SAAS,EAAE,OAAO,EAAE,CAAC;gBAC9B,CAAC;gBAED,MAAM,YAAY,GAAG,YAAY,EAAE,CAAC;gBACpC,IAAI,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC;oBAC5B,iBAAiB,CAAC,YAAY,CAAC,CAAC;gBAClC,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["import {\r\n  DestroyRef,\r\n  effect,\r\n  EffectRef,\r\n  inject,\r\n  Injector,\r\n  runInInjectionContext,\r\n  Signal,\r\n  untracked,\r\n} from '@angular/core';\r\n\r\nexport type UntilOptions = {\r\n  /**\r\n   * Optional timeout in milliseconds. If the condition is not met\r\n   * within this period, the promise will reject.\r\n   */\r\n  timeout?: number;\r\n  /**\r\n   * Optional DestroyRef. If provided and the component/context is destroyed\r\n   * before the condition is met or timeout occurs, the promise will reject.\r\n   * If not provided, it will attempt to inject one if called in an injection context.\r\n   */\r\n  destroyRef?: DestroyRef;\r\n  injector?: Injector;\r\n};\r\n\r\n/**\r\n * Creates a Promise that resolves when a signal's value satisfies a type predicate.\r\n *\r\n * This overload is used when the predicate function is a type guard (e.g., `(v): v is MyType`).\r\n * The returned promise will resolve with the narrowed type.\r\n *\r\n * @template T The base type of the signal's value.\r\n * @template U The narrowed type asserted by the predicate.\r\n * @param sourceSignal The signal to observe.\r\n * @param predicate A type guard function that returns `true` if the value is of type `U`.\r\n * @param options Optional configuration for timeout and explicit destruction.\r\n * @returns A Promise that resolves with the signal's value, narrowed to type `U`.\r\n *\r\n * @example\r\n * ```ts\r\n * const event = signal<Event | null>(null);\r\n *\r\n * // The returned promise is `Promise<MouseEvent>`\r\n * const mouseEventPromise = until(event, (e): e is MouseEvent => e instanceof MouseEvent);\r\n *\r\n * async function logMouseEvent() {\r\n * const me = await mouseEventPromise;\r\n * console.log(me.clientX); // `me` is correctly typed as MouseEvent\r\n * }\r\n * ```\r\n */\r\nexport function until<T, U extends T>(\r\n  sourceSignal: Signal<T>,\r\n  predicate: (value: T) => value is U,\r\n  options?: UntilOptions,\r\n): Promise<U>;\r\n\r\n/**\r\n * Creates a Promise that resolves when a signal's value satisfies a given predicate.\r\n *\r\n * This is useful for imperatively waiting for a reactive state to change,\r\n * for example, in tests or to orchestrate complex asynchronous operations.\r\n *\r\n * @template T The type of the signal's value.\r\n * @param sourceSignal The signal to observe.\r\n * @param predicate A function that takes the signal's value and returns `true` if the condition is met.\r\n * @param options Optional configuration for timeout and explicit destruction.\r\n * @returns A Promise that resolves with the signal's value when the predicate is true,\r\n * or rejects on timeout or context destruction.\r\n */\r\nexport function until<T>(\r\n  sourceSignal: Signal<T>,\r\n  predicate: (value: T) => boolean,\r\n  options?: UntilOptions,\r\n): Promise<T>;\r\nexport function until<T>(\r\n  sourceSignal: Signal<T>,\r\n  predicate: (value: T) => boolean,\r\n  options: UntilOptions = {},\r\n): Promise<T> {\r\n  const injector = options.injector ?? inject(Injector);\r\n  return new Promise<T>((resolve, reject) => {\r\n    let effectRef: EffectRef | undefined;\r\n    let timeoutId: ReturnType<typeof setTimeout> | undefined;\r\n    let settled = false;\r\n\r\n    const cleanupAndReject = (reason: string) => {\r\n      if (!settled) {\r\n        settled = true;\r\n        if (timeoutId) clearTimeout(timeoutId);\r\n        effectRef?.destroy();\r\n        reject(new Error(reason));\r\n      }\r\n    };\r\n\r\n    const cleanupAndResolve = (value: T) => {\r\n      if (!settled) {\r\n        settled = true;\r\n        if (timeoutId) clearTimeout(timeoutId);\r\n        effectRef?.destroy();\r\n        resolve(value);\r\n      }\r\n    };\r\n\r\n    try {\r\n      const destroyRef =\r\n        options.destroyRef ?? inject(DestroyRef, { optional: true });\r\n\r\n      destroyRef?.onDestroy(() => {\r\n        cleanupAndReject(\r\n          'until: Operation cancelled due to context destruction.',\r\n        );\r\n      });\r\n    } catch {\r\n      // noop\r\n    }\r\n\r\n    const initialValue = untracked(sourceSignal);\r\n    if (predicate(initialValue)) {\r\n      cleanupAndResolve(initialValue);\r\n      return;\r\n    }\r\n\r\n    if (options?.timeout !== undefined) {\r\n      timeoutId = setTimeout(\r\n        () => cleanupAndReject(`until: Timeout after ${options.timeout}ms.`),\r\n        options.timeout,\r\n      );\r\n    }\r\n\r\n    runInInjectionContext(injector, () => {\r\n      effectRef = effect(() => {\r\n        if (settled) {\r\n          return effectRef?.destroy();\r\n        }\r\n\r\n        const currentValue = sourceSignal();\r\n        if (predicate(currentValue)) {\r\n          cleanupAndResolve(currentValue);\r\n        }\r\n      });\r\n    });\r\n  });\r\n}\r\n"]}","import { SIGNAL } from '@angular/core/primitives/signals';\n/**\n * @interal\n */\nexport function getSignalEquality(sig) {\n const internal = sig[SIGNAL];\n if (internal && typeof internal.equal === 'function') {\n return internal.equal;\n }\n return Object.is; // Default equality check\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LXNpZ25hbC1lcXVhbGl0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvc3JjL2xpYi9nZXQtc2lnbmFsLWVxdWFsaXR5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUUxRDs7R0FFRztBQUNILE1BQU0sVUFBVSxpQkFBaUIsQ0FBSSxHQUFjO0lBQ2pELE1BQU0sUUFBUSxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBRTFCLENBQUM7SUFDRixJQUFJLFFBQVEsSUFBSSxPQUFPLFFBQVEsQ0FBQyxLQUFLLEtBQUssVUFBVSxFQUFFLENBQUM7UUFDckQsT0FBTyxRQUFRLENBQUMsS0FBSyxDQUFDO0lBQ3hCLENBQUM7SUFDRCxPQUFPLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQyx5QkFBeUI7QUFDN0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNpZ25hbCwgVmFsdWVFcXVhbGl0eUZuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNJR05BTCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcHJpbWl0aXZlcy9zaWduYWxzJztcclxuXHJcbi8qKlxyXG4gKiBAaW50ZXJhbFxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIGdldFNpZ25hbEVxdWFsaXR5PFQ+KHNpZzogU2lnbmFsPFQ+KTogVmFsdWVFcXVhbGl0eUZuPFQ+IHtcclxuICBjb25zdCBpbnRlcm5hbCA9IHNpZ1tTSUdOQUxdIGFzIHtcclxuICAgIGVxdWFsPzogVmFsdWVFcXVhbGl0eUZuPFQ+O1xyXG4gIH07XHJcbiAgaWYgKGludGVybmFsICYmIHR5cGVvZiBpbnRlcm5hbC5lcXVhbCA9PT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgcmV0dXJuIGludGVybmFsLmVxdWFsO1xyXG4gIH1cclxuICByZXR1cm4gT2JqZWN0LmlzOyAvLyBEZWZhdWx0IGVxdWFsaXR5IGNoZWNrXHJcbn1cclxuIl19","import { computed, untracked, } from '@angular/core';\nimport { getSignalEquality } from './get-signal-equality';\nimport { mutable } from './mutable';\nimport { toWritable } from './to-writable';\n/**\n * Enhances an existing `WritableSignal` by adding a complete undo/redo history\n * stack and an API to control it.\n *\n * @template T The type of value held by the signal.\n * @param source The source `WritableSignal` to add history tracking to.\n * @param options Optional configuration for the history behavior.\n * @returns A `SignalWithHistory<T>` instance, augmenting the source signal with history APIs.\n *\n * @remarks\n * - Any new `.set()` or `.update()` call on the signal will clear the entire redo stack.\n * - The primitive attempts to automatically use the source signal's own `equal` function,\n * but this relies on an internal Angular API. For maximum stability across Angular\n * versions, it is recommended to provide an explicit `equal` function in the options.\n *\n * @example\n * ```ts\n * import { signal } from '@angular/core';\n * import { withHistory } from '@mmstack/primitives';\n *\n * const name = withHistory(signal('John'), { maxSize: 5 });\n *\n * console.log('Initial value:', name()); // \"John\"\n *\n * name.set('John Doe');\n * name.set('Jane Doe');\n *\n * console.log('Current value:', name()); // \"Jane Doe\"\n * console.log('History:', name.history()); // [\"John\", \"John Doe\"]\n * console.log('Can undo:', name.canUndo()); // true\n * console.log('Can redo:', name.canRedo()); // false\n *\n * name.undo();\n * console.log('After undo:', name()); // \"John Doe\"\n * console.log('Can redo:', name.canRedo()); // true\n *\n * name.redo();\n * console.log('After redo:', name()); // \"Jane Doe\"\n *\n * // A new change will clear the redo history\n * name.set('Janine Doe');\n * console.log('Can redo:', name.canRedo()); // false\n *\n * name.clear();\n * console.log('Can undo:', name.canUndo()); // false\n * ```\n */\nexport function withHistory(source, opt) {\n const equal = opt?.equal ?? getSignalEquality(source);\n const maxSize = opt?.maxSize ?? Infinity;\n const history = mutable([], {\n ...opt,\n equal: undefined,\n });\n const redoArray = mutable([]);\n const originalSet = source.set;\n const set = (value) => {\n const current = untracked(source);\n if (equal(value, current))\n return;\n source.set(value);\n history.mutate((c) => {\n if (c.length >= maxSize) {\n if (opt?.cleanupStrategy === 'shift') {\n c.shift();\n }\n else {\n c = c.slice(Math.floor(maxSize / 2));\n }\n }\n c.push(current);\n return c;\n });\n redoArray.set([]);\n };\n const update = (updater) => {\n set(updater(untracked(source)));\n };\n const internal = toWritable(computed(() => source(), {\n equal,\n debugName: opt?.debugName,\n }), set, update);\n internal.history = history;\n internal.undo = () => {\n const historyStack = untracked(history);\n if (historyStack.length === 0)\n return;\n const valueForRedo = untracked(source);\n const valueToRestore = historyStack.at(-1);\n if (valueToRestore === undefined)\n return;\n originalSet.call(source, valueToRestore);\n history.inline((h) => h.pop());\n redoArray.inline((r) => r.push(valueForRedo));\n };\n internal.redo = () => {\n const redoStack = untracked(redoArray);\n if (redoStack.length === 0)\n return;\n const valueForUndo = untracked(source);\n const valueToRestore = redoStack.at(-1);\n if (valueToRestore === undefined)\n return;\n originalSet.call(source, valueToRestore);\n redoArray.inline((r) => r.pop());\n history.mutate((h) => {\n if (h.length >= maxSize) {\n if (opt?.cleanupStrategy === 'shift') {\n h.shift();\n }\n else {\n h = h.slice(Math.floor(maxSize / 2));\n }\n }\n h.push(valueForUndo);\n return h;\n });\n };\n internal.clear = () => {\n history.set([]);\n redoArray.set([]);\n };\n internal.canUndo = computed(() => history().length > 0, ...(ngDevMode ? [{ debugName: \"canUndo\" }] : []));\n internal.canRedo = computed(() => redoArray().length > 0, ...(ngDevMode ? [{ debugName: \"canRedo\" }] : []));\n internal.canClear = computed(() => internal.canUndo() || internal.canRedo(), ...(ngDevMode ? [{ debugName: \"canClear\" }] : []));\n return internal;\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-history.js","sourceRoot":"","sources":["../../../../../packages/primitives/src/lib/with-history.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  computed,\r\n  type CreateSignalOptions,\r\n  type Signal,\r\n  untracked,\r\n  type ValueEqualityFn,\r\n  type WritableSignal,\r\n} from '@angular/core';\r\nimport { getSignalEquality } from './get-signal-equality';\r\nimport { mutable } from './mutable';\r\nimport { toWritable } from './to-writable';\r\n\r\n/**\r\n * A WritableSignal enhanced with undo/redo capabilities and history tracking.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type SignalWithHistory<T> = WritableSignal<T> & {\r\n  /** A read-only signal of the undo history stack. The oldest changes are at the start of the array. */\r\n  history: Signal<T[]>;\r\n  /** Reverts the signal to its most recent previous state in the history. */\r\n  undo: () => void;\r\n  /** Re-applies the last state that was undone. */\r\n  redo: () => void;\r\n  /** A signal that is `true` if there are states in the redo stack. */\r\n  canRedo: Signal<boolean>;\r\n  /** A signal that is `true` if there are states in the undo history. */\r\n  canUndo: Signal<boolean>;\r\n  /** Clears both the undo and redo history stacks. */\r\n  clear: () => void;\r\n  /** A signal that is `true` if there is any history that can be cleared. */\r\n  canClear: Signal<boolean>;\r\n};\r\n\r\n/**\r\n * Options for creating a signal with history tracking.\r\n *\r\n * @template T The type of value held by the signal.\r\n */\r\nexport type CreateHistoryOptions<T> = Omit<\r\n  CreateSignalOptions<T[]>,\r\n  'equal'\r\n> & {\r\n  /**\r\n   * Optional custom equality function to determine if a value has changed before\r\n   * adding it to history. Defaults to the source signal's equality function or `Object.is`.\r\n   */\r\n  equal?: ValueEqualityFn<T>;\r\n  /**\r\n   * The maximum number of undo states to keep in the history.\r\n   * @default Infinity\r\n   */\r\n  maxSize?: number;\r\n  /**\r\n   * The strategy for trimming the history when `maxSize` is reached.\r\n   * - `shift`: Removes the single oldest entry from the history.\r\n   * - `halve`: Removes the oldest half of the history stack.\r\n   * @default 'halve'\r\n   */\r\n  cleanupStrategy?: 'shift' | 'halve';\r\n};\r\n\r\n/**\r\n * Enhances an existing `WritableSignal` by adding a complete undo/redo history\r\n * stack and an API to control it.\r\n *\r\n * @template T The type of value held by the signal.\r\n * @param source The source `WritableSignal` to add history tracking to.\r\n * @param options Optional configuration for the history behavior.\r\n * @returns A `SignalWithHistory<T>` instance, augmenting the source signal with history APIs.\r\n *\r\n * @remarks\r\n * - Any new `.set()` or `.update()` call on the signal will clear the entire redo stack.\r\n * - The primitive attempts to automatically use the source signal's own `equal` function,\r\n * but this relies on an internal Angular API. For maximum stability across Angular\r\n * versions, it is recommended to provide an explicit `equal` function in the options.\r\n *\r\n * @example\r\n * ```ts\r\n * import { signal } from '@angular/core';\r\n * import { withHistory } from '@mmstack/primitives';\r\n *\r\n * const name = withHistory(signal('John'), { maxSize: 5 });\r\n *\r\n * console.log('Initial value:', name()); // \"John\"\r\n *\r\n * name.set('John Doe');\r\n * name.set('Jane Doe');\r\n *\r\n * console.log('Current value:', name()); // \"Jane Doe\"\r\n * console.log('History:', name.history()); // [\"John\", \"John Doe\"]\r\n * console.log('Can undo:', name.canUndo()); // true\r\n * console.log('Can redo:', name.canRedo()); // false\r\n *\r\n * name.undo();\r\n * console.log('After undo:', name()); // \"John Doe\"\r\n * console.log('Can redo:', name.canRedo()); // true\r\n *\r\n * name.redo();\r\n * console.log('After redo:', name()); // \"Jane Doe\"\r\n *\r\n * // A new change will clear the redo history\r\n * name.set('Janine Doe');\r\n * console.log('Can redo:', name.canRedo()); // false\r\n *\r\n * name.clear();\r\n * console.log('Can undo:', name.canUndo()); // false\r\n * ```\r\n */\r\nexport function withHistory<T>(\r\n  source: WritableSignal<T>,\r\n  opt?: CreateHistoryOptions<T>,\r\n): SignalWithHistory<T> {\r\n  const equal = opt?.equal ?? getSignalEquality(source);\r\n  const maxSize = opt?.maxSize ?? Infinity;\r\n\r\n  const history = mutable<T[]>([], {\r\n    ...opt,\r\n    equal: undefined,\r\n  });\r\n\r\n  const redoArray = mutable<T[]>([]);\r\n\r\n  const originalSet = source.set;\r\n\r\n  const set = (value: T) => {\r\n    const current = untracked(source);\r\n    if (equal(value, current)) return;\r\n\r\n    source.set(value);\r\n\r\n    history.mutate((c) => {\r\n      if (c.length >= maxSize) {\r\n        if (opt?.cleanupStrategy === 'shift') {\r\n          c.shift();\r\n        } else {\r\n          c = c.slice(Math.floor(maxSize / 2));\r\n        }\r\n      }\r\n      c.push(current);\r\n      return c;\r\n    });\r\n    redoArray.set([]);\r\n  };\r\n\r\n  const update = (updater: (prev: T) => T) => {\r\n    set(updater(untracked(source)));\r\n  };\r\n\r\n  const internal = toWritable(\r\n    computed(() => source(), {\r\n      equal,\r\n      debugName: opt?.debugName,\r\n    }),\r\n    set,\r\n    update,\r\n  ) as SignalWithHistory<T>;\r\n  internal.history = history;\r\n\r\n  internal.undo = () => {\r\n    const historyStack = untracked(history);\r\n    if (historyStack.length === 0) return;\r\n\r\n    const valueForRedo = untracked(source);\r\n    const valueToRestore = historyStack.at(-1);\r\n    if (valueToRestore === undefined) return;\r\n\r\n    originalSet.call(source, valueToRestore);\r\n\r\n    history.inline((h) => h.pop());\r\n    redoArray.inline((r) => r.push(valueForRedo));\r\n  };\r\n\r\n  internal.redo = () => {\r\n    const redoStack = untracked(redoArray);\r\n    if (redoStack.length === 0) return;\r\n\r\n    const valueForUndo = untracked(source);\r\n    const valueToRestore = redoStack.at(-1);\r\n    if (valueToRestore === undefined) return;\r\n\r\n    originalSet.call(source, valueToRestore);\r\n\r\n    redoArray.inline((r) => r.pop());\r\n    history.mutate((h) => {\r\n      if (h.length >= maxSize) {\r\n        if (opt?.cleanupStrategy === 'shift') {\r\n          h.shift();\r\n        } else {\r\n          h = h.slice(Math.floor(maxSize / 2));\r\n        }\r\n      }\r\n      h.push(valueForUndo);\r\n      return h;\r\n    });\r\n  };\r\n\r\n  internal.clear = () => {\r\n    history.set([]);\r\n    redoArray.set([]);\r\n  };\r\n\r\n  internal.canUndo = computed(() => history().length > 0);\r\n  internal.canRedo = computed(() => redoArray().length > 0);\r\n  internal.canClear = computed(() => internal.canUndo() || internal.canRedo());\r\n\r\n  return internal;\r\n}\r\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW1zdGFjay1wcmltaXRpdmVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcHJpbWl0aXZlcy9zcmMvbW1zdGFjay1wcmltaXRpdmVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19"],"names":[],"mappings":"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"}