@angular/core 21.1.3 → 21.2.0-next.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (76) hide show
  1. package/fesm2022/_attribute-chunk.mjs +1 -1
  2. package/fesm2022/_attribute-chunk.mjs.map +1 -1
  3. package/fesm2022/_debug_node-chunk.mjs +34 -33
  4. package/fesm2022/_debug_node-chunk.mjs.map +1 -1
  5. package/fesm2022/_effect-chunk.mjs +1 -1
  6. package/fesm2022/_effect-chunk.mjs.map +1 -1
  7. package/fesm2022/_linked_signal-chunk.mjs +2 -5
  8. package/fesm2022/_linked_signal-chunk.mjs.map +1 -1
  9. package/fesm2022/_not_found-chunk.mjs +1 -1
  10. package/fesm2022/_not_found-chunk.mjs.map +1 -1
  11. package/fesm2022/_resource-chunk.mjs +19 -2
  12. package/fesm2022/_resource-chunk.mjs.map +1 -1
  13. package/fesm2022/_untracked-chunk.mjs +2 -2
  14. package/fesm2022/_untracked-chunk.mjs.map +1 -1
  15. package/fesm2022/_weak_ref-chunk.mjs +1 -1
  16. package/fesm2022/_weak_ref-chunk.mjs.map +1 -1
  17. package/fesm2022/core.mjs +36 -6
  18. package/fesm2022/core.mjs.map +1 -1
  19. package/fesm2022/primitives-di.mjs +1 -1
  20. package/fesm2022/primitives-di.mjs.map +1 -1
  21. package/fesm2022/primitives-event-dispatch.mjs +2 -2
  22. package/fesm2022/primitives-event-dispatch.mjs.map +1 -1
  23. package/fesm2022/primitives-signals.mjs +1 -1
  24. package/fesm2022/primitives-signals.mjs.map +1 -1
  25. package/fesm2022/rxjs-interop.mjs +1 -1
  26. package/fesm2022/rxjs-interop.mjs.map +1 -1
  27. package/fesm2022/testing.mjs +1 -1
  28. package/fesm2022/testing.mjs.map +1 -1
  29. package/package.json +2 -2
  30. package/resources/best-practices.md +0 -1
  31. package/schematics/bundles/add-bootstrap-context-to-server-main.cjs +1 -1
  32. package/schematics/bundles/application-config-core.cjs +1 -1
  33. package/schematics/bundles/apply_import_manager-CxA_YYgB.cjs +1 -1
  34. package/schematics/bundles/bootstrap-options-migration.cjs +1 -1
  35. package/schematics/bundles/cleanup-unused-imports.cjs +1 -1
  36. package/schematics/bundles/common-to-standalone-migration.cjs +1 -1
  37. package/schematics/bundles/compiler_host-CY14HvaP.cjs +1 -1
  38. package/schematics/bundles/control-flow-migration.cjs +1 -1
  39. package/schematics/bundles/imports-CVmcbVA9.cjs +1 -1
  40. package/schematics/bundles/index-BtLcQH8g.cjs +1 -1
  41. package/schematics/bundles/inject-migration.cjs +1 -1
  42. package/schematics/bundles/leading_space-BTPRV0wu.cjs +1 -1
  43. package/schematics/bundles/{migrate_ts_type_references-CV7qdt5t.cjs → migrate_ts_type_references-MWoZx-Cb.cjs} +11 -10
  44. package/schematics/bundles/ng_component_template-BOuKAnQd.cjs +1 -1
  45. package/schematics/bundles/ng_decorators-DYy6II6x.cjs +1 -1
  46. package/schematics/bundles/ngclass-to-class-migration.cjs +1 -1
  47. package/schematics/bundles/ngstyle-to-style-migration.cjs +1 -1
  48. package/schematics/bundles/nodes-ZSQ7WZRB.cjs +1 -1
  49. package/schematics/bundles/output-migration.cjs +1 -1
  50. package/schematics/bundles/parse_html-C8eKA9px.cjs +1 -1
  51. package/schematics/bundles/project_paths-D2V-Uh2L.cjs +1 -1
  52. package/schematics/bundles/project_tsconfig_paths-DkkMibv-.cjs +1 -1
  53. package/schematics/bundles/property_name-BCpALNpZ.cjs +1 -1
  54. package/schematics/bundles/route-lazy-loading.cjs +1 -1
  55. package/schematics/bundles/router-current-navigation.cjs +1 -1
  56. package/schematics/bundles/router-last-successful-navigation.cjs +1 -1
  57. package/schematics/bundles/router-testing-module-migration.cjs +1 -1
  58. package/schematics/bundles/self-closing-tags-migration.cjs +1 -1
  59. package/schematics/bundles/signal-input-migration.cjs +2 -2
  60. package/schematics/bundles/signal-queries-migration.cjs +2 -2
  61. package/schematics/bundles/signals.cjs +2 -2
  62. package/schematics/bundles/standalone-migration.cjs +1 -1
  63. package/schematics/bundles/symbol-DZeHSR-V.cjs +1 -1
  64. package/types/_api-chunk.d.ts +25 -2
  65. package/types/_chrome_dev_tools_performance-chunk.d.ts +1 -1
  66. package/types/_discovery-chunk.d.ts +2 -2
  67. package/types/_effect-chunk.d.ts +1 -1
  68. package/types/_event_dispatcher-chunk.d.ts +2 -2
  69. package/types/_formatter-chunk.d.ts +1 -1
  70. package/types/_weak_ref-chunk.d.ts +1 -1
  71. package/types/core.d.ts +34 -4
  72. package/types/primitives-di.d.ts +1 -1
  73. package/types/primitives-event-dispatch.d.ts +3 -3
  74. package/types/primitives-signals.d.ts +1 -1
  75. package/types/rxjs-interop.d.ts +1 -1
  76. package/types/testing.d.ts +1 -1
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v21.1.3
2
+ * @license Angular v21.2.0-next.1
3
3
  * (c) 2010-2026 Google LLC. https://angular.dev/
4
4
  * License: MIT
5
5
  */
