Vulcan/packages/nova-base-components/lib/comments/list/CommentEdit.jsx

53 lines
No EOL
1.3 KiB
JavaScript

import React, { PropTypes, Component } from 'react';
import Formsy from 'formsy-react';
import FRC from 'formsy-react-components';
import Actions from '../../actions.js';
import { Button } from 'react-bootstrap';
const Textarea = FRC.Textarea;
class CommentEdit extends Component {
constructor() {
super();
this.submitComment = this.submitComment.bind(this);
}
submitComment(data) {
data = {$set: data};
Actions.call("comments.edit", data, this.props.comment._id, (error, result) => {
if (error) {
Messages.flash(error.message);
} else {
this.props.submitCallback();
}
});
}
render() {
return (
<Formsy.Form className="comment-edit-form" onSubmit={this.submitComment}>
<Textarea
name="body"
value={this.props.comment.body}
label="Body"
type="text"
layout="vertical"
/>
<div className="comment-actions comment-edit-actions">
<Button type="submit" bsStyle="primary">Submit</Button>
<a className="comment-edit-cancel" onClick={this.props.cancelCallback}>Cancel</a>
</div>
</Formsy.Form>
)
}
}
CommentEdit.propTypes = {
comment: React.PropTypes.object.isRequired,
submitCallback: React.PropTypes.func,
cancelCallback: React.PropTypes.func
}
module.exports = CommentEdit;