bigbuffet-rw/app/soapbox/features/notifications/containers/column_settings_container.js

56 lines
2 KiB
JavaScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
import { defineMessages, injectIntl } from 'react-intl';
import { connect } from 'react-redux';
import { openModal } from 'soapbox/actions/modals';
import { clearNotifications, setFilter } from 'soapbox/actions/notifications';
import { changeAlerts as changePushNotifications } from 'soapbox/actions/push_notifications';
import { getSettings, changeSetting } from 'soapbox/actions/settings';
2022-01-10 14:01:24 -08:00
import { getFeatures } from 'soapbox/utils/features';
import ColumnSettings from '../components/column_settings';
2020-03-27 13:59:38 -07:00
const messages = defineMessages({
clearHeading: { id: 'notifications.clear_heading', defaultMessage: 'Clear notifications' },
2020-03-27 13:59:38 -07:00
clearMessage: { id: 'notifications.clear_confirmation', defaultMessage: 'Are you sure you want to permanently clear all your notifications?' },
clearConfirm: { id: 'notifications.clear', defaultMessage: 'Clear notifications' },
});
const mapStateToProps = state => {
const instance = state.get('instance');
const features = getFeatures(instance);
return {
settings: getSettings(state).get('notifications'),
pushSettings: state.get('push_notifications'),
supportsEmojiReacts: features.emojiReacts,
supportsBirthdays: features.birthdays,
};
};
2020-03-27 13:59:38 -07:00
const mapDispatchToProps = (dispatch, { intl }) => ({
onChange(path, checked) {
2020-03-27 13:59:38 -07:00
if (path[0] === 'push') {
dispatch(changePushNotifications(path.slice(1), checked));
} else if (path[0] === 'quickFilter') {
dispatch(changeSetting(['notifications', ...path], checked));
dispatch(setFilter('all'));
} else {
dispatch(changeSetting(['notifications', ...path], checked));
}
},
onClear() {
2020-03-27 13:59:38 -07:00
dispatch(openModal('CONFIRM', {
icon: require('@tabler/icons/icons/eraser.svg'),
heading: intl.formatMessage(messages.clearHeading),
2020-03-27 13:59:38 -07:00
message: intl.formatMessage(messages.clearMessage),
confirm: intl.formatMessage(messages.clearConfirm),
onConfirm: () => dispatch(clearNotifications()),
}));
},
});
export default injectIntl(connect(mapStateToProps, mapDispatchToProps)(ColumnSettings));