You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
29 lines
808 B
29 lines
808 B
import { injectIntl } from 'react-intl'; |
|
import { connect } from 'react-redux'; |
|
import { NotificationStack } from 'react-notification'; |
|
import { dismissAlert } from '../../../actions/alerts'; |
|
import { getAlerts } from '../../../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); |
|
} |
|
})); |
|
|
|
return { notifications }; |
|
}; |
|
|
|
const mapDispatchToProps = (dispatch) => { |
|
return { |
|
onDismiss: alert => { |
|
dispatch(dismissAlert(alert)); |
|
}, |
|
}; |
|
}; |
|
|
|
export default injectIntl(connect(mapStateToProps, mapDispatchToProps)(NotificationStack));
|
|
|