Skip to content

Commit

Permalink
feat(primeng/p-overlay): add listener for close overlay by escape key
Browse files Browse the repository at this point in the history
  • Loading branch information
volvachev authored and Egor Volvachev committed Jan 12, 2023
1 parent 5539bb2 commit afaad0f
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 5 deletions.
1 change: 1 addition & 0 deletions src/app/components/api/overlayoptions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ export interface OverlayOptions {
baseZIndex?: number;
showTransitionOptions?: string;
hideTransitionOptions?: string;
hideOnEscape?: boolean;
listener?: (event: Event, options?: OverlayListenerOptions) => boolean | void;
responsive?: ResponsiveOverlayOptions | undefined;
onBeforeShow?: (event?: OverlayOnBeforeShowEvent) => void;
Expand Down
43 changes: 38 additions & 5 deletions src/app/components/overlay/overlay.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ import { CommonModule, DOCUMENT } from '@angular/common';
import {
AfterContentInit,
ChangeDetectionStrategy,
ChangeDetectorRef,
Component,
ContentChildren,
ElementRef,
Expand All @@ -12,6 +11,7 @@ import {
Inject,
Input,
NgModule,
NgZone,
OnDestroy,
Output,
QueryList,
Expand Down Expand Up @@ -266,6 +266,8 @@ export class Overlay implements AfterContentInit, OnDestroy {

documentResizeListener: any;

private documentKeyboardListener: VoidFunction | null;

private window: Window | null;

protected transformOptions: any = {
Expand Down Expand Up @@ -293,11 +295,11 @@ export class Overlay implements AfterContentInit, OnDestroy {
return this.mode || (this.modal ? 'modal' : 'overlay');
}

get overlayOptions() {
get overlayOptions(): OverlayOptions {
return { ...this.config?.overlayOptions, ...this.options }; // TODO: Improve performance
}

get overlayResponsiveOptions() {
get overlayResponsiveOptions(): ResponsiveOverlayOptions {
return { ...this.overlayOptions?.responsive, ...this.responsive }; // TODO: Improve performance
}

Expand All @@ -317,7 +319,7 @@ export class Overlay implements AfterContentInit, OnDestroy {
return DomHandler.getTargetElement(this.target, this.el?.nativeElement);
}

constructor(@Inject(DOCUMENT) private document: Document, public el: ElementRef, public renderer: Renderer2, private config: PrimeNGConfig, public overlayService: OverlayService, private cd: ChangeDetectorRef) {
constructor(@Inject(DOCUMENT) private document: Document, public el: ElementRef, public renderer: Renderer2, private config: PrimeNGConfig, public overlayService: OverlayService, private zone: NgZone) {
this.window = this.document.defaultView;
}

Expand Down Expand Up @@ -435,12 +437,14 @@ export class Overlay implements AfterContentInit, OnDestroy {
this.bindScrollListener();
this.bindDocumentClickListener();
this.bindDocumentResizeListener();
this.bindDocumentKeyboardListener();
}

unbindListeners() {
this.unbindScrollListener();
this.unbindDocumentClickListener();
this.unbindDocumentResizeListener();
this.unbindDocumentKeyboardListener();
}

bindScrollListener() {
Expand Down Expand Up @@ -483,7 +487,7 @@ export class Overlay implements AfterContentInit, OnDestroy {

bindDocumentResizeListener() {
if (!this.documentResizeListener) {
this.documentResizeListener = this.renderer.listen('window', 'resize', (event) => {
this.documentResizeListener = this.renderer.listen(this.window, 'resize', (event) => {
const valid = this.listener ? this.listener(event, { type: 'resize', mode: this.overlayMode, valid: !DomHandler.isTouchDevice() }) : !DomHandler.isTouchDevice();

valid && this.hide(event, true);
Expand All @@ -498,6 +502,35 @@ export class Overlay implements AfterContentInit, OnDestroy {
}
}

bindDocumentKeyboardListener(): void {
if (this.documentKeyboardListener) {
return;
}

this.zone.runOutsideAngular(() => {
this.documentKeyboardListener = this.renderer.listen(this.window, 'keydown', (event) => {
if (!this.overlayOptions.hideOnEscape || event.keyCode !== 27) {
return;
}

const valid = this.listener ? this.listener(event, { type: 'keydown', mode: this.overlayMode, valid: !DomHandler.isTouchDevice() }) : !DomHandler.isTouchDevice();

if (valid) {
this.zone.run(() => {
this.hide(event, true);
});
}
});
});
}

unbindDocumentKeyboardListener(): void {
if (this.documentKeyboardListener) {
this.documentKeyboardListener();
this.documentKeyboardListener = null;
}
}

ngOnDestroy() {
this.hide(this.overlayEl, true);

Expand Down

0 comments on commit afaad0f

Please sign in to comment.