#120: hide active popup on route transition

This commit is contained in:
SleepWalker 2016-07-26 22:28:58 +03:00
parent 04a1022011
commit eb3d436843
2 changed files with 18 additions and 5 deletions

View File

@ -1,6 +1,7 @@
import React, { Component, PropTypes } from 'react';
import ReactCSSTransitionGroup from 'react-addons-css-transition-group';
import { browserHistory } from 'react-router';
import styles from './popup.scss';
@ -17,10 +18,12 @@ export class PopupStack extends Component {
componentWillMount() {
document.addEventListener('keyup', this.onKeyPress);
this.unlistenTransition = browserHistory.listenBefore(this.onRouteLeave);
}
componentWillUnmount() {
document.removeEventListener('keyup', this.onKeyPress);
this.unlistenTransition();
}
render() {
@ -68,14 +71,24 @@ export class PopupStack extends Component {
};
}
onKeyPress = (event) => {
if (event.which === 27) { // ESC key
popStack() {
const popup = this.props.popups.slice(-1)[0];
if (popup && !popup.disableOverlayClose) {
this.props.destroy(popup);
}
}
onKeyPress = (event) => {
if (event.which === 27) { // ESC key
this.popStack();
}
};
onRouteLeave = (nextLocation) => {
if (nextLocation) {
this.popStack();
}
};
}

View File

@ -124,7 +124,7 @@ describe('<PopupStack />', () => {
sinon.assert.calledOnce(props.destroy);
});
it('should hide first popup in stack', () => {
it('should hide first popup in stack if esc pressed', () => {
const props = {
destroy: sinon.stub(),
popups: [