From cf071c75f5dd03a5684eb2984eacef427afe94d9 Mon Sep 17 00:00:00 2001 From: Kristiyan Kostadinov Date: Fri, 28 Jul 2017 18:06:32 +0300 Subject: [PATCH] chore(dialog): switch to OnPush change detection (#5422) Switches the dialog container to `OnPush` change detection. Relates to #5035. --- src/lib/dialog/dialog-container.ts | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/src/lib/dialog/dialog-container.ts b/src/lib/dialog/dialog-container.ts index 24cc5f96958d..f70b14d5a590 100644 --- a/src/lib/dialog/dialog-container.ts +++ b/src/lib/dialog/dialog-container.ts @@ -16,6 +16,8 @@ import { EventEmitter, Inject, Optional, + ChangeDetectionStrategy, + ChangeDetectorRef, } from '@angular/core'; import { animate, @@ -49,6 +51,7 @@ export function throwMdDialogContentAlreadyAttachedError() { selector: 'md-dialog-container, mat-dialog-container', templateUrl: 'dialog-container.html', styleUrls: ['dialog.css'], + changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, animations: [ trigger('slideDialog', [ @@ -104,6 +107,7 @@ export class MdDialogContainer extends BasePortalHost { private _ngZone: NgZone, private _elementRef: ElementRef, private _focusTrapFactory: FocusTrapFactory, + private _changeDetectorRef: ChangeDetectorRef, @Optional() @Inject(DOCUMENT) _document: any) { super(); @@ -120,7 +124,12 @@ export class MdDialogContainer extends BasePortalHost { } this._savePreviouslyFocusedElement(); - return this._portalHost.attachComponentPortal(portal); + const componentRef = this._portalHost.attachComponentPortal(portal); + + // Ensure that the initial view change are picked up. + componentRef.changeDetectorRef.markForCheck(); + + return componentRef; } /** @@ -133,7 +142,12 @@ export class MdDialogContainer extends BasePortalHost { } this._savePreviouslyFocusedElement(); - return this._portalHost.attachTemplatePortal(portal); + const locals = this._portalHost.attachTemplatePortal(portal); + + // Ensure that the initial view change are picked up. + this._changeDetectorRef.markForCheck(); + + return locals; } /** Moves the focus inside the focus trap. */