* Move announcements above scroll container; add button to temporarily hide them * Remove interface for dismissing announcements * Display number of unread announcements * Count unread announcements accurately * Fix size of announcement box not fitting the currently displayed announcement * Fix announcement box background color to match button color
		
			
				
	
	
		
			20 lines
		
	
	
		
			828 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			20 lines
		
	
	
		
			828 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { connect } from 'react-redux';
 | |
| import { 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 => ({
 | |
|   addReaction: (id, name) => dispatch(addReaction(id, name)),
 | |
|   removeReaction: (id, name) => dispatch(removeReaction(id, name)),
 | |
| });
 | |
| 
 | |
| export default connect(mapStateToProps, mapDispatchToProps)(Announcements);
 |