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.

43 lines
1.9 KiB

  1. import PureRenderMixin from 'react-addons-pure-render-mixin';
  2. import IconButton from '../../../components/icon_button';
  3. import ImmutablePropTypes from 'react-immutable-proptypes';
  4. import DropdownMenu from '../../../components/dropdown_menu';
  5. const ActionBar = React.createClass({
  6. propTypes: {
  7. status: ImmutablePropTypes.map.isRequired,
  8. onReply: React.PropTypes.func.isRequired,
  9. onReblog: React.PropTypes.func.isRequired,
  10. onFavourite: React.PropTypes.func.isRequired,
  11. onDelete: React.PropTypes.func.isRequired,
  12. onMention: React.PropTypes.func.isRequired,
  13. me: React.PropTypes.number.isRequired
  14. },
  15. mixins: [PureRenderMixin],
  16. render () {
  17. const { status, me } = this.props;
  18. let menu = [];
  19. if (me === status.getIn(['account', 'id'])) {
  20. menu.push({ text: 'Delete', action: () => this.props.onDelete(status) });
  21. } else {
  22. menu.push({ text: 'Mention', action: () => this.props.onMention(status.get('account')) });
  23. }
  24. return (
  25. <div style={{ background: '#2f3441', display: 'flex', flexDirection: 'row', borderTop: '1px solid #363c4b', borderBottom: '1px solid #363c4b', padding: '10px 0' }}>
  26. <div style={{ flex: '1 1 auto', textAlign: 'center' }}><IconButton title='Reply' icon='reply' onClick={() => this.props.onReply(status)} /></div>
  27. <div style={{ flex: '1 1 auto', textAlign: 'center' }}><IconButton active={status.get('reblogged')} title='Reblog' icon='retweet' onClick={() => this.props.onReblog(status)} /></div>
  28. <div style={{ flex: '1 1 auto', textAlign: 'center' }}><IconButton active={status.get('favourited')} title='Favourite' icon='star' onClick={() => this.props.onFavourite(status)} /></div>
  29. <div style={{ flex: '1 1 auto', textAlign: 'center' }}><DropdownMenu size={18} icon='ellipsis-h' items={menu} /></div>
  30. </div>
  31. );
  32. }
  33. });
  34. export default ActionBar;