catstodon/app/javascript/mastodon/features/ui/containers/notifications_container.js

34 lines
921 B
JavaScript
Raw Normal View History

import { injectIntl } from 'react-intl';
2016-11-20 19:39:18 +01:00
import { connect } from 'react-redux';
2016-11-20 19:39:18 +01:00
import { NotificationStack } from 'react-notification';
2017-06-23 16:05:04 +02:00
import { dismissAlert } from '../../../actions/alerts';
2016-11-20 19:39:18 +01:00
import { getAlerts } from '../../../selectors';
const formatIfNeeded = (intl, message, values) => {
if (typeof message === 'object') {
return intl.formatMessage(message, values);
}
return message;
};
const mapStateToProps = (state, { intl }) => ({
notifications: getAlerts(state).map(alert => ({
...alert,
action: formatIfNeeded(intl, alert.action, alert.values),
title: formatIfNeeded(intl, alert.title, alert.values),
message: formatIfNeeded(intl, alert.message, alert.values),
})),
});
const mapDispatchToProps = (dispatch) => ({
onDismiss (alert) {
dispatch(dismissAlert(alert));
},
});
export default injectIntl(connect(mapStateToProps, mapDispatchToProps)(NotificationStack));