2024-01-08 12:57:40 +02:00
|
|
|
import { createSelector } from '@reduxjs/toolkit';
|
2023-05-23 18:15:17 +03:00
|
|
|
import { Map as ImmutableMap } from 'immutable';
|
2020-01-23 23:00:13 +02:00
|
|
|
import { connect } from 'react-redux';
|
2024-01-08 12:57:40 +02:00
|
|
|
|
2023-05-23 18:15:17 +03:00
|
|
|
|
2020-02-03 02:53:09 +02:00
|
|
|
import { addReaction, removeReaction, dismissAnnouncement } from 'mastodon/actions/announcements';
|
2023-05-23 18:15:17 +03:00
|
|
|
|
2020-01-23 23:00:13 +02:00
|
|
|
import Announcements from '../components/announcements';
|
|
|
|
|
|
|
|
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 => ({
|
2020-02-03 02:53:09 +02:00
|
|
|
dismissAnnouncement: id => dispatch(dismissAnnouncement(id)),
|
2020-01-23 23:00:13 +02:00
|
|
|
addReaction: (id, name) => dispatch(addReaction(id, name)),
|
|
|
|
removeReaction: (id, name) => dispatch(removeReaction(id, name)),
|
|
|
|
});
|
|
|
|
|
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(Announcements);
|