const React = require('react'); const PropTypes = require('prop-types'); const bindAll = require('lodash.bindall'); const classNames = require('classnames'); 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', 'handleDelete' ]); this.state = { expanded: false }; } handleExpandThread () { this.setState({ expanded: true }); } handleDelete () { this.props.onDelete(this.props.id); } render () { const { author, canReply, content, datetimeCreated, deletable, deleted, id, replies, projectId, onAddComment } = 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 && See all {replies.length} replies } ); } } 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, parentId: PropTypes.number, projectId: PropTypes.string, replies: PropTypes.arrayOf(PropTypes.object) }; module.exports = TopLevelComment;