import PropTypes from 'prop-types'; import React from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import ImmutablePureComponent from 'react-immutable-pure-component'; import { FormattedNumber } from 'react-intl'; import { connect } from 'react-redux'; import { openModal } from 'soapbox/actions/modal'; import { getSoapboxConfig } from 'soapbox/actions/soapbox'; import Icon from 'soapbox/components/icon'; import emojify from 'soapbox/features/emoji/emoji'; import { reduceEmoji } from 'soapbox/utils/emoji_reacts'; import { getFeatures } from 'soapbox/utils/features'; import SoapboxPropTypes from 'soapbox/utils/soapbox_prop_types'; const mapStateToProps = state => { const me = state.get('me'); const instance = state.get('instance'); return { me, allowedEmoji: getSoapboxConfig(state).get('allowedEmoji'), features: getFeatures(instance), }; }; const mapDispatchToProps = (dispatch) => ({ onOpenUnauthorizedModal() { dispatch(openModal('UNAUTHORIZED')); }, onOpenReblogsModal(username, statusId) { dispatch(openModal('REBLOGS', { username, statusId, })); }, onOpenFavouritesModal(username, statusId) { dispatch(openModal('FAVOURITES', { username, statusId, })); }, onOpenReactionsModal(username, statusId, reaction) { dispatch(openModal('REACTIONS', { username, statusId, reaction, })); }, }); export default @connect(mapStateToProps, mapDispatchToProps) class StatusInteractionBar extends ImmutablePureComponent { static propTypes = { status: ImmutablePropTypes.map, me: SoapboxPropTypes.me, allowedEmoji: ImmutablePropTypes.list, features: PropTypes.object.isRequired, onOpenReblogsModal: PropTypes.func, onOpenReactionsModal: PropTypes.func, } getNormalizedReacts = () => { const { status } = this.props; return reduceEmoji( status.getIn(['pleroma', 'emoji_reactions']), status.get('favourites_count'), status.get('favourited'), this.props.allowedEmoji, ).reverse(); } handleOpenReblogsModal = () => { const { me, status, onOpenUnauthorizedModal, onOpenReblogsModal } = this.props; if (!me) onOpenUnauthorizedModal(); else onOpenReblogsModal(status.getIn(['account', 'acct']), status.get('id')); } getReposts = () => { const { status } = this.props; if (status.get('reblogs_count')) { return ( ); } return ''; } handleOpenFavouritesModal = () => { const { me, status, onOpenUnauthorizedModal, onOpenFavouritesModal } = this.props; if (!me) onOpenUnauthorizedModal(); else onOpenFavouritesModal(status.getIn(['account', 'acct']), status.get('id')); } getFavourites = () => { const { features, status } = this.props; if (status.get('favourites_count')) { const favourites = ( <> ); if (features.exposableReactions) { return ( {favourites} ); } else { return (
{favourites}
); } } return ''; } handleOpenReactionsModal = (reaction) => () => { const { me, status, onOpenUnauthorizedModal, onOpenReactionsModal } = this.props; if (!me) onOpenUnauthorizedModal(); else onOpenReactionsModal(status.getIn(['account', 'acct']), status.get('id'), reaction.get('name')); } getEmojiReacts = () => { const { features } = this.props; const emojiReacts = this.getNormalizedReacts(); const count = emojiReacts.reduce((acc, cur) => ( acc + cur.get('count') ), 0); if (count > 0) { return (
{emojiReacts.map((e, i) => { const emojiReact = ( <> {e.get('count')} ); if (features.exposableReactions) { return ( {emojiReact} ); } return {emojiReact}; })}
{count}
); } return ''; }; render() { const { features } = this.props; return (
{features.emojiReacts ? this.getEmojiReacts() : this.getFavourites()} {this.getReposts()}
); } }