bigbuffet-rw/app/soapbox/features/ui/containers/modal_container.js
2022-05-12 15:32:32 -04:00

38 lines
847 B
JavaScript

import { connect } from 'react-redux';
import { cancelReport } from 'soapbox/actions/reports';
import { cancelReplyCompose } from '../../../actions/compose';
import { closeModal } from '../../../actions/modals';
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 'REPORT':
dispatch(cancelReport());
break;
default:
break;
}
dispatch(closeModal(type));
},
});
export default connect(mapStateToProps, mapDispatchToProps)(ModalRoot);