2021-02-11 23:34:01 +00:00
|
|
|
import React, { Component } from 'react'
|
|
|
|
import Notifications from '../../../utils/notifications.js'
|
|
|
|
import {observer, inject} from "mobx-react"
|
|
|
|
import { withTranslation } from 'react-i18next';
|
|
|
|
|
|
|
|
import {PageReview, PageReviewChange} from "../../view/collaboration/Review";
|
2022-10-13 15:19:39 +00:00
|
|
|
import {LocalStorage} from "../../../utils/LocalStorage.mjs";
|
2021-02-11 23:34:01 +00:00
|
|
|
|
|
|
|
class InitReview extends Component {
|
|
|
|
constructor(props){
|
|
|
|
super(props);
|
|
|
|
|
|
|
|
Common.Notifications.on('engineCreated', api => {
|
|
|
|
api.asc_registerCallback('asc_onShowRevisionsChange', this.onChangeReview.bind(this));
|
|
|
|
});
|
|
|
|
|
|
|
|
Common.Notifications.on('document:ready', () => {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
const appOptions = props.storeAppOptions;
|
2021-07-22 19:56:15 +00:00
|
|
|
|
|
|
|
let trackChanges = appOptions.customization && appOptions.customization.review ? appOptions.customization.review.trackChanges : undefined;
|
|
|
|
(trackChanges===undefined) && (trackChanges = appOptions.customization ? appOptions.customization.trackChanges : undefined);
|
|
|
|
trackChanges = appOptions.isReviewOnly || trackChanges === true || trackChanges !== false
|
2021-07-22 20:59:21 +00:00
|
|
|
&& LocalStorage.getBool("de-mobile-track-changes-" + (appOptions.fileKey || ''));
|
2021-07-22 19:56:15 +00:00
|
|
|
|
|
|
|
api.asc_SetTrackRevisions(trackChanges);
|
2021-02-11 23:34:01 +00:00
|
|
|
// Init display mode
|
2021-08-04 10:19:19 +00:00
|
|
|
|
|
|
|
const canViewReview = appOptions.canReview || appOptions.isEdit || api.asc_HaveRevisionsChanges(true);
|
|
|
|
if (!appOptions.canReview)
|
2021-02-11 23:34:01 +00:00
|
|
|
appOptions.setCanViewReview(canViewReview);
|
2021-08-04 10:19:19 +00:00
|
|
|
if (canViewReview) {
|
|
|
|
let viewReviewMode = (appOptions.isEdit || appOptions.isRestrictedEdit) ? null : LocalStorage.getItem("de-view-review-mode");
|
2021-08-25 17:51:35 +00:00
|
|
|
if (viewReviewMode === null) {
|
|
|
|
viewReviewMode = appOptions.customization && appOptions.customization.review ? appOptions.customization.review.reviewDisplay : undefined;
|
|
|
|
!viewReviewMode && (viewReviewMode = appOptions.customization ? appOptions.customization.reviewDisplay : undefined);
|
|
|
|
viewReviewMode = /^(original|final|markup|simple)$/i.test(viewReviewMode) ? viewReviewMode.toLocaleLowerCase() : ( appOptions.isEdit || appOptions.isRestrictedEdit ? 'markup' : 'original');
|
|
|
|
}
|
2021-08-04 10:19:19 +00:00
|
|
|
let displayMode = viewReviewMode.toLocaleLowerCase();
|
2021-08-10 16:32:12 +00:00
|
|
|
let type = Asc.c_oAscDisplayModeInReview.Edit;
|
|
|
|
switch (displayMode) {
|
|
|
|
case 'final':
|
|
|
|
type = Asc.c_oAscDisplayModeInReview.Final;
|
|
|
|
break;
|
|
|
|
case 'original':
|
|
|
|
type = Asc.c_oAscDisplayModeInReview.Original;
|
|
|
|
break;
|
2021-02-11 23:34:01 +00:00
|
|
|
}
|
2021-08-10 16:32:12 +00:00
|
|
|
api.asc_SetDisplayModeInReview(type);
|
2021-08-04 10:19:19 +00:00
|
|
|
props.storeReview.changeDisplayMode(displayMode);
|
2021-02-11 23:34:01 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-01-20 21:11:12 +00:00
|
|
|
onChangeReview (data, isShow) {
|
2021-02-11 23:34:01 +00:00
|
|
|
const storeReview = this.props.storeReview;
|
|
|
|
storeReview.changeArrReview(data);
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class Review extends Component {
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
this.onTrackChanges = this.onTrackChanges.bind(this);
|
|
|
|
this.onDisplayMode = this.onDisplayMode.bind(this);
|
|
|
|
|
|
|
|
this.appConfig = props.storeAppOptions;
|
|
|
|
this.editorPrefix = window.editorType || '';
|
|
|
|
|
2021-07-22 19:56:15 +00:00
|
|
|
let trackChanges = this.appConfig.customization && this.appConfig.customization.review ? this.appConfig.customization.review.trackChanges : undefined;
|
|
|
|
(trackChanges===undefined) && (trackChanges = this.appConfig.customization ? this.appConfig.customization.trackChanges : undefined);
|
2021-02-11 23:34:01 +00:00
|
|
|
trackChanges = this.appConfig.isReviewOnly || trackChanges === true || trackChanges !== false
|
|
|
|
&& LocalStorage.getBool(`${this.editorPrefix}-mobile-track-changes-${this.appConfig.fileKey || ''}`);
|
|
|
|
|
|
|
|
this.state = {
|
|
|
|
trackChanges: trackChanges
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
onTrackChanges (checked) {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
if ( this.appConfig.isReviewOnly ) {
|
|
|
|
this.setState({trackChanges: true});
|
|
|
|
} else {
|
|
|
|
this.setState({trackChanges: checked});
|
|
|
|
api.asc_SetTrackRevisions(checked);
|
|
|
|
LocalStorage.setBool(`${this.editorPrefix}-mobile-track-changes-${this.appConfig.fileKey || ''}`, checked);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
onAcceptAll () {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_AcceptAllChanges();
|
|
|
|
}
|
|
|
|
|
|
|
|
onRejectAll () {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_RejectAllChanges();
|
|
|
|
}
|
|
|
|
|
|
|
|
onDisplayMode (mode) {
|
|
|
|
const api = Common.EditorApi.get();
|
2021-08-10 16:32:12 +00:00
|
|
|
let type = Asc.c_oAscDisplayModeInReview.Edit;
|
|
|
|
switch (mode) {
|
|
|
|
case 'final':
|
|
|
|
type = Asc.c_oAscDisplayModeInReview.Final;
|
|
|
|
break;
|
|
|
|
case 'original':
|
|
|
|
type = Asc.c_oAscDisplayModeInReview.Original;
|
|
|
|
break;
|
2021-02-11 23:34:01 +00:00
|
|
|
}
|
2021-08-10 16:32:12 +00:00
|
|
|
api.asc_SetDisplayModeInReview(type);
|
2021-08-04 10:19:19 +00:00
|
|
|
!this.appConfig.isEdit && !this.appConfig.isRestrictedEdit && LocalStorage.setItem("de-view-review-mode", mode);
|
2021-02-11 23:34:01 +00:00
|
|
|
this.props.storeReview.changeDisplayMode(mode);
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2021-02-12 17:33:38 +00:00
|
|
|
const displayMode = this.props.storeReview.displayMode;
|
|
|
|
const isReviewOnly = this.appConfig.isReviewOnly;
|
|
|
|
const canReview = this.appConfig.canReview;
|
|
|
|
const canUseReviewPermissions = this.appConfig.canUseReviewPermissions;
|
|
|
|
const isRestrictedEdit = this.appConfig.isRestrictedEdit;
|
2021-02-11 23:34:01 +00:00
|
|
|
return (
|
2021-02-12 17:33:38 +00:00
|
|
|
<PageReview isReviewOnly={isReviewOnly}
|
|
|
|
canReview={canReview}
|
|
|
|
canUseReviewPermissions={canUseReviewPermissions}
|
|
|
|
isRestrictedEdit={isRestrictedEdit}
|
|
|
|
displayMode={displayMode}
|
|
|
|
trackChanges={this.state.trackChanges}
|
2021-02-11 23:34:01 +00:00
|
|
|
onTrackChanges={this.onTrackChanges}
|
|
|
|
onAcceptAll={this.onAcceptAll}
|
|
|
|
onRejectAll={this.onRejectAll}
|
|
|
|
onDisplayMode={this.onDisplayMode}
|
2021-03-17 18:57:52 +00:00
|
|
|
noBack={this.props.noBack}
|
2021-02-11 23:34:01 +00:00
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class ReviewChange extends Component {
|
|
|
|
constructor (props) {
|
|
|
|
super(props);
|
2021-02-12 17:33:38 +00:00
|
|
|
this.onAcceptCurrentChange = this.onAcceptCurrentChange.bind(this);
|
|
|
|
this.onRejectCurrentChange = this.onRejectCurrentChange.bind(this);
|
|
|
|
this.onGotoNextChange = this.onGotoNextChange.bind(this);
|
|
|
|
this.onDeleteChange = this.onDeleteChange.bind(this);
|
|
|
|
|
2021-02-11 23:34:01 +00:00
|
|
|
this.appConfig = props.storeAppOptions;
|
|
|
|
}
|
2021-07-01 16:06:03 +00:00
|
|
|
|
2021-02-11 23:34:01 +00:00
|
|
|
dateToLocaleTimeString (date) {
|
|
|
|
const format = (date) => {
|
|
|
|
let strTime,
|
|
|
|
hours = date.getHours(),
|
|
|
|
minutes = date.getMinutes(),
|
|
|
|
ampm = hours >= 12 ? 'pm' : 'am';
|
|
|
|
|
|
|
|
hours = hours % 12;
|
|
|
|
hours = hours ? hours : 12; // the hour '0' should be '12'
|
|
|
|
minutes = minutes < 10 ? '0' + minutes : minutes;
|
|
|
|
strTime = hours + ':' + minutes + ' ' + ampm;
|
|
|
|
|
|
|
|
return strTime;
|
|
|
|
};
|
|
|
|
|
|
|
|
// MM/dd/yyyy hh:mm AM
|
|
|
|
return (date.getMonth() + 1) + '/' + (date.getDate()) + '/' + date.getFullYear() + ' ' + format(date);
|
|
|
|
}
|
|
|
|
getArrChangeReview (data) {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
|
|
|
|
const { t } = this.props;
|
|
|
|
const _t = t("Common.Collaboration", { returnObjects: true });
|
|
|
|
|
|
|
|
if (data.length === 0) return [];
|
|
|
|
const arr = [];
|
|
|
|
const c_paragraphLinerule = {
|
|
|
|
LINERULE_LEAST: 0,
|
|
|
|
LINERULE_AUTO: 1,
|
|
|
|
LINERULE_EXACT: 2
|
|
|
|
};
|
|
|
|
data.forEach((item) => {
|
2021-02-19 09:22:10 +00:00
|
|
|
let changeText = [], proptext = [],
|
2021-02-11 23:34:01 +00:00
|
|
|
value = item.get_Value(),
|
|
|
|
movetype = item.get_MoveType();
|
|
|
|
switch (item.get_Type()) {
|
|
|
|
case Asc.c_oAscRevisionsChangeType.TextAdd:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextAdd}`}><b>{movetype === Asc.c_oAscRevisionsMove.NoMove ? _t.textInserted : _t.textParaMoveTo}</b></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
if (typeof value == 'object') {
|
|
|
|
value.forEach( (obj) => {
|
|
|
|
if (typeof obj === 'string')
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextAdd}-1`}> {Common.Utils.String.htmlEncode(obj)}</label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
else {
|
|
|
|
switch (obj) {
|
|
|
|
case 0:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextAdd}-2`}> <{_t.textImage}></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case 1:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextAdd}-3`}> <{_t.textShape}></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case 2:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextAdd}-4`}> <{_t.textChart}></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case 3:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextAdd}-5`}> <{_t.textEquation}></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
} else if (typeof value === 'string') {
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextAdd}-6`}> {Common.Utils.String.htmlEncode(value)}</label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case Asc.c_oAscRevisionsChangeType.TextRem:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextRem}`}><b>{(movetype === Asc.c_oAscRevisionsMove.NoMove) ? _t.textDeleted : (item.is_MovedDown() ? _t.textParaMoveFromDown : _t.textParaMoveFromUp)}</b></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
if (typeof value == 'object') {
|
|
|
|
value.forEach( (obj) => {
|
|
|
|
if (typeof obj === 'string')
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextRem}-1`}> {Common.Utils.String.htmlEncode(obj)}</label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
else {
|
|
|
|
switch (obj) {
|
|
|
|
case 0:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextRem}-2`}> <{_t.textImage}></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case 1:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextRem}-3`}> <{_t.textShape}></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case 2:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextRem}-4`}> <{_t.textChart}></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case 3:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextRem}-5`}> <{_t.textEquation}></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
} else if (typeof value === 'string') {
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextRem}-6`}> {Common.Utils.String.htmlEncode(value)}</label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case Asc.c_oAscRevisionsChangeType.ParaAdd:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaAdd}`}><b>{_t.textParaInserted}</b> </label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case Asc.c_oAscRevisionsChangeType.ParaRem:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaRem}`}><b>{_t.textParaDeleted}</b> </label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case Asc.c_oAscRevisionsChangeType.TextPr:
|
|
|
|
if (value.Get_Bold() !== undefined)
|
2021-02-19 09:22:10 +00:00
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-1`}>{(value.Get_Bold() ? '' : _t.textNot) + _t.textBold}</label>);
|
|
|
|
if (value.Get_Italic() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-02`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-2`}>{(value.Get_Italic() ? '' : _t.textNot) + _t.textItalic}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_Underline() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-03`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-3`}>{(value.Get_Underline() ? '' : _t.textNot) + _t.textUnderline}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_Strikeout() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-04`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-4`}>{(value.Get_Strikeout() ? '' : _t.textNot) + _t.textStrikeout}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_DStrikeout() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-05`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-5`}>{(value.Get_DStrikeout() ? '' : _t.textNot) + _t.textDStrikeout}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_Caps() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-06`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-6`}>{(value.Get_Caps() ? '' : _t.textNot) + _t.textCaps}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_SmallCaps() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-07`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-7`}>{(value.Get_SmallCaps() ? '' : _t.textNot) + _t.textSmallCaps}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_VertAlign() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-08`}>, </label>);
|
2022-11-16 09:28:41 +00:00
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-8`}>{((value.Get_VertAlign() === Asc.vertalign_SuperScript) ? _t.textSuperScript : ((value.Get_VertAlign() === Asc.vertalign_SubScript) ? _t.textSubScript : _t.textBaseline))}</label>);
|
2021-02-19 09:22:10 +00:00
|
|
|
}
|
|
|
|
if (value.Get_Color() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-09`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-9`}>{_t.textColor}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_Highlight() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-010`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-10`}>{_t.textHighlight}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_Shd() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-011`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-11`}>{_t.textShd}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_FontFamily() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-012`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-12`}>{value.Get_FontFamily()}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_FontSize() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-013`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-13`}>{value.Get_FontSize()}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_Spacing() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-014`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-14`}>{_t.textSpacing} {Common.Utils.Metric.fnRecalcFromMM(value.Get_Spacing()).toFixed(2)} {Common.Utils.Metric.getCurrentMetricName()}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_Position() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-015`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-15`}>{_t.textPosition} {Common.Utils.Metric.fnRecalcFromMM(value.Get_Position()).toFixed(2)} {Common.Utils.Metric.getCurrentMetricName()}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_Lang() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-016`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-16`}>{Common.util.LanguageInfo.getLocalLanguageName(value.Get_Lang())[1]}</label>);
|
|
|
|
}
|
2021-02-11 23:34:01 +00:00
|
|
|
|
|
|
|
if (proptext.length > 0) {
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-17`}><b>{_t.textFormatted}: </b></label>);
|
|
|
|
proptext.forEach((item) => {
|
|
|
|
changeText.push(item);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.TextPr}-18`}><b>{_t.textFormatted}</b></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case Asc.c_oAscRevisionsChangeType.ParaPr:
|
|
|
|
if (value.Get_ContextualSpacing())
|
2021-02-19 09:22:10 +00:00
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-1`}>{(value.Get_ContextualSpacing() ? _t.textContextual : _t.textNoContextual)}</label>);
|
|
|
|
if (value.Get_IndLeft() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-02`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-2`}>{_t.textIndentLeft} {Common.Utils.Metric.fnRecalcFromMM(value.Get_IndLeft()).toFixed(2)} {Common.Utils.Metric.getCurrentMetricName()}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_IndRight() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-03`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-3`}>{_t.textIndentRight} {Common.Utils.Metric.fnRecalcFromMM(value.Get_IndRight()).toFixed(2)} {Common.Utils.Metric.getCurrentMetricName()}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_IndFirstLine() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-04`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-4`}>{_t.textFirstLine} {Common.Utils.Metric.fnRecalcFromMM(value.Get_IndFirstLine()).toFixed(2)} {Common.Utils.Metric.getCurrentMetricName()}</label>);
|
|
|
|
}
|
2021-02-11 23:34:01 +00:00
|
|
|
if (value.Get_Jc() !== undefined) {
|
|
|
|
switch (value.Get_Jc()) {
|
|
|
|
case 0:
|
2021-02-19 09:22:10 +00:00
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-05`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-5`}>{_t.textRight}</label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case 1:
|
2021-02-19 09:22:10 +00:00
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-06`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-6`}>{_t.textLeft}</label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case 2:
|
2021-02-19 09:22:10 +00:00
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-07`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-7`}>{_t.textCenter}</label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case 3:
|
2021-02-19 09:22:10 +00:00
|
|
|
proptext.length > 0 && proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-08`}>, </label>);
|
|
|
|
proptext.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-8`}>{_t.textJustify}</label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2021-02-19 09:22:10 +00:00
|
|
|
if (value.Get_KeepLines() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`keepLines-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`keepLines-1`}>{(value.Get_KeepLines() ? _t.textKeepLines : _t.textNoKeepLines)}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_KeepNext()) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`keepNext-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`keepNext-1`}>{(value.Get_KeepNext() ? _t.textKeepNext : _t.textNoKeepNext)}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_PageBreakBefore()) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`breakBefore-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`breakBefore-1`}>{(value.Get_PageBreakBefore() ? _t.textBreakBefore : _t.textNoBreakBefore)}</label>);
|
|
|
|
}
|
2021-02-11 23:34:01 +00:00
|
|
|
if (value.Get_SpacingLineRule() !== undefined && value.Get_SpacingLine() !== undefined) {
|
2021-02-19 09:22:10 +00:00
|
|
|
proptext.length > 0 && proptext.push(<label key={`spacingLineRule-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`spacingLineRule-1`}>{t.textLineSpacing}</label>);
|
|
|
|
proptext.push(<label key={`spacingLineRule-2`}>{((value.Get_SpacingLineRule() == c_paragraphLinerule.LINERULE_LEAST) ? _t.textAtLeast : ((value.Get_SpacingLineRule() == c_paragraphLinerule.LINERULE_AUTO) ? _t.textMultiple : _t.textExact))} </label>);
|
|
|
|
proptext.push(<label key={`spacingLineRule-3`}>{((value.Get_SpacingLineRule() == c_paragraphLinerule.LINERULE_AUTO) ? value.Get_SpacingLine() : Common.Utils.Metric.fnRecalcFromMM(value.Get_SpacingLine()).toFixed(2) + ' ' + Common.Utils.Metric.getCurrentMetricName())}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_SpacingBeforeAutoSpacing()) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`spacingBeforeAutoSpacing-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`spacingBeforeAutoSpacing-1`}>{_t.textSpacingBefore} {_t.textAuto}</label>);
|
|
|
|
}
|
|
|
|
else if (value.Get_SpacingBefore() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`spacingBefore-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`spacingBefore-1`}>{_t.textSpacingBefore} {Common.Utils.Metric.fnRecalcFromMM(value.Get_SpacingBefore()).toFixed(2)} {Common.Utils.Metric.getCurrentMetricName()}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_SpacingAfterAutoSpacing()) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`spacingAfterAutoSpacing-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`spacingAfterAutoSpacing-1`}>{_t.textSpacingAfter} {_t.textAuto}</label>);
|
|
|
|
}
|
|
|
|
else if (value.Get_SpacingAfter() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`spacingAfter-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`spacingAfter-1`}>{_t.textSpacingAfter} {Common.Utils.Metric.fnRecalcFromMM(value.Get_SpacingAfter()).toFixed(2)} {Common.Utils.Metric.getCurrentMetricName()}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_WidowControl()) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`widowControl-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`widowControl-1`}>{(value.Get_WidowControl() ? _t.textWidow : _t.textNoWidow)}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_Tabs() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`tabs-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`tabs-1`}>{_t.textTabs}</label>);
|
|
|
|
}
|
|
|
|
if (value.Get_NumPr() !== undefined) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`num-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`num-1`}>{_t.textNum}</label>)
|
|
|
|
}
|
2021-02-11 23:34:01 +00:00
|
|
|
if (value.Get_PStyle() !== undefined) {
|
|
|
|
const style = api.asc_GetStyleNameById(value.Get_PStyle());
|
2021-02-19 09:22:10 +00:00
|
|
|
if (style.length > 0) {
|
|
|
|
proptext.length > 0 && proptext.push(<label key={`style-01`}>, </label>);
|
|
|
|
proptext.push(<label key={`style-1`}>{style}</label>);
|
|
|
|
}
|
2021-02-11 23:34:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (proptext.length > 0) {
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-9`}><b>{_t.textParaFormatted}: </b></label>);
|
|
|
|
proptext.forEach((item) => {
|
|
|
|
changeText.push(item);
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-10`}><b>{_t.textParaFormatted}</b></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case Asc.c_oAscRevisionsChangeType.TablePr:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-11`}><b>{_t.textTableChanged}</b></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case Asc.c_oAscRevisionsChangeType.RowsAdd:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-12`}><b>{_t.textTableRowsAdd}</b></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
case Asc.c_oAscRevisionsChangeType.RowsRem:
|
2021-02-19 09:22:10 +00:00
|
|
|
changeText.push(<label key={`${Asc.c_oAscRevisionsChangeType.ParaPr}-13`}><b>{_t.textTableRowsDel}</b></label>);
|
2021-02-11 23:34:01 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
|
|
|
let date = (item.get_DateTime() == '') ? new Date() : new Date(item.get_DateTime());
|
|
|
|
const user = item.get_UserName();
|
|
|
|
const userColor = item.get_UserColor();
|
|
|
|
const goto = (item.get_MoveType() == Asc.c_oAscRevisionsMove.MoveTo || item.get_MoveType() == Asc.c_oAscRevisionsMove.MoveFrom);
|
|
|
|
date = this.dateToLocaleTimeString(date);
|
2021-07-01 16:06:03 +00:00
|
|
|
const editable = this.appConfig.isReviewOnly && (item.get_UserId() == this.appConfig.user.id) || !this.appConfig.isReviewOnly && (!this.appConfig.canUseReviewPermissions || AscCommon.UserInfoParser.canEditReview(item.get_UserName()));
|
2021-02-11 23:34:01 +00:00
|
|
|
arr.push({date: date, user: user, userColor: userColor, changeText: changeText, goto: goto, editable: editable});
|
|
|
|
});
|
|
|
|
return arr;
|
|
|
|
}
|
|
|
|
|
2021-02-12 17:33:38 +00:00
|
|
|
onPrevChange () {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_GetPrevRevisionsChange();
|
|
|
|
}
|
|
|
|
|
|
|
|
onNextChange () {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_GetNextRevisionsChange();
|
|
|
|
}
|
|
|
|
|
|
|
|
onAcceptCurrentChange () {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_AcceptChanges(this.dataChanges[0]);
|
|
|
|
setTimeout(() => {
|
|
|
|
api.asc_GetNextRevisionsChange();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
onRejectCurrentChange () {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_RejectChanges(this.dataChanges[0]);
|
|
|
|
setTimeout(() => {
|
|
|
|
api.asc_GetNextRevisionsChange();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
onGotoNextChange () {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_FollowRevisionMove(this.dataChanges[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
onDeleteChange () {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_RejectChanges(this.dataChanges[0]);
|
|
|
|
}
|
|
|
|
|
2021-02-11 23:34:01 +00:00
|
|
|
render() {
|
2021-02-12 17:33:38 +00:00
|
|
|
this.dataChanges = this.props.storeReview.dataChanges;
|
|
|
|
const arrChangeReview = this.getArrChangeReview(this.dataChanges);
|
2021-02-11 23:34:01 +00:00
|
|
|
let change;
|
|
|
|
let goto = false;
|
|
|
|
if (arrChangeReview.length > 0) {
|
2021-07-02 14:49:53 +00:00
|
|
|
const name = AscCommon.UserInfoParser.getParsedName(arrChangeReview[0].user);
|
2021-02-11 23:34:01 +00:00
|
|
|
change = {
|
|
|
|
date: arrChangeReview[0].date,
|
|
|
|
user: arrChangeReview[0].user,
|
2021-07-02 14:49:53 +00:00
|
|
|
userName: Common.Utils.String.htmlEncode(name),
|
2021-02-11 23:34:01 +00:00
|
|
|
color: arrChangeReview[0].userColor.get_hex(),
|
|
|
|
text: arrChangeReview[0].changeText,
|
2021-07-02 14:49:53 +00:00
|
|
|
initials: this.props.users.getInitials(name),
|
2021-02-12 17:33:38 +00:00
|
|
|
editable: arrChangeReview[0].editable
|
2021-02-11 23:34:01 +00:00
|
|
|
};
|
|
|
|
goto = arrChangeReview[0].goto;
|
|
|
|
}
|
2021-02-12 17:33:38 +00:00
|
|
|
|
|
|
|
const isReviewOnly = this.appConfig.isReviewOnly;
|
|
|
|
const canReview = this.appConfig.canReview;
|
|
|
|
const displayMode = this.props.storeReview.displayMode;
|
|
|
|
|
2021-02-11 23:34:01 +00:00
|
|
|
return (
|
2021-02-12 17:33:38 +00:00
|
|
|
<PageReviewChange change={change}
|
|
|
|
goto={goto}
|
|
|
|
isReviewOnly={isReviewOnly}
|
|
|
|
canReview={canReview}
|
|
|
|
displayMode={displayMode}
|
|
|
|
onPrevChange={this.onPrevChange}
|
|
|
|
onNextChange={this.onNextChange}
|
|
|
|
onAcceptCurrentChange={this.onAcceptCurrentChange}
|
|
|
|
onRejectCurrentChange={this.onRejectCurrentChange}
|
|
|
|
onGotoNextChange={this.onGotoNextChange}
|
|
|
|
onDeleteChange={this.onDeleteChange}
|
2021-03-17 18:57:52 +00:00
|
|
|
noBack={this.props.noBack}
|
2021-02-12 17:33:38 +00:00
|
|
|
/>
|
2021-02-11 23:34:01 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const InitReviewController = inject("storeAppOptions", "storeReview")(observer(InitReview));
|
|
|
|
const ReviewController = inject("storeAppOptions", "storeReview")(observer(Review));
|
2021-02-18 15:40:54 +00:00
|
|
|
const ReviewChangeController = withTranslation()(inject("storeAppOptions", "storeReview", "users")(observer(ReviewChange)));
|
2021-02-11 23:34:01 +00:00
|
|
|
|
|
|
|
export {InitReviewController, ReviewController, ReviewChangeController};
|