chuckya/app/javascript/themes/glitch/containers/notification_purge_buttons_container.js

50 lines
1.5 KiB
JavaScript
Raw Normal View History

2017-11-18 12:11:18 +09:00
// Package imports.
import { connect } from 'react-redux';
2017-11-18 12:11:18 +09:00
import { defineMessages, injectIntl } from 'react-intl';
2017-11-18 12:11:18 +09:00
// Our imports.
import NotificationPurgeButtons from 'themes/glitch/components/notification_purge_buttons';
import {
deleteMarkedNotifications,
enterNotificationClearingMode,
markAllNotifications,
2017-11-18 12:11:18 +09:00
} from 'themes/glitch/actions/notifications';
import { openModal } from 'themes/glitch/actions/modal';
const messages = defineMessages({
clearMessage: { id: 'notifications.marked_clear_confirmation', defaultMessage: 'Are you sure you want to permanently clear all selected notifications?' },
clearConfirm: { id: 'notifications.marked_clear', defaultMessage: 'Clear selected notifications' },
});
const mapDispatchToProps = (dispatch, { intl }) => ({
onEnterCleaningMode(yes) {
dispatch(enterNotificationClearingMode(yes));
},
onDeleteMarked() {
dispatch(openModal('CONFIRM', {
message: intl.formatMessage(messages.clearMessage),
confirm: intl.formatMessage(messages.clearConfirm),
onConfirm: () => dispatch(deleteMarkedNotifications()),
}));
},
onMarkAll() {
dispatch(markAllNotifications(true));
},
onMarkNone() {
dispatch(markAllNotifications(false));
},
onInvert() {
dispatch(markAllNotifications(null));
},
});
const mapStateToProps = state => ({
markNewForDelete: state.getIn(['notifications', 'markNewForDelete']),
});
export default injectIntl(connect(mapStateToProps, mapDispatchToProps)(NotificationPurgeButtons));