const React = require('react'); const PropTypes = require('prop-types'); const bindAll = require('lodash.bindall'); const classNames = require('classnames'); const FormattedMessage = require('react-intl').FormattedMessage; const FlexRow = require('../../../components/flex-row/flex-row.jsx'); const Comment = require('./comment.jsx'); require('./comment.scss'); class TopLevelComment extends React.Component { constructor (props) { super(props); bindAll(this, [ 'handleExpandThread', 'handleAddComment', 'handleDeleteReply', 'handleReportReply' ]); this.state = { expanded: false }; } handleExpandThread () { this.setState({ expanded: true }); } handleDeleteReply (commentId) { // Only apply topLevelCommentId for deleting replies // The top level comment itself just gets passed onDelete directly this.props.onDelete(commentId, this.props.id); } handleReportReply (commentId) { // Only apply topLevelCommentId for reporting replies // The top level comment itself just gets passed onReport directly this.props.onReport(commentId, this.props.id); } handleAddComment (comment) { this.props.onAddComment(comment, this.props.id); } render () { const { author, canReply, content, datetimeCreated, deletable, deleted, id, onDelete, onReport, replies, reported, projectId } = this.props; return ( {replies.length > 0 && 3} )} key={id} > {(this.state.expanded ? replies : replies.slice(0, 3)).map(reply => ( ))} } {!this.state.expanded && replies.length > 3 && } ); } } TopLevelComment.propTypes = { author: PropTypes.shape({ id: PropTypes.number, image: PropTypes.string, username: PropTypes.string }), canReply: PropTypes.bool, content: PropTypes.string, datetimeCreated: PropTypes.string, deletable: PropTypes.bool, deleted: PropTypes.bool, id: PropTypes.number, onAddComment: PropTypes.func, onDelete: PropTypes.func, onReport: PropTypes.func, parentId: PropTypes.number, projectId: PropTypes.string, replies: PropTypes.arrayOf(PropTypes.object), reported: PropTypes.bool }; module.exports = TopLevelComment;