mirror of
https://github.com/vale981/Vulcan
synced 2025-03-10 12:36:39 -04:00

* [eslint] update eslint rules & add .eslintignore to ignore non-ready nova packages * [clean-up] nova-voting * [clean-up] [bug] nova-users: missing user parameter * [clean-up] nova-users * [clean-up] nova-subscribe * [clean-up] nova-settings * [clean-up] nova-rss * [clean-up] [bug] nova-posts: correct UsersRemoveDeletePosts * [clean-up] nova-posts * [clean-up] nova-notifications * [clean-up] [bug] nova-newsletter: no error.message on throw error * [clean-up] nova-newsletter * [clean-up] nova-lib * [clean-up] nova-kadira * [clean-up] nova-inject-data * [clean-up] nova-getting-started * [clean-up] nova-forms * [clean-up] nova-events * [clean-up] [bug] nova-embedly: no FlowRouter * [clean-up] nova-embedly * [clean-up] nova-email-templates * [clean-up] nova-email * [clean-up] nova-debug * [clean-up] nova-core * [clean-up] [bug] nova-comments: correct UsersRemoveDeleteComments * [clean-up] nova-comments * [clean-up] [bug] nova-cloudinary: use Telescope.settings.collection instand * [clean-up] nova-cloudinary * [clean-up] nova-categories * [clean-up] nova-base-components * [clean-up] nova-api * [eslint] extends react recommended * [clean-up] for jsx files * [eslint] extends meteor recommended * i forgot this one little change
49 lines
1.6 KiB
JavaScript
49 lines
1.6 KiB
JavaScript
import React, { PropTypes, Component } from 'react';
|
|
import NovaForm from "meteor/nova:forms";
|
|
import Comments from "meteor/nova:comments";
|
|
|
|
class CommentsNew extends Component {
|
|
|
|
render() {
|
|
|
|
let prefilledProps = {postId: this.props.postId};
|
|
|
|
if (this.props.parentComment) {
|
|
prefilledProps = Object.assign(prefilledProps, {
|
|
parentCommentId: this.props.parentComment._id,
|
|
// if parent comment has a topLevelCommentId use it; if it doesn't then it *is* the top level comment
|
|
topLevelCommentId: this.props.parentComment.topLevelCommentId || this.props.parentComment._id
|
|
});
|
|
}
|
|
|
|
return (
|
|
<div className="comments-new-form">
|
|
<NovaForm
|
|
collection={Comments}
|
|
methodName="comments.new"
|
|
prefilledProps={prefilledProps}
|
|
successCallback={this.props.successCallback}
|
|
layout="elementOnly"
|
|
cancelCallback={this.props.type === "reply" ? this.props.cancelCallback : null}
|
|
/>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
}
|
|
|
|
CommentsNew.propTypes = {
|
|
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
|
|
topLevelCommentId: React.PropTypes.string, // if reply
|
|
successCallback: React.PropTypes.func, // a callback to execute when the submission has been successful
|
|
cancelCallback: React.PropTypes.func
|
|
}
|
|
|
|
CommentsNew.contextTypes = {
|
|
currentUser: React.PropTypes.object
|
|
}
|
|
|
|
module.exports = CommentsNew;
|