Revision.js 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import UserDate from '../Common/UserDate';
  4. import Icon from '../Common/Icon';
  5. import UserPicture from '../User/UserPicture';
  6. export default class Revision extends React.Component {
  7. constructor(props) {
  8. super(props);
  9. this._onDiffOpenClicked = this._onDiffOpenClicked.bind(this);
  10. }
  11. componentDidMount() {
  12. }
  13. _onDiffOpenClicked() {
  14. this.props.onDiffOpenClicked(this.props.revision);
  15. }
  16. render() {
  17. const revision = this.props.revision;
  18. const author = revision.author;
  19. let pic = '';
  20. if (typeof author === 'object') {
  21. pic = <UserPicture user={author} />;
  22. }
  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 href={"?revision=" + revision._id }>
  35. <Icon name="history" /> View this version
  36. </a>
  37. <a className="diff-view" onClick={this._onDiffOpenClicked}>
  38. <Icon name="level-down" /> View diff
  39. </a>
  40. </p>
  41. </div>
  42. </div>
  43. );
  44. }
  45. }
  46. Revision.propTypes = {
  47. revision: PropTypes.object,
  48. onDiffOpenClicked: PropTypes.func.isRequired,
  49. }