From ba2ce243b0cad7733e8629431f33cdc7572273fb Mon Sep 17 00:00:00 2001 From: Wesley Cho Date: Mon, 10 Aug 2015 07:06:03 -0700 Subject: [PATCH] fix(modal): correctly remove custom class - Fix removal of custom class on closing/dismissing of modal Closes #4175 Fixes #4171 --- src/modal/modal.js | 2 +- src/modal/test/modal.spec.js | 22 +++++++++++++++++++--- 2 files changed, 20 insertions(+), 4 deletions(-) diff --git a/src/modal/modal.js b/src/modal/modal.js index 106b988a71..a6cafcce75 100644 --- a/src/modal/modal.js +++ b/src/modal/modal.js @@ -272,7 +272,7 @@ angular.module('ui.bootstrap.modal', []) openedWindows.remove(modalInstance); removeAfterAnimate(modalWindow.modalDomEl, modalWindow.modalScope, function() { - body.toggleClass(modalInstance.openedClass || OPENED_MODAL_CLASS, openedWindows.length() > 0); + body.toggleClass(modalWindow.openedClass || OPENED_MODAL_CLASS, openedWindows.length() > 0); }); checkRemoveBackdrop(); diff --git a/src/modal/test/modal.spec.js b/src/modal/test/modal.spec.js index 2be1b7c969..0b6abb8640 100644 --- a/src/modal/test/modal.spec.js +++ b/src/modal/test/modal.spec.js @@ -768,13 +768,18 @@ describe('$modal', function () { }); describe('openedClass', function () { + var body; + + beforeEach(function() { + body = $document.find('body'); + }); it('should add the modal-open class to the body element by default', function () { open({ template: '
dummy modal
' }); - expect($document.find('body')).toHaveClass('modal-open'); + expect(body).toHaveClass('modal-open'); }); it('should add the custom class to the body element', function () { @@ -783,11 +788,22 @@ describe('$modal', function () { openedClass: 'foo' }); - var body = $document.find('body'); - expect(body).toHaveClass('foo'); expect(body).not.toHaveClass('modal-open'); }); + + it('should remove the custom class on closing of modal', function () { + var modal = open({ + template: '
dummy modal
', + openedClass: 'foo' + }); + + expect(body).toHaveClass('foo'); + + close(modal); + + expect(body).not.toHaveClass('foo'); + }); }); });