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 (
{this.props.document.baseScore || 0}
) } } 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);