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' ]); this.state = { expanded: false }; } handleExpandThread () { this.setState({ expanded: true }); } render () { const { author, content, datetimeCreated, id, replies } = 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 }), content: PropTypes.string, datetimeCreated: PropTypes.string, id: PropTypes.number, parentId: PropTypes.number, projectId: PropTypes.string, replies: PropTypes.arrayOf(PropTypes.object) }; module.exports = TopLevelComment;