22 lines
993 B
JavaScript
22 lines
993 B
JavaScript
|
import { connect } from 'react-redux';
|
||
|
import { fetchAnnouncements, dismissAnnouncement, addReaction, removeReaction } from 'mastodon/actions/announcements';
|
||
|
import Announcements from '../components/announcements';
|
||
|
import { createSelector } from 'reselect';
|
||
|
import { Map as ImmutableMap } from 'immutable';
|
||
|
|
||
|
const customEmojiMap = createSelector([state => state.get('custom_emojis')], items => items.reduce((map, emoji) => map.set(emoji.get('shortcode'), emoji), ImmutableMap()));
|
||
|
|
||
|
const mapStateToProps = state => ({
|
||
|
announcements: state.getIn(['announcements', 'items']),
|
||
|
emojiMap: customEmojiMap(state),
|
||
|
});
|
||
|
|
||
|
const mapDispatchToProps = dispatch => ({
|
||
|
fetchAnnouncements: () => dispatch(fetchAnnouncements()),
|
||
|
dismissAnnouncement: id => dispatch(dismissAnnouncement(id)),
|
||
|
addReaction: (id, name) => dispatch(addReaction(id, name)),
|
||
|
removeReaction: (id, name) => dispatch(removeReaction(id, name)),
|
||
|
});
|
||
|
|
||
|
export default connect(mapStateToProps, mapDispatchToProps)(Announcements);
|