36 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
	
		
			1.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { connect } from 'react-redux';
 | |
| 
 | |
| import { openModal, closeModal } from '../../../actions/modal';
 | |
| import ModalRoot from '../components/modal_root';
 | |
| 
 | |
| const mapStateToProps = state => ({
 | |
|   ignoreFocus: state.getIn(['modal', 'ignoreFocus']),
 | |
|   type: state.getIn(['modal', 'stack', 0, 'modalType'], null),
 | |
|   props: state.getIn(['modal', 'stack', 0, 'modalProps'], {}),
 | |
| });
 | |
| 
 | |
| const mapDispatchToProps = dispatch => ({
 | |
|   onClose (confirmationMessage, ignoreFocus = false) {
 | |
|     if (confirmationMessage) {
 | |
|       dispatch(
 | |
|         openModal({
 | |
|           modalType: 'CONFIRM',
 | |
|           modalProps: {
 | |
|             message: confirmationMessage.message,
 | |
|             confirm: confirmationMessage.confirm,
 | |
|             onConfirm: () => dispatch(closeModal({
 | |
|               modalType: undefined,
 | |
|               ignoreFocus: { ignoreFocus },
 | |
|             })),
 | |
|           } }),
 | |
|       );
 | |
|     } else {
 | |
|       dispatch(closeModal({
 | |
|         modalType: undefined,
 | |
|         ignoreFocus: { ignoreFocus },
 | |
|       }));
 | |
|     }
 | |
|   },
 | |
| });
 | |
| 
 | |
| export default connect(mapStateToProps, mapDispatchToProps)(ModalRoot);
 |