Merge pull request #1374 from cseale/mct1197

[Dialogs] Close dialogs by pressing the ESC key
This commit is contained in:
Pete Richards 2017-01-17 13:23:23 -08:00 committed by GitHub
commit c2253f5010
3 changed files with 62 additions and 3 deletions

View File

@ -53,7 +53,8 @@ define([
"depends": [ "depends": [
"overlayService", "overlayService",
"$q", "$q",
"$log" "$log",
"$document"
] ]
}, },
{ {

View File

@ -35,11 +35,15 @@ define(
* @memberof platform/commonUI/dialog * @memberof platform/commonUI/dialog
* @constructor * @constructor
*/ */
function DialogService(overlayService, $q, $log) { function DialogService(overlayService, $q, $log, $document) {
this.overlayService = overlayService; this.overlayService = overlayService;
this.$q = $q; this.$q = $q;
this.$log = $log; this.$log = $log;
this.activeOverlay = undefined; this.activeOverlay = undefined;
this.findBody = function () {
return $document.find('body');
};
} }
/** /**
@ -76,13 +80,22 @@ define(
// Cancel or X button click // Cancel or X button click
function cancel() { function cancel() {
deferred.reject(); deferred.reject();
self.findBody().off('keydown', handleEscKeydown);
self.dismissOverlay(overlay); self.dismissOverlay(overlay);
} }
function handleEscKeydown(event){
if (event.keyCode === 27) {
cancel();
}
}
// Add confirm/cancel callbacks // Add confirm/cancel callbacks
model.confirm = confirm; model.confirm = confirm;
model.cancel = cancel; model.cancel = cancel;
this.findBody().on('keydown', handleEscKeydown);
if (this.canShowDialog(model)) { if (this.canShowDialog(model)) {
// Add the overlay using the OverlayService, which // Add the overlay using the OverlayService, which
// will handle actual insertion into the DOM // will handle actual insertion into the DOM

View File

@ -33,6 +33,8 @@ define(
mockLog, mockLog,
mockOverlay, mockOverlay,
mockDeferred, mockDeferred,
mockDocument,
mockBody,
dialogService; dialogService;
beforeEach(function () { beforeEach(function () {
@ -56,6 +58,16 @@ define(
"deferred", "deferred",
["resolve", "reject"] ["resolve", "reject"]
); );
mockDocument = jasmine.createSpyObj(
"$document",
["find"]
);
mockBody = angular.element(document.createElement('body'));
spyOn(mockBody, 'on').andCallThrough();
spyOn(mockBody, 'off').andCallThrough();
mockDocument.find.andReturn(mockBody);
mockDeferred.promise = "mock promise"; mockDeferred.promise = "mock promise";
mockQ.defer.andReturn(mockDeferred); mockQ.defer.andReturn(mockDeferred);
@ -64,7 +76,8 @@ define(
dialogService = new DialogService( dialogService = new DialogService(
mockOverlayService, mockOverlayService,
mockQ, mockQ,
mockLog mockLog,
mockDocument
); );
}); });
@ -130,6 +143,38 @@ define(
); );
}); });
it("adds a keydown event listener to the body", function () {
dialogService.getUserInput({}, {});
expect(mockDocument.find).toHaveBeenCalledWith("body");
expect(mockBody.on).toHaveBeenCalledWith("keydown", jasmine.any(Function));
});
it("destroys the event listener when the dialog is cancelled", function () {
dialogService.getUserInput({}, {});
mockOverlayService.createOverlay.mostRecentCall.args[1].cancel();
expect(mockBody.off).toHaveBeenCalledWith("keydown", jasmine.any(Function));
});
it("cancels the dialog when an escape keydown event is triggered", function () {
dialogService.getUserInput({}, {});
mockBody.triggerHandler({
type: 'keydown',
keyCode: 27
});
expect(mockDeferred.reject).toHaveBeenCalled();
expect(mockDeferred.resolve).not.toHaveBeenCalled();
});
it("ignores non escape keydown events", function () {
dialogService.getUserInput({}, {});
mockBody.triggerHandler({
type: 'keydown',
keyCode: 13
});
expect(mockDeferred.reject).not.toHaveBeenCalled();
expect(mockDeferred.resolve).not.toHaveBeenCalled();
});
describe("the blocking message dialog", function () { describe("the blocking message dialog", function () {
var dialogModel = {}; var dialogModel = {};
var dialogHandle; var dialogHandle;