Vulcan/packages/nova-base-components/lib/posts/PostsCommentsThread.jsx

79 lines
2.2 KiB
React
Raw Normal View History

import Telescope, { Components, registerComponent } from 'meteor/nova:lib';
import React from 'react';
2016-06-09 17:42:20 +09:00
import {FormattedMessage } from 'react-intl';
2016-11-29 14:08:24 +01:00
import { ModalTrigger, withList } from 'meteor/nova:core';
import { withCurrentUser } from 'meteor/nova:core';
import Comments from 'meteor/nova:comments';
2016-11-23 11:07:48 +09:00
import gql from 'graphql-tag';
2016-11-15 18:33:16 +01:00
2016-11-07 23:46:12 +09:00
const PostsCommentsThread = (props, context) => {
2016-11-23 11:07:48 +09:00
const {loading, terms: { postId }, results} = props;
if (loading) {
return <div className="posts-comments-thread"><Components.Loading/></div>
} else {
const commentCount = results.length;
const resultsClone = _.map(results, _.clone); // we don't want to modify the objects we got from props
const nestedComments = Telescope.utils.unflatten(resultsClone, '_id', 'parentCommentId');
return (
<div className="posts-comments-thread">
<h4 className="posts-comments-thread-title"><FormattedMessage id="comments.comments"/></h4>
<Components.CommentsList comments={nestedComments} commentCount={commentCount}/>
2016-11-15 18:33:16 +01:00
{ props.currentUser ?
<div className="posts-comments-thread-new">
<h4><FormattedMessage id="comments.new"/></h4>
<Components.CommentsNewForm
postId={postId}
type="comment"
/>
</div> :
<div>
<ModalTrigger size="small" component={<a><FormattedMessage id="comments.please_log_in"/></a>}>
<Components.UsersAccountForm/>
</ModalTrigger>
</div>
}
</div>
);
}
};
PostsCommentsThread.displayName = "PostsCommentsThread";
2016-11-15 18:33:16 +01:00
PostsCommentsThread.propTypes = {
currentUser: React.PropTypes.object
};
PostsCommentsThread.fragment = gql`
2016-11-23 11:07:48 +09:00
fragment commentsListFragment on Comment {
_id
postId
parentCommentId
topLevelCommentId
body
htmlBody
postedAt
user {
_id
__displayName
__emailHash
__slug
}
userId
2016-11-23 11:07:48 +09:00
}
`;
const options = {
collection: Comments,
2016-11-23 11:07:48 +09:00
queryName: 'commentsListQuery',
fragment: PostsCommentsThread.fragment,
};
registerComponent('PostsCommentsThread', PostsCommentsThread, withCurrentUser, withList(options));