Revision.js 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import UserDate from '../Common/UserDate';
  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. const iconName = this.props.revisionDiffOpened ? 'caret-down' : 'caret-right';
  23. return (
  24. <div className="revision-history-main">
  25. {pic}
  26. <div className="revision-history-author">
  27. <strong>{author.username}</strong>
  28. </div>
  29. <div className="revision-history-meta">
  30. <p>
  31. <UserDate dateTime={revision.createdAt} />
  32. </p>
  33. <p>
  34. <a className="diff-view" onClick={this._onDiffOpenClicked}>
  35. <Icon name={iconName} /> View diff
  36. </a>
  37. <a href={"?revision=" + revision._id }>
  38. <Icon name="sign-in" /> Go to this version
  39. </a>
  40. </p>
  41. </div>
  42. </div>
  43. );
  44. }
  45. }
  46. Revision.propTypes = {
  47. revision: PropTypes.object,
  48. revisionDiffOpened: PropTypes.bool.isRequired,
  49. onDiffOpenClicked: PropTypes.func.isRequired,
  50. }