From 742c3c1b17aaa015ad09e1fba9c0209faa07bf8e Mon Sep 17 00:00:00 2001 From: Nick Uraltsev Date: Wed, 18 Nov 2015 23:51:47 -0800 Subject: [PATCH] [fixed] Modal does not fire show callback --- src/Modal.js | 4 ++++ test/ModalSpec.js | 24 ++++++++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/src/Modal.js b/src/Modal.js index 6a65d43c..04272650 100644 --- a/src/Modal.js +++ b/src/Modal.js @@ -296,6 +296,10 @@ const Modal = React.createClass({ addFocusListener(this.enforceFocus); this.focus(); + + if (this.props.onShow) { + this.props.onShow(); + } }, onHide() { diff --git a/test/ModalSpec.js b/test/ModalSpec.js index 5ea28dfa..7fac6de9 100644 --- a/test/ModalSpec.js +++ b/test/ModalSpec.js @@ -261,6 +261,30 @@ describe('Modal', function () { , mountPoint); }); + it('Should fire show callback on mount', function () { + let onShowSpy = sinon.spy(); + render( + + Message + + , mountPoint); + + expect(onShowSpy).to.have.been.calledOnce; + }); + + it('Should fire show callback on update', function () { + let onShowSpy = sinon.spy(); + let instance = render( + + Message + + , mountPoint); + + instance.renderWithProps({ show: true }); + + expect(onShowSpy).to.have.been.calledOnce; + }); + describe('Focused state', function () { let focusableContainer = null;