1
0
puyopuyotetr.is/app/javascript/flavours/glitch/features/ui/containers/modal_container.js
2023-05-28 16:38:10 +02:00

30 lines
910 B
JavaScript

import { connect } from 'react-redux';
import { openModal, closeModal } from 'flavours/glitch/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('CONFIRM', {
message: confirmationMessage.message,
confirm: confirmationMessage.confirm,
onConfirm: () => dispatch(closeModal(undefined, { ignoreFocus })),
}),
);
} else {
dispatch(closeModal(undefined, { ignoreFocus }));
}
},
});
export default connect(mapStateToProps, mapDispatchToProps)(ModalRoot);