mirror of
https://github.com/wassname/talk.git
synced 2026-06-29 12:08:41 +08:00
70 lines
1.8 KiB
JavaScript
70 lines
1.8 KiB
JavaScript
import React, {Component} from 'react';
|
|
import styles from './style.css';
|
|
import Icon from './Icon';
|
|
|
|
import {I18n} from 'coral-framework';
|
|
import cn from 'classnames';
|
|
import translations from '../translations.json';
|
|
import {getMyActionSummary, getTotalActionCount} from 'coral-framework/utils';
|
|
|
|
const lang = new I18n(translations);
|
|
|
|
class RespectButton extends Component {
|
|
|
|
handleClick = () => {
|
|
const {postRespect, showSignInDialog, deleteAction} = this.props;
|
|
const {root: {me}, comment} = this.props;
|
|
|
|
const myRespectActionSummary = getMyActionSummary('RespectActionSummary', comment);
|
|
|
|
// If the current user does not exist, trigger sign in dialog.
|
|
if (!me) {
|
|
showSignInDialog();
|
|
return;
|
|
}
|
|
|
|
// If the current user is banned, do nothing.
|
|
if (me.status === 'BANNED') {
|
|
return;
|
|
}
|
|
|
|
if (myRespectActionSummary) {
|
|
deleteAction(myRespectActionSummary.current_user.id, comment.id);
|
|
} else {
|
|
postRespect({
|
|
item_id: comment.id,
|
|
item_type: 'COMMENTS'
|
|
});
|
|
}
|
|
}
|
|
|
|
render() {
|
|
const {comment} = this.props;
|
|
|
|
if (!comment) {
|
|
return null;
|
|
}
|
|
|
|
const myRespect = getMyActionSummary('RespectActionSummary', comment);
|
|
let count = getTotalActionCount('RespectActionSummary', comment);
|
|
|
|
return (
|
|
<div className={styles.respect}>
|
|
<button
|
|
className={cn(styles.button, {[styles.respected]: myRespect})}
|
|
onClick={this.handleClick} >
|
|
<span>{lang.t(myRespect ? 'respected' : 'respect')}</span>
|
|
<Icon className={cn(styles.icon, {[styles.respected]: myRespect})} />
|
|
{count > 0 && count}
|
|
</button>
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
RespectButton.propTypes = {
|
|
data: React.PropTypes.object.isRequired
|
|
};
|
|
|
|
export default RespectButton;
|