Skip to content

Commit

Permalink
fix(module:modal): cannot to close in order of overlay opens when usi…
Browse files Browse the repository at this point in the history
…ng esc (NG-ZORRO#3339)

close NG-ZORRO#3338
  • Loading branch information
hsuanxyz authored and Ricbet committed Apr 9, 2020
1 parent aa34d04 commit cd1923c
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 5 deletions.
30 changes: 25 additions & 5 deletions components/modal/nz-modal.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
import { FocusTrap, FocusTrapFactory } from '@angular/cdk/a11y';

import { ESCAPE } from '@angular/cdk/keycodes';
import { BlockScrollStrategy, Overlay, OverlayRef } from '@angular/cdk/overlay';
import { BlockScrollStrategy, Overlay, OverlayKeyboardDispatcher, OverlayRef } from '@angular/cdk/overlay';
import { DOCUMENT } from '@angular/common';
import {
AfterViewInit,
Expand Down Expand Up @@ -168,11 +168,13 @@ export class NzModalComponent<T = any, R = any> extends NzModalRef<T, R>
private previouslyFocusedElement: HTMLElement;
private focusTrap: FocusTrap;
private scrollStrategy: BlockScrollStrategy;
private overlayRef: OverlayRef;

[key: string]: any; // tslint:disable-line:no-any

constructor(
private overlay: Overlay,
private overlayKeyboardDispatcher: OverlayKeyboardDispatcher,
private i18n: NzI18nService,
private cfr: ComponentFactoryResolver,
private elementRef: ElementRef,
Expand All @@ -192,10 +194,6 @@ export class NzModalComponent<T = any, R = any> extends NzModalRef<T, R>
this.locale = this.i18n.getLocaleData('Modal') as { okText: string; cancelText: string };
});

fromEvent<KeyboardEvent>(this.document.body, 'keydown')
.pipe(takeUntil(this.unsubscribe$))
.subscribe(e => this.keydownListener(e));

if (this.isComponent(this.nzContent)) {
this.createDynamicComponent(this.nzContent as Type<T>); // Create component along without View
}
Expand All @@ -209,11 +207,22 @@ export class NzModalComponent<T = any, R = any> extends NzModalRef<T, R>
this.container = typeof this.nzGetContainer === 'function' ? this.nzGetContainer() : this.nzGetContainer;
if (this.container instanceof HTMLElement) {
this.container.appendChild(this.elementRef.nativeElement);
fromEvent<KeyboardEvent>(this.document.body, 'keydown')
.pipe(takeUntil(this.unsubscribe$))
.subscribe(e => this.keydownListener(e));
} else if (this.container instanceof OverlayRef) {
// NOTE: only attach the dom to overlay, the view container is not changed actually
this.setOverlayRef(this.container);
this.container.overlayElement.appendChild(this.elementRef.nativeElement);
}

if (this.overlayRef) {
this.overlayRef
.keydownEvents()
.pipe(takeUntil(this.unsubscribe$))
.subscribe(e => this.keydownListener(e));
}

// Register modal when afterOpen/afterClose is stable
this.modalControl.registerModal(this);
}
Expand Down Expand Up @@ -253,6 +262,10 @@ export class NzModalComponent<T = any, R = any> extends NzModalRef<T, R>
});
}

setOverlayRef(overlayRef: OverlayRef): void {
this.overlayRef = overlayRef;
}

keydownListener(event: KeyboardEvent): void {
if (event.keyCode === ESCAPE && this.nzKeyboard) {
this.onClickOkCancel('cancel');
Expand Down Expand Up @@ -361,6 +374,13 @@ export class NzModalComponent<T = any, R = any> extends NzModalRef<T, R>
this.scrollStrategy.enable();
this.savePreviouslyFocusedElement();
this.trapFocus();
if (this.container instanceof OverlayRef) {
this.overlayKeyboardDispatcher.add(this.overlayRef);
}
} else {
if (this.container instanceof OverlayRef) {
this.overlayKeyboardDispatcher.remove(this.overlayRef);
}
}

return Promise.resolve(animation ? this.animateTo(visible) : undefined).then(() => {
Expand Down
1 change: 1 addition & 0 deletions components/modal/nz-modal.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ export class ModalBuilderForService {
}

this.changeProps(options);
this.modalRef!.instance.setOverlayRef(this.overlayRef);
this.modalRef!.instance.open();
this.modalRef!.instance.nzAfterClose.subscribe(() => this.destroyModal()); // [NOTE] By default, close equals destroy when using as Service
}
Expand Down

0 comments on commit cd1923c

Please sign in to comment.