42 lines
989 B
JavaScript
42 lines
989 B
JavaScript
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);
|