@@ -1 +1 @@
1
- {"version":3,"file":"primitives-signals.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/primitives/signals/src/formatter.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/primitives/signals/src/watch.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/primitives/signals/index.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {SIGNAL} from './graph';\n\n// Only a subset of HTML tags are allowed in the custom formatter JsonML format.\n// See https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html#html-template-format\ntype AllowedTags = 'span' | 'div' | 'ol' | 'ul' | 'li' | 'table' | 'tr' | 'td';\n\ntype JsonMLText = string;\ntype JsonMLAttrs = Record<string, string>;\ntype JsonMLElement =\n | [tagName: AllowedTags, ...children: (JsonMLNode | JsonMLChild)[]]\n | [tagName: AllowedTags, attrs: JsonMLAttrs, ...children: (JsonMLNode | JsonMLChild)[]];\ntype JsonMLNode = JsonMLText | JsonMLElement;\ntype JsonMLChild = ['object', {object: unknown; config?: unknown}];\ntype JsonML = JsonMLNode;\n\ntype FormatterConfig = unknown & {ngSkipFormatting?: boolean};\n\ndeclare global {\n // We need to use `var` here to be able to declare a global variable.\n // `let` and `const` will be locally scoped to the file.\n // tslint:disable-next-line:no-unused-variable\n var devtoolsFormatters: any[];\n}\n\n/**\n * A custom formatter which renders signals in an easy-to-read format.\n *\n * @see https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html\n */\n\nconst formatter = {\n /**\n * If the function returns `null`, the formatter is not used for this reference\n */\n header: (sig: any, config: FormatterConfig): JsonML | null => {\n if (!isSignal(sig) || config?.ngSkipFormatting) return null;\n\n let value: unknown;\n try {\n value = sig();\n } catch (e: any) {\n // In case the signal throws, we don't want to break the formatting.\n return ['span', `Signal(⚠️ Error)${e.message ? `: ${e.message}` : ''}`];\n }\n\n const kind = 'computation' in (sig[SIGNAL] as any) ? 'Computed' : 'Signal';\n\n const isPrimitive = value === null || (!Array.isArray(value) && typeof value !== 'object');\n\n return [\n 'span',\n {},\n ['span', {}, `${kind}(`],\n (() => {\n if (isSignal(value)) {\n // Recursively call formatter. Could return an `object` to call the formatter through DevTools,\n // but then recursive signals will render multiple expando arrows which is an awkward UX.\n return formatter.header(value, config)!;\n } else if (isPrimitive && value !== undefined && typeof value !== 'function') {\n // Use built-in rendering for primitives which applies standard syntax highlighting / theming.\n // Can't do this for `undefined` however, as the browser thinks we forgot to provide an object.\n // Also don't want to do this for functions which render nested expando arrows.\n return ['object', {object: value}];\n } else {\n return prettifyPreview(value as Record<string | number | symbol, unknown>);\n }\n })(),\n ['span', {}, `)`],\n ];\n },\n\n hasBody: (sig: any, config: FormatterConfig) => {\n if (!isSignal(sig)) return false;\n\n try {\n sig();\n } catch {\n return false;\n }\n return !config?.ngSkipFormatting;\n },\n\n body: (sig: any, config: any): JsonML => {\n // We can use sys colors to fit the current DevTools theme.\n // Those are unfortunately only available on Chromium-based browsers.\n // On Firefow we fall back to the default color\n const color = 'var(--sys-color-primary)';\n\n return [\n 'div',\n {style: `background: #FFFFFF10; padding-left: 4px; padding-top: 2px; padding-bottom: 2px;`},\n ['div', {style: `color: ${color}`}, 'Signal value: '],\n ['div', {style: `padding-left: .5rem;`}, ['object', {object: sig(), config}]],\n ['div', {style: `color: ${color}`}, 'Signal function: '],\n [\n 'div',\n {style: `padding-left: .5rem;`},\n ['object', {object: sig, config: {...config, ngSkipFormatting: true}}],\n ],\n ];\n },\n};\n\nfunction prettifyPreview(\n value: Record<string | number | symbol, unknown> | Array<unknown> | undefined,\n): string | JsonMLChild {\n if (value === null) return 'null';\n if (Array.isArray(value)) return `Array(${value.length})`;\n if (value instanceof Element) return `<${value.tagName.toLowerCase()}>`;\n if (value instanceof URL) return `URL`;\n\n switch (typeof value) {\n case 'undefined': {\n return 'undefined';\n }\n case 'function': {\n if ('prototype' in value) {\n // This is what Chrome renders, can't use `object` though because it creates a nested expando arrow.\n return 'class';\n } else {\n return '() => {…}';\n }\n }\n case 'object': {\n if (value.constructor.name === 'Object') {\n return '{…}';\n } else {\n return `${value.constructor.name} {}`;\n }\n }\n default: {\n return ['object', {object: value, config: {ngSkipFormatting: true}}];\n }\n }\n}\n\nfunction isSignal(value: any): boolean {\n return value[SIGNAL] !== undefined;\n}\n\n/**\n * Installs the custom formatter into custom formatting on Signals in the devtools.\n *\n * Supported by both Chrome and Firefox.\n *\n * @see https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html\n */\nexport function installDevToolsSignalFormatter() {\n globalThis.devtoolsFormatters ??= [];\n if (!globalThis.devtoolsFormatters.some((f: any) => f === formatter)) {\n globalThis.devtoolsFormatters.push(formatter);\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n consumerAfterComputation,\n consumerBeforeComputation,\n consumerDestroy,\n consumerMarkDirty,\n consumerPollProducersForChange,\n isInNotificationPhase,\n REACTIVE_NODE,\n ReactiveNode,\n SIGNAL,\n} from './graph';\n\n// Required as the signals library is in a separate package, so we need to explicitly ensure the\n// global `ngDevMode` type is defined.\ndeclare const ngDevMode: boolean | undefined;\n\n/**\n * A cleanup function that can be optionally registered from the watch logic. If registered, the\n * cleanup logic runs before the next watch execution.\n */\nexport type WatchCleanupFn = () => void;\n\n/**\n * A callback passed to the watch function that makes it possible to register cleanup logic.\n */\nexport type WatchCleanupRegisterFn = (cleanupFn: WatchCleanupFn) => void;\n\nexport interface Watch {\n notify(): void;\n\n /**\n * Execute the reactive expression in the context of this `Watch` consumer.\n *\n * Should be called by the user scheduling algorithm when the provided\n * `schedule` hook is called by `Watch`.\n */\n run(): void;\n\n cleanup(): void;\n\n /**\n * Destroy the watcher:\n * - disconnect it from the reactive graph;\n * - mark it as destroyed so subsequent run and notify operations are noop.\n */\n destroy(): void;\n\n [SIGNAL]: WatchNode;\n}\nexport interface WatchNode extends ReactiveNode {\n fn: ((onCleanup: WatchCleanupRegisterFn) => void) | null;\n schedule: ((watch: Watch) => void) | null;\n cleanupFn: WatchCleanupFn;\n ref: Watch;\n}\n\nexport function createWatch(\n fn: (onCleanup: WatchCleanupRegisterFn) => void,\n schedule: (watch: Watch) => void,\n allowSignalWrites: boolean,\n): Watch {\n const node: WatchNode = Object.create(WATCH_NODE);\n if (allowSignalWrites) {\n node.consumerAllowSignalWrites = true;\n }\n\n node.fn = fn;\n node.schedule = schedule;\n\n const registerOnCleanup = (cleanupFn: WatchCleanupFn) => {\n node.cleanupFn = cleanupFn;\n };\n\n function isWatchNodeDestroyed(node: WatchNode) {\n return node.fn === null && node.schedule === null;\n }\n\n function destroyWatchNode(node: WatchNode) {\n if (!isWatchNodeDestroyed(node)) {\n consumerDestroy(node); // disconnect watcher from the reactive graph\n node.cleanupFn();\n\n // nullify references to the integration functions to mark node as destroyed\n node.fn = null;\n node.schedule = null;\n node.cleanupFn = NOOP_CLEANUP_FN;\n }\n }\n\n const run = () => {\n if (node.fn === null) {\n // trying to run a destroyed watch is noop\n return;\n }\n\n if (isInNotificationPhase()) {\n throw new Error(\n typeof ngDevMode !== 'undefined' && ngDevMode\n ? 'Schedulers cannot synchronously execute watches while scheduling.'\n : '',\n );\n }\n\n node.dirty = false;\n if (node.version > 0 && !consumerPollProducersForChange(node)) {\n return;\n }\n node.version++;\n\n const prevConsumer = consumerBeforeComputation(node);\n try {\n node.cleanupFn();\n node.cleanupFn = NOOP_CLEANUP_FN;\n node.fn(registerOnCleanup);\n } finally {\n consumerAfterComputation(node, prevConsumer);\n }\n };\n\n node.ref = {\n notify: () => consumerMarkDirty(node),\n run,\n cleanup: () => node.cleanupFn(),\n destroy: () => destroyWatchNode(node),\n [SIGNAL]: node,\n };\n\n return node.ref;\n}\n\nconst NOOP_CLEANUP_FN: WatchCleanupFn = () => {};\n\n// Note: Using an IIFE here to ensure that the spread assignment is not considered\n// a side-effect, ending up preserving `COMPUTED_NODE` and `REACTIVE_NODE`.\n// TODO: remove when https://github.com/evanw/esbuild/issues/3392 is resolved.\nconst WATCH_NODE: Partial<WatchNode> = /* @__PURE__ */ (() => {\n return {\n ...REACTIVE_NODE,\n consumerIsAlwaysLive: true,\n consumerAllowSignalWrites: false,\n consumerMarkedDirty: (node: WatchNode) => {\n if (node.schedule !== null) {\n node.schedule(node.ref);\n }\n },\n cleanupFn: NOOP_CLEANUP_FN,\n };\n})();\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {installDevToolsSignalFormatter} from './src/formatter';\n\nexport {ComputedNode, createComputed} from './src/computed';\nexport {\n ComputationFn,\n LinkedSignalNode,\n LinkedSignalGetter,\n PreviousValue,\n createLinkedSignal,\n linkedSignalSetFn,\n linkedSignalUpdateFn,\n} from './src/linked_signal';\nexport {ValueEqualityFn, defaultEquals} from './src/equality';\nexport {setThrowInvalidWriteToSignalError} from './src/errors';\nexport {\n REACTIVE_NODE,\n Reactive,\n ReactiveHookFn,\n ReactiveNode,\n ReactiveNodeKind,\n SIGNAL,\n consumerAfterComputation,\n consumerBeforeComputation,\n consumerDestroy,\n consumerMarkDirty,\n consumerPollProducersForChange,\n finalizeConsumerAfterComputation,\n getActiveConsumer,\n isInNotificationPhase,\n isReactive,\n producerAccessed,\n producerIncrementEpoch,\n producerMarkClean,\n producerNotifyConsumers,\n producerUpdateValueVersion,\n producerUpdatesAllowed,\n resetConsumerBeforeComputation,\n runPostProducerCreatedFn,\n setActiveConsumer,\n setPostProducerCreatedFn,\n Version,\n} from './src/graph';\nexport {\n SIGNAL_NODE,\n SignalGetter,\n SignalNode,\n createSignal,\n runPostSignalSetFn,\n setPostSignalSetFn,\n signalGetFn,\n signalSetFn,\n signalUpdateFn,\n} from './src/signal';\nexport {Watch, WatchCleanupFn, WatchCleanupRegisterFn, createWatch} from './src/watch';\nexport {setAlternateWeakRefImpl} from './src/weak_ref';\nexport {untracked} from './src/untracked';\nexport {runEffect, BASE_EFFECT_NODE, BaseEffectNode} from './src/effect';\nexport {installDevToolsSignalFormatter} from './src/formatter';\n\n// Required as the signals library is in a separate package, so we need to explicitly ensure the\n// global `ngDevMode` type is defined.\ndeclare const ngDevMode: boolean | undefined;\n\n// We're using a top-level access to enable signal formatting whenever the signals package is loaded.\n// ngDevMode might not have been init correctly yet, checking for `undefined` ensures that in case\n// it is not defined yet, we still install the formatter.\nif (typeof ngDevMode === 'undefined' || ngDevMode) {\n // tslint:disable-next-line: no-toplevel-property-access\n installDevToolsSignalFormatter();\n}\n"],"names":["formatter","header","sig","config","isSignal","ngSkipFormatting","value","e","message","kind","SIGNAL","isPrimitive","Array","isArray","undefined","object","prettifyPreview","hasBody","body","color","style","length","Element","tagName","toLowerCase","URL","constructor","name","installDevToolsSignalFormatter","globalThis","devtoolsFormatters","some","f","push","createWatch","fn","schedule","allowSignalWrites","node","Object","create","WATCH_NODE","consumerAllowSignalWrites","registerOnCleanup","cleanupFn","isWatchNodeDestroyed","destroyWatchNode","consumerDestroy","NOOP_CLEANUP_FN","run","isInNotificationPhase","Error","ngDevMode","dirty","version","consumerPollProducersForChange","prevConsumer","consumerBeforeComputation","consumerAfterComputation","ref","notify","consumerMarkDirty","cleanup","destroy","REACTIVE_NODE","consumerIsAlwaysLive","consumerMarkedDirty"],"mappings":"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"}
1
+ {"version":3,"file":"primitives-signals.mjs","sources":["../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/primitives/signals/src/formatter.ts","../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/primitives/signals/src/watch.ts","../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/primitives/signals/index.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {SIGNAL} from './graph';\n\n// Only a subset of HTML tags are allowed in the custom formatter JsonML format.\n// See https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html#html-template-format\ntype AllowedTags = 'span' | 'div' | 'ol' | 'ul' | 'li' | 'table' | 'tr' | 'td';\n\ntype JsonMLText = string;\ntype JsonMLAttrs = Record<string, string>;\ntype JsonMLElement =\n | [tagName: AllowedTags, ...children: (JsonMLNode | JsonMLChild)[]]\n | [tagName: AllowedTags, attrs: JsonMLAttrs, ...children: (JsonMLNode | JsonMLChild)[]];\ntype JsonMLNode = JsonMLText | JsonMLElement;\ntype JsonMLChild = ['object', {object: unknown; config?: unknown}];\ntype JsonML = JsonMLNode;\n\ntype FormatterConfig = unknown & {ngSkipFormatting?: boolean};\n\ndeclare global {\n // We need to use `var` here to be able to declare a global variable.\n // `let` and `const` will be locally scoped to the file.\n // tslint:disable-next-line:no-unused-variable\n var devtoolsFormatters: any[];\n}\n\n/**\n * A custom formatter which renders signals in an easy-to-read format.\n *\n * @see https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html\n */\n\nconst formatter = {\n /**\n * If the function returns `null`, the formatter is not used for this reference\n */\n header: (sig: any, config: FormatterConfig): JsonML | null => {\n if (!isSignal(sig) || config?.ngSkipFormatting) return null;\n\n let value: unknown;\n try {\n value = sig();\n } catch (e: any) {\n // In case the signal throws, we don't want to break the formatting.\n return ['span', `Signal(⚠️ Error)${e.message ? `: ${e.message}` : ''}`];\n }\n\n const kind = 'computation' in (sig[SIGNAL] as any) ? 'Computed' : 'Signal';\n\n const isPrimitive = value === null || (!Array.isArray(value) && typeof value !== 'object');\n\n return [\n 'span',\n {},\n ['span', {}, `${kind}(`],\n (() => {\n if (isSignal(value)) {\n // Recursively call formatter. Could return an `object` to call the formatter through DevTools,\n // but then recursive signals will render multiple expando arrows which is an awkward UX.\n return formatter.header(value, config)!;\n } else if (isPrimitive && value !== undefined && typeof value !== 'function') {\n // Use built-in rendering for primitives which applies standard syntax highlighting / theming.\n // Can't do this for `undefined` however, as the browser thinks we forgot to provide an object.\n // Also don't want to do this for functions which render nested expando arrows.\n return ['object', {object: value}];\n } else {\n return prettifyPreview(value as Record<string | number | symbol, unknown>);\n }\n })(),\n ['span', {}, `)`],\n ];\n },\n\n hasBody: (sig: any, config: FormatterConfig) => {\n if (!isSignal(sig)) return false;\n\n try {\n sig();\n } catch {\n return false;\n }\n return !config?.ngSkipFormatting;\n },\n\n body: (sig: any, config: any): JsonML => {\n // We can use sys colors to fit the current DevTools theme.\n // Those are unfortunately only available on Chromium-based browsers.\n // On Firefow we fall back to the default color\n const color = 'var(--sys-color-primary)';\n\n return [\n 'div',\n {style: `background: #FFFFFF10; padding-left: 4px; padding-top: 2px; padding-bottom: 2px;`},\n ['div', {style: `color: ${color}`}, 'Signal value: '],\n ['div', {style: `padding-left: .5rem;`}, ['object', {object: sig(), config}]],\n ['div', {style: `color: ${color}`}, 'Signal function: '],\n [\n 'div',\n {style: `padding-left: .5rem;`},\n ['object', {object: sig, config: {...config, ngSkipFormatting: true}}],\n ],\n ];\n },\n};\n\nfunction prettifyPreview(\n value: Record<string | number | symbol, unknown> | Array<unknown> | undefined,\n): string | JsonMLChild {\n if (value === null) return 'null';\n if (Array.isArray(value)) return `Array(${value.length})`;\n if (value instanceof Element) return `<${value.tagName.toLowerCase()}>`;\n if (value instanceof URL) return `URL`;\n\n switch (typeof value) {\n case 'undefined': {\n return 'undefined';\n }\n case 'function': {\n if ('prototype' in value) {\n // This is what Chrome renders, can't use `object` though because it creates a nested expando arrow.\n return 'class';\n } else {\n return '() => {…}';\n }\n }\n case 'object': {\n if (value.constructor.name === 'Object') {\n return '{…}';\n } else {\n return `${value.constructor.name} {}`;\n }\n }\n default: {\n return ['object', {object: value, config: {ngSkipFormatting: true}}];\n }\n }\n}\n\nfunction isSignal(value: any): boolean {\n return value[SIGNAL] !== undefined;\n}\n\n/**\n * Installs the custom formatter into custom formatting on Signals in the devtools.\n *\n * Supported by both Chrome and Firefox.\n *\n * @see https://firefox-source-docs.mozilla.org/devtools-user/custom_formatters/index.html\n */\nexport function installDevToolsSignalFormatter() {\n globalThis.devtoolsFormatters ??= [];\n if (!globalThis.devtoolsFormatters.some((f: any) => f === formatter)) {\n globalThis.devtoolsFormatters.push(formatter);\n }\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n consumerAfterComputation,\n consumerBeforeComputation,\n consumerDestroy,\n consumerMarkDirty,\n consumerPollProducersForChange,\n isInNotificationPhase,\n REACTIVE_NODE,\n ReactiveNode,\n SIGNAL,\n} from './graph';\n\n// Required as the signals library is in a separate package, so we need to explicitly ensure the\n// global `ngDevMode` type is defined.\ndeclare const ngDevMode: boolean | undefined;\n\n/**\n * A cleanup function that can be optionally registered from the watch logic. If registered, the\n * cleanup logic runs before the next watch execution.\n */\nexport type WatchCleanupFn = () => void;\n\n/**\n * A callback passed to the watch function that makes it possible to register cleanup logic.\n */\nexport type WatchCleanupRegisterFn = (cleanupFn: WatchCleanupFn) => void;\n\nexport interface Watch {\n notify(): void;\n\n /**\n * Execute the reactive expression in the context of this `Watch` consumer.\n *\n * Should be called by the user scheduling algorithm when the provided\n * `schedule` hook is called by `Watch`.\n */\n run(): void;\n\n cleanup(): void;\n\n /**\n * Destroy the watcher:\n * - disconnect it from the reactive graph;\n * - mark it as destroyed so subsequent run and notify operations are noop.\n */\n destroy(): void;\n\n [SIGNAL]: WatchNode;\n}\nexport interface WatchNode extends ReactiveNode {\n fn: ((onCleanup: WatchCleanupRegisterFn) => void) | null;\n schedule: ((watch: Watch) => void) | null;\n cleanupFn: WatchCleanupFn;\n ref: Watch;\n}\n\nexport function createWatch(\n fn: (onCleanup: WatchCleanupRegisterFn) => void,\n schedule: (watch: Watch) => void,\n allowSignalWrites: boolean,\n): Watch {\n const node: WatchNode = Object.create(WATCH_NODE);\n if (allowSignalWrites) {\n node.consumerAllowSignalWrites = true;\n }\n\n node.fn = fn;\n node.schedule = schedule;\n\n const registerOnCleanup = (cleanupFn: WatchCleanupFn) => {\n node.cleanupFn = cleanupFn;\n };\n\n function isWatchNodeDestroyed(node: WatchNode) {\n return node.fn === null && node.schedule === null;\n }\n\n function destroyWatchNode(node: WatchNode) {\n if (!isWatchNodeDestroyed(node)) {\n consumerDestroy(node); // disconnect watcher from the reactive graph\n node.cleanupFn();\n\n // nullify references to the integration functions to mark node as destroyed\n node.fn = null;\n node.schedule = null;\n node.cleanupFn = NOOP_CLEANUP_FN;\n }\n }\n\n const run = () => {\n if (node.fn === null) {\n // trying to run a destroyed watch is noop\n return;\n }\n\n if (isInNotificationPhase()) {\n throw new Error(\n typeof ngDevMode !== 'undefined' && ngDevMode\n ? 'Schedulers cannot synchronously execute watches while scheduling.'\n : '',\n );\n }\n\n node.dirty = false;\n if (node.version > 0 && !consumerPollProducersForChange(node)) {\n return;\n }\n node.version++;\n\n const prevConsumer = consumerBeforeComputation(node);\n try {\n node.cleanupFn();\n node.cleanupFn = NOOP_CLEANUP_FN;\n node.fn(registerOnCleanup);\n } finally {\n consumerAfterComputation(node, prevConsumer);\n }\n };\n\n node.ref = {\n notify: () => consumerMarkDirty(node),\n run,\n cleanup: () => node.cleanupFn(),\n destroy: () => destroyWatchNode(node),\n [SIGNAL]: node,\n };\n\n return node.ref;\n}\n\nconst NOOP_CLEANUP_FN: WatchCleanupFn = () => {};\n\n// Note: Using an IIFE here to ensure that the spread assignment is not considered\n// a side-effect, ending up preserving `COMPUTED_NODE` and `REACTIVE_NODE`.\n// TODO: remove when https://github.com/evanw/esbuild/issues/3392 is resolved.\nconst WATCH_NODE: Partial<WatchNode> = /* @__PURE__ */ (() => {\n return {\n ...REACTIVE_NODE,\n consumerIsAlwaysLive: true,\n consumerAllowSignalWrites: false,\n consumerMarkedDirty: (node: WatchNode) => {\n if (node.schedule !== null) {\n node.schedule(node.ref);\n }\n },\n cleanupFn: NOOP_CLEANUP_FN,\n };\n})();\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {installDevToolsSignalFormatter} from './src/formatter';\n\nexport {ComputedNode, createComputed} from './src/computed';\nexport {\n ComputationFn,\n LinkedSignalNode,\n LinkedSignalGetter,\n PreviousValue,\n createLinkedSignal,\n linkedSignalSetFn,\n linkedSignalUpdateFn,\n} from './src/linked_signal';\nexport {ValueEqualityFn, defaultEquals} from './src/equality';\nexport {setThrowInvalidWriteToSignalError} from './src/errors';\nexport {\n REACTIVE_NODE,\n Reactive,\n ReactiveHookFn,\n ReactiveNode,\n ReactiveNodeKind,\n SIGNAL,\n consumerAfterComputation,\n consumerBeforeComputation,\n consumerDestroy,\n consumerMarkDirty,\n consumerPollProducersForChange,\n finalizeConsumerAfterComputation,\n getActiveConsumer,\n isInNotificationPhase,\n isReactive,\n producerAccessed,\n producerIncrementEpoch,\n producerMarkClean,\n producerNotifyConsumers,\n producerUpdateValueVersion,\n producerUpdatesAllowed,\n resetConsumerBeforeComputation,\n runPostProducerCreatedFn,\n setActiveConsumer,\n setPostProducerCreatedFn,\n Version,\n} from './src/graph';\nexport {\n SIGNAL_NODE,\n SignalGetter,\n SignalNode,\n createSignal,\n runPostSignalSetFn,\n setPostSignalSetFn,\n signalGetFn,\n signalSetFn,\n signalUpdateFn,\n} from './src/signal';\nexport {Watch, WatchCleanupFn, WatchCleanupRegisterFn, createWatch} from './src/watch';\nexport {setAlternateWeakRefImpl} from './src/weak_ref';\nexport {untracked} from './src/untracked';\nexport {runEffect, BASE_EFFECT_NODE, BaseEffectNode} from './src/effect';\nexport {installDevToolsSignalFormatter} from './src/formatter';\n\n// Required as the signals library is in a separate package, so we need to explicitly ensure the\n// global `ngDevMode` type is defined.\ndeclare const ngDevMode: boolean | undefined;\n\n// We're using a top-level access to enable signal formatting whenever the signals package is loaded.\n// ngDevMode might not have been init correctly yet, checking for `undefined` ensures that in case\n// it is not defined yet, we still install the formatter.\nif (typeof ngDevMode === 'undefined' || ngDevMode) {\n // tslint:disable-next-line: no-toplevel-property-access\n installDevToolsSignalFormatter();\n}\n"],"names":["formatter","header","sig","config","isSignal","ngSkipFormatting","value","e","message","kind","SIGNAL","isPrimitive","Array","isArray","undefined","object","prettifyPreview","hasBody","body","color","style","length","Element","tagName","toLowerCase","URL","constructor","name","installDevToolsSignalFormatter","globalThis","devtoolsFormatters","some","f","push","createWatch","fn","schedule","allowSignalWrites","node","Object","create","WATCH_NODE","consumerAllowSignalWrites","registerOnCleanup","cleanupFn","isWatchNodeDestroyed","destroyWatchNode","consumerDestroy","NOOP_CLEANUP_FN","run","isInNotificationPhase","Error","ngDevMode","dirty","version","consumerPollProducersForChange","prevConsumer","consumerBeforeComputation","consumerAfterComputation","ref","notify","consumerMarkDirty","cleanup","destroy","REACTIVE_NODE","consumerIsAlwaysLive","consumerMarkedDirty"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v21.1.3
2
+ * @license Angular v21.2.0-next.1
3
3
  * (c) 2010-2026 Google LLC. https://angular.dev/
4
4
  * License: MIT
5
5
  */
@@ -1 +1 @@
1
- {"version":3,"file":"rxjs-interop.mjs","sources":["../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/take_until_destroyed.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/output_from_observable.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/output_to_observable.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/to_observable.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/to_signal.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/pending_until_event.ts","../../../../../darwin_arm64-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/rx_resource.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {assertInInjectionContext, DestroyRef, inject} from '../../src/core';\nimport {MonoTypeOperatorFunction, Observable} from 'rxjs';\nimport {takeUntil} from 'rxjs/operators';\n\n/**\n * Operator which completes the Observable when the calling context (component, directive, service,\n * etc) is destroyed.\n *\n * @param destroyRef optionally, the `DestroyRef` representing the current context. This can be\n * passed explicitly to use `takeUntilDestroyed` outside of an [injection\n * context](guide/di/dependency-injection-context). Otherwise, the current `DestroyRef` is injected.\n *\n * @see [Unsubscribing with takeUntilDestroyed](ecosystem/rxjs-interop/take-until-destroyed)\n *\n * @publicApi 19.0\n */\nexport function takeUntilDestroyed<T>(destroyRef?: DestroyRef): MonoTypeOperatorFunction<T> {\n if (!destroyRef) {\n ngDevMode && assertInInjectionContext(takeUntilDestroyed);\n destroyRef = inject(DestroyRef);\n }\n\n const destroyed$ = new Observable<void>((subscriber) => {\n if (destroyRef.destroyed) {\n subscriber.next();\n return;\n }\n const unregisterFn = destroyRef.onDestroy(subscriber.next.bind(subscriber));\n return unregisterFn;\n });\n\n return <T>(source: Observable<T>) => {\n return source.pipe(takeUntil(destroyed$));\n };\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n assertInInjectionContext,\n DestroyRef,\n inject,\n OutputOptions,\n OutputRef,\n OutputRefSubscription,\n ɵRuntimeError,\n ɵRuntimeErrorCode,\n} from '../../src/core';\nimport {Observable} from 'rxjs';\n\nimport {takeUntilDestroyed} from './take_until_destroyed';\n\n/**\n * Implementation of `OutputRef` that emits values from\n * an RxJS observable source.\n *\n * @internal\n */\nclass OutputFromObservableRef<T> implements OutputRef<T> {\n private destroyed = false;\n\n destroyRef = inject(DestroyRef);\n\n constructor(private source: Observable<T>) {\n this.destroyRef.onDestroy(() => {\n this.destroyed = true;\n });\n }\n\n subscribe(callbackFn: (value: T) => void): OutputRefSubscription {\n if (this.destroyed) {\n throw new ɵRuntimeError(\n ɵRuntimeErrorCode.OUTPUT_REF_DESTROYED,\n ngDevMode &&\n 'Unexpected subscription to destroyed `OutputRef`. ' +\n 'The owning directive/component is destroyed.',\n );\n }\n\n // Stop yielding more values when the directive/component is already destroyed.\n const subscription = this.source.pipe(takeUntilDestroyed(this.destroyRef)).subscribe({\n next: (value) => callbackFn(value),\n });\n\n return {\n unsubscribe: () => subscription.unsubscribe(),\n };\n }\n}\n\n/**\n * Declares an Angular output that is using an RxJS observable as a source\n * for events dispatched to parent subscribers.\n *\n * The behavior for an observable as source is defined as followed:\n * 1. New values are forwarded to the Angular output (next notifications).\n * 2. Errors notifications are not handled by Angular. You need to handle these manually.\n * For example by using `catchError`.\n * 3. Completion notifications stop the output from emitting new values.\n *\n * @usageNotes\n * Initialize an output in your directive by declaring a\n * class field and initializing it with the `outputFromObservable()` function.\n *\n * ```ts\n * @Directive({..})\n * export class MyDir {\n * nameChange$ = <some-observable>;\n * nameChange = outputFromObservable(this.nameChange$);\n * }\n * ```\n * @see [RxJS interop with component and directive outputs](ecosystem/rxjs-interop/output-interop)\n *\n * @publicApi 19.0\n */\nexport function outputFromObservable<T>(\n observable: Observable<T>,\n opts?: OutputOptions,\n): OutputRef<T> {\n ngDevMode && assertInInjectionContext(outputFromObservable);\n return new OutputFromObservableRef<T>(observable);\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {OutputRef, ɵgetOutputDestroyRef} from '../../src/core';\nimport {Observable} from 'rxjs';\n\n/**\n * Converts an Angular output declared via `output()` or `outputFromObservable()`\n * to an observable.\n * It creates an observable that represents the stream of \"events firing\" in an output.\n *\n * You can subscribe to the output via `Observable.subscribe` then.\n *\n * @see [RxJS interop with component and directive outputs](ecosystem/rxjs-interop/output-interop)\n *\n * @publicApi 19.0\n */\nexport function outputToObservable<T>(ref: OutputRef<T>): Observable<T> {\n const destroyRef = ɵgetOutputDestroyRef(ref);\n\n return new Observable<T>((observer) => {\n // Complete the observable upon directive/component destroy.\n // Note: May be `undefined` if an `EventEmitter` is declared outside\n // of an injection context.\n const unregisterOnDestroy = destroyRef?.onDestroy(() => observer.complete());\n\n const subscription = ref.subscribe((v) => observer.next(v));\n return () => {\n subscription.unsubscribe();\n unregisterOnDestroy?.();\n };\n });\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n assertInInjectionContext,\n DestroyRef,\n effect,\n inject,\n Injector,\n Signal,\n untracked,\n} from '../../src/core';\nimport {Observable, ReplaySubject} from 'rxjs';\n\n/**\n * Options for `toObservable`.\n *\n * @publicApi 20.0\n */\nexport interface ToObservableOptions {\n /**\n * The `Injector` to use when creating the underlying `effect` which watches the signal.\n *\n * If this isn't specified, the current [injection context](guide/di/dependency-injection-context)\n * will be used.\n */\n injector?: Injector;\n}\n\n/**\n * Exposes the value of an Angular `Signal` as an RxJS `Observable`.\n * As it reflects a state, the observable will always emit the latest value upon subscription.\n *\n * The signal's value will be propagated into the `Observable`'s subscribers using an `effect`.\n *\n * `toObservable` must be called in an injection context unless an injector is provided via options.\n *\n * @see [RxJS interop with Angular signals](ecosystem/rxjs-interop)\n * @see [Create an RxJS Observable from a signal with toObservable](ecosystem/rxjs-interop#create-an-rxjs-observable-from-a-signal-with-toobservable)\n *\n * @publicApi 20.0\n */\nexport function toObservable<T>(source: Signal<T>, options?: ToObservableOptions): Observable<T> {\n if (ngDevMode && !options?.injector) {\n assertInInjectionContext(toObservable);\n }\n const injector = options?.injector ?? inject(Injector);\n const subject = new ReplaySubject<T>(1);\n\n const watcher = effect(\n () => {\n let value: T;\n try {\n value = source();\n } catch (err) {\n untracked(() => subject.error(err));\n return;\n }\n untracked(() => subject.next(value));\n },\n {injector, manualCleanup: true},\n );\n\n injector.get(DestroyRef).onDestroy(() => {\n watcher.destroy();\n subject.complete();\n });\n\n return subject.asObservable();\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n assertInInjectionContext,\n assertNotInReactiveContext,\n computed,\n DestroyRef,\n inject,\n Injector,\n signal,\n Signal,\n WritableSignal,\n ɵRuntimeError,\n ɵRuntimeErrorCode,\n} from '../../src/core';\nimport {ValueEqualityFn} from '../../primitives/signals';\nimport {Observable, Subscribable} from 'rxjs';\n\n/**\n * Options for `toSignal`.\n *\n * @publicApi 20.0\n */\nexport interface ToSignalOptions<T> {\n /**\n * Initial value for the signal produced by `toSignal`.\n *\n * This will be the value of the signal until the observable emits its first value.\n */\n initialValue?: unknown;\n\n /**\n * Whether to require that the observable emits synchronously when `toSignal` subscribes.\n *\n * If this is `true`, `toSignal` will assert that the observable produces a value immediately upon\n * subscription. Setting this option removes the need to either deal with `undefined` in the\n * signal type or provide an `initialValue`, at the cost of a runtime error if this requirement is\n * not met.\n */\n requireSync?: boolean;\n\n /**\n * `Injector` which will provide the `DestroyRef` used to clean up the Observable subscription.\n *\n * If this is not provided, a `DestroyRef` will be retrieved from the current [injection\n * context](guide/di/dependency-injection-context), unless manual cleanup is requested.\n */\n injector?: Injector;\n\n /**\n * Whether the subscription should be automatically cleaned up (via `DestroyRef`) when\n * `toSignal`'s creation context is destroyed.\n *\n * If manual cleanup is enabled, then `DestroyRef` is not used, and the subscription will persist\n * until the `Observable` itself completes.\n */\n manualCleanup?: boolean;\n\n /**\n * A comparison function which defines equality for values emitted by the observable.\n *\n * Equality comparisons are executed against the initial value if one is provided.\n */\n equal?: ValueEqualityFn<T>;\n\n /**\n * A debug name for the signal. Used in Angular DevTools to identify the signal.\n */\n debugName?: string;\n}\n\n// Base case: no options -> `undefined` in the result type.\nexport function toSignal<T>(source: Observable<T> | Subscribable<T>): Signal<T | undefined>;\n// Options with `undefined` initial value and no `requiredSync` -> `undefined`.\nexport function toSignal<T>(\n source: Observable<T> | Subscribable<T>,\n options: NoInfer<ToSignalOptions<T | undefined>> & {\n initialValue?: undefined;\n requireSync?: false;\n },\n): Signal<T | undefined>;\n// Options with `null` initial value -> `null`.\nexport function toSignal<T>(\n source: Observable<T> | Subscribable<T>,\n options: NoInfer<ToSignalOptions<T | null>> & {initialValue?: null; requireSync?: false},\n): Signal<T | null>;\n// Options with `undefined` initial value and `requiredSync` -> strict result type.\nexport function toSignal<T>(\n source: Observable<T> | Subscribable<T>,\n options: NoInfer<ToSignalOptions<T>> & {initialValue?: undefined; requireSync: true},\n): Signal<T>;\n// Options with a more specific initial value type.\nexport function toSignal<T, const U extends T>(\n source: Observable<T> | Subscribable<T>,\n options: NoInfer<ToSignalOptions<T | U>> & {initialValue: U; requireSync?: false},\n): Signal<T | U>;\n\n/**\n * Get the current value of an `Observable` as a reactive `Signal`.\n *\n * `toSignal` returns a `Signal` which provides synchronous reactive access to values produced\n * by the given `Observable`, by subscribing to that `Observable`. The returned `Signal` will always\n * have the most recent value emitted by the subscription, and will throw an error if the\n * `Observable` errors.\n *\n * With `requireSync` set to `true`, `toSignal` will assert that the `Observable` produces a value\n * immediately upon subscription. No `initialValue` is needed in this case, and the returned signal\n * does not include an `undefined` type.\n *\n * By default, the subscription will be automatically cleaned up when the current [injection\n * context](guide/di/dependency-injection-context) is destroyed. For example, when `toSignal` is\n * called during the construction of a component, the subscription will be cleaned up when the\n * component is destroyed. If an injection context is not available, an explicit `Injector` can be\n * passed instead.\n *\n * If the subscription should persist until the `Observable` itself completes, the `manualCleanup`\n * option can be specified instead, which disables the automatic subscription teardown. No injection\n * context is needed in this configuration as well.\n *\n * @see [RxJS interop with Angular signals](ecosystem/rxjs-interop)\n */\nexport function toSignal<T, U = undefined>(\n source: Observable<T> | Subscribable<T>,\n options?: ToSignalOptions<T | U> & {initialValue?: U},\n): Signal<T | U> {\n typeof ngDevMode !== 'undefined' &&\n ngDevMode &&\n assertNotInReactiveContext(\n toSignal,\n 'Invoking `toSignal` causes new subscriptions every time. ' +\n 'Consider moving `toSignal` outside of the reactive context and read the signal value where needed.',\n );\n\n const requiresCleanup = !options?.manualCleanup;\n\n if (ngDevMode && requiresCleanup && !options?.injector) {\n assertInInjectionContext(toSignal);\n }\n\n const cleanupRef = requiresCleanup\n ? (options?.injector?.get(DestroyRef) ?? inject(DestroyRef))\n : null;\n\n const equal = makeToSignalEqual(options?.equal);\n\n // Note: T is the Observable value type, and U is the initial value type. They don't have to be\n // the same - the returned signal gives values of type `T`.\n let state: WritableSignal<State<T | U>>;\n if (options?.requireSync) {\n // Initially the signal is in a `NoValue` state.\n state = signal(\n {kind: StateKind.NoValue},\n {equal, ...(ngDevMode ? createDebugNameObject(options?.debugName, 'state') : undefined)},\n );\n } else {\n // If an initial value was passed, use it. Otherwise, use `undefined` as the initial value.\n state = signal<State<T | U>>(\n {kind: StateKind.Value, value: options?.initialValue as U},\n {equal, ...(ngDevMode ? createDebugNameObject(options?.debugName, 'state') : undefined)},\n );\n }\n\n let destroyUnregisterFn: (() => void) | undefined;\n\n // Note: This code cannot run inside a reactive context (see assertion above). If we'd support\n // this, we would subscribe to the observable outside of the current reactive context, avoiding\n // that side-effect signal reads/writes are attribute to the current consumer. The current\n // consumer only needs to be notified when the `state` signal changes through the observable\n // subscription. Additional context (related to async pipe):\n // https://github.com/angular/angular/pull/50522.\n const sub = source.subscribe({\n next: (value) => state.set({kind: StateKind.Value, value}),\n error: (error) => {\n state.set({kind: StateKind.Error, error});\n destroyUnregisterFn?.();\n },\n complete: () => {\n destroyUnregisterFn?.();\n },\n // Completion of the Observable is meaningless to the signal. Signals don't have a concept of\n // \"complete\".\n });\n\n if (options?.requireSync && state().kind === StateKind.NoValue) {\n throw new ɵRuntimeError(\n ɵRuntimeErrorCode.REQUIRE_SYNC_WITHOUT_SYNC_EMIT,\n (typeof ngDevMode === 'undefined' || ngDevMode) &&\n '`toSignal()` called with `requireSync` but `Observable` did not emit synchronously.',\n );\n }\n\n // Unsubscribe when the current context is destroyed, if requested.\n destroyUnregisterFn = cleanupRef?.onDestroy(sub.unsubscribe.bind(sub));\n\n // The actual returned signal is a `computed` of the `State` signal, which maps the various states\n // to either values or errors.\n return computed(\n () => {\n const current = state();\n switch (current.kind) {\n case StateKind.Value:\n return current.value;\n case StateKind.Error:\n throw current.error;\n case StateKind.NoValue:\n // This shouldn't really happen because the error is thrown on creation.\n throw new ɵRuntimeError(\n ɵRuntimeErrorCode.REQUIRE_SYNC_WITHOUT_SYNC_EMIT,\n (typeof ngDevMode === 'undefined' || ngDevMode) &&\n '`toSignal()` called with `requireSync` but `Observable` did not emit synchronously.',\n );\n }\n },\n {\n equal: options?.equal,\n ...(ngDevMode ? createDebugNameObject(options?.debugName, 'source') : undefined),\n },\n );\n}\n\nfunction makeToSignalEqual<T>(\n userEquality: ValueEqualityFn<T> = Object.is,\n): ValueEqualityFn<State<T>> {\n return (a, b) =>\n a.kind === StateKind.Value && b.kind === StateKind.Value && userEquality(a.value, b.value);\n}\n\n/**\n * Creates a debug name object for an internal toSignal signal.\n */\nfunction createDebugNameObject(\n toSignalDebugName: string | undefined,\n internalSignalDebugName: string,\n): {debugName?: string} {\n return {\n debugName: `toSignal${toSignalDebugName ? '#' + toSignalDebugName : ''}.${internalSignalDebugName}`,\n };\n}\n\nconst enum StateKind {\n NoValue,\n Value,\n Error,\n}\n\ninterface NoValueState {\n kind: StateKind.NoValue;\n}\n\ninterface ValueState<T> {\n kind: StateKind.Value;\n value: T;\n}\n\ninterface ErrorState {\n kind: StateKind.Error;\n error: unknown;\n}\n\ntype State<T> = NoValueState | ValueState<T> | ErrorState;\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {assertInInjectionContext, PendingTasks, inject, Injector} from '../../src/core';\nimport {MonoTypeOperatorFunction, Observable} from 'rxjs';\n\n/**\n * Operator which makes the application unstable until the observable emits, completes, errors, or is unsubscribed.\n *\n * Use this operator in observables whose subscriptions are important for rendering and should be included in SSR serialization.\n *\n * @param injector The `Injector` to use during creation. If this is not provided, the current injection context will be used instead (via `inject`).\n *\n * @developerPreview 20.0\n */\nexport function pendingUntilEvent<T>(injector?: Injector): MonoTypeOperatorFunction<T> {\n if (injector === undefined) {\n ngDevMode && assertInInjectionContext(pendingUntilEvent);\n injector = inject(Injector);\n }\n const taskService = injector.get(PendingTasks);\n\n return (sourceObservable) => {\n return new Observable<T>((originalSubscriber) => {\n // create a new task on subscription\n const removeTask = taskService.add();\n\n let cleanedUp = false;\n function cleanupTask() {\n if (cleanedUp) {\n return;\n }\n\n removeTask();\n cleanedUp = true;\n }\n\n const innerSubscription = sourceObservable.subscribe({\n next: (v) => {\n originalSubscriber.next(v);\n cleanupTask();\n },\n complete: () => {\n originalSubscriber.complete();\n cleanupTask();\n },\n error: (e) => {\n originalSubscriber.error(e);\n cleanupTask();\n },\n });\n innerSubscription.add(() => {\n originalSubscriber.unsubscribe();\n cleanupTask();\n });\n return innerSubscription;\n });\n };\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n assertInInjectionContext,\n resource,\n ResourceLoaderParams,\n ResourceRef,\n Signal,\n signal,\n BaseResourceOptions,\n ɵRuntimeError,\n ɵRuntimeErrorCode,\n ResourceStreamItem,\n} from '../../src/core';\nimport {Observable, Subscription} from 'rxjs';\nimport {encapsulateResourceError} from '../../src/resource/resource';\n\n/**\n * Like `ResourceOptions` but uses an RxJS-based `loader`.\n *\n * @experimental\n */\nexport interface RxResourceOptions<T, R> extends BaseResourceOptions<T, R> {\n stream: (params: ResourceLoaderParams<R>) => Observable<T>;\n}\n\n/**\n * Like `resource` but uses an RxJS based `loader` which maps the request to an `Observable` of the\n * resource's value.\n *\n * @see [Using rxResource for async data](ecosystem/rxjs-interop#using-rxresource-for-async-data)\n *\n * @experimental\n */\nexport function rxResource<T, R>(\n opts: RxResourceOptions<T, R> & {defaultValue: NoInfer<T>},\n): ResourceRef<T>;\n\n/**\n * Like `resource` but uses an RxJS based `loader` which maps the request to an `Observable` of the\n * resource's value.\n *\n * @experimental\n */\nexport function rxResource<T, R>(opts: RxResourceOptions<T, R>): ResourceRef<T | undefined>;\nexport function rxResource<T, R>(opts: RxResourceOptions<T, R>): ResourceRef<T | undefined> {\n if (ngDevMode && !opts?.injector) {\n assertInInjectionContext(rxResource);\n }\n return resource<T, R>({\n ...opts,\n loader: undefined,\n stream: (params) => {\n let sub: Subscription | undefined;\n\n // Track the abort listener so it can be removed if the Observable completes (as a memory\n // optimization).\n const onAbort = () => sub?.unsubscribe();\n params.abortSignal.addEventListener('abort', onAbort);\n\n // Start off stream as undefined.\n const stream = signal<ResourceStreamItem<T>>({value: undefined as T});\n let resolve: ((value: Signal<ResourceStreamItem<T>>) => void) | undefined;\n const promise = new Promise<Signal<ResourceStreamItem<T>>>((r) => (resolve = r));\n\n function send(value: ResourceStreamItem<T>): void {\n stream.set(value);\n resolve?.(stream);\n resolve = undefined;\n }\n\n // TODO(alxhub): remove after g3 updated to rename loader -> stream\n const streamFn = opts.stream ?? (opts as {loader?: RxResourceOptions<T, R>['stream']}).loader;\n if (streamFn === undefined) {\n throw new ɵRuntimeError(\n ɵRuntimeErrorCode.MUST_PROVIDE_STREAM_OPTION,\n ngDevMode && `Must provide \\`stream\\` option.`,\n );\n }\n\n sub = streamFn(params).subscribe({\n next: (value) => send({value}),\n error: (error: unknown) => {\n send({error: encapsulateResourceError(error)});\n params.abortSignal.removeEventListener('abort', onAbort);\n },\n complete: () => {\n if (resolve) {\n send({\n error: new ɵRuntimeError(\n ɵRuntimeErrorCode.RESOURCE_COMPLETED_BEFORE_PRODUCING_VALUE,\n ngDevMode && 'Resource completed before producing a value',\n ),\n });\n }\n params.abortSignal.removeEventListener('abort', onAbort);\n },\n });\n\n return promise;\n },\n });\n}\n"],"names":["takeUntilDestroyed","destroyRef","ngDevMode","assertInInjectionContext","inject","DestroyRef","destroyed$","Observable","subscriber","destroyed","next","unregisterFn","onDestroy","bind","source","pipe","takeUntil","OutputFromObservableRef","constructor","subscribe","callbackFn","ɵRuntimeError","subscription","value","unsubscribe","outputFromObservable","observable","opts","outputToObservable","ref","ɵgetOutputDestroyRef","observer","unregisterOnDestroy","complete","v","toObservable","options","injector","Injector","subject","ReplaySubject","watcher","effect","err","untracked","error","manualCleanup","get","destroy","asObservable","toSignal","assertNotInReactiveContext","requiresCleanup","cleanupRef","equal","makeToSignalEqual","state","requireSync","signal","kind","createDebugNameObject","debugName","undefined","initialValue","destroyUnregisterFn","sub","set","computed","current","userEquality","Object","is","a","b","toSignalDebugName","internalSignalDebugName","pendingUntilEvent","taskService","PendingTasks","sourceObservable","originalSubscriber","removeTask","add","cleanedUp","cleanupTask","innerSubscription","e","rxResource","resource","loader","stream","params","onAbort","abortSignal","addEventListener","resolve","promise","Promise","r","send","streamFn","encapsulateResourceError","removeEventListener"],"mappings":"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"}
1
+ {"version":3,"file":"rxjs-interop.mjs","sources":["../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/take_until_destroyed.ts","../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/output_from_observable.ts","../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/output_to_observable.ts","../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/to_observable.ts","../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/to_signal.ts","../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/pending_until_event.ts","../../../../../k8-fastbuild-ST-fdfa778d11ba/bin/packages/core/rxjs-interop/src/rx_resource.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {assertInInjectionContext, DestroyRef, inject} from '../../src/core';\nimport {MonoTypeOperatorFunction, Observable} from 'rxjs';\nimport {takeUntil} from 'rxjs/operators';\n\n/**\n * Operator which completes the Observable when the calling context (component, directive, service,\n * etc) is destroyed.\n *\n * @param destroyRef optionally, the `DestroyRef` representing the current context. This can be\n * passed explicitly to use `takeUntilDestroyed` outside of an [injection\n * context](guide/di/dependency-injection-context). Otherwise, the current `DestroyRef` is injected.\n *\n * @see [Unsubscribing with takeUntilDestroyed](ecosystem/rxjs-interop/take-until-destroyed)\n *\n * @publicApi 19.0\n */\nexport function takeUntilDestroyed<T>(destroyRef?: DestroyRef): MonoTypeOperatorFunction<T> {\n if (!destroyRef) {\n ngDevMode && assertInInjectionContext(takeUntilDestroyed);\n destroyRef = inject(DestroyRef);\n }\n\n const destroyed$ = new Observable<void>((subscriber) => {\n if (destroyRef.destroyed) {\n subscriber.next();\n return;\n }\n const unregisterFn = destroyRef.onDestroy(subscriber.next.bind(subscriber));\n return unregisterFn;\n });\n\n return <T>(source: Observable<T>) => {\n return source.pipe(takeUntil(destroyed$));\n };\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n assertInInjectionContext,\n DestroyRef,\n inject,\n OutputOptions,\n OutputRef,\n OutputRefSubscription,\n ɵRuntimeError,\n ɵRuntimeErrorCode,\n} from '../../src/core';\nimport {Observable} from 'rxjs';\n\nimport {takeUntilDestroyed} from './take_until_destroyed';\n\n/**\n * Implementation of `OutputRef` that emits values from\n * an RxJS observable source.\n *\n * @internal\n */\nclass OutputFromObservableRef<T> implements OutputRef<T> {\n private destroyed = false;\n\n destroyRef = inject(DestroyRef);\n\n constructor(private source: Observable<T>) {\n this.destroyRef.onDestroy(() => {\n this.destroyed = true;\n });\n }\n\n subscribe(callbackFn: (value: T) => void): OutputRefSubscription {\n if (this.destroyed) {\n throw new ɵRuntimeError(\n ɵRuntimeErrorCode.OUTPUT_REF_DESTROYED,\n ngDevMode &&\n 'Unexpected subscription to destroyed `OutputRef`. ' +\n 'The owning directive/component is destroyed.',\n );\n }\n\n // Stop yielding more values when the directive/component is already destroyed.\n const subscription = this.source.pipe(takeUntilDestroyed(this.destroyRef)).subscribe({\n next: (value) => callbackFn(value),\n });\n\n return {\n unsubscribe: () => subscription.unsubscribe(),\n };\n }\n}\n\n/**\n * Declares an Angular output that is using an RxJS observable as a source\n * for events dispatched to parent subscribers.\n *\n * The behavior for an observable as source is defined as followed:\n * 1. New values are forwarded to the Angular output (next notifications).\n * 2. Errors notifications are not handled by Angular. You need to handle these manually.\n * For example by using `catchError`.\n * 3. Completion notifications stop the output from emitting new values.\n *\n * @usageNotes\n * Initialize an output in your directive by declaring a\n * class field and initializing it with the `outputFromObservable()` function.\n *\n * ```ts\n * @Directive({..})\n * export class MyDir {\n * nameChange$ = <some-observable>;\n * nameChange = outputFromObservable(this.nameChange$);\n * }\n * ```\n * @see [RxJS interop with component and directive outputs](ecosystem/rxjs-interop/output-interop)\n *\n * @publicApi 19.0\n */\nexport function outputFromObservable<T>(\n observable: Observable<T>,\n opts?: OutputOptions,\n): OutputRef<T> {\n ngDevMode && assertInInjectionContext(outputFromObservable);\n return new OutputFromObservableRef<T>(observable);\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {OutputRef, ɵgetOutputDestroyRef} from '../../src/core';\nimport {Observable} from 'rxjs';\n\n/**\n * Converts an Angular output declared via `output()` or `outputFromObservable()`\n * to an observable.\n * It creates an observable that represents the stream of \"events firing\" in an output.\n *\n * You can subscribe to the output via `Observable.subscribe` then.\n *\n * @see [RxJS interop with component and directive outputs](ecosystem/rxjs-interop/output-interop)\n *\n * @publicApi 19.0\n */\nexport function outputToObservable<T>(ref: OutputRef<T>): Observable<T> {\n const destroyRef = ɵgetOutputDestroyRef(ref);\n\n return new Observable<T>((observer) => {\n // Complete the observable upon directive/component destroy.\n // Note: May be `undefined` if an `EventEmitter` is declared outside\n // of an injection context.\n const unregisterOnDestroy = destroyRef?.onDestroy(() => observer.complete());\n\n const subscription = ref.subscribe((v) => observer.next(v));\n return () => {\n subscription.unsubscribe();\n unregisterOnDestroy?.();\n };\n });\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n assertInInjectionContext,\n DestroyRef,\n effect,\n inject,\n Injector,\n Signal,\n untracked,\n} from '../../src/core';\nimport {Observable, ReplaySubject} from 'rxjs';\n\n/**\n * Options for `toObservable`.\n *\n * @publicApi 20.0\n */\nexport interface ToObservableOptions {\n /**\n * The `Injector` to use when creating the underlying `effect` which watches the signal.\n *\n * If this isn't specified, the current [injection context](guide/di/dependency-injection-context)\n * will be used.\n */\n injector?: Injector;\n}\n\n/**\n * Exposes the value of an Angular `Signal` as an RxJS `Observable`.\n * As it reflects a state, the observable will always emit the latest value upon subscription.\n *\n * The signal's value will be propagated into the `Observable`'s subscribers using an `effect`.\n *\n * `toObservable` must be called in an injection context unless an injector is provided via options.\n *\n * @see [RxJS interop with Angular signals](ecosystem/rxjs-interop)\n * @see [Create an RxJS Observable from a signal with toObservable](ecosystem/rxjs-interop#create-an-rxjs-observable-from-a-signal-with-toobservable)\n *\n * @publicApi 20.0\n */\nexport function toObservable<T>(source: Signal<T>, options?: ToObservableOptions): Observable<T> {\n if (ngDevMode && !options?.injector) {\n assertInInjectionContext(toObservable);\n }\n const injector = options?.injector ?? inject(Injector);\n const subject = new ReplaySubject<T>(1);\n\n const watcher = effect(\n () => {\n let value: T;\n try {\n value = source();\n } catch (err) {\n untracked(() => subject.error(err));\n return;\n }\n untracked(() => subject.next(value));\n },\n {injector, manualCleanup: true},\n );\n\n injector.get(DestroyRef).onDestroy(() => {\n watcher.destroy();\n subject.complete();\n });\n\n return subject.asObservable();\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n assertInInjectionContext,\n assertNotInReactiveContext,\n computed,\n DestroyRef,\n inject,\n Injector,\n signal,\n Signal,\n WritableSignal,\n ɵRuntimeError,\n ɵRuntimeErrorCode,\n} from '../../src/core';\nimport {ValueEqualityFn} from '../../primitives/signals';\nimport {Observable, Subscribable} from 'rxjs';\n\n/**\n * Options for `toSignal`.\n *\n * @publicApi 20.0\n */\nexport interface ToSignalOptions<T> {\n /**\n * Initial value for the signal produced by `toSignal`.\n *\n * This will be the value of the signal until the observable emits its first value.\n */\n initialValue?: unknown;\n\n /**\n * Whether to require that the observable emits synchronously when `toSignal` subscribes.\n *\n * If this is `true`, `toSignal` will assert that the observable produces a value immediately upon\n * subscription. Setting this option removes the need to either deal with `undefined` in the\n * signal type or provide an `initialValue`, at the cost of a runtime error if this requirement is\n * not met.\n */\n requireSync?: boolean;\n\n /**\n * `Injector` which will provide the `DestroyRef` used to clean up the Observable subscription.\n *\n * If this is not provided, a `DestroyRef` will be retrieved from the current [injection\n * context](guide/di/dependency-injection-context), unless manual cleanup is requested.\n */\n injector?: Injector;\n\n /**\n * Whether the subscription should be automatically cleaned up (via `DestroyRef`) when\n * `toSignal`'s creation context is destroyed.\n *\n * If manual cleanup is enabled, then `DestroyRef` is not used, and the subscription will persist\n * until the `Observable` itself completes.\n */\n manualCleanup?: boolean;\n\n /**\n * A comparison function which defines equality for values emitted by the observable.\n *\n * Equality comparisons are executed against the initial value if one is provided.\n */\n equal?: ValueEqualityFn<T>;\n\n /**\n * A debug name for the signal. Used in Angular DevTools to identify the signal.\n */\n debugName?: string;\n}\n\n// Base case: no options -> `undefined` in the result type.\nexport function toSignal<T>(source: Observable<T> | Subscribable<T>): Signal<T | undefined>;\n// Options with `undefined` initial value and no `requiredSync` -> `undefined`.\nexport function toSignal<T>(\n source: Observable<T> | Subscribable<T>,\n options: NoInfer<ToSignalOptions<T | undefined>> & {\n initialValue?: undefined;\n requireSync?: false;\n },\n): Signal<T | undefined>;\n// Options with `null` initial value -> `null`.\nexport function toSignal<T>(\n source: Observable<T> | Subscribable<T>,\n options: NoInfer<ToSignalOptions<T | null>> & {initialValue?: null; requireSync?: false},\n): Signal<T | null>;\n// Options with `undefined` initial value and `requiredSync` -> strict result type.\nexport function toSignal<T>(\n source: Observable<T> | Subscribable<T>,\n options: NoInfer<ToSignalOptions<T>> & {initialValue?: undefined; requireSync: true},\n): Signal<T>;\n// Options with a more specific initial value type.\nexport function toSignal<T, const U extends T>(\n source: Observable<T> | Subscribable<T>,\n options: NoInfer<ToSignalOptions<T | U>> & {initialValue: U; requireSync?: false},\n): Signal<T | U>;\n\n/**\n * Get the current value of an `Observable` as a reactive `Signal`.\n *\n * `toSignal` returns a `Signal` which provides synchronous reactive access to values produced\n * by the given `Observable`, by subscribing to that `Observable`. The returned `Signal` will always\n * have the most recent value emitted by the subscription, and will throw an error if the\n * `Observable` errors.\n *\n * With `requireSync` set to `true`, `toSignal` will assert that the `Observable` produces a value\n * immediately upon subscription. No `initialValue` is needed in this case, and the returned signal\n * does not include an `undefined` type.\n *\n * By default, the subscription will be automatically cleaned up when the current [injection\n * context](guide/di/dependency-injection-context) is destroyed. For example, when `toSignal` is\n * called during the construction of a component, the subscription will be cleaned up when the\n * component is destroyed. If an injection context is not available, an explicit `Injector` can be\n * passed instead.\n *\n * If the subscription should persist until the `Observable` itself completes, the `manualCleanup`\n * option can be specified instead, which disables the automatic subscription teardown. No injection\n * context is needed in this configuration as well.\n *\n * @see [RxJS interop with Angular signals](ecosystem/rxjs-interop)\n */\nexport function toSignal<T, U = undefined>(\n source: Observable<T> | Subscribable<T>,\n options?: ToSignalOptions<T | U> & {initialValue?: U},\n): Signal<T | U> {\n typeof ngDevMode !== 'undefined' &&\n ngDevMode &&\n assertNotInReactiveContext(\n toSignal,\n 'Invoking `toSignal` causes new subscriptions every time. ' +\n 'Consider moving `toSignal` outside of the reactive context and read the signal value where needed.',\n );\n\n const requiresCleanup = !options?.manualCleanup;\n\n if (ngDevMode && requiresCleanup && !options?.injector) {\n assertInInjectionContext(toSignal);\n }\n\n const cleanupRef = requiresCleanup\n ? (options?.injector?.get(DestroyRef) ?? inject(DestroyRef))\n : null;\n\n const equal = makeToSignalEqual(options?.equal);\n\n // Note: T is the Observable value type, and U is the initial value type. They don't have to be\n // the same - the returned signal gives values of type `T`.\n let state: WritableSignal<State<T | U>>;\n if (options?.requireSync) {\n // Initially the signal is in a `NoValue` state.\n state = signal(\n {kind: StateKind.NoValue},\n {equal, ...(ngDevMode ? createDebugNameObject(options?.debugName, 'state') : undefined)},\n );\n } else {\n // If an initial value was passed, use it. Otherwise, use `undefined` as the initial value.\n state = signal<State<T | U>>(\n {kind: StateKind.Value, value: options?.initialValue as U},\n {equal, ...(ngDevMode ? createDebugNameObject(options?.debugName, 'state') : undefined)},\n );\n }\n\n let destroyUnregisterFn: (() => void) | undefined;\n\n // Note: This code cannot run inside a reactive context (see assertion above). If we'd support\n // this, we would subscribe to the observable outside of the current reactive context, avoiding\n // that side-effect signal reads/writes are attribute to the current consumer. The current\n // consumer only needs to be notified when the `state` signal changes through the observable\n // subscription. Additional context (related to async pipe):\n // https://github.com/angular/angular/pull/50522.\n const sub = source.subscribe({\n next: (value) => state.set({kind: StateKind.Value, value}),\n error: (error) => {\n state.set({kind: StateKind.Error, error});\n destroyUnregisterFn?.();\n },\n complete: () => {\n destroyUnregisterFn?.();\n },\n // Completion of the Observable is meaningless to the signal. Signals don't have a concept of\n // \"complete\".\n });\n\n if (options?.requireSync && state().kind === StateKind.NoValue) {\n throw new ɵRuntimeError(\n ɵRuntimeErrorCode.REQUIRE_SYNC_WITHOUT_SYNC_EMIT,\n (typeof ngDevMode === 'undefined' || ngDevMode) &&\n '`toSignal()` called with `requireSync` but `Observable` did not emit synchronously.',\n );\n }\n\n // Unsubscribe when the current context is destroyed, if requested.\n destroyUnregisterFn = cleanupRef?.onDestroy(sub.unsubscribe.bind(sub));\n\n // The actual returned signal is a `computed` of the `State` signal, which maps the various states\n // to either values or errors.\n return computed(\n () => {\n const current = state();\n switch (current.kind) {\n case StateKind.Value:\n return current.value;\n case StateKind.Error:\n throw current.error;\n case StateKind.NoValue:\n // This shouldn't really happen because the error is thrown on creation.\n throw new ɵRuntimeError(\n ɵRuntimeErrorCode.REQUIRE_SYNC_WITHOUT_SYNC_EMIT,\n (typeof ngDevMode === 'undefined' || ngDevMode) &&\n '`toSignal()` called with `requireSync` but `Observable` did not emit synchronously.',\n );\n }\n },\n {\n equal: options?.equal,\n ...(ngDevMode ? createDebugNameObject(options?.debugName, 'source') : undefined),\n },\n );\n}\n\nfunction makeToSignalEqual<T>(\n userEquality: ValueEqualityFn<T> = Object.is,\n): ValueEqualityFn<State<T>> {\n return (a, b) =>\n a.kind === StateKind.Value && b.kind === StateKind.Value && userEquality(a.value, b.value);\n}\n\n/**\n * Creates a debug name object for an internal toSignal signal.\n */\nfunction createDebugNameObject(\n toSignalDebugName: string | undefined,\n internalSignalDebugName: string,\n): {debugName?: string} {\n return {\n debugName: `toSignal${toSignalDebugName ? '#' + toSignalDebugName : ''}.${internalSignalDebugName}`,\n };\n}\n\nconst enum StateKind {\n NoValue,\n Value,\n Error,\n}\n\ninterface NoValueState {\n kind: StateKind.NoValue;\n}\n\ninterface ValueState<T> {\n kind: StateKind.Value;\n value: T;\n}\n\ninterface ErrorState {\n kind: StateKind.Error;\n error: unknown;\n}\n\ntype State<T> = NoValueState | ValueState<T> | ErrorState;\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {assertInInjectionContext, PendingTasks, inject, Injector} from '../../src/core';\nimport {MonoTypeOperatorFunction, Observable} from 'rxjs';\n\n/**\n * Operator which makes the application unstable until the observable emits, completes, errors, or is unsubscribed.\n *\n * Use this operator in observables whose subscriptions are important for rendering and should be included in SSR serialization.\n *\n * @param injector The `Injector` to use during creation. If this is not provided, the current injection context will be used instead (via `inject`).\n *\n * @developerPreview 20.0\n */\nexport function pendingUntilEvent<T>(injector?: Injector): MonoTypeOperatorFunction<T> {\n if (injector === undefined) {\n ngDevMode && assertInInjectionContext(pendingUntilEvent);\n injector = inject(Injector);\n }\n const taskService = injector.get(PendingTasks);\n\n return (sourceObservable) => {\n return new Observable<T>((originalSubscriber) => {\n // create a new task on subscription\n const removeTask = taskService.add();\n\n let cleanedUp = false;\n function cleanupTask() {\n if (cleanedUp) {\n return;\n }\n\n removeTask();\n cleanedUp = true;\n }\n\n const innerSubscription = sourceObservable.subscribe({\n next: (v) => {\n originalSubscriber.next(v);\n cleanupTask();\n },\n complete: () => {\n originalSubscriber.complete();\n cleanupTask();\n },\n error: (e) => {\n originalSubscriber.error(e);\n cleanupTask();\n },\n });\n innerSubscription.add(() => {\n originalSubscriber.unsubscribe();\n cleanupTask();\n });\n return innerSubscription;\n });\n };\n}\n","/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.dev/license\n */\n\nimport {\n assertInInjectionContext,\n resource,\n ResourceLoaderParams,\n ResourceRef,\n Signal,\n signal,\n BaseResourceOptions,\n ɵRuntimeError,\n ɵRuntimeErrorCode,\n ResourceStreamItem,\n} from '../../src/core';\nimport {Observable, Subscription} from 'rxjs';\nimport {encapsulateResourceError} from '../../src/resource/resource';\n\n/**\n * Like `ResourceOptions` but uses an RxJS-based `loader`.\n *\n * @experimental\n */\nexport interface RxResourceOptions<T, R> extends BaseResourceOptions<T, R> {\n stream: (params: ResourceLoaderParams<R>) => Observable<T>;\n}\n\n/**\n * Like `resource` but uses an RxJS based `loader` which maps the request to an `Observable` of the\n * resource's value.\n *\n * @see [Using rxResource for async data](ecosystem/rxjs-interop#using-rxresource-for-async-data)\n *\n * @experimental\n */\nexport function rxResource<T, R>(\n opts: RxResourceOptions<T, R> & {defaultValue: NoInfer<T>},\n): ResourceRef<T>;\n\n/**\n * Like `resource` but uses an RxJS based `loader` which maps the request to an `Observable` of the\n * resource's value.\n *\n * @experimental\n */\nexport function rxResource<T, R>(opts: RxResourceOptions<T, R>): ResourceRef<T | undefined>;\nexport function rxResource<T, R>(opts: RxResourceOptions<T, R>): ResourceRef<T | undefined> {\n if (ngDevMode && !opts?.injector) {\n assertInInjectionContext(rxResource);\n }\n return resource<T, R>({\n ...opts,\n loader: undefined,\n stream: (params) => {\n let sub: Subscription | undefined;\n\n // Track the abort listener so it can be removed if the Observable completes (as a memory\n // optimization).\n const onAbort = () => sub?.unsubscribe();\n params.abortSignal.addEventListener('abort', onAbort);\n\n // Start off stream as undefined.\n const stream = signal<ResourceStreamItem<T>>({value: undefined as T});\n let resolve: ((value: Signal<ResourceStreamItem<T>>) => void) | undefined;\n const promise = new Promise<Signal<ResourceStreamItem<T>>>((r) => (resolve = r));\n\n function send(value: ResourceStreamItem<T>): void {\n stream.set(value);\n resolve?.(stream);\n resolve = undefined;\n }\n\n // TODO(alxhub): remove after g3 updated to rename loader -> stream\n const streamFn = opts.stream ?? (opts as {loader?: RxResourceOptions<T, R>['stream']}).loader;\n if (streamFn === undefined) {\n throw new ɵRuntimeError(\n ɵRuntimeErrorCode.MUST_PROVIDE_STREAM_OPTION,\n ngDevMode && `Must provide \\`stream\\` option.`,\n );\n }\n\n sub = streamFn(params).subscribe({\n next: (value) => send({value}),\n error: (error: unknown) => {\n send({error: encapsulateResourceError(error)});\n params.abortSignal.removeEventListener('abort', onAbort);\n },\n complete: () => {\n if (resolve) {\n send({\n error: new ɵRuntimeError(\n ɵRuntimeErrorCode.RESOURCE_COMPLETED_BEFORE_PRODUCING_VALUE,\n ngDevMode && 'Resource completed before producing a value',\n ),\n });\n }\n params.abortSignal.removeEventListener('abort', onAbort);\n },\n });\n\n return promise;\n },\n });\n}\n"],"names":["takeUntilDestroyed","destroyRef","ngDevMode","assertInInjectionContext","inject","DestroyRef","destroyed$","Observable","subscriber","destroyed","next","unregisterFn","onDestroy","bind","source","pipe","takeUntil","OutputFromObservableRef","constructor","subscribe","callbackFn","ɵRuntimeError","subscription","value","unsubscribe","outputFromObservable","observable","opts","outputToObservable","ref","ɵgetOutputDestroyRef","observer","unregisterOnDestroy","complete","v","toObservable","options","injector","Injector","subject","ReplaySubject","watcher","effect","err","untracked","error","manualCleanup","get","destroy","asObservable","toSignal","assertNotInReactiveContext","requiresCleanup","cleanupRef","equal","makeToSignalEqual","state","requireSync","signal","kind","createDebugNameObject","debugName","undefined","initialValue","destroyUnregisterFn","sub","set","computed","current","userEquality","Object","is","a","b","toSignalDebugName","internalSignalDebugName","pendingUntilEvent","taskService","PendingTasks","sourceObservable","originalSubscriber","removeTask","add","cleanedUp","cleanupTask","innerSubscription","e","rxResource","resource","loader","stream","params","onAbort","abortSignal","addEventListener","resolve","promise","Promise","r","send","streamFn","encapsulateResourceError","removeEventListener"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v21.1.3
2
+ * @license Angular v21.2.0-next.1
3
3
  * (c) 2010-2026 Google LLC. https://angular.dev/
4
4
  * License: MIT
5
5
  */