Vulcan/packages/example-forum/lib/components/common/Vote.jsx

71 lines
2 KiB
JavaScript

import { Components, registerComponent, withMessages } from 'meteor/vulcan:core';
import React, { PureComponent } from 'react';
import PropTypes from 'prop-types';
import classNames from 'classnames';
import { withVote, hasVotedClient } from 'meteor/vulcan:voting';
import { FormattedMessage, intlShape } from 'meteor/vulcan:i18n';
class Vote extends PureComponent {
constructor() {
super();
this.vote = this.vote.bind(this);
this.getActionClass = this.getActionClass.bind(this);
this.hasVoted = this.hasVoted.bind(this);
}
vote(e) {
e.preventDefault();
const document = this.props.document;
const collection = this.props.collection;
const user = this.props.currentUser;
if(!user){
this.props.flash(this.context.intl.formatMessage({id: 'users.please_log_in'}));
} else {
this.props.vote({document, voteType: 'upvote', collection, currentUser: this.props.currentUser});
}
}
hasVoted() {
return hasVotedClient({document: this.props.document, voteType: 'upvote'})
}
getActionClass() {
const actionsClass = classNames(
'vote-button',
{upvoted: this.hasVoted()},
);
return actionsClass;
}
render() {
return (
<div className={this.getActionClass()}>
<a className="upvote-button" onClick={this.vote}>
<Components.Icon name="upvote" />
<div className="sr-only"><FormattedMessage id="voting.upvote"/></div>
<div className="vote-count">{this.props.document.baseScore || 0}</div>
</a>
</div>
)
}
}
Vote.propTypes = {
document: PropTypes.object.isRequired, // the document to upvote
collection: PropTypes.object.isRequired, // the collection containing the document
vote: PropTypes.func.isRequired, // mutate function with callback inside
currentUser: PropTypes.object, // user might not be logged in, so don't make it required
};
Vote.contextTypes = {
intl: intlShape
};
registerComponent('Vote', Vote, withMessages, withVote);