mastodon/app/javascript/flavours/glitch/features/ui/containers/notifications_container.js

33 lines
856 B
JavaScript
Raw Normal View History

import { injectIntl } from 'react-intl';
2016-11-20 18:39:18 +00:00
import { connect } from 'react-redux';
2016-11-20 18:39:18 +00:00
import { NotificationStack } from 'react-notification';
2017-12-04 07:26:40 +00:00
import { dismissAlert } from 'flavours/glitch/actions/alerts';
import { getAlerts } from 'flavours/glitch/selectors';
const mapStateToProps = (state, { intl }) => {
const notifications = getAlerts(state);
notifications.forEach(notification => ['title', 'message'].forEach(key => {
const value = notification[key];
if (typeof value === 'object') {
notification[key] = intl.formatMessage(value, notification[`${key}_values`]);
}
}));
return { notifications };
};
const mapDispatchToProps = (dispatch) => {
return {
2016-11-20 18:39:18 +00:00
onDismiss: alert => {
dispatch(dismissAlert(alert));
},
};
};
export default injectIntl(connect(mapStateToProps, mapDispatchToProps)(NotificationStack));