Commit 4a000b10 authored by Ilya.Kirillov's avatar Ilya.Kirillov Committed by Alexander.Trofimov

Сделано, чтобы добавленный/удаленный в рецензировании текст разными людьми не объединялся.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@66744 954022d7-b5bf-4e40-9824-e11837661b57
parent ee6ce825
...@@ -14943,6 +14943,10 @@ CParagraphRevisionsChangesChecker.prototype.Get_AddRemoveType = function() ...@@ -14943,6 +14943,10 @@ CParagraphRevisionsChangesChecker.prototype.Get_AddRemoveType = function()
{ {
return this.AddRemove.ChangeType; return this.AddRemove.ChangeType;
}; };
CParagraphRevisionsChangesChecker.prototype.Get_AddRemoveUserId = function()
{
return this.AddRemove.UserId;
};
CParagraphRevisionsChangesChecker.prototype.Start_AddRemove = function(ChangeType, ContentPos) CParagraphRevisionsChangesChecker.prototype.Start_AddRemove = function(ChangeType, ContentPos)
{ {
this.AddRemove.ChangeType = ChangeType; this.AddRemove.ChangeType = ChangeType;
...@@ -15040,7 +15044,6 @@ CParagraphRevisionsChangesChecker.prototype.Update_PrChangeReviewInfo = function ...@@ -15040,7 +15044,6 @@ CParagraphRevisionsChangesChecker.prototype.Update_PrChangeReviewInfo = function
this.TextPr.UserName = ReviewInfo.Get_UserName(); this.TextPr.UserName = ReviewInfo.Get_UserName();
this.TextPr.DateTime = ReviewInfo.Get_DateTime(); this.TextPr.DateTime = ReviewInfo.Get_DateTime();
} }
}; };
CParagraphRevisionsChangesChecker.prototype.Is_ParaEndRun = function() CParagraphRevisionsChangesChecker.prototype.Is_ParaEndRun = function()
{ {
...@@ -15062,3 +15065,7 @@ CParagraphRevisionsChangesChecker.prototype.Is_CheckOnlyTextPr = function() ...@@ -15062,3 +15065,7 @@ CParagraphRevisionsChangesChecker.prototype.Is_CheckOnlyTextPr = function()
{ {
return (0 === this.CheckOnlyTextPr ? false : true); return (0 === this.CheckOnlyTextPr ? false : true);
}; };
CParagraphRevisionsChangesChecker.prototype.Get_PrChangeUserId = function()
{
return this.TextPr.UserId;
};
\ No newline at end of file
...@@ -357,7 +357,7 @@ ParaRun.prototype.Add = function(Item, bMath) ...@@ -357,7 +357,7 @@ ParaRun.prototype.Add = function(Item, bMath)
TrackRevisions = this.Paragraph.LogicDocument.Is_TrackRevisions(); TrackRevisions = this.Paragraph.LogicDocument.Is_TrackRevisions();
var ReviewType = this.Get_ReviewType(); var ReviewType = this.Get_ReviewType();
if ((true === TrackRevisions && reviewtype_Add !== ReviewType) || (false === TrackRevisions && reviewtype_Common !== ReviewType)) if ((true === TrackRevisions && (reviewtype_Add !== ReviewType || true !== this.ReviewInfo.Is_CurrentUser())) || (false === TrackRevisions && reviewtype_Common !== ReviewType))
{ {
var DstReviewType = true === TrackRevisions ? reviewtype_Add : reviewtype_Common; var DstReviewType = true === TrackRevisions ? reviewtype_Add : reviewtype_Common;
...@@ -378,7 +378,7 @@ ParaRun.prototype.Add = function(Item, bMath) ...@@ -378,7 +378,7 @@ ParaRun.prototype.Add = function(Item, bMath)
if (0 === CurPos && RunPos > 0) if (0 === CurPos && RunPos > 0)
{ {
var PrevElement = Parent.Content[RunPos - 1]; var PrevElement = Parent.Content[RunPos - 1];
if (para_Run === PrevElement.Type && DstReviewType === PrevElement.Get_ReviewType() && true === this.Pr.Is_Equal(PrevElement.Pr)) if (para_Run === PrevElement.Type && DstReviewType === PrevElement.Get_ReviewType() && true === this.Pr.Is_Equal(PrevElement.Pr) && PrevElement.ReviewInfo && true === PrevElement.ReviewInfo.Is_CurrentUser())
{ {
PrevElement.State.ContentPos = PrevElement.Content.length; PrevElement.State.ContentPos = PrevElement.Content.length;
PrevElement.Add_ToContent(PrevElement.Content.length, Item, true); PrevElement.Add_ToContent(PrevElement.Content.length, Item, true);
...@@ -390,7 +390,7 @@ ParaRun.prototype.Add = function(Item, bMath) ...@@ -390,7 +390,7 @@ ParaRun.prototype.Add = function(Item, bMath)
if (this.Content.length === CurPos && (RunPos < Parent.Content.length - 2 || (RunPos < Parent.Content.length - 1 && !(Parent instanceof Paragraph)))) if (this.Content.length === CurPos && (RunPos < Parent.Content.length - 2 || (RunPos < Parent.Content.length - 1 && !(Parent instanceof Paragraph))))
{ {
var NextElement = Parent.Content[RunPos + 1]; var NextElement = Parent.Content[RunPos + 1];
if (para_Run === NextElement.Type && DstReviewType === NextElement.Get_ReviewType() && true === this.Pr.Is_Equal(NextElement.Pr)) if (para_Run === NextElement.Type && DstReviewType === NextElement.Get_ReviewType() && true === this.Pr.Is_Equal(NextElement.Pr) && NextElement.ReviewInfo && true === NextElement.ReviewInfo.Is_CurrentUser())
{ {
NextElement.State.ContentPos = 0; NextElement.State.ContentPos = 0;
NextElement.Add_ToContent(0, Item, true); NextElement.Add_ToContent(0, Item, true);
...@@ -411,10 +411,16 @@ ParaRun.prototype.Add = function(Item, bMath) ...@@ -411,10 +411,16 @@ ParaRun.prototype.Add = function(Item, bMath)
Parent.Add_ToContent(RunPos + 1, NewRun); Parent.Add_ToContent(RunPos + 1, NewRun);
else else
{ {
var OldReviewInfo = (this.ReviewInfo ? this.ReviewInfo.Copy() : undefined);
var OldReviewType = this.ReviewType;
// Нужно разделить данный ран в текущей позиции // Нужно разделить данный ран в текущей позиции
var RightRun = this.Split2(CurPos); var RightRun = this.Split2(CurPos);
Parent.Add_ToContent(RunPos + 1, NewRun); Parent.Add_ToContent(RunPos + 1, NewRun);
Parent.Add_ToContent(RunPos + 2, RightRun); Parent.Add_ToContent(RunPos + 2, RightRun);
this.Set_ReviewTypeWithInfo(OldReviewType, OldReviewInfo);
RightRun.Set_ReviewTypeWithInfo(OldReviewType, OldReviewInfo);
} }
NewRun.Make_ThisElementCurrent(); NewRun.Make_ThisElementCurrent();
...@@ -10190,7 +10196,7 @@ ParaRun.prototype.Check_RevisionsChanges = function(Checker, ContentPos, Depth) ...@@ -10190,7 +10196,7 @@ ParaRun.prototype.Check_RevisionsChanges = function(Checker, ContentPos, Depth)
if (true !== Checker.Is_ParaEndRun() && true !== Checker.Is_CheckOnlyTextPr()) if (true !== Checker.Is_ParaEndRun() && true !== Checker.Is_CheckOnlyTextPr())
{ {
var ReviewType = this.Get_ReviewType(); var ReviewType = this.Get_ReviewType();
if (ReviewType !== Checker.Get_AddRemoveType()) if (ReviewType !== Checker.Get_AddRemoveType() || (reviewtype_Common !== ReviewType && this.ReviewInfo.Get_UserId() !== Checker.Get_AddRemoveUserId()))
{ {
Checker.Flush_AddRemoveChange(); Checker.Flush_AddRemoveChange();
ContentPos.Update(0, Depth); ContentPos.Update(0, Depth);
...@@ -10243,7 +10249,7 @@ ParaRun.prototype.Check_RevisionsChanges = function(Checker, ContentPos, Depth) ...@@ -10243,7 +10249,7 @@ ParaRun.prototype.Check_RevisionsChanges = function(Checker, ContentPos, Depth)
var HavePrChange = this.Have_PrChange(); var HavePrChange = this.Have_PrChange();
var DiffPr = this.Get_DiffPrChange(); var DiffPr = this.Get_DiffPrChange();
if (HavePrChange !== Checker.Have_PrChange() || true !== Checker.Compare_PrChange(DiffPr)) if (HavePrChange !== Checker.Have_PrChange() || true !== Checker.Compare_PrChange(DiffPr) || this.Pr.ReviewInfo.Get_UserId() !== Checker.Get_PrChangeUserId())
{ {
Checker.Flush_TextPrChange(); Checker.Flush_TextPrChange();
ContentPos.Update(0, Depth); ContentPos.Update(0, Depth);
...@@ -10266,7 +10272,7 @@ ParaRun.prototype.private_UpdateTrackRevisionOnChangeContent = function(bUpdateI ...@@ -10266,7 +10272,7 @@ ParaRun.prototype.private_UpdateTrackRevisionOnChangeContent = function(bUpdateI
{ {
this.private_UpdateTrackRevisions(); this.private_UpdateTrackRevisions();
if (true === bUpdateInfo && this.Paragraph && this.Paragraph.LogicDocument && true === this.Paragraph.LogicDocument.Is_TrackRevisions()) if (true === bUpdateInfo && this.Paragraph && this.Paragraph.LogicDocument && true === this.Paragraph.LogicDocument.Is_TrackRevisions() && this.ReviewInfo && true === this.ReviewInfo.Is_CurrentUser())
{ {
var OldReviewInfo = this.ReviewInfo.Copy(); var OldReviewInfo = this.ReviewInfo.Copy();
this.ReviewInfo.Update(); this.ReviewInfo.Update();
...@@ -10577,3 +10583,17 @@ CReviewInfo.prototype.Get_Color = function() ...@@ -10577,3 +10583,17 @@ CReviewInfo.prototype.Get_Color = function()
return getUserColorById(this.UserId, this.UserName, true, false); return getUserColorById(this.UserId, this.UserName, true, false);
}; };
CReviewInfo.prototype.Is_CurrentUser = function()
{
if (this.Editor)
{
var UserId = this.Editor.DocInfo.get_UserId();
return (UserId === this.UserId);
}
return true;
};
CReviewInfo.prototype.Get_UserId = function()
{
return this.UserId;
};
\ No newline at end of file
...@@ -2450,7 +2450,7 @@ CMathBase.prototype.Check_RevisionsChanges = function(Checker, ContentPos, Depth ...@@ -2450,7 +2450,7 @@ CMathBase.prototype.Check_RevisionsChanges = function(Checker, ContentPos, Depth
if (true !== Checker.Is_CheckOnlyTextPr()) if (true !== Checker.Is_CheckOnlyTextPr())
{ {
if (ReviewType !== Checker.Get_AddRemoveType()) if (ReviewType !== Checker.Get_AddRemoveType() || (reviewtype_Common !== ReviewType && this.ReviewInfo.Get_UserId() !== Checker.Get_AddRemoveUserId()))
{ {
Checker.Flush_AddRemoveChange(); Checker.Flush_AddRemoveChange();
ContentPos.Update(0, Depth); ContentPos.Update(0, Depth);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment