import { connect } from 'react-redux'; import { cancelReplyCompose } from 'soapbox/actions/compose'; import { cancelEventCompose } from 'soapbox/actions/events'; import { closeModal } from 'soapbox/actions/modals'; import { cancelReport } from 'soapbox/actions/reports'; import ModalRoot from '../components/modal_root'; const mapStateToProps = state => { const modal = state.get('modals').last({ modalType: null, modalProps: {}, }); return { type: modal.modalType, props: modal.modalProps, }; }; const mapDispatchToProps = (dispatch) => ({ onClose(type) { switch (type) { case 'COMPOSE': dispatch(cancelReplyCompose()); break; case 'COMPOSE_EVENT': dispatch(cancelEventCompose()); break; case 'REPORT': dispatch(cancelReport()); break; default: break; } dispatch(closeModal(type)); }, }); export default connect(mapStateToProps, mapDispatchToProps)(ModalRoot);