2019-12-07 13:28:52 +02:00
|
|
|
import React from 'react';
|
2019-06-30 16:32:50 +03:00
|
|
|
import { TransitionGroup, CSSTransition } from 'react-transition-group';
|
2019-12-07 21:02:00 +02:00
|
|
|
import { browserHistory } from 'app/services/history';
|
2019-06-30 16:32:50 +03:00
|
|
|
import { connect } from 'react-redux';
|
2019-12-07 21:02:00 +02:00
|
|
|
import { RootState } from 'app/reducers';
|
2016-06-03 22:38:59 +03:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
import { PopupConfig } from './reducer';
|
|
|
|
import { destroy } from './actions';
|
2016-05-01 20:50:55 +03:00
|
|
|
import styles from './popup.scss';
|
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
export class PopupStack extends React.Component<{
|
|
|
|
popups: PopupConfig[];
|
|
|
|
destroy: (popup: PopupConfig) => void;
|
|
|
|
}> {
|
|
|
|
unlistenTransition: () => void;
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2019-12-10 09:47:32 +02:00
|
|
|
componentDidMount() {
|
2019-11-27 11:03:32 +02:00
|
|
|
document.addEventListener('keyup', this.onKeyPress);
|
|
|
|
this.unlistenTransition = browserHistory.listen(this.onRouteLeave);
|
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
document.removeEventListener('keyup', this.onKeyPress);
|
|
|
|
this.unlistenTransition();
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const { popups } = this.props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<TransitionGroup>
|
|
|
|
{popups.map((popup, index) => {
|
|
|
|
const { Popup } = popup;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<CSSTransition
|
|
|
|
key={index}
|
2019-12-29 13:57:44 +02:00
|
|
|
classNames={{
|
2019-11-27 11:03:32 +02:00
|
|
|
enter: styles.trEnter,
|
|
|
|
enterActive: styles.trEnterActive,
|
|
|
|
exit: styles.trExit,
|
|
|
|
exitActive: styles.trExitActive,
|
|
|
|
}}
|
|
|
|
timeout={500}
|
|
|
|
>
|
|
|
|
<div
|
|
|
|
className={styles.overlay}
|
|
|
|
onClick={this.onOverlayClick(popup)}
|
|
|
|
>
|
|
|
|
<Popup onClose={this.onClose(popup)} />
|
|
|
|
</div>
|
|
|
|
</CSSTransition>
|
|
|
|
);
|
|
|
|
})}
|
|
|
|
</TransitionGroup>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
onClose(popup: PopupConfig) {
|
2019-11-27 11:03:32 +02:00
|
|
|
return this.props.destroy.bind(null, popup);
|
|
|
|
}
|
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
onOverlayClick(popup: PopupConfig) {
|
|
|
|
return (event: React.MouseEvent) => {
|
2019-11-27 11:03:32 +02:00
|
|
|
if (event.target !== event.currentTarget || popup.disableOverlayClose) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
this.props.destroy(popup);
|
2016-05-01 20:50:55 +03:00
|
|
|
};
|
2019-11-27 11:03:32 +02:00
|
|
|
}
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
popStack() {
|
2019-12-07 13:28:52 +02:00
|
|
|
const [popup] = this.props.popups.slice(-1);
|
2016-07-26 08:20:37 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
if (popup && !popup.disableOverlayClose) {
|
|
|
|
this.props.destroy(popup);
|
2016-07-26 08:20:37 +03:00
|
|
|
}
|
2019-11-27 11:03:32 +02:00
|
|
|
}
|
2016-07-26 08:20:37 +03:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
onKeyPress = (event: KeyboardEvent) => {
|
2019-11-27 11:03:32 +02:00
|
|
|
if (event.which === 27) {
|
|
|
|
// ESC key
|
|
|
|
this.popStack();
|
2016-05-01 20:50:55 +03:00
|
|
|
}
|
2019-11-27 11:03:32 +02:00
|
|
|
};
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
onRouteLeave = nextLocation => {
|
|
|
|
if (nextLocation) {
|
|
|
|
this.popStack();
|
2016-05-01 20:50:55 +03:00
|
|
|
}
|
2019-11-27 11:03:32 +02:00
|
|
|
};
|
2016-05-01 20:50:55 +03:00
|
|
|
}
|
|
|
|
|
2019-06-30 16:32:50 +03:00
|
|
|
export default connect(
|
2019-12-07 13:28:52 +02:00
|
|
|
(state: RootState) => ({
|
2019-11-27 11:03:32 +02:00
|
|
|
...state.popup,
|
|
|
|
}),
|
|
|
|
{
|
|
|
|
destroy,
|
|
|
|
},
|
2019-06-30 16:32:50 +03:00
|
|
|
)(PopupStack);
|