@angular/core 18.1.0-next.0 → 18.1.0-next.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/primitives/event-dispatch/index.mjs +2 -1
- package/esm2022/primitives/event-dispatch/src/dispatcher.mjs +4 -3
- package/esm2022/primitives/event-dispatch/src/event_dispatcher.mjs +4 -6
- package/esm2022/primitives/event-dispatch/src/event_type.mjs +2 -2
- package/esm2022/primitives/signals/src/graph.mjs +6 -5
- package/esm2022/src/change_detection/scheduling/ng_zone_scheduling.mjs +2 -4
- package/esm2022/src/core.mjs +1 -1
- package/esm2022/src/core_private_export.mjs +2 -2
- package/esm2022/src/event_delegation_utils.mjs +68 -0
- package/esm2022/src/event_emitter.mjs +20 -11
- package/esm2022/src/hydration/annotate.mjs +18 -7
- package/esm2022/src/hydration/api.mjs +2 -2
- package/esm2022/src/hydration/event_replay.mjs +46 -69
- package/esm2022/src/hydration/tokens.mjs +6 -1
- package/esm2022/src/pending_tasks.mjs +15 -20
- package/esm2022/src/render3/after_render_hooks.mjs +67 -132
- package/esm2022/src/render3/component_ref.mjs +1 -1
- package/esm2022/src/render3/instructions/change_detection.mjs +27 -24
- package/esm2022/src/render3/instructions/listener.mjs +5 -5
- package/esm2022/src/render3/instructions/shared.mjs +3 -3
- package/esm2022/src/render3/reactive_lview_consumer.mjs +56 -3
- package/esm2022/src/version.mjs +1 -1
- package/esm2022/testing/src/logger.mjs +3 -3
- package/fesm2022/core.mjs +474 -432
- package/fesm2022/core.mjs.map +1 -1
- package/fesm2022/primitives/event-dispatch.mjs +9 -10
- package/fesm2022/primitives/event-dispatch.mjs.map +1 -1
- package/fesm2022/primitives/signals.mjs +6 -5
- package/fesm2022/primitives/signals.mjs.map +1 -1
- package/fesm2022/rxjs-interop.mjs +1 -1
- package/fesm2022/testing.mjs +1 -1
- package/index.d.ts +218 -28
- package/package.json +2 -2
- package/primitives/event-dispatch/index.d.ts +66 -1
- package/primitives/signals/index.d.ts +1 -1
- package/rxjs-interop/index.d.ts +1 -1
- package/schematics/migrations/after-render-phase/bundle.js +602 -0
- package/schematics/migrations/after-render-phase/bundle.js.map +7 -0
- package/schematics/migrations/http-providers/bundle.js +10 -2
- package/schematics/migrations/http-providers/bundle.js.map +2 -2
- package/schematics/migrations/invalid-two-way-bindings/bundle.js +177 -8
- package/schematics/migrations/invalid-two-way-bindings/bundle.js.map +3 -3
- package/schematics/migrations.json +5 -0
- package/schematics/ng-generate/control-flow-migration/bundle.js +192 -16
- package/schematics/ng-generate/control-flow-migration/bundle.js.map +3 -3
- package/schematics/ng-generate/standalone-migration/bundle.js +9197 -9490
- package/schematics/ng-generate/standalone-migration/bundle.js.map +4 -4
- package/testing/index.d.ts +1 -1
|
@@ -5,13 +5,13 @@
|
|
|
5
5
|
* Use of this source code is governed by an MIT-style license that can be
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
|
-
import { consumerAfterComputation, consumerBeforeComputation, consumerPollProducersForChange, } from '@angular/core/primitives/signals';
|
|
8
|
+
import { consumerAfterComputation, consumerBeforeComputation, consumerDestroy, consumerPollProducersForChange, getActiveConsumer, } from '@angular/core/primitives/signals';
|
|
9
9
|
import { RuntimeError } from '../../errors';
|
|
10
10
|
import { assertDefined, assertEqual } from '../../util/assert';
|
|
11
11
|
import { executeCheckHooks, executeInitAndCheckHooks, incrementInitPhaseFlags } from '../hooks';
|
|
12
12
|
import { CONTAINER_HEADER_OFFSET, LContainerFlags, MOVED_VIEWS } from '../interfaces/container';
|
|
13
13
|
import { CONTEXT, EFFECTS_TO_SCHEDULE, ENVIRONMENT, FLAGS, REACTIVE_TEMPLATE_CONSUMER, TVIEW, } from '../interfaces/view';
|
|
14
|
-
import { getOrBorrowReactiveLViewConsumer, maybeReturnReactiveLViewConsumer, } from '../reactive_lview_consumer';
|
|
14
|
+
import { getOrCreateTemporaryConsumer, getOrBorrowReactiveLViewConsumer, maybeReturnReactiveLViewConsumer, viewShouldHaveReactiveConsumer, } from '../reactive_lview_consumer';
|
|
15
15
|
import { CheckNoChangesMode, enterView, isExhaustiveCheckNoChanges, isInCheckNoChangesMode, isRefreshingViews, leaveView, setBindingIndex, setIsInCheckNoChangesMode, setIsRefreshingViews, } from '../state';
|
|
16
16
|
import { getFirstLContainer, getNextLContainer } from '../util/view_traversal_utils';
|
|
17
17
|
import { getComponentLViewByIndex, isCreationMode, markAncestorsForTraversal, markViewForRefresh, requiresRefreshOrTraversal, resetPreOrderHookFlags, viewAttachedToChangeDetector, } from '../util/view_utils';
|
|
@@ -113,11 +113,29 @@ export function refreshView(tView, lView, templateFn, context) {
|
|
|
113
113
|
// - We might already be in a reactive context if this is an embedded view of the host.
|
|
114
114
|
// - We might be descending into a view that needs a consumer.
|
|
115
115
|
enterView(lView);
|
|
116
|
+
let returnConsumerToPool = true;
|
|
116
117
|
let prevConsumer = null;
|
|
117
118
|
let currentConsumer = null;
|
|
118
|
-
if (!isInCheckNoChangesPass
|
|
119
|
-
|
|
120
|
-
|
|
119
|
+
if (!isInCheckNoChangesPass) {
|
|
120
|
+
if (viewShouldHaveReactiveConsumer(tView)) {
|
|
121
|
+
currentConsumer = getOrBorrowReactiveLViewConsumer(lView);
|
|
122
|
+
prevConsumer = consumerBeforeComputation(currentConsumer);
|
|
123
|
+
}
|
|
124
|
+
else if (getActiveConsumer() === null) {
|
|
125
|
+
// If the current view should not have a reactive consumer but we don't have an active consumer,
|
|
126
|
+
// we still need to create a temporary consumer to track any signal reads in this template.
|
|
127
|
+
// This is a rare case that can happen with `viewContainerRef.createEmbeddedView(...).detectChanges()`.
|
|
128
|
+
// This temporary consumer marks the first parent that _should_ have a consumer for refresh.
|
|
129
|
+
// Once that refresh happens, the signals will be tracked in the parent consumer and we can destroy
|
|
130
|
+
// the temporary one.
|
|
131
|
+
returnConsumerToPool = false;
|
|
132
|
+
currentConsumer = getOrCreateTemporaryConsumer(lView);
|
|
133
|
+
prevConsumer = consumerBeforeComputation(currentConsumer);
|
|
134
|
+
}
|
|
135
|
+
else if (lView[REACTIVE_TEMPLATE_CONSUMER]) {
|
|
136
|
+
consumerDestroy(lView[REACTIVE_TEMPLATE_CONSUMER]);
|
|
137
|
+
lView[REACTIVE_TEMPLATE_CONSUMER] = null;
|
|
138
|
+
}
|
|
121
139
|
}
|
|
122
140
|
try {
|
|
123
141
|
resetPreOrderHookFlags(lView);
|
|
@@ -243,28 +261,13 @@ export function refreshView(tView, lView, templateFn, context) {
|
|
|
243
261
|
finally {
|
|
244
262
|
if (currentConsumer !== null) {
|
|
245
263
|
consumerAfterComputation(currentConsumer, prevConsumer);
|
|
246
|
-
|
|
264
|
+
if (returnConsumerToPool) {
|
|
265
|
+
maybeReturnReactiveLViewConsumer(currentConsumer);
|
|
266
|
+
}
|
|
247
267
|
}
|
|
248
268
|
leaveView();
|
|
249
269
|
}
|
|
250
270
|
}
|
|
251
|
-
/**
|
|
252
|
-
* Indicates if the view should get its own reactive consumer node.
|
|
253
|
-
*
|
|
254
|
-
* In the current design, all embedded views share a consumer with the component view. This allows
|
|
255
|
-
* us to refresh at the component level rather than at a per-view level. In addition, root views get
|
|
256
|
-
* their own reactive node because root component will have a host view that executes the
|
|
257
|
-
* component's host bindings. This needs to be tracked in a consumer as well.
|
|
258
|
-
*
|
|
259
|
-
* To get a more granular change detection than per-component, all we would just need to update the
|
|
260
|
-
* condition here so that a given view gets a reactive consumer which can become dirty independently
|
|
261
|
-
* from its parent component. For example embedded views for signal components could be created with
|
|
262
|
-
* a new type "SignalEmbeddedView" and the condition here wouldn't even need updating in order to
|
|
263
|
-
* get granular per-view change detection for signal components.
|
|
264
|
-
*/
|
|
265
|
-
function viewShouldHaveReactiveConsumer(tView) {
|
|
266
|
-
return tView.type !== 2 /* TViewType.Embedded */;
|
|
267
|
-
}
|
|
268
271
|
/**
|
|
269
272
|
* Goes over embedded views (ones created through ViewContainerRef APIs) and refreshes
|
|
270
273
|
* them by executing an associated template function.
|
|
@@ -370,4 +373,4 @@ function detectChangesInChildComponents(hostLView, components, mode) {
|
|
|
370
373
|
detectChangesInComponent(hostLView, components[i], mode);
|
|
371
374
|
}
|
|
372
375
|
}
|
|
373
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"change_detection.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/change_detection.ts"],"names":[],"mappings":"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","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.io/license\n */\n\nimport {\n  consumerAfterComputation,\n  consumerBeforeComputation,\n  consumerPollProducersForChange,\n  ReactiveNode,\n} from '@angular/core/primitives/signals';\n\nimport {RuntimeError, RuntimeErrorCode} from '../../errors';\nimport {assertDefined, assertEqual} from '../../util/assert';\nimport {executeCheckHooks, executeInitAndCheckHooks, incrementInitPhaseFlags} from '../hooks';\nimport {CONTAINER_HEADER_OFFSET, LContainerFlags, MOVED_VIEWS} from '../interfaces/container';\nimport {ComponentTemplate, RenderFlags} from '../interfaces/definition';\nimport {\n  CONTEXT,\n  EFFECTS_TO_SCHEDULE,\n  ENVIRONMENT,\n  FLAGS,\n  InitPhaseState,\n  LView,\n  LViewFlags,\n  REACTIVE_TEMPLATE_CONSUMER,\n  TVIEW,\n  TView,\n  TViewType,\n} from '../interfaces/view';\nimport {\n  getOrBorrowReactiveLViewConsumer,\n  maybeReturnReactiveLViewConsumer,\n  ReactiveLViewConsumer,\n} from '../reactive_lview_consumer';\nimport {\n  CheckNoChangesMode,\n  enterView,\n  isExhaustiveCheckNoChanges,\n  isInCheckNoChangesMode,\n  isRefreshingViews,\n  leaveView,\n  setBindingIndex,\n  setIsInCheckNoChangesMode,\n  setIsRefreshingViews,\n} from '../state';\nimport {getFirstLContainer, getNextLContainer} from '../util/view_traversal_utils';\nimport {\n  getComponentLViewByIndex,\n  isCreationMode,\n  markAncestorsForTraversal,\n  markViewForRefresh,\n  requiresRefreshOrTraversal,\n  resetPreOrderHookFlags,\n  viewAttachedToChangeDetector,\n} from '../util/view_utils';\n\nimport {\n  executeTemplate,\n  executeViewQueryFn,\n  handleError,\n  processHostBindingOpCodes,\n  refreshContentQueries,\n} from './shared';\n\n/**\n * The maximum number of times the change detection traversal will rerun before throwing an error.\n */\nexport const MAXIMUM_REFRESH_RERUNS = 100;\n\nexport function detectChangesInternal(\n  lView: LView,\n  notifyErrorHandler = true,\n  mode = ChangeDetectionMode.Global,\n) {\n  const environment = lView[ENVIRONMENT];\n  const rendererFactory = environment.rendererFactory;\n\n  // Check no changes mode is a dev only mode used to verify that bindings have not changed\n  // since they were assigned. We do not want to invoke renderer factory functions in that mode\n  // to avoid any possible side-effects.\n  const checkNoChangesMode = !!ngDevMode && isInCheckNoChangesMode();\n\n  if (!checkNoChangesMode) {\n    rendererFactory.begin?.();\n  }\n\n  try {\n    detectChangesInViewWhileDirty(lView, mode);\n  } catch (error) {\n    if (notifyErrorHandler) {\n      handleError(lView, error);\n    }\n    throw error;\n  } finally {\n    if (!checkNoChangesMode) {\n      rendererFactory.end?.();\n\n      // One final flush of the effects queue to catch any effects created in `ngAfterViewInit` or\n      // other post-order hooks.\n      environment.inlineEffectRunner?.flush();\n    }\n  }\n}\n\nfunction detectChangesInViewWhileDirty(lView: LView, mode: ChangeDetectionMode) {\n  const lastIsRefreshingViewsValue = isRefreshingViews();\n  try {\n    setIsRefreshingViews(true);\n    detectChangesInView(lView, mode);\n\n    // We don't need or want to do any looping when in exhaustive checkNoChanges because we\n    // already traverse all the views and nothing should change so we shouldn't have to do\n    // another pass to pick up new changes.\n    if (ngDevMode && isExhaustiveCheckNoChanges()) {\n      return;\n    }\n\n    let retries = 0;\n    // If after running change detection, this view still needs to be refreshed or there are\n    // descendants views that need to be refreshed due to re-dirtying during the change detection\n    // run, detect changes on the view again. We run change detection in `Targeted` mode to only\n    // refresh views with the `RefreshView` flag.\n    while (requiresRefreshOrTraversal(lView)) {\n      if (retries === MAXIMUM_REFRESH_RERUNS) {\n        throw new RuntimeError(\n          RuntimeErrorCode.INFINITE_CHANGE_DETECTION,\n          ngDevMode &&\n            'Infinite change detection while trying to refresh views. ' +\n              'There may be components which each cause the other to require a refresh, ' +\n              'causing an infinite loop.',\n        );\n      }\n      retries++;\n      // Even if this view is detached, we still detect changes in targeted mode because this was\n      // the root of the change detection run.\n      detectChangesInView(lView, ChangeDetectionMode.Targeted);\n    }\n  } finally {\n    // restore state to what it was before entering this change detection loop\n    setIsRefreshingViews(lastIsRefreshingViewsValue);\n  }\n}\n\nexport function checkNoChangesInternal(\n  lView: LView,\n  mode: CheckNoChangesMode,\n  notifyErrorHandler = true,\n) {\n  setIsInCheckNoChangesMode(mode);\n  try {\n    detectChangesInternal(lView, notifyErrorHandler);\n  } finally {\n    setIsInCheckNoChangesMode(CheckNoChangesMode.Off);\n  }\n}\n\n/**\n * Different modes of traversing the logical view tree during change detection.\n *\n *\n * The change detection traversal algorithm switches between these modes based on various\n * conditions.\n */\nexport const enum ChangeDetectionMode {\n  /**\n   * In `Global` mode, `Dirty` and `CheckAlways` views are refreshed as well as views with the\n   * `RefreshView` flag.\n   */\n  Global,\n  /**\n   * In `Targeted` mode, only views with the `RefreshView` flag or updated signals are refreshed.\n   */\n  Targeted,\n}\n\n/**\n * Processes a view in update mode. This includes a number of steps in a specific order:\n * - executing a template function in update mode;\n * - executing hooks;\n * - refreshing queries;\n * - setting host bindings;\n * - refreshing child (embedded and component) views.\n */\n\nexport function refreshView<T>(\n  tView: TView,\n  lView: LView,\n  templateFn: ComponentTemplate<{}> | null,\n  context: T,\n) {\n  ngDevMode && assertEqual(isCreationMode(lView), false, 'Should be run in update mode');\n  const flags = lView[FLAGS];\n  if ((flags & LViewFlags.Destroyed) === LViewFlags.Destroyed) return;\n\n  // Check no changes mode is a dev only mode used to verify that bindings have not changed\n  // since they were assigned. We do not want to execute lifecycle hooks in that mode.\n  const isInCheckNoChangesPass = ngDevMode && isInCheckNoChangesMode();\n  const isInExhaustiveCheckNoChangesPass = ngDevMode && isExhaustiveCheckNoChanges();\n\n  !isInCheckNoChangesPass && lView[ENVIRONMENT].inlineEffectRunner?.flush();\n\n  // Start component reactive context\n  // - We might already be in a reactive context if this is an embedded view of the host.\n  // - We might be descending into a view that needs a consumer.\n  enterView(lView);\n  let prevConsumer: ReactiveNode | null = null;\n  let currentConsumer: ReactiveLViewConsumer | null = null;\n  if (!isInCheckNoChangesPass && viewShouldHaveReactiveConsumer(tView)) {\n    currentConsumer = getOrBorrowReactiveLViewConsumer(lView);\n    prevConsumer = consumerBeforeComputation(currentConsumer);\n  }\n\n  try {\n    resetPreOrderHookFlags(lView);\n\n    setBindingIndex(tView.bindingStartIndex);\n    if (templateFn !== null) {\n      executeTemplate(tView, lView, templateFn, RenderFlags.Update, context);\n    }\n\n    const hooksInitPhaseCompleted =\n      (flags & LViewFlags.InitPhaseStateMask) === InitPhaseState.InitPhaseCompleted;\n\n    // execute pre-order hooks (OnInit, OnChanges, DoCheck)\n    // PERF WARNING: do NOT extract this to a separate function without running benchmarks\n    if (!isInCheckNoChangesPass) {\n      if (hooksInitPhaseCompleted) {\n        const preOrderCheckHooks = tView.preOrderCheckHooks;\n        if (preOrderCheckHooks !== null) {\n          executeCheckHooks(lView, preOrderCheckHooks, null);\n        }\n      } else {\n        const preOrderHooks = tView.preOrderHooks;\n        if (preOrderHooks !== null) {\n          executeInitAndCheckHooks(lView, preOrderHooks, InitPhaseState.OnInitHooksToBeRun, null);\n        }\n        incrementInitPhaseFlags(lView, InitPhaseState.OnInitHooksToBeRun);\n      }\n    }\n\n    // We do not need to mark transplanted views for refresh when doing exhaustive checks\n    // because all views will be reached anyways during the traversal.\n    if (!isInExhaustiveCheckNoChangesPass) {\n      // First mark transplanted views that are declared in this lView as needing a refresh at their\n      // insertion points. This is needed to avoid the situation where the template is defined in this\n      // `LView` but its declaration appears after the insertion component.\n      markTransplantedViewsForRefresh(lView);\n    }\n    detectChangesInEmbeddedViews(lView, ChangeDetectionMode.Global);\n\n    // Content query results must be refreshed before content hooks are called.\n    if (tView.contentQueries !== null) {\n      refreshContentQueries(tView, lView);\n    }\n\n    // execute content hooks (AfterContentInit, AfterContentChecked)\n    // PERF WARNING: do NOT extract this to a separate function without running benchmarks\n    if (!isInCheckNoChangesPass) {\n      if (hooksInitPhaseCompleted) {\n        const contentCheckHooks = tView.contentCheckHooks;\n        if (contentCheckHooks !== null) {\n          executeCheckHooks(lView, contentCheckHooks);\n        }\n      } else {\n        const contentHooks = tView.contentHooks;\n        if (contentHooks !== null) {\n          executeInitAndCheckHooks(\n            lView,\n            contentHooks,\n            InitPhaseState.AfterContentInitHooksToBeRun,\n          );\n        }\n        incrementInitPhaseFlags(lView, InitPhaseState.AfterContentInitHooksToBeRun);\n      }\n    }\n\n    processHostBindingOpCodes(tView, lView);\n\n    // Refresh child component views.\n    const components = tView.components;\n    if (components !== null) {\n      detectChangesInChildComponents(lView, components, ChangeDetectionMode.Global);\n    }\n\n    // View queries must execute after refreshing child components because a template in this view\n    // could be inserted in a child component. If the view query executes before child component\n    // refresh, the template might not yet be inserted.\n    const viewQuery = tView.viewQuery;\n    if (viewQuery !== null) {\n      executeViewQueryFn<T>(RenderFlags.Update, viewQuery, context);\n    }\n\n    // execute view hooks (AfterViewInit, AfterViewChecked)\n    // PERF WARNING: do NOT extract this to a separate function without running benchmarks\n    if (!isInCheckNoChangesPass) {\n      if (hooksInitPhaseCompleted) {\n        const viewCheckHooks = tView.viewCheckHooks;\n        if (viewCheckHooks !== null) {\n          executeCheckHooks(lView, viewCheckHooks);\n        }\n      } else {\n        const viewHooks = tView.viewHooks;\n        if (viewHooks !== null) {\n          executeInitAndCheckHooks(lView, viewHooks, InitPhaseState.AfterViewInitHooksToBeRun);\n        }\n        incrementInitPhaseFlags(lView, InitPhaseState.AfterViewInitHooksToBeRun);\n      }\n    }\n    if (tView.firstUpdatePass === true) {\n      // We need to make sure that we only flip the flag on successful `refreshView` only\n      // Don't do this in `finally` block.\n      // If we did this in `finally` block then an exception could block the execution of styling\n      // instructions which in turn would be unable to insert themselves into the styling linked\n      // list. The result of this would be that if the exception would not be throw on subsequent CD\n      // the styling would be unable to process it data and reflect to the DOM.\n      tView.firstUpdatePass = false;\n    }\n\n    // Schedule any effects that are waiting on the update pass of this view.\n    if (lView[EFFECTS_TO_SCHEDULE]) {\n      for (const notifyEffect of lView[EFFECTS_TO_SCHEDULE]) {\n        notifyEffect();\n      }\n\n      // Once they've been run, we can drop the array.\n      lView[EFFECTS_TO_SCHEDULE] = null;\n    }\n\n    // Do not reset the dirty state when running in check no changes mode. We don't want components\n    // to behave differently depending on whether check no changes is enabled or not. For example:\n    // Marking an OnPush component as dirty from within the `ngAfterViewInit` hook in order to\n    // refresh a `NgClass` binding should work. If we would reset the dirty state in the check\n    // no changes cycle, the component would be not be dirty for the next update pass. This would\n    // be different in production mode where the component dirty state is not reset.\n    if (!isInCheckNoChangesPass) {\n      lView[FLAGS] &= ~(LViewFlags.Dirty | LViewFlags.FirstLViewPass);\n    }\n  } catch (e) {\n    if (!isInCheckNoChangesPass) {\n      // If refreshing a view causes an error, we need to remark the ancestors as needing traversal\n      // because the error might have caused a situation where views below the current location are\n      // dirty but will be unreachable because the \"has dirty children\" flag in the ancestors has been\n      // cleared during change detection and we failed to run to completion.\n      markAncestorsForTraversal(lView);\n    }\n    throw e;\n  } finally {\n    if (currentConsumer !== null) {\n      consumerAfterComputation(currentConsumer, prevConsumer);\n      maybeReturnReactiveLViewConsumer(currentConsumer);\n    }\n    leaveView();\n  }\n}\n\n/**\n * Indicates if the view should get its own reactive consumer node.\n *\n * In the current design, all embedded views share a consumer with the component view. This allows\n * us to refresh at the component level rather than at a per-view level. In addition, root views get\n * their own reactive node because root component will have a host view that executes the\n * component's host bindings. This needs to be tracked in a consumer as well.\n *\n * To get a more granular change detection than per-component, all we would just need to update the\n * condition here so that a given view gets a reactive consumer which can become dirty independently\n * from its parent component. For example embedded views for signal components could be created with\n * a new type \"SignalEmbeddedView\" and the condition here wouldn't even need updating in order to\n * get granular per-view change detection for signal components.\n */\nfunction viewShouldHaveReactiveConsumer(tView: TView) {\n  return tView.type !== TViewType.Embedded;\n}\n\n/**\n * Goes over embedded views (ones created through ViewContainerRef APIs) and refreshes\n * them by executing an associated template function.\n */\nfunction detectChangesInEmbeddedViews(lView: LView, mode: ChangeDetectionMode) {\n  for (\n    let lContainer = getFirstLContainer(lView);\n    lContainer !== null;\n    lContainer = getNextLContainer(lContainer)\n  ) {\n    for (let i = CONTAINER_HEADER_OFFSET; i < lContainer.length; i++) {\n      const embeddedLView = lContainer[i];\n      detectChangesInViewIfAttached(embeddedLView, mode);\n    }\n  }\n}\n\n/**\n * Mark transplanted views as needing to be refreshed at their attachment points.\n *\n * @param lView The `LView` that may have transplanted views.\n */\nfunction markTransplantedViewsForRefresh(lView: LView) {\n  for (\n    let lContainer = getFirstLContainer(lView);\n    lContainer !== null;\n    lContainer = getNextLContainer(lContainer)\n  ) {\n    if (!(lContainer[FLAGS] & LContainerFlags.HasTransplantedViews)) continue;\n\n    const movedViews = lContainer[MOVED_VIEWS]!;\n    ngDevMode && assertDefined(movedViews, 'Transplanted View flags set but missing MOVED_VIEWS');\n    for (let i = 0; i < movedViews.length; i++) {\n      const movedLView = movedViews[i]!;\n      markViewForRefresh(movedLView);\n    }\n  }\n}\n\n/**\n * Detects changes in a component by entering the component view and processing its bindings,\n * queries, etc. if it is CheckAlways, OnPush and Dirty, etc.\n *\n * @param componentHostIdx  Element index in LView[] (adjusted for HEADER_OFFSET)\n */\nfunction detectChangesInComponent(\n  hostLView: LView,\n  componentHostIdx: number,\n  mode: ChangeDetectionMode,\n): void {\n  ngDevMode && assertEqual(isCreationMode(hostLView), false, 'Should be run in update mode');\n  const componentView = getComponentLViewByIndex(componentHostIdx, hostLView);\n  detectChangesInViewIfAttached(componentView, mode);\n}\n\n/**\n * Visits a view as part of change detection traversal.\n *\n * If the view is detached, no additional traversal happens.\n */\nfunction detectChangesInViewIfAttached(lView: LView, mode: ChangeDetectionMode) {\n  if (!viewAttachedToChangeDetector(lView)) {\n    return;\n  }\n  detectChangesInView(lView, mode);\n}\n\n/**\n * Visits a view as part of change detection traversal.\n *\n * The view is refreshed if:\n * - If the view is CheckAlways or Dirty and ChangeDetectionMode is `Global`\n * - If the view has the `RefreshView` flag\n *\n * The view is not refreshed, but descendants are traversed in `ChangeDetectionMode.Targeted` if the\n * view HasChildViewsToRefresh flag is set.\n */\nfunction detectChangesInView(lView: LView, mode: ChangeDetectionMode) {\n  const isInCheckNoChangesPass = ngDevMode && isInCheckNoChangesMode();\n  const tView = lView[TVIEW];\n  const flags = lView[FLAGS];\n  const consumer = lView[REACTIVE_TEMPLATE_CONSUMER];\n\n  // Refresh CheckAlways views in Global mode.\n  let shouldRefreshView: boolean = !!(\n    mode === ChangeDetectionMode.Global && flags & LViewFlags.CheckAlways\n  );\n\n  // Refresh Dirty views in Global mode, as long as we're not in checkNoChanges.\n  // CheckNoChanges never worked with `OnPush` components because the `Dirty` flag was\n  // cleared before checkNoChanges ran. Because there is now a loop for to check for\n  // backwards views, it gives an opportunity for `OnPush` components to be marked `Dirty`\n  // before the CheckNoChanges pass. We don't want existing errors that are hidden by the\n  // current CheckNoChanges bug to surface when making unrelated changes.\n  shouldRefreshView ||= !!(\n    flags & LViewFlags.Dirty &&\n    mode === ChangeDetectionMode.Global &&\n    !isInCheckNoChangesPass\n  );\n\n  // Always refresh views marked for refresh, regardless of mode.\n  shouldRefreshView ||= !!(flags & LViewFlags.RefreshView);\n\n  // Refresh views when they have a dirty reactive consumer, regardless of mode.\n  shouldRefreshView ||= !!(consumer?.dirty && consumerPollProducersForChange(consumer));\n\n  shouldRefreshView ||= !!(ngDevMode && isExhaustiveCheckNoChanges());\n\n  // Mark the Flags and `ReactiveNode` as not dirty before refreshing the component, so that they\n  // can be re-dirtied during the refresh process.\n  if (consumer) {\n    consumer.dirty = false;\n  }\n  lView[FLAGS] &= ~(LViewFlags.HasChildViewsToRefresh | LViewFlags.RefreshView);\n\n  if (shouldRefreshView) {\n    refreshView(tView, lView, tView.template, lView[CONTEXT]);\n  } else if (flags & LViewFlags.HasChildViewsToRefresh) {\n    detectChangesInEmbeddedViews(lView, ChangeDetectionMode.Targeted);\n    const components = tView.components;\n    if (components !== null) {\n      detectChangesInChildComponents(lView, components, ChangeDetectionMode.Targeted);\n    }\n  }\n}\n\n/** Refreshes child components in the current view (update mode). */\nfunction detectChangesInChildComponents(\n  hostLView: LView,\n  components: number[],\n  mode: ChangeDetectionMode,\n): void {\n  for (let i = 0; i < components.length; i++) {\n    detectChangesInComponent(hostLView, components[i], mode);\n  }\n}\n"]}
|
|
376
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"change_detection.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/change_detection.ts"],"names":[],"mappings":"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","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.io/license\n */\n\nimport {\n  consumerAfterComputation,\n  consumerBeforeComputation,\n  consumerDestroy,\n  consumerPollProducersForChange,\n  getActiveConsumer,\n  ReactiveNode,\n} from '@angular/core/primitives/signals';\n\nimport {RuntimeError, RuntimeErrorCode} from '../../errors';\nimport {assertDefined, assertEqual} from '../../util/assert';\nimport {executeCheckHooks, executeInitAndCheckHooks, incrementInitPhaseFlags} from '../hooks';\nimport {CONTAINER_HEADER_OFFSET, LContainerFlags, MOVED_VIEWS} from '../interfaces/container';\nimport {ComponentTemplate, RenderFlags} from '../interfaces/definition';\nimport {\n  CONTEXT,\n  EFFECTS_TO_SCHEDULE,\n  ENVIRONMENT,\n  FLAGS,\n  InitPhaseState,\n  LView,\n  LViewFlags,\n  REACTIVE_TEMPLATE_CONSUMER,\n  TVIEW,\n  TView,\n} from '../interfaces/view';\nimport {\n  getOrCreateTemporaryConsumer,\n  getOrBorrowReactiveLViewConsumer,\n  maybeReturnReactiveLViewConsumer,\n  ReactiveLViewConsumer,\n  viewShouldHaveReactiveConsumer,\n} from '../reactive_lview_consumer';\nimport {\n  CheckNoChangesMode,\n  enterView,\n  isExhaustiveCheckNoChanges,\n  isInCheckNoChangesMode,\n  isRefreshingViews,\n  leaveView,\n  setBindingIndex,\n  setIsInCheckNoChangesMode,\n  setIsRefreshingViews,\n} from '../state';\nimport {getFirstLContainer, getNextLContainer} from '../util/view_traversal_utils';\nimport {\n  getComponentLViewByIndex,\n  isCreationMode,\n  markAncestorsForTraversal,\n  markViewForRefresh,\n  requiresRefreshOrTraversal,\n  resetPreOrderHookFlags,\n  viewAttachedToChangeDetector,\n} from '../util/view_utils';\n\nimport {\n  executeTemplate,\n  executeViewQueryFn,\n  handleError,\n  processHostBindingOpCodes,\n  refreshContentQueries,\n} from './shared';\n\n/**\n * The maximum number of times the change detection traversal will rerun before throwing an error.\n */\nexport const MAXIMUM_REFRESH_RERUNS = 100;\n\nexport function detectChangesInternal(\n  lView: LView,\n  notifyErrorHandler = true,\n  mode = ChangeDetectionMode.Global,\n) {\n  const environment = lView[ENVIRONMENT];\n  const rendererFactory = environment.rendererFactory;\n\n  // Check no changes mode is a dev only mode used to verify that bindings have not changed\n  // since they were assigned. We do not want to invoke renderer factory functions in that mode\n  // to avoid any possible side-effects.\n  const checkNoChangesMode = !!ngDevMode && isInCheckNoChangesMode();\n\n  if (!checkNoChangesMode) {\n    rendererFactory.begin?.();\n  }\n\n  try {\n    detectChangesInViewWhileDirty(lView, mode);\n  } catch (error) {\n    if (notifyErrorHandler) {\n      handleError(lView, error);\n    }\n    throw error;\n  } finally {\n    if (!checkNoChangesMode) {\n      rendererFactory.end?.();\n\n      // One final flush of the effects queue to catch any effects created in `ngAfterViewInit` or\n      // other post-order hooks.\n      environment.inlineEffectRunner?.flush();\n    }\n  }\n}\n\nfunction detectChangesInViewWhileDirty(lView: LView, mode: ChangeDetectionMode) {\n  const lastIsRefreshingViewsValue = isRefreshingViews();\n  try {\n    setIsRefreshingViews(true);\n    detectChangesInView(lView, mode);\n\n    // We don't need or want to do any looping when in exhaustive checkNoChanges because we\n    // already traverse all the views and nothing should change so we shouldn't have to do\n    // another pass to pick up new changes.\n    if (ngDevMode && isExhaustiveCheckNoChanges()) {\n      return;\n    }\n\n    let retries = 0;\n    // If after running change detection, this view still needs to be refreshed or there are\n    // descendants views that need to be refreshed due to re-dirtying during the change detection\n    // run, detect changes on the view again. We run change detection in `Targeted` mode to only\n    // refresh views with the `RefreshView` flag.\n    while (requiresRefreshOrTraversal(lView)) {\n      if (retries === MAXIMUM_REFRESH_RERUNS) {\n        throw new RuntimeError(\n          RuntimeErrorCode.INFINITE_CHANGE_DETECTION,\n          ngDevMode &&\n            'Infinite change detection while trying to refresh views. ' +\n              'There may be components which each cause the other to require a refresh, ' +\n              'causing an infinite loop.',\n        );\n      }\n      retries++;\n      // Even if this view is detached, we still detect changes in targeted mode because this was\n      // the root of the change detection run.\n      detectChangesInView(lView, ChangeDetectionMode.Targeted);\n    }\n  } finally {\n    // restore state to what it was before entering this change detection loop\n    setIsRefreshingViews(lastIsRefreshingViewsValue);\n  }\n}\n\nexport function checkNoChangesInternal(\n  lView: LView,\n  mode: CheckNoChangesMode,\n  notifyErrorHandler = true,\n) {\n  setIsInCheckNoChangesMode(mode);\n  try {\n    detectChangesInternal(lView, notifyErrorHandler);\n  } finally {\n    setIsInCheckNoChangesMode(CheckNoChangesMode.Off);\n  }\n}\n\n/**\n * Different modes of traversing the logical view tree during change detection.\n *\n *\n * The change detection traversal algorithm switches between these modes based on various\n * conditions.\n */\nexport const enum ChangeDetectionMode {\n  /**\n   * In `Global` mode, `Dirty` and `CheckAlways` views are refreshed as well as views with the\n   * `RefreshView` flag.\n   */\n  Global,\n  /**\n   * In `Targeted` mode, only views with the `RefreshView` flag or updated signals are refreshed.\n   */\n  Targeted,\n}\n\n/**\n * Processes a view in update mode. This includes a number of steps in a specific order:\n * - executing a template function in update mode;\n * - executing hooks;\n * - refreshing queries;\n * - setting host bindings;\n * - refreshing child (embedded and component) views.\n */\n\nexport function refreshView<T>(\n  tView: TView,\n  lView: LView,\n  templateFn: ComponentTemplate<{}> | null,\n  context: T,\n) {\n  ngDevMode && assertEqual(isCreationMode(lView), false, 'Should be run in update mode');\n  const flags = lView[FLAGS];\n  if ((flags & LViewFlags.Destroyed) === LViewFlags.Destroyed) return;\n\n  // Check no changes mode is a dev only mode used to verify that bindings have not changed\n  // since they were assigned. We do not want to execute lifecycle hooks in that mode.\n  const isInCheckNoChangesPass = ngDevMode && isInCheckNoChangesMode();\n  const isInExhaustiveCheckNoChangesPass = ngDevMode && isExhaustiveCheckNoChanges();\n\n  !isInCheckNoChangesPass && lView[ENVIRONMENT].inlineEffectRunner?.flush();\n\n  // Start component reactive context\n  // - We might already be in a reactive context if this is an embedded view of the host.\n  // - We might be descending into a view that needs a consumer.\n  enterView(lView);\n  let returnConsumerToPool = true;\n  let prevConsumer: ReactiveNode | null = null;\n  let currentConsumer: ReactiveLViewConsumer | null = null;\n  if (!isInCheckNoChangesPass) {\n    if (viewShouldHaveReactiveConsumer(tView)) {\n      currentConsumer = getOrBorrowReactiveLViewConsumer(lView);\n      prevConsumer = consumerBeforeComputation(currentConsumer);\n    } else if (getActiveConsumer() === null) {\n      // If the current view should not have a reactive consumer but we don't have an active consumer,\n      // we still need to create a temporary consumer to track any signal reads in this template.\n      // This is a rare case that can happen with `viewContainerRef.createEmbeddedView(...).detectChanges()`.\n      // This temporary consumer marks the first parent that _should_ have a consumer for refresh.\n      // Once that refresh happens, the signals will be tracked in the parent consumer and we can destroy\n      // the temporary one.\n      returnConsumerToPool = false;\n      currentConsumer = getOrCreateTemporaryConsumer(lView);\n      prevConsumer = consumerBeforeComputation(currentConsumer);\n    } else if (lView[REACTIVE_TEMPLATE_CONSUMER]) {\n      consumerDestroy(lView[REACTIVE_TEMPLATE_CONSUMER]);\n      lView[REACTIVE_TEMPLATE_CONSUMER] = null;\n    }\n  }\n\n  try {\n    resetPreOrderHookFlags(lView);\n\n    setBindingIndex(tView.bindingStartIndex);\n    if (templateFn !== null) {\n      executeTemplate(tView, lView, templateFn, RenderFlags.Update, context);\n    }\n\n    const hooksInitPhaseCompleted =\n      (flags & LViewFlags.InitPhaseStateMask) === InitPhaseState.InitPhaseCompleted;\n\n    // execute pre-order hooks (OnInit, OnChanges, DoCheck)\n    // PERF WARNING: do NOT extract this to a separate function without running benchmarks\n    if (!isInCheckNoChangesPass) {\n      if (hooksInitPhaseCompleted) {\n        const preOrderCheckHooks = tView.preOrderCheckHooks;\n        if (preOrderCheckHooks !== null) {\n          executeCheckHooks(lView, preOrderCheckHooks, null);\n        }\n      } else {\n        const preOrderHooks = tView.preOrderHooks;\n        if (preOrderHooks !== null) {\n          executeInitAndCheckHooks(lView, preOrderHooks, InitPhaseState.OnInitHooksToBeRun, null);\n        }\n        incrementInitPhaseFlags(lView, InitPhaseState.OnInitHooksToBeRun);\n      }\n    }\n\n    // We do not need to mark transplanted views for refresh when doing exhaustive checks\n    // because all views will be reached anyways during the traversal.\n    if (!isInExhaustiveCheckNoChangesPass) {\n      // First mark transplanted views that are declared in this lView as needing a refresh at their\n      // insertion points. This is needed to avoid the situation where the template is defined in this\n      // `LView` but its declaration appears after the insertion component.\n      markTransplantedViewsForRefresh(lView);\n    }\n    detectChangesInEmbeddedViews(lView, ChangeDetectionMode.Global);\n\n    // Content query results must be refreshed before content hooks are called.\n    if (tView.contentQueries !== null) {\n      refreshContentQueries(tView, lView);\n    }\n\n    // execute content hooks (AfterContentInit, AfterContentChecked)\n    // PERF WARNING: do NOT extract this to a separate function without running benchmarks\n    if (!isInCheckNoChangesPass) {\n      if (hooksInitPhaseCompleted) {\n        const contentCheckHooks = tView.contentCheckHooks;\n        if (contentCheckHooks !== null) {\n          executeCheckHooks(lView, contentCheckHooks);\n        }\n      } else {\n        const contentHooks = tView.contentHooks;\n        if (contentHooks !== null) {\n          executeInitAndCheckHooks(\n            lView,\n            contentHooks,\n            InitPhaseState.AfterContentInitHooksToBeRun,\n          );\n        }\n        incrementInitPhaseFlags(lView, InitPhaseState.AfterContentInitHooksToBeRun);\n      }\n    }\n\n    processHostBindingOpCodes(tView, lView);\n\n    // Refresh child component views.\n    const components = tView.components;\n    if (components !== null) {\n      detectChangesInChildComponents(lView, components, ChangeDetectionMode.Global);\n    }\n\n    // View queries must execute after refreshing child components because a template in this view\n    // could be inserted in a child component. If the view query executes before child component\n    // refresh, the template might not yet be inserted.\n    const viewQuery = tView.viewQuery;\n    if (viewQuery !== null) {\n      executeViewQueryFn<T>(RenderFlags.Update, viewQuery, context);\n    }\n\n    // execute view hooks (AfterViewInit, AfterViewChecked)\n    // PERF WARNING: do NOT extract this to a separate function without running benchmarks\n    if (!isInCheckNoChangesPass) {\n      if (hooksInitPhaseCompleted) {\n        const viewCheckHooks = tView.viewCheckHooks;\n        if (viewCheckHooks !== null) {\n          executeCheckHooks(lView, viewCheckHooks);\n        }\n      } else {\n        const viewHooks = tView.viewHooks;\n        if (viewHooks !== null) {\n          executeInitAndCheckHooks(lView, viewHooks, InitPhaseState.AfterViewInitHooksToBeRun);\n        }\n        incrementInitPhaseFlags(lView, InitPhaseState.AfterViewInitHooksToBeRun);\n      }\n    }\n    if (tView.firstUpdatePass === true) {\n      // We need to make sure that we only flip the flag on successful `refreshView` only\n      // Don't do this in `finally` block.\n      // If we did this in `finally` block then an exception could block the execution of styling\n      // instructions which in turn would be unable to insert themselves into the styling linked\n      // list. The result of this would be that if the exception would not be throw on subsequent CD\n      // the styling would be unable to process it data and reflect to the DOM.\n      tView.firstUpdatePass = false;\n    }\n\n    // Schedule any effects that are waiting on the update pass of this view.\n    if (lView[EFFECTS_TO_SCHEDULE]) {\n      for (const notifyEffect of lView[EFFECTS_TO_SCHEDULE]) {\n        notifyEffect();\n      }\n\n      // Once they've been run, we can drop the array.\n      lView[EFFECTS_TO_SCHEDULE] = null;\n    }\n\n    // Do not reset the dirty state when running in check no changes mode. We don't want components\n    // to behave differently depending on whether check no changes is enabled or not. For example:\n    // Marking an OnPush component as dirty from within the `ngAfterViewInit` hook in order to\n    // refresh a `NgClass` binding should work. If we would reset the dirty state in the check\n    // no changes cycle, the component would be not be dirty for the next update pass. This would\n    // be different in production mode where the component dirty state is not reset.\n    if (!isInCheckNoChangesPass) {\n      lView[FLAGS] &= ~(LViewFlags.Dirty | LViewFlags.FirstLViewPass);\n    }\n  } catch (e) {\n    if (!isInCheckNoChangesPass) {\n      // If refreshing a view causes an error, we need to remark the ancestors as needing traversal\n      // because the error might have caused a situation where views below the current location are\n      // dirty but will be unreachable because the \"has dirty children\" flag in the ancestors has been\n      // cleared during change detection and we failed to run to completion.\n      markAncestorsForTraversal(lView);\n    }\n    throw e;\n  } finally {\n    if (currentConsumer !== null) {\n      consumerAfterComputation(currentConsumer, prevConsumer);\n      if (returnConsumerToPool) {\n        maybeReturnReactiveLViewConsumer(currentConsumer);\n      }\n    }\n    leaveView();\n  }\n}\n\n/**\n * Goes over embedded views (ones created through ViewContainerRef APIs) and refreshes\n * them by executing an associated template function.\n */\nfunction detectChangesInEmbeddedViews(lView: LView, mode: ChangeDetectionMode) {\n  for (\n    let lContainer = getFirstLContainer(lView);\n    lContainer !== null;\n    lContainer = getNextLContainer(lContainer)\n  ) {\n    for (let i = CONTAINER_HEADER_OFFSET; i < lContainer.length; i++) {\n      const embeddedLView = lContainer[i];\n      detectChangesInViewIfAttached(embeddedLView, mode);\n    }\n  }\n}\n\n/**\n * Mark transplanted views as needing to be refreshed at their attachment points.\n *\n * @param lView The `LView` that may have transplanted views.\n */\nfunction markTransplantedViewsForRefresh(lView: LView) {\n  for (\n    let lContainer = getFirstLContainer(lView);\n    lContainer !== null;\n    lContainer = getNextLContainer(lContainer)\n  ) {\n    if (!(lContainer[FLAGS] & LContainerFlags.HasTransplantedViews)) continue;\n\n    const movedViews = lContainer[MOVED_VIEWS]!;\n    ngDevMode && assertDefined(movedViews, 'Transplanted View flags set but missing MOVED_VIEWS');\n    for (let i = 0; i < movedViews.length; i++) {\n      const movedLView = movedViews[i]!;\n      markViewForRefresh(movedLView);\n    }\n  }\n}\n\n/**\n * Detects changes in a component by entering the component view and processing its bindings,\n * queries, etc. if it is CheckAlways, OnPush and Dirty, etc.\n *\n * @param componentHostIdx  Element index in LView[] (adjusted for HEADER_OFFSET)\n */\nfunction detectChangesInComponent(\n  hostLView: LView,\n  componentHostIdx: number,\n  mode: ChangeDetectionMode,\n): void {\n  ngDevMode && assertEqual(isCreationMode(hostLView), false, 'Should be run in update mode');\n  const componentView = getComponentLViewByIndex(componentHostIdx, hostLView);\n  detectChangesInViewIfAttached(componentView, mode);\n}\n\n/**\n * Visits a view as part of change detection traversal.\n *\n * If the view is detached, no additional traversal happens.\n */\nfunction detectChangesInViewIfAttached(lView: LView, mode: ChangeDetectionMode) {\n  if (!viewAttachedToChangeDetector(lView)) {\n    return;\n  }\n  detectChangesInView(lView, mode);\n}\n\n/**\n * Visits a view as part of change detection traversal.\n *\n * The view is refreshed if:\n * - If the view is CheckAlways or Dirty and ChangeDetectionMode is `Global`\n * - If the view has the `RefreshView` flag\n *\n * The view is not refreshed, but descendants are traversed in `ChangeDetectionMode.Targeted` if the\n * view HasChildViewsToRefresh flag is set.\n */\nfunction detectChangesInView(lView: LView, mode: ChangeDetectionMode) {\n  const isInCheckNoChangesPass = ngDevMode && isInCheckNoChangesMode();\n  const tView = lView[TVIEW];\n  const flags = lView[FLAGS];\n  const consumer = lView[REACTIVE_TEMPLATE_CONSUMER];\n\n  // Refresh CheckAlways views in Global mode.\n  let shouldRefreshView: boolean = !!(\n    mode === ChangeDetectionMode.Global && flags & LViewFlags.CheckAlways\n  );\n\n  // Refresh Dirty views in Global mode, as long as we're not in checkNoChanges.\n  // CheckNoChanges never worked with `OnPush` components because the `Dirty` flag was\n  // cleared before checkNoChanges ran. Because there is now a loop for to check for\n  // backwards views, it gives an opportunity for `OnPush` components to be marked `Dirty`\n  // before the CheckNoChanges pass. We don't want existing errors that are hidden by the\n  // current CheckNoChanges bug to surface when making unrelated changes.\n  shouldRefreshView ||= !!(\n    flags & LViewFlags.Dirty &&\n    mode === ChangeDetectionMode.Global &&\n    !isInCheckNoChangesPass\n  );\n\n  // Always refresh views marked for refresh, regardless of mode.\n  shouldRefreshView ||= !!(flags & LViewFlags.RefreshView);\n\n  // Refresh views when they have a dirty reactive consumer, regardless of mode.\n  shouldRefreshView ||= !!(consumer?.dirty && consumerPollProducersForChange(consumer));\n\n  shouldRefreshView ||= !!(ngDevMode && isExhaustiveCheckNoChanges());\n\n  // Mark the Flags and `ReactiveNode` as not dirty before refreshing the component, so that they\n  // can be re-dirtied during the refresh process.\n  if (consumer) {\n    consumer.dirty = false;\n  }\n  lView[FLAGS] &= ~(LViewFlags.HasChildViewsToRefresh | LViewFlags.RefreshView);\n\n  if (shouldRefreshView) {\n    refreshView(tView, lView, tView.template, lView[CONTEXT]);\n  } else if (flags & LViewFlags.HasChildViewsToRefresh) {\n    detectChangesInEmbeddedViews(lView, ChangeDetectionMode.Targeted);\n    const components = tView.components;\n    if (components !== null) {\n      detectChangesInChildComponents(lView, components, ChangeDetectionMode.Targeted);\n    }\n  }\n}\n\n/** Refreshes child components in the current view (update mode). */\nfunction detectChangesInChildComponents(\n  hostLView: LView,\n  components: number[],\n  mode: ChangeDetectionMode,\n): void {\n  for (let i = 0; i < components.length; i++) {\n    detectChangesInComponent(hostLView, components[i], mode);\n  }\n}\n"]}
|
|
@@ -21,9 +21,9 @@ import { getOrCreateLViewCleanup, getOrCreateTViewCleanup, handleError, loadComp
|
|
|
21
21
|
* an actual implementation when the event replay feature is enabled via
|
|
22
22
|
* `withEventReplay()` call.
|
|
23
23
|
*/
|
|
24
|
-
let
|
|
25
|
-
export function
|
|
26
|
-
|
|
24
|
+
let stashEventListener = (el, eventName, listenerFn) => { };
|
|
25
|
+
export function setStashFn(fn) {
|
|
26
|
+
stashEventListener = fn;
|
|
27
27
|
}
|
|
28
28
|
/**
|
|
29
29
|
* Adds an event listener to the current node.
|
|
@@ -129,7 +129,6 @@ export function listenerInternal(tView, lView, renderer, tNode, eventName, liste
|
|
|
129
129
|
const idxOrTargetGetter = eventTargetResolver
|
|
130
130
|
? (_lView) => eventTargetResolver(unwrapRNode(_lView[tNode.index]))
|
|
131
131
|
: tNode.index;
|
|
132
|
-
disableEventReplayFn(native, eventName, listenerFn);
|
|
133
132
|
// In order to match current behavior, native DOM event listeners must be added for all
|
|
134
133
|
// events (including outputs).
|
|
135
134
|
// There might be cases where multiple directives on the same element try to register an event
|
|
@@ -164,6 +163,7 @@ export function listenerInternal(tView, lView, renderer, tNode, eventName, liste
|
|
|
164
163
|
}
|
|
165
164
|
else {
|
|
166
165
|
listenerFn = wrapListener(tNode, lView, context, listenerFn);
|
|
166
|
+
stashEventListener(native, eventName, listenerFn);
|
|
167
167
|
const cleanupFn = renderer.listen(target, eventName, listenerFn);
|
|
168
168
|
ngDevMode && ngDevMode.rendererAddEventListener++;
|
|
169
169
|
lCleanup.push(listenerFn, cleanupFn);
|
|
@@ -258,4 +258,4 @@ function wrapListener(tNode, lView, context, listenerFn) {
|
|
|
258
258
|
function isOutputSubscribable(value) {
|
|
259
259
|
return (value != null && typeof value.subscribe === 'function');
|
|
260
260
|
}
|
|
261
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"listener.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/listener.ts"],"names":[],"mappings":"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","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.io/license\n */\n\nimport {setActiveConsumer} from '@angular/core/primitives/signals';\n\nimport {NotificationSource} from '../../change_detection/scheduling/zoneless_scheduling';\nimport {assertIndexInRange} from '../../util/assert';\nimport {NodeOutputBindings, TNode, TNodeType} from '../interfaces/node';\nimport {GlobalTargetResolver, Renderer} from '../interfaces/renderer';\nimport {RElement} from '../interfaces/renderer_dom';\nimport {isDirectiveHost} from '../interfaces/type_checks';\nimport {CLEANUP, CONTEXT, LView, RENDERER, TView} from '../interfaces/view';\nimport {assertTNodeType} from '../node_assert';\nimport {profiler} from '../profiler';\nimport {ProfilerEvent} from '../profiler_types';\nimport {getCurrentDirectiveDef, getCurrentTNode, getLView, getTView} from '../state';\nimport {getComponentLViewByIndex, getNativeByTNode, unwrapRNode} from '../util/view_utils';\n\nimport {markViewDirty} from './mark_view_dirty';\nimport {\n  getOrCreateLViewCleanup,\n  getOrCreateTViewCleanup,\n  handleError,\n  loadComponentRenderer,\n} from './shared';\n\n/**\n * Contains a reference to a function that disables event replay feature\n * for server-side rendered applications. This function is overridden with\n * an actual implementation when the event replay feature is enabled via\n * `withEventReplay()` call.\n */\nlet disableEventReplayFn = (el: RElement, eventName: string, listenerFn: (e?: any) => any) => {};\n\nexport function setDisableEventReplayImpl(fn: typeof disableEventReplayFn) {\n  disableEventReplayFn = fn;\n}\n\n/**\n * Adds an event listener to the current node.\n *\n * If an output exists on one of the node's directives, it also subscribes to the output\n * and saves the subscription for later cleanup.\n *\n * @param eventName Name of the event\n * @param listenerFn The function to be called when event emits\n * @param useCapture Whether or not to use capture in event listener - this argument is a reminder\n *     from the Renderer3 infrastructure and should be removed from the instruction arguments\n * @param eventTargetResolver Function that returns global target information in case this listener\n * should be attached to a global object like window, document or body\n *\n * @codeGenApi\n */\nexport function ɵɵlistener(\n  eventName: string,\n  listenerFn: (e?: any) => any,\n  useCapture?: boolean,\n  eventTargetResolver?: GlobalTargetResolver,\n): typeof ɵɵlistener {\n  const lView = getLView<{} | null>();\n  const tView = getTView();\n  const tNode = getCurrentTNode()!;\n  listenerInternal(\n    tView,\n    lView,\n    lView[RENDERER],\n    tNode,\n    eventName,\n    listenerFn,\n    eventTargetResolver,\n  );\n  return ɵɵlistener;\n}\n\n/**\n * Registers a synthetic host listener (e.g. `(@foo.start)`) on a component or directive.\n *\n * This instruction is for compatibility purposes and is designed to ensure that a\n * synthetic host listener (e.g. `@HostListener('@foo.start')`) properly gets rendered\n * in the component's renderer. Normally all host listeners are evaluated with the\n * parent component's renderer, but, in the case of animation @triggers, they need\n * to be evaluated with the sub component's renderer (because that's where the\n * animation triggers are defined).\n *\n * Do not use this instruction as a replacement for `listener`. This instruction\n * only exists to ensure compatibility with the ViewEngine's host binding behavior.\n *\n * @param eventName Name of the event\n * @param listenerFn The function to be called when event emits\n * @param useCapture Whether or not to use capture in event listener\n * @param eventTargetResolver Function that returns global target information in case this listener\n * should be attached to a global object like window, document or body\n *\n * @codeGenApi\n */\nexport function ɵɵsyntheticHostListener(\n  eventName: string,\n  listenerFn: (e?: any) => any,\n): typeof ɵɵsyntheticHostListener {\n  const tNode = getCurrentTNode()!;\n  const lView = getLView<{} | null>();\n  const tView = getTView();\n  const currentDef = getCurrentDirectiveDef(tView.data);\n  const renderer = loadComponentRenderer(currentDef, tNode, lView);\n  listenerInternal(tView, lView, renderer, tNode, eventName, listenerFn);\n  return ɵɵsyntheticHostListener;\n}\n\n/**\n * A utility function that checks if a given element has already an event handler registered for an\n * event with a specified name. The TView.cleanup data structure is used to find out which events\n * are registered for a given element.\n */\nfunction findExistingListener(\n  tView: TView,\n  lView: LView,\n  eventName: string,\n  tNodeIdx: number,\n): ((e?: any) => any) | null {\n  const tCleanup = tView.cleanup;\n  if (tCleanup != null) {\n    for (let i = 0; i < tCleanup.length - 1; i += 2) {\n      const cleanupEventName = tCleanup[i];\n      if (cleanupEventName === eventName && tCleanup[i + 1] === tNodeIdx) {\n        // We have found a matching event name on the same node but it might not have been\n        // registered yet, so we must explicitly verify entries in the LView cleanup data\n        // structures.\n        const lCleanup = lView[CLEANUP]!;\n        const listenerIdxInLCleanup = tCleanup[i + 2];\n        return lCleanup.length > listenerIdxInLCleanup ? lCleanup[listenerIdxInLCleanup] : null;\n      }\n      // TView.cleanup can have a mix of 4-elements entries (for event handler cleanups) or\n      // 2-element entries (for directive and queries destroy hooks). As such we can encounter\n      // blocks of 4 or 2 items in the tView.cleanup and this is why we iterate over 2 elements\n      // first and jump another 2 elements if we detect listeners cleanup (4 elements). Also check\n      // documentation of TView.cleanup for more details of this data structure layout.\n      if (typeof cleanupEventName === 'string') {\n        i += 2;\n      }\n    }\n  }\n  return null;\n}\n\nexport function listenerInternal(\n  tView: TView,\n  lView: LView<{} | null>,\n  renderer: Renderer,\n  tNode: TNode,\n  eventName: string,\n  listenerFn: (e?: any) => any,\n  eventTargetResolver?: GlobalTargetResolver,\n): void {\n  const isTNodeDirectiveHost = isDirectiveHost(tNode);\n  const firstCreatePass = tView.firstCreatePass;\n  const tCleanup: false | any[] = firstCreatePass && getOrCreateTViewCleanup(tView);\n  const context = lView[CONTEXT];\n\n  // When the ɵɵlistener instruction was generated and is executed we know that there is either a\n  // native listener or a directive output on this element. As such we we know that we will have to\n  // register a listener and store its cleanup function on LView.\n  const lCleanup = getOrCreateLViewCleanup(lView);\n\n  ngDevMode && assertTNodeType(tNode, TNodeType.AnyRNode | TNodeType.AnyContainer);\n\n  let processOutputs = true;\n\n  // Adding a native event listener is applicable when:\n  // - The corresponding TNode represents a DOM element.\n  // - The event target has a resolver (usually resulting in a global object,\n  //   such as `window` or `document`).\n  if (tNode.type & TNodeType.AnyRNode || eventTargetResolver) {\n    const native = getNativeByTNode(tNode, lView) as RElement;\n    const target = eventTargetResolver ? eventTargetResolver(native) : native;\n    const lCleanupIndex = lCleanup.length;\n    const idxOrTargetGetter = eventTargetResolver\n      ? (_lView: LView) => eventTargetResolver(unwrapRNode(_lView[tNode.index]))\n      : tNode.index;\n\n    disableEventReplayFn(native, eventName, listenerFn);\n\n    // In order to match current behavior, native DOM event listeners must be added for all\n    // events (including outputs).\n\n    // There might be cases where multiple directives on the same element try to register an event\n    // handler function for the same event. In this situation we want to avoid registration of\n    // several native listeners as each registration would be intercepted by NgZone and\n    // trigger change detection. This would mean that a single user action would result in several\n    // change detections being invoked. To avoid this situation we want to have only one call to\n    // native handler registration (for the same element and same type of event).\n    //\n    // In order to have just one native event handler in presence of multiple handler functions,\n    // we just register a first handler function as a native event listener and then chain\n    // (coalesce) other handler functions on top of the first native handler function.\n    let existingListener = null;\n    // Please note that the coalescing described here doesn't happen for events specifying an\n    // alternative target (ex. (document:click)) - this is to keep backward compatibility with the\n    // view engine.\n    // Also, we don't have to search for existing listeners is there are no directives\n    // matching on a given node as we can't register multiple event handlers for the same event in\n    // a template (this would mean having duplicate attributes).\n    if (!eventTargetResolver && isTNodeDirectiveHost) {\n      existingListener = findExistingListener(tView, lView, eventName, tNode.index);\n    }\n    if (existingListener !== null) {\n      // Attach a new listener to coalesced listeners list, maintaining the order in which\n      // listeners are registered. For performance reasons, we keep a reference to the last\n      // listener in that list (in `__ngLastListenerFn__` field), so we can avoid going through\n      // the entire set each time we need to add a new listener.\n      const lastListenerFn = (<any>existingListener).__ngLastListenerFn__ || existingListener;\n      lastListenerFn.__ngNextListenerFn__ = listenerFn;\n      (<any>existingListener).__ngLastListenerFn__ = listenerFn;\n      processOutputs = false;\n    } else {\n      listenerFn = wrapListener(tNode, lView, context, listenerFn);\n      const cleanupFn = renderer.listen(target as RElement, eventName, listenerFn);\n      ngDevMode && ngDevMode.rendererAddEventListener++;\n\n      lCleanup.push(listenerFn, cleanupFn);\n      tCleanup && tCleanup.push(eventName, idxOrTargetGetter, lCleanupIndex, lCleanupIndex + 1);\n    }\n  } else {\n    // Even if there is no native listener to add, we still need to wrap the listener so that OnPush\n    // ancestors are marked dirty when an event occurs.\n    listenerFn = wrapListener(tNode, lView, context, listenerFn);\n  }\n\n  // subscribe to directive outputs\n  const outputs = tNode.outputs;\n  let props: NodeOutputBindings[keyof NodeOutputBindings] | undefined;\n  if (processOutputs && outputs !== null && (props = outputs[eventName])) {\n    const propsLength = props.length;\n    if (propsLength) {\n      for (let i = 0; i < propsLength; i += 2) {\n        const index = props[i] as number;\n        ngDevMode && assertIndexInRange(lView, index);\n        const minifiedName = props[i + 1];\n        const directiveInstance = lView[index];\n        const output = directiveInstance[minifiedName];\n\n        if (ngDevMode && !isOutputSubscribable(output)) {\n          throw new Error(\n            `@Output ${minifiedName} not initialized in '${directiveInstance.constructor.name}'.`,\n          );\n        }\n\n        const subscription = (output as SubscribableOutput<unknown>).subscribe(listenerFn);\n        const idx = lCleanup.length;\n        lCleanup.push(listenerFn, subscription);\n        tCleanup && tCleanup.push(eventName, tNode.index, idx, -(idx + 1));\n      }\n    }\n  }\n}\n\nfunction executeListenerWithErrorHandling(\n  lView: LView,\n  context: {} | null,\n  listenerFn: (e?: any) => any,\n  e: any,\n): boolean {\n  const prevConsumer = setActiveConsumer(null);\n  try {\n    profiler(ProfilerEvent.OutputStart, context, listenerFn);\n    // Only explicitly returning false from a listener should preventDefault\n    return listenerFn(e) !== false;\n  } catch (error) {\n    handleError(lView, error);\n    return false;\n  } finally {\n    profiler(ProfilerEvent.OutputEnd, context, listenerFn);\n    setActiveConsumer(prevConsumer);\n  }\n}\n\n/**\n * Wraps an event listener with a function that marks ancestors dirty and prevents default behavior,\n * if applicable.\n *\n * @param tNode The TNode associated with this listener\n * @param lView The LView that contains this listener\n * @param listenerFn The listener function to call\n * @param wrapWithPreventDefault Whether or not to prevent default behavior\n * (the procedural renderer does this already, so in those cases, we should skip)\n */\nfunction wrapListener(\n  tNode: TNode,\n  lView: LView<{} | null>,\n  context: {} | null,\n  listenerFn: (e?: any) => any,\n): EventListener {\n  // Note: we are performing most of the work in the listener function itself\n  // to optimize listener registration.\n  return function wrapListenerIn_markDirtyAndPreventDefault(e: any) {\n    // Ivy uses `Function` as a special token that allows us to unwrap the function\n    // so that it can be invoked programmatically by `DebugNode.triggerEventHandler`.\n    if (e === Function) {\n      return listenerFn;\n    }\n\n    // In order to be backwards compatible with View Engine, events on component host nodes\n    // must also mark the component view itself dirty (i.e. the view that it owns).\n    const startView =\n      tNode.componentOffset > -1 ? getComponentLViewByIndex(tNode.index, lView) : lView;\n    markViewDirty(startView, NotificationSource.Listener);\n\n    let result = executeListenerWithErrorHandling(lView, context, listenerFn, e);\n    // A just-invoked listener function might have coalesced listeners so we need to check for\n    // their presence and invoke as needed.\n    let nextListenerFn = (<any>wrapListenerIn_markDirtyAndPreventDefault).__ngNextListenerFn__;\n    while (nextListenerFn) {\n      // We should prevent default if any of the listeners explicitly return false\n      result = executeListenerWithErrorHandling(lView, context, nextListenerFn, e) && result;\n      nextListenerFn = (<any>nextListenerFn).__ngNextListenerFn__;\n    }\n\n    return result;\n  };\n}\n\n/** Describes a subscribable output field value. */\ninterface SubscribableOutput<T> {\n  subscribe(listener: (v: T) => void): {unsubscribe: () => void};\n}\n\n/**\n * Whether the given value represents a subscribable output.\n *\n * For example, an `EventEmitter, a `Subject`, an `Observable` or an\n * `OutputEmitter`.\n */\nfunction isOutputSubscribable(value: unknown): value is SubscribableOutput<unknown> {\n  return (\n    value != null && typeof (value as Partial<SubscribableOutput<unknown>>).subscribe === 'function'\n  );\n}\n"]}
|
|
261
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"listener.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/instructions/listener.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AAGnE,OAAO,EAAC,kBAAkB,EAAC,MAAM,mBAAmB,CAAC;AAIrD,OAAO,EAAC,eAAe,EAAC,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAC,OAAO,EAAE,OAAO,EAAS,QAAQ,EAAQ,MAAM,oBAAoB,CAAC;AAC5E,OAAO,EAAC,eAAe,EAAC,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAC,QAAQ,EAAC,MAAM,aAAa,CAAC;AAErC,OAAO,EAAC,sBAAsB,EAAE,eAAe,EAAE,QAAQ,EAAE,QAAQ,EAAC,MAAM,UAAU,CAAC;AACrF,OAAO,EAAC,wBAAwB,EAAE,gBAAgB,EAAE,WAAW,EAAC,MAAM,oBAAoB,CAAC;AAE3F,OAAO,EAAC,aAAa,EAAC,MAAM,mBAAmB,CAAC;AAChD,OAAO,EACL,uBAAuB,EACvB,uBAAuB,EACvB,WAAW,EACX,qBAAqB,GACtB,MAAM,UAAU,CAAC;AAElB;;;;;GAKG;AACH,IAAI,kBAAkB,GAAG,CAAC,EAAY,EAAE,SAAiB,EAAE,UAA4B,EAAE,EAAE,GAAE,CAAC,CAAC;AAE/F,MAAM,UAAU,UAAU,CAAC,EAA6B;IACtD,kBAAkB,GAAG,EAAE,CAAC;AAC1B,CAAC;AAED;;;;;;;;;;;;;;GAcG;AACH,MAAM,UAAU,UAAU,CACxB,SAAiB,EACjB,UAA4B,EAC5B,UAAoB,EACpB,mBAA0C;IAE1C,MAAM,KAAK,GAAG,QAAQ,EAAa,CAAC;IACpC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IACjC,gBAAgB,CACd,KAAK,EACL,KAAK,EACL,KAAK,CAAC,QAAQ,CAAC,EACf,KAAK,EACL,SAAS,EACT,UAAU,EACV,mBAAmB,CACpB,CAAC;IACF,OAAO,UAAU,CAAC;AACpB,CAAC;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,UAAU,uBAAuB,CACrC,SAAiB,EACjB,UAA4B;IAE5B,MAAM,KAAK,GAAG,eAAe,EAAG,CAAC;IACjC,MAAM,KAAK,GAAG,QAAQ,EAAa,CAAC;IACpC,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,MAAM,UAAU,GAAG,sBAAsB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACtD,MAAM,QAAQ,GAAG,qBAAqB,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IACjE,gBAAgB,CAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;IACvE,OAAO,uBAAuB,CAAC;AACjC,CAAC;AAED;;;;GAIG;AACH,SAAS,oBAAoB,CAC3B,KAAY,EACZ,KAAY,EACZ,SAAiB,EACjB,QAAgB;IAEhB,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC;IAC/B,IAAI,QAAQ,IAAI,IAAI,EAAE,CAAC;QACrB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;YAChD,MAAM,gBAAgB,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;YACrC,IAAI,gBAAgB,KAAK,SAAS,IAAI,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,QAAQ,EAAE,CAAC;gBACnE,kFAAkF;gBAClF,iFAAiF;gBACjF,cAAc;gBACd,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAE,CAAC;gBACjC,MAAM,qBAAqB,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC9C,OAAO,QAAQ,CAAC,MAAM,GAAG,qBAAqB,CAAC,CAAC,CAAC,QAAQ,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAC1F,CAAC;YACD,qFAAqF;YACrF,wFAAwF;YACxF,yFAAyF;YACzF,4FAA4F;YAC5F,iFAAiF;YACjF,IAAI,OAAO,gBAAgB,KAAK,QAAQ,EAAE,CAAC;gBACzC,CAAC,IAAI,CAAC,CAAC;YACT,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,KAAY,EACZ,KAAuB,EACvB,QAAkB,EAClB,KAAY,EACZ,SAAiB,EACjB,UAA4B,EAC5B,mBAA0C;IAE1C,MAAM,oBAAoB,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;IACpD,MAAM,eAAe,GAAG,KAAK,CAAC,eAAe,CAAC;IAC9C,MAAM,QAAQ,GAAkB,eAAe,IAAI,uBAAuB,CAAC,KAAK,CAAC,CAAC;IAClF,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC;IAE/B,+FAA+F;IAC/F,iGAAiG;IACjG,+DAA+D;IAC/D,MAAM,QAAQ,GAAG,uBAAuB,CAAC,KAAK,CAAC,CAAC;IAEhD,SAAS,IAAI,eAAe,CAAC,KAAK,EAAE,4DAA2C,CAAC,CAAC;IAEjF,IAAI,cAAc,GAAG,IAAI,CAAC;IAE1B,qDAAqD;IACrD,sDAAsD;IACtD,2EAA2E;IAC3E,qCAAqC;IACrC,IAAI,KAAK,CAAC,IAAI,6BAAqB,IAAI,mBAAmB,EAAE,CAAC;QAC3D,MAAM,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAa,CAAC;QAC1D,MAAM,MAAM,GAAG,mBAAmB,CAAC,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;QAC1E,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC;QACtC,MAAM,iBAAiB,GAAG,mBAAmB;YAC3C,CAAC,CAAC,CAAC,MAAa,EAAE,EAAE,CAAC,mBAAmB,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;YAC1E,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC;QAEhB,uFAAuF;QACvF,8BAA8B;QAE9B,8FAA8F;QAC9F,0FAA0F;QAC1F,mFAAmF;QACnF,8FAA8F;QAC9F,4FAA4F;QAC5F,6EAA6E;QAC7E,EAAE;QACF,4FAA4F;QAC5F,sFAAsF;QACtF,kFAAkF;QAClF,IAAI,gBAAgB,GAAG,IAAI,CAAC;QAC5B,yFAAyF;QACzF,8FAA8F;QAC9F,eAAe;QACf,kFAAkF;QAClF,8FAA8F;QAC9F,4DAA4D;QAC5D,IAAI,CAAC,mBAAmB,IAAI,oBAAoB,EAAE,CAAC;YACjD,gBAAgB,GAAG,oBAAoB,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QAChF,CAAC;QACD,IAAI,gBAAgB,KAAK,IAAI,EAAE,CAAC;YAC9B,oFAAoF;YACpF,qFAAqF;YACrF,yFAAyF;YACzF,0DAA0D;YAC1D,MAAM,cAAc,GAAS,gBAAiB,CAAC,oBAAoB,IAAI,gBAAgB,CAAC;YACxF,cAAc,CAAC,oBAAoB,GAAG,UAAU,CAAC;YAC3C,gBAAiB,CAAC,oBAAoB,GAAG,UAAU,CAAC;YAC1D,cAAc,GAAG,KAAK,CAAC;QACzB,CAAC;aAAM,CAAC;YACN,UAAU,GAAG,YAAY,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;YAC7D,kBAAkB,CAAC,MAAM,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;YAClD,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAkB,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;YAC7E,SAAS,IAAI,SAAS,CAAC,wBAAwB,EAAE,CAAC;YAElD,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;YACrC,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,iBAAiB,EAAE,aAAa,EAAE,aAAa,GAAG,CAAC,CAAC,CAAC;QAC5F,CAAC;IACH,CAAC;SAAM,CAAC;QACN,gGAAgG;QAChG,mDAAmD;QACnD,UAAU,GAAG,YAAY,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;IAC/D,CAAC;IAED,iCAAiC;IACjC,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;IAC9B,IAAI,KAA+D,CAAC;IACpE,IAAI,cAAc,IAAI,OAAO,KAAK,IAAI,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC;QACvE,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC;QACjC,IAAI,WAAW,EAAE,CAAC;YAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;gBACxC,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAW,CAAC;gBACjC,SAAS,IAAI,kBAAkB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBAC9C,MAAM,YAAY,GAAG,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;gBAClC,MAAM,iBAAiB,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;gBACvC,MAAM,MAAM,GAAG,iBAAiB,CAAC,YAAY,CAAC,CAAC;gBAE/C,IAAI,SAAS,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC/C,MAAM,IAAI,KAAK,CACb,WAAW,YAAY,wBAAwB,iBAAiB,CAAC,WAAW,CAAC,IAAI,IAAI,CACtF,CAAC;gBACJ,CAAC;gBAED,MAAM,YAAY,GAAI,MAAsC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;gBACnF,MAAM,GAAG,GAAG,QAAQ,CAAC,MAAM,CAAC;gBAC5B,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;gBACxC,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;YACrE,CAAC;QACH,CAAC;IACH,CAAC;AACH,CAAC;AAED,SAAS,gCAAgC,CACvC,KAAY,EACZ,OAAkB,EAClB,UAA4B,EAC5B,CAAM;IAEN,MAAM,YAAY,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAC7C,IAAI,CAAC;QACH,QAAQ,oCAA4B,OAAO,EAAE,UAAU,CAAC,CAAC;QACzD,wEAAwE;QACxE,OAAO,UAAU,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC;IACjC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC1B,OAAO,KAAK,CAAC;IACf,CAAC;YAAS,CAAC;QACT,QAAQ,kCAA0B,OAAO,EAAE,UAAU,CAAC,CAAC;QACvD,iBAAiB,CAAC,YAAY,CAAC,CAAC;IAClC,CAAC;AACH,CAAC;AAED;;;;;;;;;GASG;AACH,SAAS,YAAY,CACnB,KAAY,EACZ,KAAuB,EACvB,OAAkB,EAClB,UAA4B;IAE5B,2EAA2E;IAC3E,qCAAqC;IACrC,OAAO,SAAS,yCAAyC,CAAC,CAAM;QAC9D,+EAA+E;QAC/E,iFAAiF;QACjF,IAAI,CAAC,KAAK,QAAQ,EAAE,CAAC;YACnB,OAAO,UAAU,CAAC;QACpB,CAAC;QAED,uFAAuF;QACvF,+EAA+E;QAC/E,MAAM,SAAS,GACb,KAAK,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,wBAAwB,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACpF,aAAa,CAAC,SAAS,sCAA8B,CAAC;QAEtD,IAAI,MAAM,GAAG,gCAAgC,CAAC,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;QAC7E,0FAA0F;QAC1F,uCAAuC;QACvC,IAAI,cAAc,GAAS,yCAA0C,CAAC,oBAAoB,CAAC;QAC3F,OAAO,cAAc,EAAE,CAAC;YACtB,4EAA4E;YAC5E,MAAM,GAAG,gCAAgC,CAAC,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,CAAC,CAAC,IAAI,MAAM,CAAC;YACvF,cAAc,GAAS,cAAe,CAAC,oBAAoB,CAAC;QAC9D,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC;AACJ,CAAC;AAOD;;;;;GAKG;AACH,SAAS,oBAAoB,CAAC,KAAc;IAC1C,OAAO,CACL,KAAK,IAAI,IAAI,IAAI,OAAQ,KAA8C,CAAC,SAAS,KAAK,UAAU,CACjG,CAAC;AACJ,CAAC","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.io/license\n */\n\nimport {setActiveConsumer} from '@angular/core/primitives/signals';\n\nimport {NotificationSource} from '../../change_detection/scheduling/zoneless_scheduling';\nimport {assertIndexInRange} from '../../util/assert';\nimport {NodeOutputBindings, TNode, TNodeType} from '../interfaces/node';\nimport {GlobalTargetResolver, Renderer} from '../interfaces/renderer';\nimport {RElement} from '../interfaces/renderer_dom';\nimport {isDirectiveHost} from '../interfaces/type_checks';\nimport {CLEANUP, CONTEXT, LView, RENDERER, TView} from '../interfaces/view';\nimport {assertTNodeType} from '../node_assert';\nimport {profiler} from '../profiler';\nimport {ProfilerEvent} from '../profiler_types';\nimport {getCurrentDirectiveDef, getCurrentTNode, getLView, getTView} from '../state';\nimport {getComponentLViewByIndex, getNativeByTNode, unwrapRNode} from '../util/view_utils';\n\nimport {markViewDirty} from './mark_view_dirty';\nimport {\n  getOrCreateLViewCleanup,\n  getOrCreateTViewCleanup,\n  handleError,\n  loadComponentRenderer,\n} from './shared';\n\n/**\n * Contains a reference to a function that disables event replay feature\n * for server-side rendered applications. This function is overridden with\n * an actual implementation when the event replay feature is enabled via\n * `withEventReplay()` call.\n */\nlet stashEventListener = (el: RElement, eventName: string, listenerFn: (e?: any) => any) => {};\n\nexport function setStashFn(fn: typeof stashEventListener) {\n  stashEventListener = fn;\n}\n\n/**\n * Adds an event listener to the current node.\n *\n * If an output exists on one of the node's directives, it also subscribes to the output\n * and saves the subscription for later cleanup.\n *\n * @param eventName Name of the event\n * @param listenerFn The function to be called when event emits\n * @param useCapture Whether or not to use capture in event listener - this argument is a reminder\n *     from the Renderer3 infrastructure and should be removed from the instruction arguments\n * @param eventTargetResolver Function that returns global target information in case this listener\n * should be attached to a global object like window, document or body\n *\n * @codeGenApi\n */\nexport function ɵɵlistener(\n  eventName: string,\n  listenerFn: (e?: any) => any,\n  useCapture?: boolean,\n  eventTargetResolver?: GlobalTargetResolver,\n): typeof ɵɵlistener {\n  const lView = getLView<{} | null>();\n  const tView = getTView();\n  const tNode = getCurrentTNode()!;\n  listenerInternal(\n    tView,\n    lView,\n    lView[RENDERER],\n    tNode,\n    eventName,\n    listenerFn,\n    eventTargetResolver,\n  );\n  return ɵɵlistener;\n}\n\n/**\n * Registers a synthetic host listener (e.g. `(@foo.start)`) on a component or directive.\n *\n * This instruction is for compatibility purposes and is designed to ensure that a\n * synthetic host listener (e.g. `@HostListener('@foo.start')`) properly gets rendered\n * in the component's renderer. Normally all host listeners are evaluated with the\n * parent component's renderer, but, in the case of animation @triggers, they need\n * to be evaluated with the sub component's renderer (because that's where the\n * animation triggers are defined).\n *\n * Do not use this instruction as a replacement for `listener`. This instruction\n * only exists to ensure compatibility with the ViewEngine's host binding behavior.\n *\n * @param eventName Name of the event\n * @param listenerFn The function to be called when event emits\n * @param useCapture Whether or not to use capture in event listener\n * @param eventTargetResolver Function that returns global target information in case this listener\n * should be attached to a global object like window, document or body\n *\n * @codeGenApi\n */\nexport function ɵɵsyntheticHostListener(\n  eventName: string,\n  listenerFn: (e?: any) => any,\n): typeof ɵɵsyntheticHostListener {\n  const tNode = getCurrentTNode()!;\n  const lView = getLView<{} | null>();\n  const tView = getTView();\n  const currentDef = getCurrentDirectiveDef(tView.data);\n  const renderer = loadComponentRenderer(currentDef, tNode, lView);\n  listenerInternal(tView, lView, renderer, tNode, eventName, listenerFn);\n  return ɵɵsyntheticHostListener;\n}\n\n/**\n * A utility function that checks if a given element has already an event handler registered for an\n * event with a specified name. The TView.cleanup data structure is used to find out which events\n * are registered for a given element.\n */\nfunction findExistingListener(\n  tView: TView,\n  lView: LView,\n  eventName: string,\n  tNodeIdx: number,\n): ((e?: any) => any) | null {\n  const tCleanup = tView.cleanup;\n  if (tCleanup != null) {\n    for (let i = 0; i < tCleanup.length - 1; i += 2) {\n      const cleanupEventName = tCleanup[i];\n      if (cleanupEventName === eventName && tCleanup[i + 1] === tNodeIdx) {\n        // We have found a matching event name on the same node but it might not have been\n        // registered yet, so we must explicitly verify entries in the LView cleanup data\n        // structures.\n        const lCleanup = lView[CLEANUP]!;\n        const listenerIdxInLCleanup = tCleanup[i + 2];\n        return lCleanup.length > listenerIdxInLCleanup ? lCleanup[listenerIdxInLCleanup] : null;\n      }\n      // TView.cleanup can have a mix of 4-elements entries (for event handler cleanups) or\n      // 2-element entries (for directive and queries destroy hooks). As such we can encounter\n      // blocks of 4 or 2 items in the tView.cleanup and this is why we iterate over 2 elements\n      // first and jump another 2 elements if we detect listeners cleanup (4 elements). Also check\n      // documentation of TView.cleanup for more details of this data structure layout.\n      if (typeof cleanupEventName === 'string') {\n        i += 2;\n      }\n    }\n  }\n  return null;\n}\n\nexport function listenerInternal(\n  tView: TView,\n  lView: LView<{} | null>,\n  renderer: Renderer,\n  tNode: TNode,\n  eventName: string,\n  listenerFn: (e?: any) => any,\n  eventTargetResolver?: GlobalTargetResolver,\n): void {\n  const isTNodeDirectiveHost = isDirectiveHost(tNode);\n  const firstCreatePass = tView.firstCreatePass;\n  const tCleanup: false | any[] = firstCreatePass && getOrCreateTViewCleanup(tView);\n  const context = lView[CONTEXT];\n\n  // When the ɵɵlistener instruction was generated and is executed we know that there is either a\n  // native listener or a directive output on this element. As such we we know that we will have to\n  // register a listener and store its cleanup function on LView.\n  const lCleanup = getOrCreateLViewCleanup(lView);\n\n  ngDevMode && assertTNodeType(tNode, TNodeType.AnyRNode | TNodeType.AnyContainer);\n\n  let processOutputs = true;\n\n  // Adding a native event listener is applicable when:\n  // - The corresponding TNode represents a DOM element.\n  // - The event target has a resolver (usually resulting in a global object,\n  //   such as `window` or `document`).\n  if (tNode.type & TNodeType.AnyRNode || eventTargetResolver) {\n    const native = getNativeByTNode(tNode, lView) as RElement;\n    const target = eventTargetResolver ? eventTargetResolver(native) : native;\n    const lCleanupIndex = lCleanup.length;\n    const idxOrTargetGetter = eventTargetResolver\n      ? (_lView: LView) => eventTargetResolver(unwrapRNode(_lView[tNode.index]))\n      : tNode.index;\n\n    // In order to match current behavior, native DOM event listeners must be added for all\n    // events (including outputs).\n\n    // There might be cases where multiple directives on the same element try to register an event\n    // handler function for the same event. In this situation we want to avoid registration of\n    // several native listeners as each registration would be intercepted by NgZone and\n    // trigger change detection. This would mean that a single user action would result in several\n    // change detections being invoked. To avoid this situation we want to have only one call to\n    // native handler registration (for the same element and same type of event).\n    //\n    // In order to have just one native event handler in presence of multiple handler functions,\n    // we just register a first handler function as a native event listener and then chain\n    // (coalesce) other handler functions on top of the first native handler function.\n    let existingListener = null;\n    // Please note that the coalescing described here doesn't happen for events specifying an\n    // alternative target (ex. (document:click)) - this is to keep backward compatibility with the\n    // view engine.\n    // Also, we don't have to search for existing listeners is there are no directives\n    // matching on a given node as we can't register multiple event handlers for the same event in\n    // a template (this would mean having duplicate attributes).\n    if (!eventTargetResolver && isTNodeDirectiveHost) {\n      existingListener = findExistingListener(tView, lView, eventName, tNode.index);\n    }\n    if (existingListener !== null) {\n      // Attach a new listener to coalesced listeners list, maintaining the order in which\n      // listeners are registered. For performance reasons, we keep a reference to the last\n      // listener in that list (in `__ngLastListenerFn__` field), so we can avoid going through\n      // the entire set each time we need to add a new listener.\n      const lastListenerFn = (<any>existingListener).__ngLastListenerFn__ || existingListener;\n      lastListenerFn.__ngNextListenerFn__ = listenerFn;\n      (<any>existingListener).__ngLastListenerFn__ = listenerFn;\n      processOutputs = false;\n    } else {\n      listenerFn = wrapListener(tNode, lView, context, listenerFn);\n      stashEventListener(native, eventName, listenerFn);\n      const cleanupFn = renderer.listen(target as RElement, eventName, listenerFn);\n      ngDevMode && ngDevMode.rendererAddEventListener++;\n\n      lCleanup.push(listenerFn, cleanupFn);\n      tCleanup && tCleanup.push(eventName, idxOrTargetGetter, lCleanupIndex, lCleanupIndex + 1);\n    }\n  } else {\n    // Even if there is no native listener to add, we still need to wrap the listener so that OnPush\n    // ancestors are marked dirty when an event occurs.\n    listenerFn = wrapListener(tNode, lView, context, listenerFn);\n  }\n\n  // subscribe to directive outputs\n  const outputs = tNode.outputs;\n  let props: NodeOutputBindings[keyof NodeOutputBindings] | undefined;\n  if (processOutputs && outputs !== null && (props = outputs[eventName])) {\n    const propsLength = props.length;\n    if (propsLength) {\n      for (let i = 0; i < propsLength; i += 2) {\n        const index = props[i] as number;\n        ngDevMode && assertIndexInRange(lView, index);\n        const minifiedName = props[i + 1];\n        const directiveInstance = lView[index];\n        const output = directiveInstance[minifiedName];\n\n        if (ngDevMode && !isOutputSubscribable(output)) {\n          throw new Error(\n            `@Output ${minifiedName} not initialized in '${directiveInstance.constructor.name}'.`,\n          );\n        }\n\n        const subscription = (output as SubscribableOutput<unknown>).subscribe(listenerFn);\n        const idx = lCleanup.length;\n        lCleanup.push(listenerFn, subscription);\n        tCleanup && tCleanup.push(eventName, tNode.index, idx, -(idx + 1));\n      }\n    }\n  }\n}\n\nfunction executeListenerWithErrorHandling(\n  lView: LView,\n  context: {} | null,\n  listenerFn: (e?: any) => any,\n  e: any,\n): boolean {\n  const prevConsumer = setActiveConsumer(null);\n  try {\n    profiler(ProfilerEvent.OutputStart, context, listenerFn);\n    // Only explicitly returning false from a listener should preventDefault\n    return listenerFn(e) !== false;\n  } catch (error) {\n    handleError(lView, error);\n    return false;\n  } finally {\n    profiler(ProfilerEvent.OutputEnd, context, listenerFn);\n    setActiveConsumer(prevConsumer);\n  }\n}\n\n/**\n * Wraps an event listener with a function that marks ancestors dirty and prevents default behavior,\n * if applicable.\n *\n * @param tNode The TNode associated with this listener\n * @param lView The LView that contains this listener\n * @param listenerFn The listener function to call\n * @param wrapWithPreventDefault Whether or not to prevent default behavior\n * (the procedural renderer does this already, so in those cases, we should skip)\n */\nfunction wrapListener(\n  tNode: TNode,\n  lView: LView<{} | null>,\n  context: {} | null,\n  listenerFn: (e?: any) => any,\n): EventListener {\n  // Note: we are performing most of the work in the listener function itself\n  // to optimize listener registration.\n  return function wrapListenerIn_markDirtyAndPreventDefault(e: any) {\n    // Ivy uses `Function` as a special token that allows us to unwrap the function\n    // so that it can be invoked programmatically by `DebugNode.triggerEventHandler`.\n    if (e === Function) {\n      return listenerFn;\n    }\n\n    // In order to be backwards compatible with View Engine, events on component host nodes\n    // must also mark the component view itself dirty (i.e. the view that it owns).\n    const startView =\n      tNode.componentOffset > -1 ? getComponentLViewByIndex(tNode.index, lView) : lView;\n    markViewDirty(startView, NotificationSource.Listener);\n\n    let result = executeListenerWithErrorHandling(lView, context, listenerFn, e);\n    // A just-invoked listener function might have coalesced listeners so we need to check for\n    // their presence and invoke as needed.\n    let nextListenerFn = (<any>wrapListenerIn_markDirtyAndPreventDefault).__ngNextListenerFn__;\n    while (nextListenerFn) {\n      // We should prevent default if any of the listeners explicitly return false\n      result = executeListenerWithErrorHandling(lView, context, nextListenerFn, e) && result;\n      nextListenerFn = (<any>nextListenerFn).__ngNextListenerFn__;\n    }\n\n    return result;\n  };\n}\n\n/** Describes a subscribable output field value. */\ninterface SubscribableOutput<T> {\n  subscribe(listener: (v: T) => void): {unsubscribe: () => void};\n}\n\n/**\n * Whether the given value represents a subscribable output.\n *\n * For example, an `EventEmitter, a `Subject`, an `Observable` or an\n * `OutputEmitter`.\n */\nfunction isOutputSubscribable(value: unknown): value is SubscribableOutput<unknown> {\n  return (\n    value != null && typeof (value as Partial<SubscribableOutput<unknown>>).subscribe === 'function'\n  );\n}\n"]}
|