mirror of
https://github.com/vale981/Vulcan
synced 2025-03-10 04:26:41 -04:00
42 lines
No EOL
998 B
JavaScript
42 lines
No EOL
998 B
JavaScript
import React, { PropTypes, Component } from 'react';
|
|
|
|
class CommentsNode extends Component {
|
|
|
|
renderComment(comment) {
|
|
|
|
({CommentsItem} = Telescope.components);
|
|
|
|
return (
|
|
<CommentsItem comment={comment} key={comment._id} currentUser={this.props.currentUser}/>
|
|
)
|
|
}
|
|
|
|
renderChildren(children) {
|
|
return (
|
|
<div className="comment-children">
|
|
{children.map(comment => <CommentsNode comment={comment} key={comment._id} currentUser={this.props.currentUser}/>)}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
render() {
|
|
|
|
const comment = this.props.comment;
|
|
const children = this.props.comment.childrenResults;
|
|
|
|
return (
|
|
<div className="comment-node">
|
|
{this.renderComment(comment)}
|
|
{children ? this.renderChildren(children) : ""}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
};
|
|
|
|
CommentsNode.propTypes = {
|
|
comment: React.PropTypes.object.isRequired, // the current comment
|
|
currentUser: React.PropTypes.object, // the current user
|
|
}
|
|
|
|
module.exports = CommentsNode; |