From 1d78f784077a42c13f3f85c4a6843b2c9319acd1 Mon Sep 17 00:00:00 2001 From: Dan Bucholtz Date: Thu, 9 Jun 2016 13:54:46 -0500 Subject: [PATCH] feat(popover): background dismiss, escape dismiss background dismiss, escape dismiss closes #6817 --- src/components/popover/popover.ts | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/components/popover/popover.ts b/src/components/popover/popover.ts index a759de98a55..be42ffbfcd4 100644 --- a/src/components/popover/popover.ts +++ b/src/components/popover/popover.ts @@ -1,5 +1,4 @@ -import {Component, ViewChild, ViewContainerRef, ComponentResolver} from '@angular/core'; -import {Renderer, ElementRef} from '@angular/core'; +import {Component, ComponentResolver, ElementRef, HostListener, Renderer, ViewChild, ViewContainerRef} from '@angular/core'; import {addSelector} from '../../config/bootstrap'; import {Animation} from '../../animations/animation'; @@ -7,6 +6,7 @@ import {Transition, TransitionOptions} from '../../transitions/transition'; import {Config} from '../../config/config'; import {NavParams} from '../nav/nav-params'; import {Platform} from '../../platform/platform'; +import {Key} from '../../util/key'; import {isPresent, isUndefined, isDefined} from '../../util/util'; import {nativeRaf, CSS} from '../../util/dom'; import {ViewController} from '../nav/view-controller'; @@ -204,7 +204,7 @@ class PopoverCmp { }); } - ionViewDidEnter() { + ngAfterViewInit() { let activeElement: any = document.activeElement; if (document.activeElement) { activeElement.blur(); @@ -226,6 +226,13 @@ class PopoverCmp { this.dismiss('backdrop'); } } + + @HostListener('body:keyup', ['$event']) + private _keyUp(ev: KeyboardEvent) { + if (this.enabled && this._viewCtrl.isLast() && ev.keyCode === Key.ESCAPE ) { + this.bdClick(); + } + } } export interface PopoverOptions {