Revision.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. import React from 'react';
  2. import UserDate from '../Common/UserDate';
  3. import Icon from '../Common/Icon';
  4. import UserPicture from '../User/UserPicture';
  5. export default class Revision extends React.Component {
  6. constructor(props) {
  7. super(props);
  8. this._onDiffOpenClicked = this._onDiffOpenClicked.bind(this);
  9. }
  10. componentDidMount() {
  11. }
  12. _onDiffOpenClicked() {
  13. this.props.onDiffOpenClicked(this.props.revision);
  14. }
  15. render() {
  16. const revision = this.props.revision;
  17. const author = revision.author;
  18. let pic = '';
  19. if (typeof author === 'object') {
  20. pic = <UserPicture user={author} />;
  21. }
  22. return (
  23. <div className="revision-history-main">
  24. {pic}
  25. <div className="revision-history-author">
  26. <strong>{author.username}</strong>
  27. </div>
  28. <div className="revision-history-meta">
  29. <p>
  30. <UserDate dateTime={revision.createdAt} />
  31. </p>
  32. <p>
  33. <a href={"?revision=" + revision._id }>
  34. <Icon name="history" /> View this version
  35. </a>
  36. <a className="diff-view" onClick={this._onDiffOpenClicked}>
  37. <Icon name="level-down" /> View diff
  38. </a>
  39. </p>
  40. </div>
  41. </div>
  42. );
  43. }
  44. }
  45. Revision.propTypes = {
  46. revision: React.PropTypes.object,
  47. onDiffOpenClicked: React.PropTypes.func.isRequired,
  48. }