2019-02-18 18:29:32 +00:00
|
|
|
import { injectIntl } from 'react-intl';
|
2023-05-28 14:38:10 +00:00
|
|
|
|
2016-11-20 18:39:18 +00:00
|
|
|
import { connect } from 'react-redux';
|
2023-05-28 14:38:10 +00:00
|
|
|
|
2016-11-20 18:39:18 +00:00
|
|
|
import { NotificationStack } from 'react-notification';
|
2023-05-28 14:38:10 +00:00
|
|
|
|
2017-12-04 07:26:40 +00:00
|
|
|
import { dismissAlert } from 'flavours/glitch/actions/alerts';
|
|
|
|
import { getAlerts } from 'flavours/glitch/selectors';
|
2016-09-12 17:20:55 +00:00
|
|
|
|
2019-02-18 18:29:32 +00:00
|
|
|
const mapStateToProps = (state, { intl }) => {
|
|
|
|
const notifications = getAlerts(state);
|
|
|
|
|
|
|
|
notifications.forEach(notification => ['title', 'message'].forEach(key => {
|
|
|
|
const value = notification[key];
|
|
|
|
|
|
|
|
if (typeof value === 'object') {
|
2019-08-27 14:50:39 +00:00
|
|
|
notification[key] = intl.formatMessage(value, notification[`${key}_values`]);
|
2019-02-18 18:29:32 +00:00
|
|
|
}
|
|
|
|
}));
|
|
|
|
|
|
|
|
return { notifications };
|
|
|
|
};
|
2016-09-12 17:20:55 +00:00
|
|
|
|
|
|
|
const mapDispatchToProps = (dispatch) => {
|
|
|
|
return {
|
2016-11-20 18:39:18 +00:00
|
|
|
onDismiss: alert => {
|
|
|
|
dispatch(dismissAlert(alert));
|
2017-05-20 15:31:47 +00:00
|
|
|
},
|
2016-09-12 17:20:55 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2019-02-18 18:29:32 +00:00
|
|
|
export default injectIntl(connect(mapStateToProps, mapDispatchToProps)(NotificationStack));
|