2021-02-28 17:47:47 +00:00
|
|
|
import React, {Component, Fragment} from 'react';
|
2021-02-18 15:40:54 +00:00
|
|
|
import { inject, observer } from "mobx-react";
|
|
|
|
import { f7 } from 'framework7-react';
|
|
|
|
import {Device} from '../../../../../common/mobile/utils/device';
|
|
|
|
import { withTranslation} from 'react-i18next';
|
2022-10-13 15:19:39 +00:00
|
|
|
import { LocalStorage } from '../../../utils/LocalStorage.mjs';
|
2021-02-18 15:40:54 +00:00
|
|
|
|
2021-10-21 19:45:19 +00:00
|
|
|
import {AddComment, EditComment, AddReply, EditReply, ViewComments, ViewCurrentComments} from '../../view/collaboration/Comments';
|
2021-02-18 15:40:54 +00:00
|
|
|
|
|
|
|
// utils
|
|
|
|
const timeZoneOffsetInMs = (new Date()).getTimezoneOffset() * 60000;
|
|
|
|
const utcDateToString = (date) => {
|
|
|
|
if (Object.prototype.toString.call(date) === '[object Date]')
|
|
|
|
return (date.getTime() - timeZoneOffsetInMs).toString();
|
|
|
|
return '';
|
|
|
|
};
|
|
|
|
const ooDateToString = (date) => {
|
|
|
|
if (Object.prototype.toString.call(date) === '[object Date]')
|
|
|
|
return (date.getTime()).toString();
|
|
|
|
return '';
|
|
|
|
};
|
2021-02-25 16:26:42 +00:00
|
|
|
const stringOOToLocalDate = (date) => {
|
|
|
|
if (typeof date === 'string')
|
|
|
|
return parseInt(date);
|
|
|
|
return 0;
|
|
|
|
};
|
|
|
|
const stringUtcToLocalDate = (date) => {
|
|
|
|
if (typeof date === 'string')
|
|
|
|
return parseInt(date) + timeZoneOffsetInMs;
|
|
|
|
return 0;
|
|
|
|
};
|
|
|
|
const dateToLocaleTimeString = (date) => {
|
|
|
|
const format = (date) => {
|
|
|
|
let hours = date.getHours();
|
|
|
|
let minutes = date.getMinutes();
|
|
|
|
let ampm = hours >= 12 ? 'pm' : 'am';
|
|
|
|
|
|
|
|
hours = hours % 12;
|
|
|
|
hours = hours ? hours : 12; // the hour '0' should be '12'
|
|
|
|
minutes = minutes < 10 ? '0' + minutes : minutes;
|
|
|
|
return hours + ':' + minutes + ' ' + ampm;
|
|
|
|
};
|
|
|
|
// MM/dd/yyyy hh:mm AM
|
|
|
|
return (date.getMonth() + 1) + '/' + (date.getDate()) + '/' + date.getFullYear() + ' ' + format(date);
|
|
|
|
};
|
2021-07-02 12:48:50 +00:00
|
|
|
const parseUserName = name => {
|
2021-07-02 14:49:53 +00:00
|
|
|
return AscCommon.UserInfoParser.getParsedName(name);
|
2021-07-02 12:48:50 +00:00
|
|
|
};
|
2021-02-18 15:40:54 +00:00
|
|
|
//end utils
|
|
|
|
|
2021-02-25 16:26:42 +00:00
|
|
|
class CommentsController extends Component {
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
this.usersStore = this.props.users;
|
|
|
|
this.appOptions = this.props.storeAppOptions;
|
|
|
|
this.storeComments = this.props.storeComments;
|
2021-06-07 16:54:19 +00:00
|
|
|
this.storeApplicationSettings = this.props.storeApplicationSettings;
|
2021-02-25 16:26:42 +00:00
|
|
|
|
|
|
|
Common.Notifications.on('engineCreated', api => {
|
|
|
|
api.asc_registerCallback('asc_onAddComment', this.addComment.bind(this));
|
|
|
|
api.asc_registerCallback('asc_onAddComments', this.addComments.bind(this));
|
|
|
|
api.asc_registerCallback('asc_onRemoveComment', this.removeComment.bind(this));
|
|
|
|
api.asc_registerCallback('asc_onRemoveComments', this.removeComments.bind(this));
|
|
|
|
api.asc_registerCallback('asc_onChangeCommentData', this.changeCommentData.bind(this));
|
2021-03-10 18:08:59 +00:00
|
|
|
api.asc_registerCallback('asc_onShowComment', this.changeShowComments.bind(this));
|
|
|
|
api.asc_registerCallback('asc_onHideComment', this.hideComments.bind(this));
|
2021-02-25 16:26:42 +00:00
|
|
|
|
2021-03-24 22:07:10 +00:00
|
|
|
if (window.editorType === 'sse') {
|
|
|
|
api.asc_registerCallback('asc_onActiveSheetChanged', this.onApiActiveSheetChanged.bind(this));
|
|
|
|
Common.Notifications.on('comments:filterchange', this.onFilterChange.bind(this));
|
|
|
|
Common.Notifications.on('sheet:active', this.onApiActiveSheetChanged.bind(this));
|
|
|
|
}
|
2021-02-25 16:26:42 +00:00
|
|
|
});
|
2021-03-01 20:09:39 +00:00
|
|
|
|
|
|
|
Common.Notifications.on('document:ready', () => {
|
|
|
|
if (window.editorType === 'de' || window.editorType === 'sse') {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
/** coauthoring begin **/
|
|
|
|
const isLiveCommenting = LocalStorage.getBool(`${window.editorType}-mobile-settings-livecomment`, true);
|
2021-07-07 15:31:44 +00:00
|
|
|
const resolved = LocalStorage.getBool(`${window.editorType}-settings-resolvedcomment`);
|
2021-06-07 16:54:19 +00:00
|
|
|
this.storeApplicationSettings.changeDisplayComments(isLiveCommenting);
|
|
|
|
this.storeApplicationSettings.changeDisplayResolved(resolved);
|
2021-03-01 20:09:39 +00:00
|
|
|
isLiveCommenting ? api.asc_showComments(resolved) : api.asc_hideComments();
|
|
|
|
/** coauthoring end **/
|
|
|
|
}
|
2021-03-24 22:07:10 +00:00
|
|
|
|
|
|
|
this.curUserId = this.props.users.currentUser.asc_getIdOriginal();
|
2021-03-01 20:09:39 +00:00
|
|
|
});
|
2021-02-25 16:26:42 +00:00
|
|
|
}
|
2021-03-24 22:07:10 +00:00
|
|
|
onApiActiveSheetChanged (index) {
|
|
|
|
this.onFilterChange(['doc', 'sheet' + Common.EditorApi.get().asc_getWorksheetId(index)]);
|
|
|
|
}
|
2021-02-25 16:26:42 +00:00
|
|
|
addComment (id, data) {
|
|
|
|
const comment = this.readSDKComment(id, data);
|
|
|
|
if (comment) {
|
|
|
|
this.storeComments.addComment(comment);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
addComments (data) {
|
|
|
|
for (let i = 0; i < data.length; ++i) {
|
|
|
|
const comment = this.readSDKComment(data[i].asc_getId(), data[i]);
|
|
|
|
this.storeComments.addComment(comment);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
removeComment (id) {
|
|
|
|
this.storeComments.removeComment(id);
|
2021-06-09 14:17:42 +00:00
|
|
|
if (this.storeComments.showComments.length < 1) {
|
|
|
|
Device.phone ? f7.sheet.close('#view-comment-sheet') : f7.popover.close('#view-comment-popover');
|
|
|
|
}
|
2021-02-25 16:26:42 +00:00
|
|
|
}
|
|
|
|
removeComments (data) {
|
|
|
|
for (let i = 0; i < data.length; i++) {
|
|
|
|
this.removeComment(data[i]);
|
|
|
|
}
|
|
|
|
}
|
2021-03-10 18:08:59 +00:00
|
|
|
changeShowComments (id) {
|
|
|
|
this.storeComments.changeShowComment(id);
|
|
|
|
}
|
|
|
|
hideComments () {
|
|
|
|
//Common.Notifications.trigger('closeviewcomment');
|
|
|
|
}
|
2021-02-25 16:26:42 +00:00
|
|
|
changeCommentData (id, data) {
|
2021-03-10 18:08:59 +00:00
|
|
|
const changeComment = {};
|
2021-02-25 16:26:42 +00:00
|
|
|
|
2021-03-10 18:08:59 +00:00
|
|
|
const date = (data.asc_getOnlyOfficeTime()) ? new Date(stringOOToLocalDate(data.asc_getOnlyOfficeTime())) :
|
|
|
|
((data.asc_getTime() === '') ? new Date() : new Date(stringUtcToLocalDate(data.asc_getTime())));
|
2021-02-25 16:26:42 +00:00
|
|
|
|
2021-03-10 18:08:59 +00:00
|
|
|
let user = this.usersStore.searchUserById(data.asc_getUserId());
|
2021-07-02 12:48:50 +00:00
|
|
|
const name = data.asc_getUserName();
|
2021-07-02 14:49:53 +00:00
|
|
|
const parsedName = parseUserName(name);
|
2021-02-25 16:26:42 +00:00
|
|
|
|
2021-03-10 18:08:59 +00:00
|
|
|
changeComment.comment = data.asc_getText();
|
|
|
|
changeComment.userId = data.asc_getUserId();
|
2021-07-02 12:48:50 +00:00
|
|
|
changeComment.userName = name;
|
2021-07-02 14:49:53 +00:00
|
|
|
changeComment.parsedName = Common.Utils.String.htmlEncode(parsedName);
|
|
|
|
changeComment.userInitials = this.usersStore.getInitials(parsedName);
|
2021-03-10 18:08:59 +00:00
|
|
|
changeComment.userColor = (user) ? user.asc_getColor() : null;
|
|
|
|
changeComment.resolved = data.asc_getSolved();
|
|
|
|
changeComment.quote = data.asc_getQuoteText();
|
|
|
|
changeComment.time = date.getTime();
|
|
|
|
changeComment.date = dateToLocaleTimeString(date);
|
2021-07-08 14:21:29 +00:00
|
|
|
changeComment.editable = (this.appOptions.canEditComments || (data.asc_getUserId() === this.curUserId)) && AscCommon.UserInfoParser.canEditComment(name);
|
|
|
|
changeComment.removable = (this.appOptions.canDeleteComments || (data.asc_getUserId() === this.curUserId)) && AscCommon.UserInfoParser.canDeleteComment(name);
|
|
|
|
changeComment.hide = !AscCommon.UserInfoParser.canViewComment(name);
|
2021-02-25 16:26:42 +00:00
|
|
|
|
2021-03-10 18:08:59 +00:00
|
|
|
let dateReply = null;
|
|
|
|
const replies = [];
|
2021-02-25 16:26:42 +00:00
|
|
|
|
2021-03-10 18:08:59 +00:00
|
|
|
const repliesCount = data.asc_getRepliesCount();
|
|
|
|
for (let i = 0; i < repliesCount; ++i) {
|
|
|
|
|
|
|
|
dateReply = (data.asc_getReply(i).asc_getOnlyOfficeTime()) ? new Date(stringOOToLocalDate(data.asc_getReply(i).asc_getOnlyOfficeTime())) :
|
|
|
|
((data.asc_getReply(i).asc_getTime() === '') ? new Date() : new Date(stringUtcToLocalDate(data.asc_getReply(i).asc_getTime())));
|
|
|
|
|
|
|
|
user = this.usersStore.searchUserById(data.asc_getReply(i).asc_getUserId());
|
|
|
|
const userName = data.asc_getReply(i).asc_getUserName();
|
2021-07-02 12:48:50 +00:00
|
|
|
const parsedName = parseUserName(userName);
|
2021-03-10 18:08:59 +00:00
|
|
|
replies.push({
|
|
|
|
ind: i,
|
|
|
|
userId: data.asc_getReply(i).asc_getUserId(),
|
|
|
|
userName: userName,
|
2021-07-02 14:49:53 +00:00
|
|
|
parsedName: Common.Utils.String.htmlEncode(parsedName),
|
2021-03-10 18:08:59 +00:00
|
|
|
userColor: (user) ? user.asc_getColor() : null,
|
|
|
|
date: dateToLocaleTimeString(dateReply),
|
|
|
|
reply: data.asc_getReply(i).asc_getText(),
|
|
|
|
time: dateReply.getTime(),
|
2021-07-02 12:48:50 +00:00
|
|
|
userInitials: this.usersStore.getInitials(parsedName),
|
2021-07-08 14:21:29 +00:00
|
|
|
editable: (this.appOptions.canEditComments || (data.asc_getReply(i).asc_getUserId() === this.curUserId)) && AscCommon.UserInfoParser.canEditComment(userName),
|
|
|
|
removable: (this.appOptions.canDeleteComments || (data.asc_getReply(i).asc_getUserId() === this.curUserId)) && AscCommon.UserInfoParser.canDeleteComment(userName)
|
2021-03-10 18:08:59 +00:00
|
|
|
});
|
2021-02-25 16:26:42 +00:00
|
|
|
}
|
2021-03-10 18:08:59 +00:00
|
|
|
changeComment.replies = replies;
|
|
|
|
|
|
|
|
this.props.storeComments.changeComment(id, changeComment);
|
2021-02-25 16:26:42 +00:00
|
|
|
}
|
|
|
|
onFilterChange (filter) {
|
|
|
|
this.storeComments.changeFilter(filter);
|
|
|
|
}
|
|
|
|
readSDKComment (id, data) {
|
|
|
|
const date = (data.asc_getOnlyOfficeTime()) ? new Date(stringOOToLocalDate(data.asc_getOnlyOfficeTime())) :
|
|
|
|
((data.asc_getTime() === '') ? new Date() : new Date(stringUtcToLocalDate(data.asc_getTime())));
|
|
|
|
const user = this.usersStore.searchUserById(data.asc_getUserId());
|
|
|
|
const groupName = id.substr(0, id.lastIndexOf('_')+1).match(/^(doc|sheet[0-9_]+)_/);
|
|
|
|
const userName = data.asc_getUserName();
|
2021-07-02 12:48:50 +00:00
|
|
|
const parsedName = parseUserName(userName);
|
2021-02-25 16:26:42 +00:00
|
|
|
const comment = {
|
|
|
|
uid : id,
|
|
|
|
userId : data.asc_getUserId(),
|
|
|
|
userName : userName,
|
2021-12-17 14:09:16 +00:00
|
|
|
parsedName,
|
2021-02-25 16:26:42 +00:00
|
|
|
userColor : (user) ? user.asc_getColor() : null,
|
|
|
|
date : dateToLocaleTimeString(date),
|
|
|
|
quote : data.asc_getQuoteText(),
|
|
|
|
comment : data.asc_getText(),
|
|
|
|
resolved : data.asc_getSolved(),
|
|
|
|
unattached : !!data.asc_getDocumentFlag ? data.asc_getDocumentFlag() : false,
|
|
|
|
time : date.getTime(),
|
|
|
|
replies : [],
|
|
|
|
groupName : (groupName && groupName.length>1) ? groupName[1] : null,
|
2021-07-02 12:48:50 +00:00
|
|
|
userInitials : this.usersStore.getInitials(parsedName),
|
2021-07-08 14:21:29 +00:00
|
|
|
editable : (this.appOptions.canEditComments || (data.asc_getUserId() === this.curUserId)) && AscCommon.UserInfoParser.canEditComment(userName),
|
|
|
|
removable : (this.appOptions.canDeleteComments || (data.asc_getUserId() === this.curUserId)) && AscCommon.UserInfoParser.canDeleteComment(userName),
|
|
|
|
hide : !AscCommon.UserInfoParser.canViewComment(userName),
|
2021-02-25 16:26:42 +00:00
|
|
|
};
|
|
|
|
if (comment) {
|
|
|
|
const replies = this.readSDKReplies(data);
|
|
|
|
if (replies.length > 0) {
|
|
|
|
comment.replies = replies;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return comment;
|
|
|
|
}
|
|
|
|
readSDKReplies (data) {
|
|
|
|
const replies = [];
|
|
|
|
const repliesCount = data.asc_getRepliesCount();
|
|
|
|
let i = 0;
|
|
|
|
let date = null;
|
|
|
|
if (repliesCount) {
|
|
|
|
for (i = 0; i < repliesCount; ++i) {
|
|
|
|
date = (data.asc_getReply(i).asc_getOnlyOfficeTime()) ? new Date(stringOOToLocalDate(data.asc_getReply(i).asc_getOnlyOfficeTime())) :
|
|
|
|
((data.asc_getReply(i).asc_getTime() === '') ? new Date() : new Date(stringUtcToLocalDate(data.asc_getReply(i).asc_getTime())));
|
|
|
|
const user = this.usersStore.searchUserById(data.asc_getReply(i).asc_getUserId());
|
|
|
|
const userName = data.asc_getReply(i).asc_getUserName();
|
2021-07-02 12:48:50 +00:00
|
|
|
const parsedName = parseUserName(userName);
|
2021-02-25 16:26:42 +00:00
|
|
|
replies.push({
|
|
|
|
ind : i,
|
|
|
|
userId : data.asc_getReply(i).asc_getUserId(),
|
|
|
|
userName : userName,
|
2021-07-02 14:49:53 +00:00
|
|
|
parsedName : Common.Utils.String.htmlEncode(parsedName),
|
2021-02-25 16:26:42 +00:00
|
|
|
userColor : (user) ? user.asc_getColor() : null,
|
|
|
|
date : dateToLocaleTimeString(date),
|
|
|
|
reply : data.asc_getReply(i).asc_getText(),
|
|
|
|
time : date.getTime(),
|
2021-07-02 12:48:50 +00:00
|
|
|
userInitials : this.usersStore.getInitials(parsedName),
|
2021-07-08 14:21:29 +00:00
|
|
|
editable : (this.appOptions.canEditComments || (data.asc_getReply(i).asc_getUserId() === this.curUserId)) && AscCommon.UserInfoParser.canEditComment(userName),
|
|
|
|
removable : (this.appOptions.canDeleteComments || (data.asc_getReply(i).asc_getUserId() === this.curUserId)) && AscCommon.UserInfoParser.canDeleteComment(userName)
|
2021-02-25 16:26:42 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return replies;
|
|
|
|
}
|
|
|
|
render() {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-18 15:40:54 +00:00
|
|
|
class AddCommentController extends Component {
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
2021-03-05 15:23:35 +00:00
|
|
|
this.closeAddComment = this.closeAddComment.bind(this);
|
2021-02-18 15:40:54 +00:00
|
|
|
this.getUserInfo = this.getUserInfo.bind(this);
|
|
|
|
this.onAddNewComment = this.onAddNewComment.bind(this);
|
2021-03-05 15:23:35 +00:00
|
|
|
|
|
|
|
this.state = {
|
|
|
|
isOpen: false
|
|
|
|
};
|
|
|
|
|
|
|
|
Common.Notifications.on('addcomment', () => {
|
2021-07-05 20:01:51 +00:00
|
|
|
f7.popover.close('#idx-context-menu-popover'); //close context menu
|
2021-03-05 15:23:35 +00:00
|
|
|
this.setState({isOpen: true});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
closeAddComment () {
|
|
|
|
this.setState({isOpen: false});
|
2021-02-18 15:40:54 +00:00
|
|
|
}
|
|
|
|
getUserInfo () {
|
|
|
|
this.currentUser = this.props.users.currentUser;
|
2021-03-22 11:35:16 +00:00
|
|
|
if (!this.currentUser) {
|
|
|
|
this.currentUser = this.props.users.setCurrentUser(this.props.storeAppOptions.user.id);
|
|
|
|
}
|
2021-07-02 12:48:50 +00:00
|
|
|
const name = parseUserName(this.currentUser.asc_getUserName());
|
2021-02-18 15:40:54 +00:00
|
|
|
return {
|
2021-07-02 14:49:53 +00:00
|
|
|
name: Common.Utils.String.htmlEncode(name),
|
2021-02-18 15:40:54 +00:00
|
|
|
initials: this.props.users.getInitials(name),
|
|
|
|
color: this.currentUser.asc_getColor()
|
|
|
|
};
|
|
|
|
}
|
|
|
|
onAddNewComment (commentText, documentFlag) {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
let comment;
|
|
|
|
if (typeof Asc.asc_CCommentDataWord !== 'undefined') {
|
|
|
|
comment = new Asc.asc_CCommentDataWord(null);
|
|
|
|
} else {
|
|
|
|
comment = new Asc.asc_CCommentData(null);
|
|
|
|
}
|
|
|
|
if (commentText.length > 0) {
|
|
|
|
comment.asc_putText(commentText);
|
|
|
|
comment.asc_putTime(utcDateToString(new Date()));
|
|
|
|
comment.asc_putOnlyOfficeTime(ooDateToString(new Date()));
|
|
|
|
comment.asc_putUserId(this.currentUser.asc_getIdOriginal());
|
|
|
|
comment.asc_putUserName(this.currentUser.asc_getUserName());
|
|
|
|
comment.asc_putSolved(false);
|
|
|
|
|
|
|
|
!!comment.asc_putDocumentFlag && comment.asc_putDocumentFlag(documentFlag);
|
|
|
|
|
|
|
|
api.asc_addComment(comment);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
render() {
|
|
|
|
return(
|
2021-03-05 15:23:35 +00:00
|
|
|
this.state.isOpen ? <AddComment userInfo={this.getUserInfo()} onAddNewComment={this.onAddNewComment} closeAddComment={this.closeAddComment}/> : null
|
2021-02-18 15:40:54 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-03-03 16:49:36 +00:00
|
|
|
class EditCommentController extends Component {
|
2021-02-28 17:47:47 +00:00
|
|
|
constructor (props) {
|
2021-02-25 16:26:42 +00:00
|
|
|
super(props);
|
2021-02-28 17:47:47 +00:00
|
|
|
this.onEditComment = this.onEditComment.bind(this);
|
2021-03-03 16:49:36 +00:00
|
|
|
this.onAddReply = this.onAddReply.bind(this);
|
2021-03-03 18:21:03 +00:00
|
|
|
this.onEditReply = this.onEditReply.bind(this);
|
2021-03-03 16:49:36 +00:00
|
|
|
}
|
|
|
|
getUserInfo () {
|
2021-02-28 17:47:47 +00:00
|
|
|
this.currentUser = this.props.users.currentUser;
|
2021-07-02 12:48:50 +00:00
|
|
|
const name = parseUserName(this.currentUser.asc_getUserName());
|
2021-03-03 16:49:36 +00:00
|
|
|
return {
|
2021-07-02 14:49:53 +00:00
|
|
|
name: Common.Utils.String.htmlEncode(name),
|
2021-03-03 16:49:36 +00:00
|
|
|
initials: this.props.users.getInitials(name),
|
|
|
|
color: this.currentUser.asc_getColor()
|
2021-02-28 17:47:47 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
onChangeComment (comment) {
|
2021-03-03 16:49:36 +00:00
|
|
|
const ascComment = typeof Asc.asc_CCommentDataWord !== 'undefined' ? new Asc.asc_CCommentDataWord(null) : new Asc.asc_CCommentData(null);
|
2021-02-28 17:47:47 +00:00
|
|
|
if (ascComment && comment) {
|
|
|
|
ascComment.asc_putText(comment.comment);
|
|
|
|
ascComment.asc_putQuoteText(comment.quote);
|
|
|
|
ascComment.asc_putTime(utcDateToString(new Date(comment.time)));
|
|
|
|
ascComment.asc_putOnlyOfficeTime(ooDateToString(new Date(comment.time)));
|
|
|
|
ascComment.asc_putUserId(comment.userId);
|
|
|
|
ascComment.asc_putUserName(comment.userName);
|
|
|
|
ascComment.asc_putSolved(comment.resolved);
|
|
|
|
ascComment.asc_putGuid(comment.guid);
|
|
|
|
|
|
|
|
if (!!ascComment.asc_putDocumentFlag) {
|
|
|
|
ascComment.asc_putDocumentFlag(comment.unattached);
|
|
|
|
}
|
|
|
|
|
2021-03-26 13:23:17 +00:00
|
|
|
const reply = comment.replies;
|
2021-02-28 17:47:47 +00:00
|
|
|
if (reply && reply.length > 0) {
|
|
|
|
reply.forEach((reply) => {
|
2021-03-26 13:23:17 +00:00
|
|
|
const addReply = (typeof Asc.asc_CCommentDataWord !== 'undefined' ? new Asc.asc_CCommentDataWord(null) : new Asc.asc_CCommentData(null));
|
2021-02-28 17:47:47 +00:00
|
|
|
if (addReply) {
|
|
|
|
addReply.asc_putText(reply.reply);
|
|
|
|
addReply.asc_putTime(utcDateToString(new Date(reply.time)));
|
|
|
|
addReply.asc_putOnlyOfficeTime(ooDateToString(new Date(reply.time)));
|
|
|
|
addReply.asc_putUserId(reply.userId);
|
|
|
|
addReply.asc_putUserName(reply.userName);
|
|
|
|
|
|
|
|
ascComment.asc_addReply(addReply);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_changeComment(comment.uid, ascComment);
|
|
|
|
}
|
|
|
|
}
|
2021-03-03 16:49:36 +00:00
|
|
|
onEditComment (comment, text) {
|
2021-03-10 18:08:59 +00:00
|
|
|
const changeComment = {...comment};
|
|
|
|
changeComment.comment = text.trim();
|
2021-03-03 16:49:36 +00:00
|
|
|
const user = this.props.users.currentUser;
|
2021-03-10 18:08:59 +00:00
|
|
|
changeComment.userid = user.asc_getIdOriginal();
|
|
|
|
changeComment.username = user.asc_getUserName();
|
|
|
|
this.onChangeComment(changeComment);
|
2021-03-03 16:49:36 +00:00
|
|
|
}
|
|
|
|
onAddReply (comment, replyVal) {
|
|
|
|
let reply = null;
|
|
|
|
let addReply = null;
|
|
|
|
const ascComment = (typeof Asc.asc_CCommentDataWord !== 'undefined' ? new Asc.asc_CCommentDataWord(null) : new Asc.asc_CCommentData(null));
|
|
|
|
|
|
|
|
if (ascComment) {
|
|
|
|
ascComment.asc_putText(comment.comment);
|
|
|
|
ascComment.asc_putQuoteText(comment.quote);
|
|
|
|
ascComment.asc_putTime(utcDateToString(new Date(comment.time)));
|
|
|
|
ascComment.asc_putOnlyOfficeTime(ooDateToString(new Date(comment.time)));
|
|
|
|
ascComment.asc_putUserId(comment.userId);
|
|
|
|
ascComment.asc_putUserName(comment.userName);
|
|
|
|
ascComment.asc_putSolved(comment.resolved);
|
|
|
|
ascComment.asc_putGuid(comment.guid);
|
|
|
|
|
|
|
|
if (!!ascComment.asc_putDocumentFlag) {
|
|
|
|
ascComment.asc_putDocumentFlag(comment.unattached);
|
|
|
|
}
|
|
|
|
|
|
|
|
reply = comment.replies;
|
|
|
|
if (reply && reply.length) {
|
|
|
|
reply.forEach(function (reply) {
|
|
|
|
|
|
|
|
addReply = (typeof Asc.asc_CCommentDataWord !== 'undefined' ? new Asc.asc_CCommentDataWord(null) : new Asc.asc_CCommentData(null));
|
|
|
|
if (addReply) {
|
|
|
|
addReply.asc_putText(reply.reply);
|
|
|
|
addReply.asc_putTime(utcDateToString(new Date(reply.time)));
|
|
|
|
addReply.asc_putOnlyOfficeTime(ooDateToString(new Date(reply.time)));
|
|
|
|
addReply.asc_putUserId(reply.userId);
|
|
|
|
addReply.asc_putUserName(reply.userName);
|
|
|
|
|
|
|
|
ascComment.asc_addReply(addReply);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
addReply = (typeof Asc.asc_CCommentDataWord !== 'undefined' ? new Asc.asc_CCommentDataWord(null) : new Asc.asc_CCommentData(null));
|
|
|
|
if (addReply) {
|
|
|
|
addReply.asc_putText(replyVal);
|
|
|
|
addReply.asc_putTime(utcDateToString(new Date()));
|
|
|
|
addReply.asc_putOnlyOfficeTime(ooDateToString(new Date()));
|
|
|
|
const currentUser = this.props.users.currentUser;
|
|
|
|
addReply.asc_putUserId(currentUser.asc_getIdOriginal());
|
|
|
|
addReply.asc_putUserName(currentUser.asc_getUserName());
|
|
|
|
|
|
|
|
ascComment.asc_addReply(addReply);
|
|
|
|
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_changeComment(comment.uid, ascComment);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-03-03 18:21:03 +00:00
|
|
|
onEditReply (comment, reply, textReply) {
|
|
|
|
const currentUser = this.props.users.currentUser;
|
|
|
|
const indReply = reply.ind;
|
2021-03-10 18:08:59 +00:00
|
|
|
const changeComment = {...comment};
|
|
|
|
changeComment.replies = [...comment.replies];
|
|
|
|
changeComment.replies[indReply] = {...reply};
|
|
|
|
changeComment.replies[indReply].reply = textReply;
|
|
|
|
changeComment.replies[indReply].userid = currentUser.asc_getIdOriginal();
|
|
|
|
changeComment.replies[indReply].username = currentUser.asc_getUserName();
|
|
|
|
this.onChangeComment(changeComment);
|
2021-03-03 18:21:03 +00:00
|
|
|
}
|
2021-03-03 16:49:36 +00:00
|
|
|
render() {
|
|
|
|
const storeComments = this.props.storeComments;
|
|
|
|
const comment = storeComments.currentComment;
|
|
|
|
return (
|
|
|
|
<Fragment>
|
|
|
|
{storeComments.isOpenEditComment && <EditComment comment={comment} onEditComment={this.onEditComment}/>}
|
|
|
|
{storeComments.isOpenAddReply && <AddReply userInfo={this.getUserInfo()} comment={comment} onAddReply={this.onAddReply}/>}
|
2021-03-03 18:21:03 +00:00
|
|
|
{storeComments.isOpenEditReply && <EditReply comment={comment} reply={storeComments.currentReply} onEditReply={this.onEditReply}/>}
|
2021-03-03 16:49:36 +00:00
|
|
|
</Fragment>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class ViewCommentsController extends Component {
|
|
|
|
constructor (props) {
|
|
|
|
super(props);
|
|
|
|
this.onCommentMenuClick = this.onCommentMenuClick.bind(this);
|
|
|
|
this.onResolveComment = this.onResolveComment.bind(this);
|
2021-03-08 18:30:42 +00:00
|
|
|
this.closeViewCurComments = this.closeViewCurComments.bind(this);
|
2021-03-03 16:49:36 +00:00
|
|
|
|
2021-03-08 18:30:42 +00:00
|
|
|
this.state = {
|
|
|
|
isOpenViewCurComments: false
|
|
|
|
};
|
|
|
|
|
|
|
|
Common.Notifications.on('viewcomment', () => {
|
|
|
|
this.setState({isOpenViewCurComments: true});
|
|
|
|
});
|
2021-03-10 18:08:59 +00:00
|
|
|
Common.Notifications.on('closeviewcomment', () => {
|
|
|
|
this.closeViewCurComments();
|
|
|
|
});
|
2021-03-08 18:30:42 +00:00
|
|
|
}
|
|
|
|
closeViewCurComments () {
|
2021-07-13 12:50:55 +00:00
|
|
|
if (Device.phone) {
|
|
|
|
f7.sheet.close('#view-comment-sheet');
|
|
|
|
} else {
|
|
|
|
f7.popover.close('#view-comment-popover');
|
|
|
|
}
|
2021-03-08 18:30:42 +00:00
|
|
|
this.setState({isOpenViewCurComments: false});
|
2021-03-03 16:49:36 +00:00
|
|
|
}
|
2021-02-28 17:47:47 +00:00
|
|
|
onResolveComment (comment) {
|
|
|
|
let reply = null,
|
|
|
|
addReply = null,
|
2021-03-10 18:08:59 +00:00
|
|
|
ascComment = (typeof Asc.asc_CCommentDataWord !== 'undefined' ? new Asc.asc_CCommentDataWord(null) : new Asc.asc_CCommentData(null));
|
2021-02-28 17:47:47 +00:00
|
|
|
|
|
|
|
if (ascComment && comment) {
|
|
|
|
ascComment.asc_putText(comment.comment);
|
|
|
|
ascComment.asc_putQuoteText(comment.quote);
|
|
|
|
ascComment.asc_putTime(utcDateToString(new Date(comment.time)));
|
|
|
|
ascComment.asc_putOnlyOfficeTime(ooDateToString(new Date(comment.time)));
|
|
|
|
ascComment.asc_putUserId(comment.userId);
|
|
|
|
ascComment.asc_putUserName(comment.userName);
|
|
|
|
ascComment.asc_putSolved(!comment.resolved);
|
|
|
|
ascComment.asc_putGuid(comment.guid);
|
|
|
|
|
|
|
|
if (!!ascComment.asc_putDocumentFlag) {
|
|
|
|
ascComment.asc_putDocumentFlag(comment.unattached);
|
|
|
|
}
|
|
|
|
|
|
|
|
reply = comment.replies;
|
|
|
|
if (reply && reply.length > 0) {
|
|
|
|
reply.forEach((reply) => {
|
2021-03-10 18:08:59 +00:00
|
|
|
addReply = (typeof Asc.asc_CCommentDataWord !== 'undefined' ? new Asc.asc_CCommentDataWord(null) : new Asc.asc_CCommentData(null));
|
2021-02-28 17:47:47 +00:00
|
|
|
if (addReply) {
|
|
|
|
addReply.asc_putText(reply.reply);
|
|
|
|
addReply.asc_putTime(utcDateToString(new Date(reply.time)));
|
|
|
|
addReply.asc_putOnlyOfficeTime(ooDateToString(new Date(reply.time)));
|
|
|
|
addReply.asc_putUserId(reply.userId);
|
|
|
|
addReply.asc_putUserName(reply.userName);
|
|
|
|
|
|
|
|
ascComment.asc_addReply(addReply);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
const api = Common.EditorApi.get();
|
2021-07-07 15:31:44 +00:00
|
|
|
api.asc_showComments(this.props.storeApplicationSettings.isResolvedComments);
|
2021-02-28 17:47:47 +00:00
|
|
|
api.asc_changeComment(comment.uid, ascComment);
|
2021-06-28 11:40:46 +00:00
|
|
|
|
|
|
|
if(!this.props.storeApplicationSettings.isResolvedComments) {
|
|
|
|
this.closeViewCurComments();
|
|
|
|
}
|
2021-02-28 17:47:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
deleteComment (comment) {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
comment && api.asc_removeComment(comment.uid);
|
|
|
|
}
|
2021-03-03 18:21:03 +00:00
|
|
|
deleteReply (comment, reply) {
|
2021-02-28 17:47:47 +00:00
|
|
|
let replies = null,
|
|
|
|
addReply = null,
|
|
|
|
ascComment = (!!Asc.asc_CCommentDataWord ? new Asc.asc_CCommentDataWord(null) : new Asc.asc_CCommentData(null));
|
|
|
|
|
2021-03-03 18:21:03 +00:00
|
|
|
const indReply = reply.ind;
|
|
|
|
|
2021-02-28 17:47:47 +00:00
|
|
|
if (ascComment && comment) {
|
|
|
|
ascComment.asc_putText(comment.comment);
|
|
|
|
ascComment.asc_putQuoteText(comment.quote);
|
|
|
|
ascComment.asc_putTime(utcDateToString(new Date(comment.time)));
|
|
|
|
ascComment.asc_putOnlyOfficeTime(ooDateToString(new Date(comment.time)));
|
|
|
|
ascComment.asc_putUserId(comment.userId);
|
|
|
|
ascComment.asc_putUserName(comment.userName);
|
|
|
|
ascComment.asc_putSolved(comment.resolved);
|
|
|
|
ascComment.asc_putGuid(comment.guid);
|
|
|
|
|
|
|
|
if (!!ascComment.asc_putDocumentFlag) {
|
|
|
|
ascComment.asc_putDocumentFlag(comment.unattached);
|
|
|
|
}
|
|
|
|
|
|
|
|
replies = comment.replies;
|
|
|
|
if (replies && replies.length) {
|
|
|
|
replies.forEach((reply) => {
|
|
|
|
if (reply.ind !== indReply) {
|
|
|
|
addReply = (!!Asc.asc_CCommentDataWord ? new Asc.asc_CCommentDataWord(null) : new Asc.asc_CCommentData(null));
|
|
|
|
if (addReply) {
|
|
|
|
addReply.asc_putText(reply.reply);
|
|
|
|
addReply.asc_putTime(utcDateToString(new Date(reply.time)));
|
|
|
|
addReply.asc_putOnlyOfficeTime(ooDateToString(new Date(reply.time)));
|
|
|
|
addReply.asc_putUserId(reply.userId);
|
|
|
|
addReply.asc_putUserName(reply.userName);
|
|
|
|
|
|
|
|
ascComment.asc_addReply(addReply);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
api.asc_changeComment(comment.uid, ascComment);
|
|
|
|
}
|
|
|
|
}
|
2021-03-03 18:21:03 +00:00
|
|
|
onCommentMenuClick (action, comment, reply) {
|
2021-02-28 17:47:47 +00:00
|
|
|
const { t } = this.props;
|
|
|
|
const _t = t("Common.Collaboration", { returnObjects: true });
|
|
|
|
switch (action) {
|
|
|
|
case 'editComment':
|
2021-03-03 16:49:36 +00:00
|
|
|
this.props.storeComments.openEditComment(true, comment);
|
2021-02-28 17:47:47 +00:00
|
|
|
break;
|
|
|
|
case 'resolve':
|
|
|
|
this.onResolveComment(comment);
|
|
|
|
break;
|
|
|
|
case 'deleteComment':
|
2021-08-23 10:47:41 +00:00
|
|
|
f7.dialog.create({
|
|
|
|
title: _t.textDeleteComment,
|
|
|
|
text: _t.textMessageDeleteComment,
|
|
|
|
buttons: [
|
|
|
|
{
|
|
|
|
text: _t.textCancel
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: _t.textOk,
|
|
|
|
onClick: () => this.deleteComment(comment)
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}).open();
|
2021-02-28 17:47:47 +00:00
|
|
|
break;
|
|
|
|
case 'editReply':
|
2021-03-03 18:21:03 +00:00
|
|
|
this.props.storeComments.openEditReply(true, comment, reply);
|
2021-02-28 17:47:47 +00:00
|
|
|
break;
|
|
|
|
case 'deleteReply':
|
2021-08-23 10:47:41 +00:00
|
|
|
f7.dialog.create({
|
|
|
|
title: _t.textDeleteReply,
|
|
|
|
text: _t.textMessageDeleteReply,
|
|
|
|
buttons: [
|
|
|
|
{
|
|
|
|
text: _t.textCancel
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: _t.textOk,
|
|
|
|
onClick: () => this.deleteReply(comment, reply)
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}).open();
|
2021-02-28 17:47:47 +00:00
|
|
|
break;
|
|
|
|
case 'addReply':
|
2021-03-03 16:49:36 +00:00
|
|
|
this.props.storeComments.openAddReply(true, comment);
|
2021-02-28 17:47:47 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2021-05-31 15:08:02 +00:00
|
|
|
|
|
|
|
showComment (comment) {
|
|
|
|
const api = Common.EditorApi.get();
|
|
|
|
|
|
|
|
api.asc_selectComment(comment.uid);
|
|
|
|
api.asc_showComment(comment.uid, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-02-25 16:26:42 +00:00
|
|
|
render() {
|
|
|
|
return(
|
2021-03-08 18:30:42 +00:00
|
|
|
<Fragment>
|
2021-10-21 19:45:19 +00:00
|
|
|
{this.props.allComments && <ViewComments wsProps={this.props?.storeWorksheets?.wsProps} onCommentMenuClick={this.onCommentMenuClick} onResolveComment={this.onResolveComment}
|
2021-05-31 15:08:02 +00:00
|
|
|
showComment={this.showComment} />}
|
2021-10-21 19:45:19 +00:00
|
|
|
{this.state.isOpenViewCurComments && <ViewCurrentComments wsProps={this.props?.storeWorksheets?.wsProps} opened={this.state.isOpenViewCurComments}
|
2021-03-10 18:08:59 +00:00
|
|
|
closeCurComments={this.closeViewCurComments}
|
|
|
|
onCommentMenuClick={this.onCommentMenuClick}
|
|
|
|
onResolveComment={this.onResolveComment}
|
|
|
|
/>}
|
2021-03-08 18:30:42 +00:00
|
|
|
</Fragment>
|
2021-02-25 16:26:42 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-20 17:24:08 +00:00
|
|
|
class ViewCommentsSheetsController extends ViewCommentsController {
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-07 16:54:19 +00:00
|
|
|
const _CommentsController = inject('storeAppOptions', 'storeComments', 'users', "storeApplicationSettings")(observer(CommentsController));
|
2021-02-25 16:26:42 +00:00
|
|
|
const _AddCommentController = inject('storeAppOptions', 'storeComments', 'users')(observer(AddCommentController));
|
2021-03-03 16:49:36 +00:00
|
|
|
const _EditCommentController = inject('storeComments', 'users')(observer(EditCommentController));
|
2021-10-20 17:24:08 +00:00
|
|
|
const _ViewCommentsController = inject('storeComments', 'users', "storeApplicationSettings", "storeReview", "storeAppOptions")(observer(withTranslation()(ViewCommentsController)));
|
|
|
|
const _ViewCommentsSheetsController = inject('storeComments', 'users', "storeApplicationSettings", "storeWorksheets", "storeReview", "storeAppOptions")(observer(withTranslation()(ViewCommentsSheetsController)));
|
2021-02-25 16:26:42 +00:00
|
|
|
|
|
|
|
export {
|
|
|
|
_CommentsController as CommentsController,
|
|
|
|
_AddCommentController as AddCommentController,
|
2021-03-03 16:49:36 +00:00
|
|
|
_EditCommentController as EditCommentController,
|
2021-10-20 17:24:08 +00:00
|
|
|
_ViewCommentsController as ViewCommentsController,
|
|
|
|
_ViewCommentsSheetsController as ViewCommentsSheetsController
|
2021-02-25 16:26:42 +00:00
|
|
|
};
|