2016-03-17 17:48:25 +09:00
|
|
|
import React, { PropTypes, Component } from 'react';
|
2016-04-04 10:21:18 +09:00
|
|
|
import NovaForm from "meteor/nova:forms";
|
2016-06-23 12:17:39 +09:00
|
|
|
import Comments from "meteor/nova:comments";
|
2016-11-07 23:46:12 +09:00
|
|
|
import { bindActionCreators } from 'redux';
|
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import update from 'immutability-helper';
|
2016-02-18 17:53:04 +09:00
|
|
|
|
2016-11-05 18:42:57 +09:00
|
|
|
const CommentsNewForm = (props, context) => {
|
2016-02-18 17:53:04 +09:00
|
|
|
|
2016-11-05 18:42:57 +09:00
|
|
|
let prefilledProps = {postId: props.postId};
|
2016-02-23 16:49:56 +09:00
|
|
|
|
2016-11-05 18:42:57 +09:00
|
|
|
if (props.parentComment) {
|
|
|
|
prefilledProps = Object.assign(prefilledProps, {
|
|
|
|
parentCommentId: props.parentComment._id,
|
|
|
|
// if parent comment has a topLevelCommentId use it; if it doesn't then it *is* the top level comment
|
|
|
|
topLevelCommentId: props.parentComment.topLevelCommentId || props.parentComment._id
|
|
|
|
});
|
|
|
|
}
|
2016-02-18 17:53:04 +09:00
|
|
|
|
2016-11-05 18:42:57 +09:00
|
|
|
return (
|
|
|
|
<Telescope.components.CanDo
|
|
|
|
action="comments.new"
|
|
|
|
noPermissionMessage="users.cannot_comment"
|
|
|
|
displayNoPermissionMessage={true}
|
|
|
|
>
|
2016-04-19 15:45:36 +09:00
|
|
|
<div className="comments-new-form">
|
2016-11-07 23:46:12 +09:00
|
|
|
<NovaForm
|
|
|
|
collection={Comments}
|
|
|
|
mutationName="commentsNew"
|
|
|
|
resultQuery={Comments.graphQLQueries.single}
|
|
|
|
updateQueries={{
|
|
|
|
getPost: (prev, { mutationResult }) => {
|
|
|
|
console.log(prev)
|
|
|
|
console.log(mutationResult)
|
|
|
|
const newComment = mutationResult.data.commentsNew;
|
|
|
|
const newPost = update(prev, {
|
|
|
|
post: {
|
|
|
|
commentCount: {
|
|
|
|
$set: prev.post.commentCount + 1
|
|
|
|
},
|
|
|
|
comments: {
|
|
|
|
$push: [newComment]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
console.log(newPost)
|
|
|
|
return newPost;
|
|
|
|
},
|
|
|
|
}}
|
|
|
|
successCallback={this.replySuccessCallback}
|
|
|
|
cancelCallback={props.type === "reply" ? props.cancelCallback : null}
|
2016-04-03 20:58:11 +09:00
|
|
|
prefilledProps={prefilledProps}
|
2016-04-08 10:29:32 +09:00
|
|
|
layout="elementOnly"
|
2016-02-18 17:53:04 +09:00
|
|
|
/>
|
2016-04-03 20:58:11 +09:00
|
|
|
</div>
|
2016-11-05 18:42:57 +09:00
|
|
|
</Telescope.components.CanDo>
|
|
|
|
)
|
2016-02-18 17:53:04 +09:00
|
|
|
|
2016-03-17 17:48:25 +09:00
|
|
|
};
|
|
|
|
|
2016-11-05 18:37:46 +09:00
|
|
|
CommentsNewForm.propTypes = {
|
2016-03-17 17:48:25 +09:00
|
|
|
postId: React.PropTypes.string.isRequired,
|
|
|
|
type: React.PropTypes.string, // "comment" or "reply"
|
|
|
|
parentComment: React.PropTypes.object, // if reply, the comment being replied to
|
|
|
|
parentCommentId: React.PropTypes.string, // if reply
|
2016-03-25 12:17:29 +09:00
|
|
|
topLevelCommentId: React.PropTypes.string, // if reply
|
2016-04-04 10:21:18 +09:00
|
|
|
successCallback: React.PropTypes.func, // a callback to execute when the submission has been successful
|
2016-11-05 18:37:46 +09:00
|
|
|
cancelCallback: React.PropTypes.func,
|
|
|
|
novaFormMutation: React.PropTypes.func,
|
|
|
|
router: React.PropTypes.object,
|
2016-11-05 18:42:57 +09:00
|
|
|
flash: React.PropTypes.func,
|
2016-03-17 17:48:25 +09:00
|
|
|
}
|
2016-02-18 17:53:04 +09:00
|
|
|
|
2016-11-05 18:37:46 +09:00
|
|
|
CommentsNewForm.contextTypes = {
|
2016-04-03 20:58:11 +09:00
|
|
|
currentUser: React.PropTypes.object
|
|
|
|
}
|
|
|
|
|
2016-11-07 23:46:12 +09:00
|
|
|
const mapStateToProps = state => ({ messages: state.messages });
|
|
|
|
const mapDispatchToProps = dispatch => bindActionCreators(Telescope.actions.messages, dispatch);
|
|
|
|
|
|
|
|
module.exports = connect(mapStateToProps, mapDispatchToProps)(CommentsNewForm);
|