import React from 'react'; import PropTypes from 'prop-types'; import { withTranslation } from 'react-i18next'; import Revision from './Revision'; import RevisionDiff from './RevisionDiff'; class PageRevisionList extends React.Component { constructor(props) { super(props); this.state = { isCompactNodiffRevisions: true, }; this.cbCompactizeChangeHandler = this.cbCompactizeChangeHandler.bind(this); } cbCompactizeChangeHandler() { this.setState({ isCompactNodiffRevisions: !this.state.isCompactNodiffRevisions }); } /** * render a row (Revision component and RevisionDiff component) * @param {Revison} revision * @param {Revision} previousRevision * @param {boolean} hasDiff whether revision has difference to previousRevision * @param {boolean} isContiguousNodiff true if the current 'hasDiff' and one of previous row is both false */ renderRow(revision, previousRevision, hasDiff, isContiguousNodiff) { const revisionId = revision._id; const revisionDiffOpened = this.props.diffOpened[revisionId] || false; const classNames = ['revision-history-outer']; if (isContiguousNodiff) { classNames.push('revision-history-outer-contiguous-nodiff'); } return (
{ hasDiff && ( ) }
); } render() { const { t } = this.props; const revisions = this.props.revisions; const revisionCount = this.props.revisions.length; let hasDiffPrev; const revisionList = this.props.revisions.map((revision, idx) => { let previousRevision; if (idx + 1 < revisionCount) { previousRevision = revisions[idx + 1]; } else { previousRevision = revision; // if it is the first revision, show full text as diff text } const hasDiff = revision.hasDiffToPrev !== false; // set 'true' if undefined for backward compatibility const isContiguousNodiff = !hasDiff && !hasDiffPrev; hasDiffPrev = hasDiff; return this.renderRow(revision, previousRevision, hasDiff, isContiguousNodiff); }); const classNames = ['revision-history-list']; if (this.state.isCompactNodiffRevisions) { classNames.push('revision-history-list-compact'); } return (
{revisionList}
); } } PageRevisionList.propTypes = { t: PropTypes.func.isRequired, // i18next revisions: PropTypes.array, diffOpened: PropTypes.object, onDiffOpenClicked: PropTypes.func.isRequired, }; export default withTranslation()(PageRevisionList);