Commit 6b6507da authored by Anna.Pavlova's avatar Anna.Pavlova Committed by Alexander.Trofimov

1. Реализовала поиск текста в формулах

2. Поправила баг при смене любых текстовых настроек для математического текста менялся шрифт на Cambria Math (сейчас только при смене Font)
3. Реализовала заливку для формул (http://bugzserver/show_bug.cgi?id=26912), кроме случая с EqArray

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@59279 954022d7-b5bf-4e40-9824-e11837661b57
parent d3d24b98
...@@ -108,11 +108,11 @@ ParaMath.prototype.Set_Paragraph = function(Paragraph) ...@@ -108,11 +108,11 @@ ParaMath.prototype.Set_Paragraph = function(Paragraph)
ParaMath.prototype.Is_Empty = function() ParaMath.prototype.Is_Empty = function()
{ {
if (this.Root.content.length <= 0) if (this.Root.Content.length <= 0)
return true; return true;
if (1 === this.Root.content.length) if (1 === this.Root.Content.length)
return this.Root.content[0].Is_Empty({SkipPlcHldr : true}); return this.Root.Content[0].Is_Empty({SkipPlcHldr : true});
return false; return false;
}; };
...@@ -163,7 +163,7 @@ ParaMath.prototype.Add = function(Item) ...@@ -163,7 +163,7 @@ ParaMath.prototype.Add = function(Item)
var oContent = oSelectedContent.Content; var oContent = oSelectedContent.Content;
var StartPos = oSelectedContent.Start; var StartPos = oSelectedContent.Start;
var Run = oContent.content[StartPos]; var Run = oContent.Content[StartPos];
// Мы вставляем только в Run // Мы вставляем только в Run
if (para_Math_Run !== Run.Type) if (para_Math_Run !== Run.Type)
...@@ -207,10 +207,10 @@ ParaMath.prototype.Add = function(Item) ...@@ -207,10 +207,10 @@ ParaMath.prototype.Add = function(Item)
oContent.Internal_Content_Add(StartPos + 1, RightRun, false); oContent.Internal_Content_Add(StartPos + 1, RightRun, false);
oContent.CurPos = StartPos; oContent.CurPos = StartPos;
var lng = oContent.content.length; var lng = oContent.Content.length;
oContent.Load_FromMenu(Item.Menu, this.Paragraph); oContent.Load_FromMenu(Item.Menu, this.Paragraph);
var lng2 = oContent.content.length; var lng2 = oContent.Content.length;
oContent.Set_MathTextPr2(MathTxtPr.TextPr, MathTxtPr.MathPr, false, StartPos + 1, lng2 - lng); oContent.Set_MathTextPr2(MathTxtPr.TextPr, MathTxtPr.MathPr, false, StartPos + 1, lng2 - lng);
oContent.CurPos = StartPos + 2; // позиция RightRun oContent.CurPos = StartPos + 2; // позиция RightRun
...@@ -245,7 +245,7 @@ ParaMath.prototype.Remove = function(Direction, bOnAddText) ...@@ -245,7 +245,7 @@ ParaMath.prototype.Remove = function(Direction, bOnAddText)
{ {
if (false === oElement.Remove(Direction) && true !== this.bSelectionUse) if (false === oElement.Remove(Direction) && true !== this.bSelectionUse)
{ {
if ((Direction > 0 && oContent.content.length - 1 === nStartPos) || (Direction < 0 && 0 === nStartPos)) if ((Direction > 0 && oContent.Content.length - 1 === nStartPos) || (Direction < 0 && 0 === nStartPos))
{ {
// Проверяем находимся ли мы на верхнем уровне // Проверяем находимся ли мы на верхнем уровне
if (oContent.bRoot) if (oContent.bRoot)
...@@ -324,8 +324,8 @@ ParaMath.prototype.Remove = function(Direction, bOnAddText) ...@@ -324,8 +324,8 @@ ParaMath.prototype.Remove = function(Direction, bOnAddText)
oContent.CurPos = nStartPos; oContent.CurPos = nStartPos;
if (para_Math_Run === oContent.content[nStartPos].Type) if (para_Math_Run === oContent.Content[nStartPos].Type)
oContent.content[nStartPos].Cursor_MoveToStartPos(); oContent.Content[nStartPos].Cursor_MoveToStartPos();
oContent.Correct_Content(); oContent.Correct_Content();
oContent.Correct_ContentPos(-1); // -1, потому что нам надо встать перед элементом, а не после oContent.Correct_ContentPos(-1); // -1, потому что нам надо встать перед элементом, а не после
...@@ -688,7 +688,7 @@ ParaMath.prototype.Recalculate_Range = function(PRS, ParaPr, Depth) ...@@ -688,7 +688,7 @@ ParaMath.prototype.Recalculate_Range = function(PRS, ParaPr, Depth)
if ( true !== PRS.NewRange ) if ( true !== PRS.NewRange )
{ {
RangeEndPos = this.Root.content.length; // RangeEndPos = 1; to RangeEndPos = this.Content.length; RangeEndPos = this.Root.Content.length; // RangeEndPos = 1; to RangeEndPos = this.Content.length;
// Обновляем метрику строки // Обновляем метрику строки
if ( PRS.LineAscent < this.Ascent ) if ( PRS.LineAscent < this.Ascent )
...@@ -1273,12 +1273,13 @@ ParaMath.prototype.Draw_HighLights = function(PDSH) ...@@ -1273,12 +1273,13 @@ ParaMath.prototype.Draw_HighLights = function(PDSH)
var StartPos = this.protected_GetRangeStartPos(CurLine, CurRange); var StartPos = this.protected_GetRangeStartPos(CurLine, CurRange);
var EndPos = this.protected_GetRangeEndPos(CurLine, CurRange); var EndPos = this.protected_GetRangeEndPos(CurLine, CurRange);
var X = PDSH.X;
if ( EndPos >= 1 ) if ( EndPos >= 1 )
{ {
PDSH.X += this.Width; this.Root.Draw_HighLights(PDSH, false);
} }
}; };
ParaMath.prototype.Draw_Elements = function(PDSE) ParaMath.prototype.Draw_Elements = function(PDSE)
{ {
var CurLine = PDSE.Line - this.StartLine; var CurLine = PDSE.Line - this.StartLine;
...@@ -1714,7 +1715,7 @@ ParaMath.prototype.Handle_AddNewLine = function() ...@@ -1714,7 +1715,7 @@ ParaMath.prototype.Handle_AddNewLine = function()
var Run = CurrContent.getElem(0); var Run = CurrContent.getElem(0);
Run.Remove_FromContent(0, Run.Content.length, true); Run.Remove_FromContent(0, Run.Content.length, true);
CurrContent.Remove_FromContent(1, CurrContent.content.length); CurrContent.Remove_FromContent(1, CurrContent.Content.length);
CurrContent.Add_ToContent(1, EqArray); CurrContent.Add_ToContent(1, EqArray);
...@@ -1751,18 +1752,18 @@ ParaMath.prototype.Split = function (ContentPos, Depth) ...@@ -1751,18 +1752,18 @@ ParaMath.prototype.Split = function (ContentPos, Depth)
//var Pos = ContentPos.Get(Depth); //var Pos = ContentPos.Get(Depth);
/*if(this.Root.content[Pos].Type == para_Math_Run) /*if(this.Root.Content[Pos].Type == para_Math_Run)
{ {
var NewRun = this.Root.content[Pos].Split(ContentPos, Depth+1); var NewRun = this.Root.Content[Pos].Split(ContentPos, Depth+1);
NewParaMath.Root.Add_ToContent(0, NewRun); NewParaMath.Root.Add_ToContent(0, NewRun);
var len = this.Root.content.length; var len = this.Root.Content.length;
if(Pos < len - 1) if(Pos < len - 1)
{ {
NewParaMath.Root.Concat_ToContent( this.Root.content.slice(Pos + 1) ); NewParaMath.Root.Concat_ToContent( this.Root.Content.slice(Pos + 1) );
this.Root.Remove_FromContent(Pos+1, len - Pos - 1); this.Root.Remove_FromContent(Pos+1, len - Pos - 1);
} }
......
...@@ -1126,7 +1126,7 @@ ParaRun.prototype.Get_NextRunElements = function(RunElements, UseContentPos, Dep ...@@ -1126,7 +1126,7 @@ ParaRun.prototype.Get_NextRunElements = function(RunElements, UseContentPos, Dep
var Item = this.Content[CurPos]; var Item = this.Content[CurPos];
var ItemType = Item.Type; var ItemType = Item.Type;
if ( para_Text === ItemType || para_Space === ItemType || para_Tab === ItemType ) if ( para_Text === ItemType || para_Space === ItemType || para_Tab === ItemType)
{ {
RunElements.Elements.push( Item ); RunElements.Elements.push( Item );
RunElements.Count--; RunElements.Count--;
...@@ -3235,6 +3235,8 @@ ParaRun.prototype.Draw_HighLights = function(PDSH) ...@@ -3235,6 +3235,8 @@ ParaRun.prototype.Draw_HighLights = function(PDSH)
case para_Drawing: case para_Drawing:
case para_Tab: case para_Tab:
case para_Text: case para_Text:
case para_Math_Text:
case para_Math_Ampersand:
case para_Sym: case para_Sym:
{ {
if ( para_Drawing === ItemType && drawing_Anchor === Item.DrawingType ) if ( para_Drawing === ItemType && drawing_Anchor === Item.DrawingType )
...@@ -5121,15 +5123,19 @@ ParaRun.prototype.Apply_Pr = function(TextPr) ...@@ -5121,15 +5123,19 @@ ParaRun.prototype.Apply_Pr = function(TextPr)
if ( undefined != TextPr.RFonts ) if ( undefined != TextPr.RFonts )
{ {
if(this.Type == para_Math_Run && !this.IsNormalText()) // при смене Font в этом случае (даже на Cambria Math) cs, eastAsia не меняются if(this.Type == para_Math_Run && !this.IsNormalText()) // при смене Font в этом случае (даже на Cambria Math) cs, eastAsia не меняются
{ {
var RFonts = // делаем так для проверки действительно ли нужно сменить Font, чтобы при смене других текстовых настроек не выставился Cambria Math (TextPr.RFonts приходит всегда в виде объекта)
if(TextPr.RFonts.Ascii !== undefined || TextPr.RFonts.HAnsi !== undefined)
{ {
Ascii: {Name: "Cambria Math", Index: -1}, var RFonts =
HAnsi: {Name: "Cambria Math", Index: -1} {
}; Ascii: {Name: "Cambria Math", Index: -1},
HAnsi: {Name: "Cambria Math", Index: -1}
};
this.Set_RFonts2(RFonts); this.Set_RFonts2(RFonts);
}
} }
else else
this.Set_RFonts2(TextPr.RFonts); this.Set_RFonts2(TextPr.RFonts);
......
...@@ -981,7 +981,7 @@ ParaRun.prototype.Search = function(ParaSearch, Depth) ...@@ -981,7 +981,7 @@ ParaRun.prototype.Search = function(ParaSearch, Depth)
ParaSearch.Reset(); ParaSearch.Reset();
} }
if ( (" " === Str[ParaSearch.SearchIndex] && para_Space === Item.Type) || ( para_Text === Item.Type && ( ( true != MatchCase && (String.fromCharCode(Item.Value)).toLowerCase() === Str[ParaSearch.SearchIndex].toLowerCase() ) || ( true === MatchCase && Item.Value === Str.charCodeAt(ParaSearch.SearchIndex) ) ) ) ) if ( (" " === Str[ParaSearch.SearchIndex] && para_Space === Item.Type)|| (para_Math_Text == Item.Type && Item.value === Str.charCodeAt(ParaSearch.SearchIndex)) || ( para_Text === Item.Type && ( ( true != MatchCase && (String.fromCharCode(Item.Value)).toLowerCase() === Str[ParaSearch.SearchIndex].toLowerCase() ) || ( true === MatchCase && Item.Value === Str.charCodeAt(ParaSearch.SearchIndex) ) ) ) )
{ {
if ( 0 === ParaSearch.SearchIndex ) if ( 0 === ParaSearch.SearchIndex )
{ {
...@@ -1253,24 +1253,33 @@ ParaComment.prototype.Search_GetId = function(bNext, bUseContentPos, ContentPos, ...@@ -1253,24 +1253,33 @@ ParaComment.prototype.Search_GetId = function(bNext, bUseContentPos, ContentPos,
ParaMath.prototype.Search = function(ParaSearch, Depth) ParaMath.prototype.Search = function(ParaSearch, Depth)
{ {
// Обнуляем поиск // Обнуляем поиск
ParaSearch.Reset(); //ParaSearch.Reset();
this.SearchMarks = [];
this.Root.Search(ParaSearch, Depth);
}; };
ParaMath.prototype.Add_SearchResult = function(SearchResult, Start, ContentPos, Depth) ParaMath.prototype.Add_SearchResult = function(SearchResult, Start, ContentPos, Depth)
{ {
this.Root.Add_SearchResult(SearchResult, Start, ContentPos, Depth);
}; };
ParaMath.prototype.Clear_SearchResults = function() ParaMath.prototype.Clear_SearchResults = function()
{ {
this.Root.Clear_SearchResults();
}; };
ParaMath.prototype.Remove_SearchResult = function(SearchResult) ParaMath.prototype.Remove_SearchResult = function(SearchResult)
{ {
this.Root.Remove_SearchResult(SearchResult);
}; };
ParaMath.prototype.Search_GetId = function(bNext, bUseContentPos, ContentPos, Depth) ParaMath.prototype.Search_GetId = function(bNext, bUseContentPos, ContentPos, Depth)
{ {
return null; return this.Root.Search_GetId(bNext, bUseContentPos, ContentPos, Depth);
//return null;
}; };
//---------------------------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------------------------
......
...@@ -466,7 +466,6 @@ CAccent.prototype.fillContent = function() ...@@ -466,7 +466,6 @@ CAccent.prototype.fillContent = function()
{ {
this.setDimension(1, 1); this.setDimension(1, 1);
this.elements[0][0] = this.getBase(); this.elements[0][0] = this.getBase();
this.elements[0][0].SetDot(true);
}; };
CAccent.prototype.IsAccent = function() CAccent.prototype.IsAccent = function()
{ {
......
...@@ -368,9 +368,12 @@ CMathBase.prototype = ...@@ -368,9 +368,12 @@ CMathBase.prototype =
if(this.bInside == false) if(this.bInside == false)
GapsInfo.setGaps(this, this.TextPrControlLetter.FontSize); GapsInfo.setGaps(this, this.TextPrControlLetter.FontSize);
for(var Pos = 0; Pos < this.Content.length; Pos++)
this.Content[Pos].SetParent(this, ParaMath);
for(var i=0; i < this.nRow; i++) for(var i=0; i < this.nRow; i++)
for(var j = 0; j < this.nCol; j++) for(var j = 0; j < this.nCol; j++)
this.elements[i][j].PreRecalc(this, ParaMath, ArgSize, RPI); this.elements[i][j].PreRecalc(this, ParaMath, ArgSize, RPI);
}, },
recalculateSize: function(oMeasure, RPI) recalculateSize: function(oMeasure, RPI)
...@@ -659,6 +662,8 @@ CMathBase.prototype = ...@@ -659,6 +662,8 @@ CMathBase.prototype =
{ {
if(TextPr.FontSize !== undefined) if(TextPr.FontSize !== undefined)
this.Set_FontSizeCtrPrp(TextPr.FontSize); this.Set_FontSizeCtrPrp(TextPr.FontSize);
else if(TextPr.Shd !== undefined)
this.Set_Shd(TextPr.Shd);
} }
for(var i=0; i < this.nRow; i++) for(var i=0; i < this.nRow; i++)
...@@ -670,6 +675,7 @@ CMathBase.prototype = ...@@ -670,6 +675,7 @@ CMathBase.prototype =
} }
} }
}, },
GetMathTextPr: function(ContentPos, Depth) GetMathTextPr: function(ContentPos, Depth)
{ {
var pos = ContentPos.Get(Depth); var pos = ContentPos.Get(Depth);
...@@ -688,7 +694,26 @@ CMathBase.prototype = ...@@ -688,7 +694,26 @@ CMathBase.prototype =
History.Add(this, new CChangesMathFontSize(Value, this.CtrPrp.FontSize)); History.Add(this, new CChangesMathFontSize(Value, this.CtrPrp.FontSize));
this.raw_SetFontSize(Value); this.raw_SetFontSize(Value);
}, },
Set_Shd: function(Shd)
{
if ( (undefined === this.CtrPrp.Shd && undefined === Shd) || (undefined !== this.CtrPrp.Shd && undefined !== Shd && true === this.CtrPrp.Shd.Compare( Shd ) ) )
return;
//var OldShd = this.CtrPrp.Shd;
if ( undefined !== Shd )
{
this.CtrPrp.Shd = new CDocumentShd();
this.CtrPrp.Shd.Set_FromObject( Shd );
}
else
this.CtrPrp.Shd = undefined;
this.RecalcInfo.bCtrPrp = true;
if (null !== this.ParaMath)
this.ParaMath.SetNeedResize();
},
raw_SetFontSize : function(Value) raw_SetFontSize : function(Value)
{ {
this.CtrPrp.FontSize = Value; this.CtrPrp.FontSize = Value;
...@@ -975,13 +1000,33 @@ CMathBase.prototype.Select_MathContent = function(MathContent) ...@@ -975,13 +1000,33 @@ CMathBase.prototype.Select_MathContent = function(MathContent)
} }
} }
}; };
CMathBase.prototype.Test_Math_SetStyleNormal = function(Value, bAll) CMathBase.prototype.Draw_HighLights = function(PDSH, bAll)
{ {
for(var i = 0; i < this.Content.length; i++) var oShd = this.Get_CompiledCtrPrp().Shd;
{ var bDrawShd = ( oShd === undefined || shd_Nil === oShd.Value ? false : true );
this.Content[i].Test_Math_SetStyleNormal(Value, bAll); var ShdColor = ( true === bDrawShd ? oShd.Get_Color( PDSH.Paragraph ) : null );
}
} var X = PDSH.X,
Y0 = PDSH.Y0,
Y1 = PDSH.Y1;
var bAllCont = this.Selection.StartPos !== this.Selection.EndPos;
for (var CurPos = 0; CurPos < this.Content.length; CurPos++)
this.Content[CurPos].Draw_HighLights(PDSH, bAllCont);
if (true === bDrawShd)
PDSH.Shd.Add(Y0, Y1, X, X + this.size.width, 0, ShdColor.r, ShdColor.g, ShdColor.b );
PDSH.X = this.pos.x + this.ParaMath.X + this.size.width;
};
CMathBase.prototype.Search = ParaHyperlink.prototype.Search;
CMathBase.prototype.Add_SearchResult = ParaHyperlink.prototype.Add_SearchResult;
CMathBase.prototype.Clear_SearchResults = ParaHyperlink.prototype.Clear_SearchResults;
CMathBase.prototype.Remove_SearchResult = ParaHyperlink.prototype.Remove_SearchResult;
CMathBase.prototype.Search_GetId = ParaHyperlink.prototype.Search_GetId;
CMathBase.prototype.Set_SelectionContentPos = ParaHyperlink.prototype.Set_SelectionContentPos; CMathBase.prototype.Set_SelectionContentPos = ParaHyperlink.prototype.Set_SelectionContentPos;
CMathBase.prototype.Get_LeftPos = ParaHyperlink.prototype.Get_LeftPos; CMathBase.prototype.Get_LeftPos = ParaHyperlink.prototype.Get_LeftPos;
......
...@@ -651,7 +651,7 @@ function CMathContent() ...@@ -651,7 +651,7 @@ function CMathContent()
{ {
this.Id = g_oIdCounter.Get_NewId(); this.Id = g_oIdCounter.Get_NewId();
this.content = []; // array of mathElem this.Content = []; // array of mathElem
this.CurPos = 0; this.CurPos = 0;
this.WidthToElement = []; this.WidthToElement = [];
...@@ -701,12 +701,12 @@ CMathContent.prototype = ...@@ -701,12 +701,12 @@ CMathContent.prototype =
}, },
addElementToContent: function(obj) //for "read" addElementToContent: function(obj) //for "read"
{ {
this.Internal_Content_Add(this.content.length, obj, false); this.Internal_Content_Add(this.Content.length, obj, false);
this.CurPos = this.content.length-1; this.CurPos = this.Content.length-1;
}, },
fillPlaceholders: function() fillPlaceholders: function()
{ {
this.content.length = 0; this.Content.length = 0;
var oMRun = new ParaRun(null, true); var oMRun = new ParaRun(null, true);
oMRun.fillPlaceholders(); oMRun.fillPlaceholders();
...@@ -716,7 +716,7 @@ CMathContent.prototype = ...@@ -716,7 +716,7 @@ CMathContent.prototype =
//placeholder.relate(this); //placeholder.relate(this);
placeholder.fillPlaceholders(); placeholder.fillPlaceholders();
this.content.push( placeholder );*/ this.Content.push( placeholder );*/
}, },
////////////////////////////////////// //////////////////////////////////////
/*recalculateSize: function() /*recalculateSize: function()
...@@ -729,16 +729,16 @@ CMathContent.prototype = ...@@ -729,16 +729,16 @@ CMathContent.prototype =
this.WidthToElement.length = 0; this.WidthToElement.length = 0;
for(var i = 0; i < this.content.length; i++) for(var i = 0; i < this.Content.length; i++)
{ {
if(this.content[i].Type == para_Math_Composition) if(this.Content[i].Type == para_Math_Composition)
this.content[i].ApplyGaps(); this.Content[i].ApplyGaps();
else if(this.content[i].Type == para_Math_Run) else if(this.Content[i].Type == para_Math_Run)
this.content[i].Math_ApplyGaps(); this.Content[i].Math_ApplyGaps();
this.WidthToElement[i] = width; this.WidthToElement[i] = width;
oSize = this.content[i].size; oSize = this.Content[i].size;
width += oSize.width; width += oSize.width;
ascent = ascent > oSize.ascent ? ascent : oSize.ascent; ascent = ascent > oSize.ascent ? ascent : oSize.ascent;
...@@ -770,18 +770,18 @@ CMathContent.prototype = ...@@ -770,18 +770,18 @@ CMathContent.prototype =
this.Compiled_ArgSz.Merge(ArgSize); this.Compiled_ArgSz.Merge(ArgSize);
} }
var lng = this.content.length; var lng = this.Content.length;
var GapsInfo = new CMathGapsInfo(this.Compiled_ArgSz.value); var GapsInfo = new CMathGapsInfo(this.Compiled_ArgSz.value);
for(var pos = 0; pos < lng; pos++) for(var pos = 0; pos < lng; pos++)
{ {
if(this.content[pos].Type == para_Math_Composition) if(this.Content[pos].Type == para_Math_Composition)
{ {
this.content[pos].PreRecalc(this, ParaMath, this.Compiled_ArgSz, RPI, GapsInfo); this.Content[pos].PreRecalc(this, ParaMath, this.Compiled_ArgSz, RPI, GapsInfo);
} }
else if(this.content[pos].Type == para_Math_Run) else if(this.Content[pos].Type == para_Math_Run)
this.content[pos].Math_PreRecalc(this, ParaMath, this.Compiled_ArgSz, RPI, GapsInfo); this.Content[pos].Math_PreRecalc(this, ParaMath, this.Compiled_ArgSz, RPI, GapsInfo);
} }
if(GapsInfo.Current !== null) if(GapsInfo.Current !== null)
...@@ -793,32 +793,32 @@ CMathContent.prototype = ...@@ -793,32 +793,32 @@ CMathContent.prototype =
this.WidthToElement.length = 0; this.WidthToElement.length = 0;
this.RecalcInfo.bEqqArray = RPI.bEqqArray; this.RecalcInfo.bEqqArray = RPI.bEqqArray;
var lng = this.content.length; var lng = this.Content.length;
this.size.SetZero(); this.size.SetZero();
this.InfoPoints.SetDefault(); this.InfoPoints.SetDefault();
for(var pos = 0; pos < lng; pos++) for(var pos = 0; pos < lng; pos++)
{ {
if(this.content[pos].Type == para_Math_Composition) if(this.Content[pos].Type == para_Math_Composition)
{ {
var NewRPI = RPI.Copy(); var NewRPI = RPI.Copy();
NewRPI.bEqqArray = false; NewRPI.bEqqArray = false;
this.content[pos].Resize(oMeasure, NewRPI); this.Content[pos].Resize(oMeasure, NewRPI);
if(RPI.bEqqArray) if(RPI.bEqqArray)
this.InfoPoints.ContentPoints.UpdatePoint(this.content[pos].size.width); this.InfoPoints.ContentPoints.UpdatePoint(this.Content[pos].size.width);
} }
else if(this.content[pos].Type == para_Math_Run) else if(this.Content[pos].Type == para_Math_Run)
{ {
//this.content[pos].Recalculate_Range(); //this.Content[pos].Recalculate_Range();
this.content[pos].Math_Recalculate(oMeasure, RPI, this.InfoPoints.ContentPoints); this.Content[pos].Math_Recalculate(oMeasure, RPI, this.InfoPoints.ContentPoints);
} }
this.WidthToElement[pos] = this.size.width; this.WidthToElement[pos] = this.size.width;
var oSize = this.content[pos].size; var oSize = this.Content[pos].size;
this.size.width += oSize.width; this.size.width += oSize.width;
var oDescent = oSize.height - oSize.ascent, var oDescent = oSize.height - oSize.ascent,
...@@ -832,13 +832,13 @@ CMathContent.prototype = ...@@ -832,13 +832,13 @@ CMathContent.prototype =
// особый случай: вызываем, когда пересчет всей формулы не нужен, а нужно выставить только Lines (Реализована, чтобы не править Resize у каждого элемента) // особый случай: вызываем, когда пересчет всей формулы не нужен, а нужно выставить только Lines (Реализована, чтобы не править Resize у каждого элемента)
Resize_2: function(oMeasure, ParentElement, ParaMath, RPI, ArgSize) Resize_2: function(oMeasure, ParentElement, ParaMath, RPI, ArgSize)
{ {
var lng = this.content.length; var lng = this.Content.length;
for(var i = 0; i < lng; i++) for(var i = 0; i < lng; i++)
{ {
if(this.content[i].Type == para_Math_Composition) if(this.Content[i].Type == para_Math_Composition)
this.content[i].Resize_2(oMeasure, this, ParaMath, RPI, ArgSize); this.Content[i].Resize_2(oMeasure, this, ParaMath, RPI, ArgSize);
else else
this.content[i].Math_Recalculate(oMeasure, RPI, null); this.Content[i].Math_Recalculate(oMeasure, RPI, null);
} }
}, },
getWidthsPoints: function() getWidthsPoints: function()
...@@ -859,37 +859,37 @@ CMathContent.prototype = ...@@ -859,37 +859,37 @@ CMathContent.prototype =
var bFirstComp = false, var bFirstComp = false,
bLastComp = false; bLastComp = false;
var len = this.content.length; var len = this.Content.length;
if(len > 1) if(len > 1)
{ {
var bFRunEmpty = this.content[0].Is_Empty(); var bFRunEmpty = this.Content[0].Is_Empty();
bFirstComp = bFRunEmpty && this.content[1].Type == para_Math_Composition; // первый всегда идет Run bFirstComp = bFRunEmpty && this.Content[1].Type == para_Math_Composition; // первый всегда идет Run
var bLastRunEmpty = this.content[len - 1].Is_Empty(); // т.к. после мат. объекта стоит пустой Run var bLastRunEmpty = this.Content[len - 1].Is_Empty(); // т.к. после мат. объекта стоит пустой Run
bLastComp = bLastRunEmpty && this.content[len - 2].Type == para_Math_Composition; bLastComp = bLastRunEmpty && this.Content[len - 2].Type == para_Math_Composition;
} }
var checkGap; var checkGap;
if(bFirstComp) if(bFirstComp)
{ {
checkGap = GapsInfo.checkGapKind(this.content[1].kind); checkGap = GapsInfo.checkGapKind(this.Content[1].kind);
if(!checkGap.bChildGaps) if(!checkGap.bChildGaps)
{ {
gaps.left = GapsInfo.getGapsMComp(this.content[1], -1); gaps.left = GapsInfo.getGapsMComp(this.Content[1], -1);
//gaps.left = gapsMComp.left; //gaps.left = gapsMComp.left;
} }
} }
if(bLastComp) if(bLastComp)
{ {
checkGap = GapsInfo.checkGapKind(this.content[len - 1].kind); checkGap = GapsInfo.checkGapKind(this.Content[len - 1].kind);
if(!checkGap.bChildGaps) if(!checkGap.bChildGaps)
{ {
gaps.right = GapsInfo.getGapsMComp(this.content[len - 1], 1); gaps.right = GapsInfo.getGapsMComp(this.Content[len - 1], 1);
//gaps.right = gapsMComp.right; //gaps.right = gapsMComp.right;
} }
} }
...@@ -900,11 +900,11 @@ CMathContent.prototype = ...@@ -900,11 +900,11 @@ CMathContent.prototype =
{ {
var bOneLineText = true; var bOneLineText = true;
for(var i = 0; i < this.content.length; i++) for(var i = 0; i < this.Content.length; i++)
{ {
if(this.content[i].Type == para_Math_Composition) if(this.Content[i].Type == para_Math_Composition)
{ {
if(!this.content[i].IsOneLineText()) if(!this.Content[i].IsOneLineText())
{ {
bOneLineText = false; bOneLineText = false;
break; break;
...@@ -920,30 +920,30 @@ CMathContent.prototype = ...@@ -920,30 +920,30 @@ CMathContent.prototype =
if( !bHidePlh ) if( !bHidePlh )
{ {
for(var i=0; i < this.content.length;i++) for(var i=0; i < this.Content.length;i++)
{ {
if(this.content[i].Type == para_Math_Composition) if(this.Content[i].Type == para_Math_Composition)
{ {
this.content[i].draw(x, y, pGraphics); this.Content[i].draw(x, y, pGraphics);
} }
else else
this.content[i].Math_Draw(x, y, pGraphics); this.Content[i].Math_Draw(x, y, pGraphics);
} }
} }
}, },
update_Cursor: function(CurPage, UpdateTarget) update_Cursor: function(CurPage, UpdateTarget)
{ {
var result; var result;
if(this.content[this.CurPos].Type == para_Math_Composition) if(this.Content[this.CurPos].Type == para_Math_Composition)
{ {
result = this.content[this.CurPos].update_Cursor(CurPage, UpdateTarget); result = this.Content[this.CurPos].update_Cursor(CurPage, UpdateTarget);
} }
else else
{ {
var X = this.pos.x + this.ParaMath.X + this.WidthToElement[this.CurPos], var X = this.pos.x + this.ParaMath.X + this.WidthToElement[this.CurPos],
Y = this.pos.y + this.ParaMath.Y + this.size.ascent; Y = this.pos.y + this.ParaMath.Y + this.size.ascent;
result = this.content[this.CurPos].Math_Update_Cursor(X, Y, CurPage, UpdateTarget); result = this.Content[this.CurPos].Math_Update_Cursor(X, Y, CurPage, UpdateTarget);
} }
return result; return result;
...@@ -954,16 +954,16 @@ CMathContent.prototype = ...@@ -954,16 +954,16 @@ CMathContent.prototype =
}, },
getInfoLetter: function(Info) getInfoLetter: function(Info)
{ {
if(this.content.length == 1) if(this.Content.length == 1)
this.content[0].Math_GetInfoLetter(Info); this.Content[0].Math_GetInfoLetter(Info);
else else
Info.Result = false; Info.Result = false;
}, },
IsPlaceholder: function() IsPlaceholder: function()
{ {
var flag = false; var flag = false;
if(!this.bRoot && this.content.length == 1) if(!this.bRoot && this.Content.length == 1)
flag = this.content[0].IsPlaceholder(); flag = this.Content[0].IsPlaceholder();
return flag; return flag;
}, },
...@@ -991,11 +991,11 @@ CMathContent.prototype = ...@@ -991,11 +991,11 @@ CMathContent.prototype =
} }
for(var i=0; i < this.content.length; i++) for(var i=0; i < this.Content.length; i++)
{ {
if(this.content[i].Type == para_Math_Run) if(this.Content[i].Type == para_Math_Run)
{ {
this.content[i].Math_SetPosition(PosInfo); this.Content[i].Math_SetPosition(PosInfo);
} }
else else
{ {
...@@ -1003,16 +1003,17 @@ CMathContent.prototype = ...@@ -1003,16 +1003,17 @@ CMathContent.prototype =
NewPos.x = PosInfo.x; NewPos.x = PosInfo.x;
NewPos.y = PosInfo.y; NewPos.y = PosInfo.y;
this.content[i].setPosition(NewPos); this.Content[i].setPosition(NewPos);
PosInfo.UpdateX(this.content[i].size.width); PosInfo.UpdateX(this.Content[i].size.width);
} }
} }
}, },
///// properties ///// SetParent: function(Parent, ParaMath)
SetDot: function(flag)
{ {
this.bDot = flag; this.Parent = Parent;
this.ParaMath = ParaMath;
}, },
///// properties /////
hidePlaceholder: function(flag) hidePlaceholder: function(flag)
{ {
this.plhHide = flag; this.plhHide = flag;
...@@ -1020,7 +1021,7 @@ CMathContent.prototype = ...@@ -1020,7 +1021,7 @@ CMathContent.prototype =
///////// RunPrp, CtrPrp ///////// RunPrp, CtrPrp
getFirstRPrp: function(ParaMath) getFirstRPrp: function(ParaMath)
{ {
return this.content[0].Get_CompiledPr(true); return this.Content[0].Get_CompiledPr(true);
}, },
GetCtrPrp: function() // for placeholder GetCtrPrp: function() // for placeholder
{ {
...@@ -1063,15 +1064,15 @@ CMathContent.prototype = ...@@ -1063,15 +1064,15 @@ CMathContent.prototype =
{ {
var bFirst = false, bEnd = false; var bFirst = false, bEnd = false;
if(this.Selection.Start == 0 && this.Selection.End == this.content.length - 1) if(this.Selection.Start == 0 && this.Selection.End == this.Content.length - 1)
{ {
if(this.content[this.Selection.Start].Type == para_Math_Run) if(this.Content[this.Selection.Start].Type == para_Math_Run)
bFirst = this.content[this.Selection.Start].Is_SelectedAll(Props); bFirst = this.Content[this.Selection.Start].Is_SelectedAll(Props);
else else
bFirst = true; bFirst = true;
if(this.content[this.Selection.End].Type == para_Math_Run) if(this.Content[this.Selection.End].Type == para_Math_Run)
bEnd = this.content[this.Selection.End].Is_SelectedAll(Props); bEnd = this.Content[this.Selection.End].Is_SelectedAll(Props);
else else
bEnd = true; bEnd = true;
} }
...@@ -1092,7 +1093,7 @@ CMathContent.prototype = ...@@ -1092,7 +1093,7 @@ CMathContent.prototype =
private_CorrectContent : function() private_CorrectContent : function()
{ {
var len = this.content.length; var len = this.Content.length;
var current = null; var current = null;
var emptyRun, ctrPrp, mathPrp; var emptyRun, ctrPrp, mathPrp;
...@@ -1101,10 +1102,10 @@ CMathContent.prototype = ...@@ -1101,10 +1102,10 @@ CMathContent.prototype =
while(currPos < len) while(currPos < len)
{ {
current = this.content[currPos]; current = this.Content[currPos];
var bLeftRun = currPos > 0 ? this.content[currPos-1].Type == para_Math_Run : false, var bLeftRun = currPos > 0 ? this.Content[currPos-1].Type == para_Math_Run : false,
bRightRun = currPos < len - 1 ? this.content[currPos + 1].Type === para_Math_Run : false; bRightRun = currPos < len - 1 ? this.Content[currPos + 1].Type === para_Math_Run : false;
var bCurrComp = current.Type == para_Math_Composition, var bCurrComp = current.Type == para_Math_Composition,
bCurrEmptyRun = current.Type == para_Math_Run && current.Is_Empty(); bCurrEmptyRun = current.Type == para_Math_Run && current.Is_Empty();
...@@ -1140,23 +1141,23 @@ CMathContent.prototype = ...@@ -1140,23 +1141,23 @@ CMathContent.prototype =
if (bLeftRun) if (bLeftRun)
{ {
this.CurPos = currPos - 1; this.CurPos = currPos - 1;
this.content[this.CurPos].Cursor_MoveToEndPos(false); this.Content[this.CurPos].Cursor_MoveToEndPos(false);
} }
else //if (bRightRun) else //if (bRightRun)
{ {
this.CurPos = currPos; this.CurPos = currPos;
this.content[this.CurPos].Cursor_MoveToStartPos(); this.Content[this.CurPos].Cursor_MoveToStartPos();
} }
} }
} }
else else
currPos++; currPos++;
len = this.content.length; len = this.Content.length;
} }
if(len > 0 && this.content[len - 1].Type == para_Math_Composition) if(len > 0 && this.Content[len - 1].Type == para_Math_Composition)
{ {
emptyRun = new ParaRun(null, true); emptyRun = new ParaRun(null, true);
...@@ -1180,20 +1181,20 @@ CMathContent.prototype = ...@@ -1180,20 +1181,20 @@ CMathContent.prototype =
{ {
if (true === bInnerCorrection) if (true === bInnerCorrection)
{ {
for (var nPos = 0, nCount = this.content.length; nPos < nCount; nPos++) for (var nPos = 0, nCount = this.Content.length; nPos < nCount; nPos++)
{ {
if (para_Math_Composition === this.content[nPos].Type) if (para_Math_Composition === this.Content[nPos].Type)
this.content[nPos].Correct_Content(true); this.Content[nPos].Correct_Content(true);
} }
} }
this.private_CorrectContent(); this.private_CorrectContent();
// Удаляем лишние пустые раны // Удаляем лишние пустые раны
for (var nPos = 0, nLen = this.content.length; nPos < nLen - 1; nPos++) for (var nPos = 0, nLen = this.Content.length; nPos < nLen - 1; nPos++)
{ {
var oCurrElement = this.content[nPos]; var oCurrElement = this.Content[nPos];
var oNextElement = this.content[nPos + 1]; var oNextElement = this.Content[nPos + 1];
if (para_Math_Run === oCurrElement.Type && para_Math_Run === oNextElement.Type) if (para_Math_Run === oCurrElement.Type && para_Math_Run === oNextElement.Type)
{ {
if (oCurrElement.Is_Empty()) if (oCurrElement.Is_Empty())
...@@ -1215,21 +1216,21 @@ CMathContent.prototype = ...@@ -1215,21 +1216,21 @@ CMathContent.prototype =
} }
// Если в контенте ничего нет, тогда добавляем пустой ран // Если в контенте ничего нет, тогда добавляем пустой ран
if (this.content.length < 1) if (this.Content.length < 1)
{ {
this.Add_ToContent(0, new ParaRun(null, true)); this.Add_ToContent(0, new ParaRun(null, true));
} }
for (var nPos = 0, nCount = this.content.length; nPos < nCount; nPos++) for (var nPos = 0, nCount = this.Content.length; nPos < nCount; nPos++)
{ {
if(para_Math_Run === this.content[nPos].Type) if(para_Math_Run === this.Content[nPos].Type)
this.content[nPos].Math_Correct_Content(); this.Content[nPos].Math_Correct_Content();
} }
if (this.content.length == 1) if (this.Content.length == 1)
{ {
if(this.content[0].Is_Empty()) if(this.Content[0].Is_Empty())
this.content[0].fillPlaceholders(); this.Content[0].fillPlaceholders();
} }
}, },
...@@ -1240,24 +1241,24 @@ CMathContent.prototype = ...@@ -1240,24 +1241,24 @@ CMathContent.prototype =
if (nCurPos < 0) if (nCurPos < 0)
{ {
this.CurPos = 0; this.CurPos = 0;
this.content[0].Cursor_MoveToStartPos(); this.Content[0].Cursor_MoveToStartPos();
} }
else if (nCurPos > this.content.length - 1) else if (nCurPos > this.Content.length - 1)
{ {
this.CurPos = this.content.length - 1; this.CurPos = this.Content.length - 1;
this.content[this.CurPos].Cursor_MoveToEndPos(); this.Content[this.CurPos].Cursor_MoveToEndPos();
} }
else if (para_Math_Run !== this.content[nCurPos].Type) else if (para_Math_Run !== this.Content[nCurPos].Type)
{ {
if (nDirection > 0) if (nDirection > 0)
{ {
this.CurPos = nCurPos + 1; this.CurPos = nCurPos + 1;
this.content[this.CurPos].Cursor_MoveToStartPos(); this.Content[this.CurPos].Cursor_MoveToStartPos();
} }
else else
{ {
this.CurPos = nCurPos - 1; this.CurPos = nCurPos - 1;
this.content[this.CurPos].Cursor_MoveToEndPos(); this.Content[this.CurPos].Cursor_MoveToEndPos();
} }
} }
}, },
...@@ -1270,7 +1271,7 @@ CMathContent.prototype = ...@@ -1270,7 +1271,7 @@ CMathContent.prototype =
if( !this.Is_Empty() ) if( !this.Is_Empty() )
{ {
if(this.CurPos == 0) if(this.CurPos == 0)
result = this.content[0].Cursor_Is_Start(); result = this.Content[0].Cursor_Is_Start();
} }
return result; return result;
...@@ -1281,10 +1282,10 @@ CMathContent.prototype = ...@@ -1281,10 +1282,10 @@ CMathContent.prototype =
if(!this.Is_Empty()) if(!this.Is_Empty())
{ {
var len = this.content.length - 1; var len = this.Content.length - 1;
if(this.CurPos == len) if(this.CurPos == len)
{ {
result = this.content[len].Cursor_Is_End(); result = this.Content[len].Cursor_Is_End();
} }
} }
...@@ -1304,7 +1305,7 @@ CMathContent.prototype = ...@@ -1304,7 +1305,7 @@ CMathContent.prototype =
if(this.IsPlaceholder()) if(this.IsPlaceholder())
TextPr = this.ParentElement.Get_CtrPrp(); TextPr = this.ParentElement.Get_CtrPrp();
else else
TextPr = this.content[pos].Get_TextPr(ContentPos, Depth + 1); TextPr = this.Content[pos].Get_TextPr(ContentPos, Depth + 1);
return TextPr; return TextPr;
}, },
...@@ -1323,7 +1324,7 @@ CMathContent.prototype = ...@@ -1323,7 +1324,7 @@ CMathContent.prototype =
if(bAll == true) if(bAll == true)
{ {
StartPos = 0; StartPos = 0;
EndPos = this.content.length - 1; EndPos = this.Content.length - 1;
} }
else else
{ {
...@@ -1342,16 +1343,16 @@ CMathContent.prototype = ...@@ -1342,16 +1343,16 @@ CMathContent.prototype =
while ( null === TextPr && StartPos <= EndPos ) while ( null === TextPr && StartPos <= EndPos )
{ {
var bComp = this.content[StartPos].Type == para_Math_Composition, var bComp = this.Content[StartPos].Type == para_Math_Composition,
bEmptyRun = this.content[StartPos].Type == para_Math_Run && true === this.content[StartPos].Selection_IsEmpty(); bEmptyRun = this.Content[StartPos].Type == para_Math_Run && true === this.Content[StartPos].Selection_IsEmpty();
if(bComp || !bEmptyRun || bAll) //пропускаем пустые Run if(bComp || !bEmptyRun || bAll) //пропускаем пустые Run
TextPr = this.content[StartPos].Get_CompiledTextPr(true); TextPr = this.Content[StartPos].Get_CompiledTextPr(true);
StartPos++; StartPos++;
} }
while(this.content[EndPos].Type == para_Math_Run && true === this.content[EndPos].Selection_IsEmpty() && StartPos < EndPos + 1 && bAll == false) //пропускаем пустые Run while(this.Content[EndPos].Type == para_Math_Run && true === this.Content[EndPos].Selection_IsEmpty() && StartPos < EndPos + 1 && bAll == false) //пропускаем пустые Run
{ {
EndPos--; EndPos--;
} }
...@@ -1359,8 +1360,8 @@ CMathContent.prototype = ...@@ -1359,8 +1360,8 @@ CMathContent.prototype =
for ( var CurPos = StartPos; CurPos < EndPos + 1; CurPos++ ) for ( var CurPos = StartPos; CurPos < EndPos + 1; CurPos++ )
{ {
//var CurTextPr = this.content[CurPos].Get_CompiledPr(false); //var CurTextPr = this.Content[CurPos].Get_CompiledPr(false);
var CurTextPr = this.content[CurPos].Get_CompiledTextPr(false); var CurTextPr = this.Content[CurPos].Get_CompiledTextPr(false);
if ( null !== CurTextPr ) if ( null !== CurTextPr )
TextPr = TextPr.Compare( CurTextPr ); TextPr = TextPr.Compare( CurTextPr );
...@@ -1370,8 +1371,8 @@ CMathContent.prototype = ...@@ -1370,8 +1371,8 @@ CMathContent.prototype =
{ {
var CurPos = this.CurPos; var CurPos = this.CurPos;
if ( CurPos >= 0 && CurPos < this.content.length ) if ( CurPos >= 0 && CurPos < this.Content.length )
TextPr = this.content[CurPos].Get_CompiledTextPr(Copy); TextPr = this.Content[CurPos].Get_CompiledTextPr(Copy);
} }
return TextPr; return TextPr;
...@@ -1380,14 +1381,14 @@ CMathContent.prototype = ...@@ -1380,14 +1381,14 @@ CMathContent.prototype =
{ {
var pos = ContentPos.Get(Depth); var pos = ContentPos.Get(Depth);
return this.content[pos].GetMathTextPr(ContentPos, Depth + 1); return this.Content[pos].GetMathTextPr(ContentPos, Depth + 1);
}, },
Apply_TextPr: function(TextPr, IncFontSize, ApplyToAll) Apply_TextPr: function(TextPr, IncFontSize, ApplyToAll)
{ {
if ( true === ApplyToAll ) if ( true === ApplyToAll )
{ {
for ( var i = 0; i < this.content.length; i++ ) for ( var i = 0; i < this.Content.length; i++ )
this.content[i].Apply_TextPr( TextPr, IncFontSize, true ); this.Content[i].Apply_TextPr( TextPr, IncFontSize, true );
} }
else else
{ {
...@@ -1404,11 +1405,11 @@ CMathContent.prototype = ...@@ -1404,11 +1405,11 @@ CMathContent.prototype =
if(FirstPos == 0) if(FirstPos == 0)
this.ParaMath.NeedCompiledCtrPr(); this.ParaMath.NeedCompiledCtrPr();
if( !this.Selection.Use || (bSelectOneElement && this.content[StartPos].Type == para_Math_Run) ) // TextPr меняем только в одном Run if( !this.Selection.Use || (bSelectOneElement && this.Content[StartPos].Type == para_Math_Run) ) // TextPr меняем только в одном Run
{ {
var Pos = !this.Selection.Use ? this.CurPos : StartPos; var Pos = !this.Selection.Use ? this.CurPos : StartPos;
NewRuns = this.content[Pos].Apply_TextPr(TextPr, IncFontSize, false); NewRuns = this.Content[Pos].Apply_TextPr(TextPr, IncFontSize, false);
LRun = NewRuns[0]; LRun = NewRuns[0];
CRun = NewRuns[1]; CRun = NewRuns[1];
...@@ -1432,9 +1433,9 @@ CMathContent.prototype = ...@@ -1432,9 +1433,9 @@ CMathContent.prototype =
this.Selection.End = CRunPos; this.Selection.End = CRunPos;
} }
else if(bSelectOneElement && this.content[StartPos].Type == para_Math_Composition) else if(bSelectOneElement && this.Content[StartPos].Type == para_Math_Composition)
{ {
this.content[StartPos].Apply_TextPr(TextPr, IncFontSize, true); this.Content[StartPos].Apply_TextPr(TextPr, IncFontSize, true);
} }
else else
{ {
...@@ -1448,12 +1449,12 @@ CMathContent.prototype = ...@@ -1448,12 +1449,12 @@ CMathContent.prototype =
for(var i = StartPos + 1; i < EndPos; i++) for(var i = StartPos + 1; i < EndPos; i++)
this.content[i].Apply_TextPr(TextPr, IncFontSize, true ); this.Content[i].Apply_TextPr(TextPr, IncFontSize, true );
if(this.content[EndPos].Type == para_Math_Run) if(this.Content[EndPos].Type == para_Math_Run)
{ {
NewRuns = this.content[EndPos].Apply_TextPr(TextPr, IncFontSize, false); NewRuns = this.Content[EndPos].Apply_TextPr(TextPr, IncFontSize, false);
// LRun - null // LRun - null
CRun = NewRuns[1]; CRun = NewRuns[1];
...@@ -1466,12 +1467,12 @@ CMathContent.prototype = ...@@ -1466,12 +1467,12 @@ CMathContent.prototype =
} }
else else
this.content[EndPos].Apply_TextPr(TextPr, IncFontSize, true); this.Content[EndPos].Apply_TextPr(TextPr, IncFontSize, true);
if(this.content[StartPos].Type == para_Math_Run) if(this.Content[StartPos].Type == para_Math_Run)
{ {
NewRuns = this.content[StartPos].Apply_TextPr(TextPr, IncFontSize, false); NewRuns = this.Content[StartPos].Apply_TextPr(TextPr, IncFontSize, false);
LRun = NewRuns[0]; LRun = NewRuns[0];
CRun = NewRuns[1]; CRun = NewRuns[1];
...@@ -1485,26 +1486,26 @@ CMathContent.prototype = ...@@ -1485,26 +1486,26 @@ CMathContent.prototype =
} }
else else
this.content[StartPos].Apply_TextPr(TextPr, IncFontSize, true); this.Content[StartPos].Apply_TextPr(TextPr, IncFontSize, true);
var bStartComposition = this.content[StartPos].Type == para_Math_Composition || (this.content[StartPos].Is_Empty() && this.content[StartPos + 1].Type == para_Math_Composition); var bStartComposition = this.Content[StartPos].Type == para_Math_Composition || (this.Content[StartPos].Is_Empty() && this.Content[StartPos + 1].Type == para_Math_Composition);
var bEndCompostion = this.content[EndPos].Type == para_Math_Composition || (this.content[EndPos].Is_Empty() && this.content[EndPos - 1].Type == para_Math_Composition); var bEndCompostion = this.Content[EndPos].Type == para_Math_Composition || (this.Content[EndPos].Is_Empty() && this.Content[EndPos - 1].Type == para_Math_Composition);
if(!bStartComposition) if(!bStartComposition)
{ {
if(this.Selection.Start < this.Selection.End && true === this.content[this.Selection.Start].Selection_IsEmpty(true) ) if(this.Selection.Start < this.Selection.End && true === this.Content[this.Selection.Start].Selection_IsEmpty(true) )
this.Selection.Start++; this.Selection.Start++;
else if (this.Selection.End < this.Selection.Start && true === this.content[this.Selection.End].Selection_IsEmpty(true) ) else if (this.Selection.End < this.Selection.Start && true === this.Content[this.Selection.End].Selection_IsEmpty(true) )
this.Selection.End++; this.Selection.End++;
} }
if(!bEndCompostion) if(!bEndCompostion)
{ {
if(this.Selection.Start < this.Selection.End && true === this.content[this.Selection.End].Selection_IsEmpty(true) ) if(this.Selection.Start < this.Selection.End && true === this.Content[this.Selection.End].Selection_IsEmpty(true) )
this.Selection.End--; this.Selection.End--;
else if (this.Selection.End < this.Selection.Start && true === this.content[this.Selection.Start].Selection_IsEmpty(true) ) else if (this.Selection.End < this.Selection.Start && true === this.Content[this.Selection.Start].Selection_IsEmpty(true) )
this.Selection.Start--; this.Selection.Start--;
} }
...@@ -1517,14 +1518,14 @@ CMathContent.prototype = ...@@ -1517,14 +1518,14 @@ CMathContent.prototype =
if(bAll) if(bAll)
{ {
StartPos = 0; StartPos = 0;
Count = this.content.length - 1; Count = this.Content.length - 1;
} }
if(Count < 0 || StartPos + Count > this.content.length - 1) if(Count < 0 || StartPos + Count > this.Content.length - 1)
return; return;
for(var pos = StartPos; pos <= StartPos + Count; pos++) for(var pos = StartPos; pos <= StartPos + Count; pos++)
this.content[pos].Set_MathTextPr2(TextPr, MathPr, true); this.Content[pos].Set_MathTextPr2(TextPr, MathPr, true);
}, },
IsNormalTextInRuns: function() IsNormalTextInRuns: function()
...@@ -1544,7 +1545,7 @@ CMathContent.prototype = ...@@ -1544,7 +1545,7 @@ CMathContent.prototype =
for(var i = StartPos; i < EndPos+1; i++) for(var i = StartPos; i < EndPos+1; i++)
{ {
var curr = this.content[i], var curr = this.Content[i],
currType = curr.Type; currType = curr.Type;
if(currType == para_Math_Composition || (currType == para_Math_Run && false == curr.IsNormalText())) if(currType == para_Math_Composition || (currType == para_Math_Run && false == curr.IsNormalText()))
{ {
...@@ -1561,7 +1562,7 @@ CMathContent.prototype = ...@@ -1561,7 +1562,7 @@ CMathContent.prototype =
Internal_Content_Add : function(Pos, Item, bUpdatePosition) Internal_Content_Add : function(Pos, Item, bUpdatePosition)
{ {
History.Add( this, { Type : historyitem_Math_AddItem, Pos : Pos, EndPos : Pos, Items : [ Item ] } ); History.Add( this, { Type : historyitem_Math_AddItem, Pos : Pos, EndPos : Pos, Items : [ Item ] } );
this.content.splice( Pos, 0, Item ); this.Content.splice( Pos, 0, Item );
if(bUpdatePosition !== false) if(bUpdatePosition !== false)
{ {
...@@ -1592,33 +1593,33 @@ CMathContent.prototype = ...@@ -1592,33 +1593,33 @@ CMathContent.prototype =
}, },
NeedCompiledCtrPr: function() NeedCompiledCtrPr: function()
{ {
for(var i = 0; i < this.content.length; i++) for(var i = 0; i < this.Content.length; i++)
if(this.content[i].Type == para_Math_Composition) if(this.Content[i].Type == para_Math_Composition)
this.content[i].NeedCompiledCtrPr(); this.Content[i].NeedCompiledCtrPr();
}, },
private_CorrectSelectionPos : function() private_CorrectSelectionPos : function()
{ {
this.Selection.Start = Math.max(0, Math.min(this.content.length - 1, this.Selection.Start)); this.Selection.Start = Math.max(0, Math.min(this.Content.length - 1, this.Selection.Start));
this.Selection.End = Math.max(0, Math.min(this.content.length - 1, this.Selection.End)); this.Selection.End = Math.max(0, Math.min(this.Content.length - 1, this.Selection.End));
}, },
private_CorrectCurPos : function() private_CorrectCurPos : function()
{ {
if (this.CurPos > this.content.length - 1) if (this.CurPos > this.Content.length - 1)
{ {
this.CurPos = this.content.length - 1; this.CurPos = this.Content.length - 1;
if (para_Math_Run === this.content[this.CurPos].Type) if (para_Math_Run === this.Content[this.CurPos].Type)
this.content[this.CurPos].Cursor_MoveToEndPos(false); this.Content[this.CurPos].Cursor_MoveToEndPos(false);
} }
if (this.CurPos < 0) if (this.CurPos < 0)
{ {
this.CurPos = this.content.length - 1; this.CurPos = this.Content.length - 1;
if (para_Math_Run === this.content[this.CurPos].Type) if (para_Math_Run === this.Content[this.CurPos].Type)
this.content[this.CurPos].Cursor_MoveToStartPos(); this.Content[this.CurPos].Cursor_MoveToStartPos();
} }
}, },
...@@ -1626,16 +1627,16 @@ CMathContent.prototype = ...@@ -1626,16 +1627,16 @@ CMathContent.prototype =
{ {
var Pos = ContentPos.Get(Depth); var Pos = ContentPos.Get(Depth);
if(this.content[Pos].Type == para_Math_Run) if(this.Content[Pos].Type == para_Math_Run)
{ {
var NewRun = this.content[Pos].Split(ContentPos, Depth+1); var NewRun = this.Content[Pos].Split(ContentPos, Depth+1);
NewContent.Add_ToContent(0, NewRun); NewContent.Add_ToContent(0, NewRun);
var len = this.content.length; var len = this.Content.length;
if(Pos < len - 1) if(Pos < len - 1)
{ {
NewContent.Concat_ToContent( this.content.slice(Pos + 1) ); NewContent.Concat_ToContent( this.Content.slice(Pos + 1) );
this.Remove_FromContent(Pos+1, len - Pos - 1); this.Remove_FromContent(Pos+1, len - Pos - 1);
} }
} }
...@@ -1649,15 +1650,15 @@ CMathContent.prototype = ...@@ -1649,15 +1650,15 @@ CMathContent.prototype =
}, },
Concat_ToContent: function(NewItems) Concat_ToContent: function(NewItems)
{ {
var StartPos = this.content.length; var StartPos = this.Content.length;
this.content = this.content.concat( NewItems ); this.Content = this.Content.concat( NewItems );
History.Add( this, { Type : historyitem_Math_AddItem, Pos : StartPos, EndPos : this.content.length - 1, Items : NewItems } ); History.Add( this, { Type : historyitem_Math_AddItem, Pos : StartPos, EndPos : this.Content.length - 1, Items : NewItems } );
}, },
Remove_FromContent : function(Pos, Count) Remove_FromContent : function(Pos, Count)
{ {
var DeletedItems = this.content.splice(Pos, Count); var DeletedItems = this.Content.splice(Pos, Count);
History.Add( this, { Type : historyitem_Math_RemoveItem, Pos : Pos, EndPos : Pos + Count - 1, Items : DeletedItems } ); History.Add( this, { Type : historyitem_Math_RemoveItem, Pos : Pos, EndPos : Pos + Count - 1, Items : DeletedItems } );
// Обновим текущую позицию // Обновим текущую позицию
...@@ -1720,7 +1721,7 @@ CMathContent.prototype = ...@@ -1720,7 +1721,7 @@ CMathContent.prototype =
///////////////////////// /////////////////////////
Is_Empty: function() Is_Empty: function()
{ {
return this.content.length == 0; return this.Content.length == 0;
}, },
Copy: function(Selected) Copy: function(Selected)
...@@ -1750,7 +1751,7 @@ CMathContent.prototype = ...@@ -1750,7 +1751,7 @@ CMathContent.prototype =
else else
{ {
nStartPos = 0; nStartPos = 0;
nEndPos = this.content.length - 1; nEndPos = this.Content.length - 1;
} }
OtherContent.plHid = this.plhHide; OtherContent.plHid = this.plhHide;
...@@ -1758,26 +1759,26 @@ CMathContent.prototype = ...@@ -1758,26 +1759,26 @@ CMathContent.prototype =
for(var nPos = nStartPos; nPos <= nEndPos; nPos++) for(var nPos = nStartPos; nPos <= nEndPos; nPos++)
{ {
var oElement; var oElement;
if(this.content[nPos].Type == para_Math_Run) if(this.Content[nPos].Type == para_Math_Run)
oElement = this.content[nPos].Copy(Selected); oElement = this.Content[nPos].Copy(Selected);
else else
oElement = this.content[nPos].Copy(false); oElement = this.Content[nPos].Copy(false);
OtherContent.Internal_Content_Add(OtherContent.content.length, oElement); OtherContent.Internal_Content_Add(OtherContent.Content.length, oElement);
} }
}, },
getElem: function(nNum) getElem: function(nNum)
{ {
return this.content[nNum]; return this.Content[nNum];
}, },
Is_FirstComposition: function() Is_FirstComposition: function()
{ {
var result = false; var result = false;
if(this.content.length > 1) if(this.Content.length > 1)
{ {
var bEmptyRun = this.content[0].Is_Empty(), var bEmptyRun = this.Content[0].Is_Empty(),
bMathComp = this.content[1].Type == para_Math_Composition; bMathComp = this.Content[1].Type == para_Math_Composition;
if(bEmptyRun && bMathComp) if(bEmptyRun && bMathComp)
result = true; result = true;
...@@ -1796,7 +1797,7 @@ CMathContent.prototype = ...@@ -1796,7 +1797,7 @@ CMathContent.prototype =
{ {
case historyitem_Math_AddItem: case historyitem_Math_AddItem:
{ {
this.content.splice(Data.Pos, Data.EndPos - Data.Pos + 1); this.Content.splice(Data.Pos, Data.EndPos - Data.Pos + 1);
if (null !== this.ParaMath) if (null !== this.ParaMath)
this.ParaMath.SetNeedResize(); this.ParaMath.SetNeedResize();
...@@ -1807,10 +1808,10 @@ CMathContent.prototype = ...@@ -1807,10 +1808,10 @@ CMathContent.prototype =
{ {
var Pos = Data.Pos; var Pos = Data.Pos;
var Array_start = this.content.slice(0, Pos); var Array_start = this.Content.slice(0, Pos);
var Array_end = this.content.slice(Pos); var Array_end = this.Content.slice(Pos);
this.content = Array_start.concat(Data.Items, Array_end); this.Content = Array_start.concat(Data.Items, Array_end);
if (null !== this.ParaMath) if (null !== this.ParaMath)
this.ParaMath.SetNeedResize(); this.ParaMath.SetNeedResize();
...@@ -1829,10 +1830,10 @@ CMathContent.prototype = ...@@ -1829,10 +1830,10 @@ CMathContent.prototype =
{ {
var Pos = Data.Pos; var Pos = Data.Pos;
var Array_start = this.content.slice(0, Pos); var Array_start = this.Content.slice(0, Pos);
var Array_end = this.content.slice(Pos); var Array_end = this.Content.slice(Pos);
this.content = Array_start.concat(Data.Items, Array_end); this.Content = Array_start.concat(Data.Items, Array_end);
if (null !== this.ParaMath) if (null !== this.ParaMath)
this.ParaMath.SetNeedResize(); this.ParaMath.SetNeedResize();
...@@ -1841,7 +1842,7 @@ CMathContent.prototype = ...@@ -1841,7 +1842,7 @@ CMathContent.prototype =
} }
case historyitem_Math_RemoveItem: case historyitem_Math_RemoveItem:
{ {
this.content.splice(Data.Pos, Data.EndPos - Data.Pos + 1); this.Content.splice(Data.Pos, Data.EndPos - Data.Pos + 1);
if (null !== this.ParaMath) if (null !== this.ParaMath)
this.ParaMath.SetNeedResize(); this.ParaMath.SetNeedResize();
...@@ -1929,7 +1930,7 @@ CMathContent.prototype = ...@@ -1929,7 +1930,7 @@ CMathContent.prototype =
var Element = g_oTableId.Get_ById( Reader.GetString2() ); var Element = g_oTableId.Get_ById( Reader.GetString2() );
if ( null != Element ) if ( null != Element )
this.content.splice(Pos, 0, Element); this.Content.splice(Pos, 0, Element);
} }
this.private_SetNeedResize(); this.private_SetNeedResize();
...@@ -1946,7 +1947,7 @@ CMathContent.prototype = ...@@ -1946,7 +1947,7 @@ CMathContent.prototype =
for ( var Index = 0; Index < Count; Index++ ) for ( var Index = 0; Index < Count; Index++ )
{ {
var ChangesPos = Reader.GetLong(); var ChangesPos = Reader.GetLong();
this.content.splice(ChangesPos, 1); this.Content.splice(ChangesPos, 1);
} }
this.private_SetNeedResize(); this.private_SetNeedResize();
...@@ -1981,14 +1982,14 @@ CMathContent.prototype = ...@@ -1981,14 +1982,14 @@ CMathContent.prototype =
if (undefined === Pos) if (undefined === Pos)
Pos = this.CurPos; Pos = this.CurPos;
var nCount = oMathContent.content.length; var nCount = oMathContent.Content.length;
for (var nIndex = 0; nIndex < nCount; nIndex++) for (var nIndex = 0; nIndex < nCount; nIndex++)
{ {
this.Internal_Content_Add(Pos + nIndex, oMathContent.content[nIndex], false); this.Internal_Content_Add(Pos + nIndex, oMathContent.Content[nIndex], false);
if (true === bSelect) if (true === bSelect)
{ {
oMathContent.content[nIndex].Select_All(); oMathContent.Content[nIndex].Select_All();
} }
} }
...@@ -2676,7 +2677,7 @@ CMathContent.prototype.private_LoadFromMenuMatrix = function(Type, Pr) ...@@ -2676,7 +2677,7 @@ CMathContent.prototype.private_LoadFromMenuMatrix = function(Type, Pr)
}; };
CMathContent.prototype.Add_Element = function(Element) CMathContent.prototype.Add_Element = function(Element)
{ {
this.Internal_Content_Add(this.content.length, Element, true); this.Internal_Content_Add(this.Content.length, Element, true);
}; };
CMathContent.prototype.Add_Text = function(sText, MathStyle) CMathContent.prototype.Add_Text = function(sText, MathStyle)
{ {
...@@ -2700,7 +2701,7 @@ CMathContent.prototype.Add_Text = function(sText, MathStyle) ...@@ -2700,7 +2701,7 @@ CMathContent.prototype.Add_Text = function(sText, MathStyle)
if (undefined !== MathStyle && null !== MathStyle) if (undefined !== MathStyle && null !== MathStyle)
MathRun.Math_Apply_Style(MathStyle); MathRun.Math_Apply_Style(MathStyle);
this.Internal_Content_Add(this.content.length, MathRun, true); this.Internal_Content_Add(this.Content.length, MathRun, true);
} }
}; };
CMathContent.prototype.Add_Symbol = function(Code) CMathContent.prototype.Add_Symbol = function(Code)
...@@ -3029,9 +3030,9 @@ CMathContent.prototype.Add_MatrixWithBrackets = function(begChr, endChr, ctrPr, ...@@ -3029,9 +3030,9 @@ CMathContent.prototype.Add_MatrixWithBrackets = function(begChr, endChr, ctrPr,
}; };
CMathContent.prototype.Recalculate_Reset = function(StartRange, StartLine) CMathContent.prototype.Recalculate_Reset = function(StartRange, StartLine)
{ {
for(var nPos = 0, nCount = this.content.length; nPos < nCount; nPos++) for(var nPos = 0, nCount = this.Content.length; nPos < nCount; nPos++)
{ {
this.content[nPos].Recalculate_Reset(StartRange, StartLine); this.Content[nPos].Recalculate_Reset(StartRange, StartLine);
} }
}; };
CMathContent.prototype.Get_Bounds = function() CMathContent.prototype.Get_Bounds = function()
...@@ -3060,20 +3061,20 @@ CMathContent.prototype.Recalculate_CurPos = function(_X, _Y, CurrentRun, _CurRan ...@@ -3060,20 +3061,20 @@ CMathContent.prototype.Recalculate_CurPos = function(_X, _Y, CurrentRun, _CurRan
for(var nPos = 0; nPos < this.CurPos; nPos++) for(var nPos = 0; nPos < this.CurPos; nPos++)
{ {
if(para_Math_Run === this.content[nPos].Type) if(para_Math_Run === this.Content[nPos].Type)
X = this.content[nPos].Recalculate_CurPos(X, Y, false, _CurRange, _CurLine, _CurPage, UpdateCurPos, UpdateTarget, ReturnTarget, PointInfo).X; X = this.Content[nPos].Recalculate_CurPos(X, Y, false, _CurRange, _CurLine, _CurPage, UpdateCurPos, UpdateTarget, ReturnTarget, PointInfo).X;
else else
X += this.content[nPos].size.width; X += this.Content[nPos].size.width;
} }
} }
else else
X += this.WidthToElement[this.CurPos]; X += this.WidthToElement[this.CurPos];
return this.content[this.CurPos].Recalculate_CurPos(X, Y, CurrentRun, _CurRange, _CurLine, _CurPage, UpdateCurPos, UpdateTarget, ReturnTarget, PointInfo); return this.Content[this.CurPos].Recalculate_CurPos(X, Y, CurrentRun, _CurRange, _CurLine, _CurPage, UpdateCurPos, UpdateTarget, ReturnTarget, PointInfo);
}; };
CMathContent.prototype.Get_ParaContentPosByXY = function(SearchPos, Depth, _CurLine, _CurRange, StepEnd) CMathContent.prototype.Get_ParaContentPosByXY = function(SearchPos, Depth, _CurLine, _CurRange, StepEnd)
{ {
var nLength = this.content.length; var nLength = this.Content.length;
if (nLength <= 0) if (nLength <= 0)
return false; return false;
...@@ -3089,13 +3090,13 @@ CMathContent.prototype.Get_ParaContentPosByXY = function(SearchPos, Depth, _CurL ...@@ -3089,13 +3090,13 @@ CMathContent.prototype.Get_ParaContentPosByXY = function(SearchPos, Depth, _CurL
{ {
var CurX = SearchPos.CurX; var CurX = SearchPos.CurX;
if(true === this.content[nPos].Get_ParaContentPosByXY(SearchPos, Depth + 1, _CurLine, _CurRange, StepEnd)) if(true === this.Content[nPos].Get_ParaContentPosByXY(SearchPos, Depth + 1, _CurLine, _CurRange, StepEnd))
{ {
SearchPos.Pos.Update2(nPos, Depth); SearchPos.Pos.Update2(nPos, Depth);
bResult = true; bResult = true;
} }
SearchPos.CurX = CurX + this.content[nPos].size.width; SearchPos.CurX = CurX + this.Content[nPos].size.width;
} }
return bResult; return bResult;
...@@ -3105,8 +3106,8 @@ CMathContent.prototype.Get_ParaContentPos = function(bSelection, bStart, Content ...@@ -3105,8 +3106,8 @@ CMathContent.prototype.Get_ParaContentPos = function(bSelection, bStart, Content
var nPos = (true !== bSelection ? this.CurPos : (false !== bStart ? this.Selection.Start : this.Selection.End)); var nPos = (true !== bSelection ? this.CurPos : (false !== bStart ? this.Selection.Start : this.Selection.End));
ContentPos.Add(nPos); ContentPos.Add(nPos);
if (undefined !== this.content[nPos]) if (undefined !== this.Content[nPos])
this.content[nPos].Get_ParaContentPos(bSelection, bStart, ContentPos); this.Content[nPos].Get_ParaContentPos(bSelection, bStart, ContentPos);
}; };
CMathContent.prototype.Set_ParaContentPos = function(ContentPos, Depth) CMathContent.prototype.Set_ParaContentPos = function(ContentPos, Depth)
{ {
...@@ -3114,20 +3115,20 @@ CMathContent.prototype.Set_ParaContentPos = function(ContentPos, Depth) ...@@ -3114,20 +3115,20 @@ CMathContent.prototype.Set_ParaContentPos = function(ContentPos, Depth)
// Делаем такие проверки, потому что после совместного редактирования, позиция может остаться старой, а // Делаем такие проверки, потому что после совместного редактирования, позиция может остаться старой, а
// контент измениться. // контент измениться.
if (CurPos > this.content.length - 1) if (CurPos > this.Content.length - 1)
{ {
this.CurPos = this.content.length - 1; this.CurPos = this.Content.length - 1;
this.content[this.CurPos].Cursor_MoveToEndPos(false); this.Content[this.CurPos].Cursor_MoveToEndPos(false);
} }
else if (CurPos < 0) else if (CurPos < 0)
{ {
this.CurPos = 0; this.CurPos = 0;
this.content[this.CurPos].Cursor_MoveToStartPos(); this.Content[this.CurPos].Cursor_MoveToStartPos();
} }
else else
{ {
this.CurPos = ContentPos.Get(Depth); this.CurPos = ContentPos.Get(Depth);
this.content[this.CurPos].Set_ParaContentPos(ContentPos, Depth + 1); this.Content[this.CurPos].Set_ParaContentPos(ContentPos, Depth + 1);
} }
}; };
CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndContentPos, Depth, StartFlag, EndFlag) CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndContentPos, Depth, StartFlag, EndFlag)
...@@ -3145,7 +3146,7 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo ...@@ -3145,7 +3146,7 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo
switch(StartFlag) switch(StartFlag)
{ {
case 1: StartPos = 0; break; case 1: StartPos = 0; break;
case -1: StartPos = this.content.length - 1; break; case -1: StartPos = this.Content.length - 1; break;
case 0: StartPos = StartContentPos.Get(Depth); break; case 0: StartPos = StartContentPos.Get(Depth); break;
} }
...@@ -3153,7 +3154,7 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo ...@@ -3153,7 +3154,7 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo
switch(EndFlag) switch(EndFlag)
{ {
case 1: EndPos = 0; break; case 1: EndPos = 0; break;
case -1: EndPos = this.content.length - 1; break; case -1: EndPos = this.Content.length - 1; break;
case 0: EndPos = EndContentPos.Get(Depth); break; case 0: EndPos = EndContentPos.Get(Depth); break;
} }
...@@ -3163,7 +3164,7 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo ...@@ -3163,7 +3164,7 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo
var TempLimit = Math.min(StartPos, EndPos); var TempLimit = Math.min(StartPos, EndPos);
for (var CurPos = OldStartPos; CurPos < TempLimit; CurPos++) for (var CurPos = OldStartPos; CurPos < TempLimit; CurPos++)
{ {
this.content[CurPos].Selection_Remove(); this.Content[CurPos].Selection_Remove();
} }
} }
...@@ -3172,7 +3173,7 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo ...@@ -3172,7 +3173,7 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo
var TempLimit = Math.max(StartPos, EndPos); var TempLimit = Math.max(StartPos, EndPos);
for (var CurPos = TempLimit + 1; CurPos <= OldEndPos; CurPos++) for (var CurPos = TempLimit + 1; CurPos <= OldEndPos; CurPos++)
{ {
this.content[CurPos].Selection_Remove(); this.Content[CurPos].Selection_Remove();
} }
} }
...@@ -3183,8 +3184,8 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo ...@@ -3183,8 +3184,8 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo
if (StartPos !== EndPos) if (StartPos !== EndPos)
{ {
this.content[StartPos].Set_SelectionContentPos(StartContentPos, null, Depth + 1, StartFlag, StartPos > EndPos ? 1 : -1); this.Content[StartPos].Set_SelectionContentPos(StartContentPos, null, Depth + 1, StartFlag, StartPos > EndPos ? 1 : -1);
this.content[EndPos].Set_SelectionContentPos(null, EndContentPos, Depth + 1, StartPos > EndPos ? -1 : 1, EndFlag); this.Content[EndPos].Set_SelectionContentPos(null, EndContentPos, Depth + 1, StartPos > EndPos ? -1 : 1, EndFlag);
var _StartPos = StartPos; var _StartPos = StartPos;
var _EndPos = EndPos; var _EndPos = EndPos;
...@@ -3199,12 +3200,12 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo ...@@ -3199,12 +3200,12 @@ CMathContent.prototype.Set_SelectionContentPos = function(StartContentPos, EndCo
for (var CurPos = _StartPos + 1; CurPos < _EndPos; CurPos++) for (var CurPos = _StartPos + 1; CurPos < _EndPos; CurPos++)
{ {
this.content[CurPos].Select_All( Direction ); this.Content[CurPos].Select_All( Direction );
} }
} }
else else
{ {
this.content[StartPos].Set_SelectionContentPos(StartContentPos, EndContentPos, Depth + 1, StartFlag, EndFlag); this.Content[StartPos].Set_SelectionContentPos(StartContentPos, EndContentPos, Depth + 1, StartFlag, EndFlag);
} }
}; };
CMathContent.prototype.Selection_IsEmpty = function() CMathContent.prototype.Selection_IsEmpty = function()
...@@ -3213,7 +3214,7 @@ CMathContent.prototype.Selection_IsEmpty = function() ...@@ -3213,7 +3214,7 @@ CMathContent.prototype.Selection_IsEmpty = function()
return true; return true;
if (this.Selection.Start === this.Selection.End) if (this.Selection.Start === this.Selection.End)
return this.content[this.Selection.Start].Selection_IsEmpty(); return this.Content[this.Selection.Start].Selection_IsEmpty();
return false; return false;
}; };
...@@ -3221,8 +3222,8 @@ CMathContent.prototype.GetSelectContent = function() ...@@ -3221,8 +3222,8 @@ CMathContent.prototype.GetSelectContent = function()
{ {
if (false === this.Selection.Use) if (false === this.Selection.Use)
{ {
if (para_Math_Composition === this.content[this.CurPos].Type) if (para_Math_Composition === this.Content[this.CurPos].Type)
return this.content[this.CurPos].GetSelectContent(); return this.Content[this.CurPos].GetSelectContent();
else else
return {Content : this, Start : this.CurPos, End : this.CurPos}; return {Content : this, Start : this.CurPos, End : this.CurPos};
} }
...@@ -3237,32 +3238,32 @@ CMathContent.prototype.GetSelectContent = function() ...@@ -3237,32 +3238,32 @@ CMathContent.prototype.GetSelectContent = function()
EndPos = this.Selection.Start; EndPos = this.Selection.Start;
} }
if (StartPos === EndPos && para_Math_Composition === this.content[StartPos].Type && true === this.content[StartPos].Is_InnerSelection()) if (StartPos === EndPos && para_Math_Composition === this.Content[StartPos].Type && true === this.Content[StartPos].Is_InnerSelection())
return this.content[StartPos].GetSelectContent(); return this.Content[StartPos].GetSelectContent();
return {Content : this, Start : StartPos, End : EndPos}; return {Content : this, Start : StartPos, End : EndPos};
} }
}; };
CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseContentPos) CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseContentPos)
{ {
if (false === UseContentPos && para_Math_Run === this.content[this.content.length - 1].Type) if (false === UseContentPos && para_Math_Run === this.Content[this.Content.length - 1].Type)
{ {
// При переходе в новый контент встаем в его конец // При переходе в новый контент встаем в его конец
var CurPos = this.content.length - 1; var CurPos = this.Content.length - 1;
this.content[CurPos].Get_EndPos(false, SearchPos.Pos, Depth + 1); this.Content[CurPos].Get_EndPos(false, SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
SearchPos.Found = true; SearchPos.Found = true;
return true; return true;
} }
var CurPos = UseContentPos ? ContentPos.Get(Depth) : this.content.length - 1; var CurPos = UseContentPos ? ContentPos.Get(Depth) : this.Content.length - 1;
var bStepStart = false; var bStepStart = false;
if (CurPos > 0 || !this.content[0].Cursor_Is_Start()) if (CurPos > 0 || !this.Content[0].Cursor_Is_Start())
bStepStart = true; bStepStart = true;
this.content[CurPos].Get_LeftPos(SearchPos, ContentPos, Depth + 1, UseContentPos); this.Content[CurPos].Get_LeftPos(SearchPos, ContentPos, Depth + 1, UseContentPos);
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
if (true === SearchPos.Found) if (true === SearchPos.Found)
...@@ -3270,10 +3271,10 @@ CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseC ...@@ -3270,10 +3271,10 @@ CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseC
CurPos--; CurPos--;
if (true === UseContentPos && para_Math_Composition === this.content[CurPos + 1].Type) if (true === UseContentPos && para_Math_Composition === this.Content[CurPos + 1].Type)
{ {
// При выходе из формулы встаем в конец рана // При выходе из формулы встаем в конец рана
this.content[CurPos].Get_EndPos(false, SearchPos.Pos, Depth + 1); this.Content[CurPos].Get_EndPos(false, SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
SearchPos.Found = true; SearchPos.Found = true;
return true; return true;
...@@ -3281,7 +3282,7 @@ CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseC ...@@ -3281,7 +3282,7 @@ CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseC
while (CurPos >= 0) while (CurPos >= 0)
{ {
this.content[CurPos].Get_LeftPos(SearchPos, ContentPos, Depth + 1, false); this.Content[CurPos].Get_LeftPos(SearchPos, ContentPos, Depth + 1, false);
SearchPos.Pos.Update( CurPos, Depth ); SearchPos.Pos.Update( CurPos, Depth );
if (true === SearchPos.Found) if (true === SearchPos.Found)
...@@ -3293,7 +3294,7 @@ CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseC ...@@ -3293,7 +3294,7 @@ CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseC
if (true === bStepStart) if (true === bStepStart)
{ {
// Перед выходом из контента встаем в его начало // Перед выходом из контента встаем в его начало
this.content[0].Get_StartPos(SearchPos.Pos, Depth + 1); this.Content[0].Get_StartPos(SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(0, Depth); SearchPos.Pos.Update(0, Depth);
SearchPos.Found = true; SearchPos.Found = true;
...@@ -3304,10 +3305,10 @@ CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseC ...@@ -3304,10 +3305,10 @@ CMathContent.prototype.Get_LeftPos = function(SearchPos, ContentPos, Depth, UseC
}; };
CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, UseContentPos, StepEnd) CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, UseContentPos, StepEnd)
{ {
if (false === UseContentPos && para_Math_Run === this.content[0].Type) if (false === UseContentPos && para_Math_Run === this.Content[0].Type)
{ {
// При переходе в новый контент встаем в его начало // При переходе в новый контент встаем в его начало
this.content[0].Get_StartPos(SearchPos.Pos, Depth + 1); this.Content[0].Get_StartPos(SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(0, Depth); SearchPos.Pos.Update(0, Depth);
SearchPos.Found = true; SearchPos.Found = true;
...@@ -3316,12 +3317,12 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use ...@@ -3316,12 +3317,12 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use
var CurPos = true === UseContentPos ? ContentPos.Get(Depth) : 0; var CurPos = true === UseContentPos ? ContentPos.Get(Depth) : 0;
var Count = this.content.length; var Count = this.Content.length;
var bStepEnd = false; var bStepEnd = false;
if (CurPos < Count - 1 || !this.content[Count - 1].Cursor_Is_End()) if (CurPos < Count - 1 || !this.Content[Count - 1].Cursor_Is_End())
bStepEnd = true; bStepEnd = true;
this.content[CurPos].Get_RightPos(SearchPos, ContentPos, Depth + 1, UseContentPos, StepEnd); this.Content[CurPos].Get_RightPos(SearchPos, ContentPos, Depth + 1, UseContentPos, StepEnd);
SearchPos.Pos.Update( CurPos, Depth ); SearchPos.Pos.Update( CurPos, Depth );
if (true === SearchPos.Found) if (true === SearchPos.Found)
...@@ -3329,10 +3330,10 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use ...@@ -3329,10 +3330,10 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use
CurPos++; CurPos++;
if (true === UseContentPos && para_Math_Composition === this.content[CurPos - 1].Type) if (true === UseContentPos && para_Math_Composition === this.Content[CurPos - 1].Type)
{ {
// При выходе из формулы встаем в начало рана // При выходе из формулы встаем в начало рана
this.content[CurPos].Get_StartPos(SearchPos.Pos, Depth + 1); this.Content[CurPos].Get_StartPos(SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
SearchPos.Found = true; SearchPos.Found = true;
return true; return true;
...@@ -3340,7 +3341,7 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use ...@@ -3340,7 +3341,7 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use
while (CurPos < Count) while (CurPos < Count)
{ {
this.content[CurPos].Get_RightPos(SearchPos, ContentPos, Depth + 1, false, StepEnd); this.Content[CurPos].Get_RightPos(SearchPos, ContentPos, Depth + 1, false, StepEnd);
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
if (true === SearchPos.Found) if (true === SearchPos.Found)
...@@ -3352,7 +3353,7 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use ...@@ -3352,7 +3353,7 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use
if (true === bStepEnd) if (true === bStepEnd)
{ {
// Перед выходом из контента встаем в его конец // Перед выходом из контента встаем в его конец
this.content[Count - 1].Get_EndPos(false, SearchPos.Pos, Depth + 1); this.Content[Count - 1].Get_EndPos(false, SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(Count - 1, Depth); SearchPos.Pos.Update(Count - 1, Depth);
SearchPos.Found = true; SearchPos.Found = true;
...@@ -3363,24 +3364,24 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use ...@@ -3363,24 +3364,24 @@ CMathContent.prototype.Get_RightPos = function(SearchPos, ContentPos, Depth, Use
}; };
CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth, UseContentPos) CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth, UseContentPos)
{ {
if (false === UseContentPos && para_Math_Run === this.content[this.content.length - 1].Type) if (false === UseContentPos && para_Math_Run === this.Content[this.Content.length - 1].Type)
{ {
// При переходе в новый контент встаем в его конец // При переходе в новый контент встаем в его конец
var CurPos = this.content.length - 1; var CurPos = this.Content.length - 1;
this.content[CurPos].Get_EndPos(false, SearchPos.Pos, Depth + 1); this.Content[CurPos].Get_EndPos(false, SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
SearchPos.Found = true; SearchPos.Found = true;
SearchPos.UpdatePos = true; SearchPos.UpdatePos = true;
return true; return true;
} }
var CurPos = true === UseContentPos ? ContentPos.Get(Depth) : this.content.length - 1; var CurPos = true === UseContentPos ? ContentPos.Get(Depth) : this.Content.length - 1;
var bStepStart = false; var bStepStart = false;
if (CurPos > 0 || !this.content[0].Cursor_Is_Start()) if (CurPos > 0 || !this.Content[0].Cursor_Is_Start())
bStepStart = true; bStepStart = true;
this.content[CurPos].Get_WordStartPos(SearchPos, ContentPos, Depth + 1, UseContentPos); this.Content[CurPos].Get_WordStartPos(SearchPos, ContentPos, Depth + 1, UseContentPos);
if (true === SearchPos.UpdatePos) if (true === SearchPos.UpdatePos)
SearchPos.Pos.Update( CurPos, Depth ); SearchPos.Pos.Update( CurPos, Depth );
...@@ -3391,25 +3392,25 @@ CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth, ...@@ -3391,25 +3392,25 @@ CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth,
CurPos--; CurPos--;
var bStepStartRun = false; var bStepStartRun = false;
if (true === UseContentPos && para_Math_Composition === this.content[CurPos + 1].Type) if (true === UseContentPos && para_Math_Composition === this.Content[CurPos + 1].Type)
{ {
// При выходе из формулы встаем в конец рана // При выходе из формулы встаем в конец рана
this.content[CurPos].Get_EndPos(false, SearchPos.Pos, Depth + 1); this.Content[CurPos].Get_EndPos(false, SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
SearchPos.Found = true; SearchPos.Found = true;
SearchPos.UpdatePos = true; SearchPos.UpdatePos = true;
return true; return true;
} }
else if (para_Math_Run === this.content[CurPos + 1].Type && true === SearchPos.Shift) else if (para_Math_Run === this.Content[CurPos + 1].Type && true === SearchPos.Shift)
bStepStartRun = true; bStepStartRun = true;
while (CurPos >= 0) while (CurPos >= 0)
{ {
if (true !== bStepStartRun || para_Math_Run === this.content[CurPos].Type) if (true !== bStepStartRun || para_Math_Run === this.Content[CurPos].Type)
{ {
var OldUpdatePos = SearchPos.UpdatePos; var OldUpdatePos = SearchPos.UpdatePos;
this.content[CurPos].Get_WordStartPos(SearchPos, ContentPos, Depth + 1, false); this.Content[CurPos].Get_WordStartPos(SearchPos, ContentPos, Depth + 1, false);
if (true === SearchPos.UpdatePos) if (true === SearchPos.UpdatePos)
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
...@@ -3425,7 +3426,7 @@ CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth, ...@@ -3425,7 +3426,7 @@ CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth,
else else
{ {
// Встаем в начало рана перед формулой // Встаем в начало рана перед формулой
this.content[CurPos + 1].Get_StartPos(SearchPos.Pos, Depth + 1); this.Content[CurPos + 1].Get_StartPos(SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(CurPos + 1, Depth); SearchPos.Pos.Update(CurPos + 1, Depth);
SearchPos.Found = true; SearchPos.Found = true;
SearchPos.UpdatePos = true; SearchPos.UpdatePos = true;
...@@ -3437,7 +3438,7 @@ CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth, ...@@ -3437,7 +3438,7 @@ CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth,
if (true === bStepStart) if (true === bStepStart)
{ {
// Перед выходом из контента встаем в его начало // Перед выходом из контента встаем в его начало
this.content[0].Get_StartPos(SearchPos.Pos, Depth + 1); this.Content[0].Get_StartPos(SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(0, Depth); SearchPos.Pos.Update(0, Depth);
SearchPos.Found = true; SearchPos.Found = true;
SearchPos.UpdatePos = true; SearchPos.UpdatePos = true;
...@@ -3446,10 +3447,10 @@ CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth, ...@@ -3446,10 +3447,10 @@ CMathContent.prototype.Get_WordStartPos = function(SearchPos, ContentPos, Depth,
}; };
CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, UseContentPos, StepEnd) CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, UseContentPos, StepEnd)
{ {
if (false === UseContentPos && para_Math_Run === this.content[0].Type) if (false === UseContentPos && para_Math_Run === this.Content[0].Type)
{ {
// При переходе в новый контент встаем в его начало // При переходе в новый контент встаем в его начало
this.content[0].Get_StartPos(SearchPos.Pos, Depth + 1); this.Content[0].Get_StartPos(SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(0, Depth); SearchPos.Pos.Update(0, Depth);
SearchPos.Found = true; SearchPos.Found = true;
SearchPos.UpdatePos = true; SearchPos.UpdatePos = true;
...@@ -3458,12 +3459,12 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U ...@@ -3458,12 +3459,12 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U
var CurPos = true === UseContentPos ? ContentPos.Get(Depth) : 0; var CurPos = true === UseContentPos ? ContentPos.Get(Depth) : 0;
var Count = this.content.length; var Count = this.Content.length;
var bStepEnd = false; var bStepEnd = false;
if (CurPos < Count - 1 || !this.content[Count - 1].Cursor_Is_End()) if (CurPos < Count - 1 || !this.Content[Count - 1].Cursor_Is_End())
bStepEnd = true; bStepEnd = true;
this.content[CurPos].Get_WordEndPos(SearchPos, ContentPos, Depth + 1, UseContentPos, StepEnd); this.Content[CurPos].Get_WordEndPos(SearchPos, ContentPos, Depth + 1, UseContentPos, StepEnd);
if (true === SearchPos.UpdatePos) if (true === SearchPos.UpdatePos)
SearchPos.Pos.Update( CurPos, Depth); SearchPos.Pos.Update( CurPos, Depth);
...@@ -3474,25 +3475,25 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U ...@@ -3474,25 +3475,25 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U
CurPos++; CurPos++;
var bStepEndRun = false; var bStepEndRun = false;
if (true === UseContentPos && para_Math_Composition === this.content[CurPos - 1].Type) if (true === UseContentPos && para_Math_Composition === this.Content[CurPos - 1].Type)
{ {
// При выходе из формулы встаем в начало рана // При выходе из формулы встаем в начало рана
this.content[CurPos].Get_StartPos(SearchPos.Pos, Depth + 1); this.Content[CurPos].Get_StartPos(SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
SearchPos.Found = true; SearchPos.Found = true;
SearchPos.UpdatePos = true; SearchPos.UpdatePos = true;
return true; return true;
} }
else if (para_Math_Run === this.content[CurPos - 1].Type && true === SearchPos.Shift) else if (para_Math_Run === this.Content[CurPos - 1].Type && true === SearchPos.Shift)
bStepEndRun = true; bStepEndRun = true;
while (CurPos < Count) while (CurPos < Count)
{ {
if (true !== bStepEndRun || para_Math_Run === this.content[CurPos].Type) if (true !== bStepEndRun || para_Math_Run === this.Content[CurPos].Type)
{ {
var OldUpdatePos = SearchPos.UpdatePos; var OldUpdatePos = SearchPos.UpdatePos;
this.content[CurPos].Get_WordEndPos(SearchPos, ContentPos, Depth + 1, false, StepEnd); this.Content[CurPos].Get_WordEndPos(SearchPos, ContentPos, Depth + 1, false, StepEnd);
if (true === SearchPos.UpdatePos) if (true === SearchPos.UpdatePos)
SearchPos.Pos.Update(CurPos, Depth); SearchPos.Pos.Update(CurPos, Depth);
...@@ -3508,7 +3509,7 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U ...@@ -3508,7 +3509,7 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U
else else
{ {
// Встаем в конец рана перед формулой // Встаем в конец рана перед формулой
this.content[CurPos - 1].Get_EndPos(false, SearchPos.Pos, Depth + 1); this.Content[CurPos - 1].Get_EndPos(false, SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(CurPos - 1, Depth); SearchPos.Pos.Update(CurPos - 1, Depth);
SearchPos.Found = true; SearchPos.Found = true;
SearchPos.UpdatePos = true; SearchPos.UpdatePos = true;
...@@ -3521,7 +3522,7 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U ...@@ -3521,7 +3522,7 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U
if (true === bStepEnd) if (true === bStepEnd)
{ {
// Перед выходом из контента встаем в его конец // Перед выходом из контента встаем в его конец
this.content[Count - 1].Get_EndPos(false, SearchPos.Pos, Depth + 1); this.Content[Count - 1].Get_EndPos(false, SearchPos.Pos, Depth + 1);
SearchPos.Pos.Update(Count - 1, Depth); SearchPos.Pos.Update(Count - 1, Depth);
SearchPos.Found = true; SearchPos.Found = true;
SearchPos.UpdatePos = true; SearchPos.UpdatePos = true;
...@@ -3531,15 +3532,41 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U ...@@ -3531,15 +3532,41 @@ CMathContent.prototype.Get_WordEndPos = function(SearchPos, ContentPos, Depth, U
CMathContent.prototype.Get_StartPos = function(ContentPos, Depth) CMathContent.prototype.Get_StartPos = function(ContentPos, Depth)
{ {
ContentPos.Update(0, Depth); ContentPos.Update(0, Depth);
this.content[0].Get_StartPos(ContentPos, Depth + 1); this.Content[0].Get_StartPos(ContentPos, Depth + 1);
}; };
CMathContent.prototype.Get_EndPos = function(BehindEnd, ContentPos, Depth) CMathContent.prototype.Get_EndPos = function(BehindEnd, ContentPos, Depth)
{ {
var nLastPos = this.content.length - 1; var nLastPos = this.Content.length - 1;
ContentPos.Update(nLastPos, Depth); ContentPos.Update(nLastPos, Depth);
if(undefined !== this.content[nLastPos]) if(undefined !== this.Content[nLastPos])
this.content[nLastPos].Get_EndPos(BehindEnd, ContentPos, Depth + 1); this.Content[nLastPos].Get_EndPos(BehindEnd, ContentPos, Depth + 1);
};
CMathContent.prototype.Draw_HighLights = function(PDSH, bAll)
{
PDSH.X = this.ParaMath.X + this.pos.x;
var PointsInfo = new CMathPointInfo();
PointsInfo.SetInfoPoints(this.InfoPoints);
if(this.RecalcInfo.bEqqArray)
PDSH.X += PointsInfo.GetAlign();
var len = this.Content.length;
for ( var CurPos = 0; CurPos < len; CurPos++ )
{
PDSH.Y0 = this.ParaMath.Y + this.pos.y;
PDSH.Y1 = this.ParaMath.Y + this.pos.y + this.size.height;
if(bAll && this.Content[CurPos].Type == para_Math_Run)
this.Content[CurPos].Select_All();
this.Content[CurPos].Draw_HighLights(PDSH, bAll);
}
}; };
CMathContent.prototype.Selection_Remove = function() CMathContent.prototype.Selection_Remove = function()
{ {
...@@ -3553,11 +3580,11 @@ CMathContent.prototype.Selection_Remove = function() ...@@ -3553,11 +3580,11 @@ CMathContent.prototype.Selection_Remove = function()
} }
StartPos = Math.max(0, StartPos); StartPos = Math.max(0, StartPos);
EndPos = Math.min(this.content.length - 1, EndPos); EndPos = Math.min(this.Content.length - 1, EndPos);
for (var nPos = StartPos; nPos <= EndPos; nPos++) for (var nPos = StartPos; nPos <= EndPos; nPos++)
{ {
this.content[nPos].Selection_Remove(); this.Content[nPos].Selection_Remove();
} }
this.Selection.Use = false; this.Selection.Use = false;
...@@ -3568,11 +3595,11 @@ CMathContent.prototype.Select_All = function(Direction) ...@@ -3568,11 +3595,11 @@ CMathContent.prototype.Select_All = function(Direction)
{ {
this.Selection.Use = true; this.Selection.Use = true;
this.Selection.Start = 0; this.Selection.Start = 0;
this.Selection.End = this.content.length - 1; this.Selection.End = this.Content.length - 1;
for (var nPos = 0, nCount = this.content.length; nPos < nCount; nPos++) for (var nPos = 0, nCount = this.Content.length; nPos < nCount; nPos++)
{ {
this.content[nPos].Select_All(Direction); this.Content[nPos].Select_All(Direction);
} }
}; };
CMathContent.prototype.Selection_DrawRange = function(_CurLine, _CurRange, SelectionDraw) CMathContent.prototype.Selection_DrawRange = function(_CurLine, _CurRange, SelectionDraw)
...@@ -3600,21 +3627,21 @@ CMathContent.prototype.Selection_DrawRange = function(_CurLine, _CurRange, Selec ...@@ -3600,21 +3627,21 @@ CMathContent.prototype.Selection_DrawRange = function(_CurLine, _CurRange, Selec
} }
var bDrawSelection = false; var bDrawSelection = false;
for(var nPos = 0, nCount = this.content.length; nPos < nCount; nPos++) for(var nPos = 0, nCount = this.Content.length; nPos < nCount; nPos++)
{ {
bDrawSelection = nPos >= Start && nPos <= End ? true : false; bDrawSelection = nPos >= Start && nPos <= End ? true : false;
if(para_Math_Run === this.content[nPos].Type) if(para_Math_Run === this.Content[nPos].Type)
this.content[nPos].Selection_DrawRange(_CurLine, _CurRange, SelectionDraw, PointsInfo); this.Content[nPos].Selection_DrawRange(_CurLine, _CurRange, SelectionDraw, PointsInfo);
else else
{ {
if(true === bDrawSelection) if(true === bDrawSelection)
{ {
SelectionDraw.W += this.content[nPos].size.width; SelectionDraw.W += this.Content[nPos].size.width;
SelectionDraw.FindStart = false; SelectionDraw.FindStart = false;
} }
else if(true === SelectionDraw.FindStart) else if(true === SelectionDraw.FindStart)
SelectionDraw.StartX += this.content[nPos].size.width; SelectionDraw.StartX += this.Content[nPos].size.width;
} }
} }
...@@ -3631,7 +3658,7 @@ CMathContent.prototype.Select_ElementByPos = function(nPos, bWhole) ...@@ -3631,7 +3658,7 @@ CMathContent.prototype.Select_ElementByPos = function(nPos, bWhole)
this.Selection.Start = nPos; this.Selection.Start = nPos;
this.Selection.End = nPos; this.Selection.End = nPos;
this.content[nPos].Select_All(); this.Content[nPos].Select_All();
if (bWhole) if (bWhole)
this.Correct_Selection(); this.Correct_Selection();
...@@ -3644,9 +3671,9 @@ CMathContent.prototype.Select_ElementByPos = function(nPos, bWhole) ...@@ -3644,9 +3671,9 @@ CMathContent.prototype.Select_ElementByPos = function(nPos, bWhole)
CMathContent.prototype.Select_Element = function(Element, bWhole) CMathContent.prototype.Select_Element = function(Element, bWhole)
{ {
var nPos = -1; var nPos = -1;
for (var nCurPos = 0, nCount = this.content.length; nCurPos < nCount; nCurPos++) for (var nCurPos = 0, nCount = this.Content.length; nCurPos < nCount; nCurPos++)
{ {
if (this.content[nCurPos] === Element) if (this.Content[nCurPos] === Element)
{ {
nPos = nCurPos; nPos = nCurPos;
break; break;
...@@ -3676,7 +3703,7 @@ CMathContent.prototype.Correct_Selection = function() ...@@ -3676,7 +3703,7 @@ CMathContent.prototype.Correct_Selection = function()
// Здесь мы делаем так, чтобы селект всегда начинался и заканчивался в ране. // Здесь мы делаем так, чтобы селект всегда начинался и заканчивался в ране.
// Предполагается, что контент скорректирован верно до выполнения данной функции. // Предполагается, что контент скорректирован верно до выполнения данной функции.
var nContentLen = this.content.length; var nContentLen = this.Content.length;
var nStartPos = Math.max(0, Math.min(this.Selection.Start, nContentLen - 1)); var nStartPos = Math.max(0, Math.min(this.Selection.Start, nContentLen - 1));
var nEndPos = Math.max(0, Math.min(this.Selection.End, nContentLen - 1)); var nEndPos = Math.max(0, Math.min(this.Selection.End, nContentLen - 1));
...@@ -3687,40 +3714,40 @@ CMathContent.prototype.Correct_Selection = function() ...@@ -3687,40 +3714,40 @@ CMathContent.prototype.Correct_Selection = function()
nEndPos = nTemp; nEndPos = nTemp;
} }
var oStartElement = this.content[nStartPos]; var oStartElement = this.Content[nStartPos];
if (para_Math_Run !== oStartElement.Type) if (para_Math_Run !== oStartElement.Type)
{ {
// Предыдущий элемент должен быть раном // Предыдущий элемент должен быть раном
this.Selection.Start = nStartPos - 1; this.Selection.Start = nStartPos - 1;
this.content[this.Selection.Start].Set_SelectionAtEndPos(); this.Content[this.Selection.Start].Set_SelectionAtEndPos();
} }
var oEndElement = this.content[nEndPos]; var oEndElement = this.Content[nEndPos];
if (para_Math_Run !== oEndElement.Type) if (para_Math_Run !== oEndElement.Type)
{ {
// Следующий элемент должен быть раном // Следующий элемент должен быть раном
this.Selection.End = nEndPos + 1; this.Selection.End = nEndPos + 1;
this.content[this.Selection.End].Set_SelectionAtStartPos(); this.Content[this.Selection.End].Set_SelectionAtStartPos();
} }
}; };
CMathContent.prototype.Create_FontMap = function(Map) CMathContent.prototype.Create_FontMap = function(Map)
{ {
for (var nIndex = 0, nCount = this.content.length; nIndex < nCount; nIndex++) for (var nIndex = 0, nCount = this.Content.length; nIndex < nCount; nIndex++)
this.content[nIndex].Create_FontMap(Map, this.Compiled_ArgSz); // ArgSize компилируется только тогда, когда выставлены все ссылки на родительские классы this.Content[nIndex].Create_FontMap(Map, this.Compiled_ArgSz); // ArgSize компилируется только тогда, когда выставлены все ссылки на родительские классы
}; };
CMathContent.prototype.Get_AllFontNames = function(AllFonts) CMathContent.prototype.Get_AllFontNames = function(AllFonts)
{ {
for (var nIndex = 0, nCount = this.content.length; nIndex < nCount; nIndex++) for (var nIndex = 0, nCount = this.Content.length; nIndex < nCount; nIndex++)
this.content[nIndex].Get_AllFontNames(AllFonts); this.Content[nIndex].Get_AllFontNames(AllFonts);
}; };
CMathContent.prototype.Selection_CheckParaContentPos = function(ContentPos, Depth, bStart, bEnd) CMathContent.prototype.Selection_CheckParaContentPos = function(ContentPos, Depth, bStart, bEnd)
{ {
var CurPos = ContentPos.Get(Depth); var CurPos = ContentPos.Get(Depth);
if (this.Selection.Start <= CurPos && CurPos <= this.Selection.End) if (this.Selection.Start <= CurPos && CurPos <= this.Selection.End)
return this.content[CurPos].Selection_CheckParaContentPos(ContentPos, Depth + 1, bStart && this.Selection.Start === CurPos, bEnd && CurPos === this.Selection.End); return this.Content[CurPos].Selection_CheckParaContentPos(ContentPos, Depth + 1, bStart && this.Selection.Start === CurPos, bEnd && CurPos === this.Selection.End);
else if (this.Selection.End <= CurPos && CurPos <= this.Selection.Start) else if (this.Selection.End <= CurPos && CurPos <= this.Selection.Start)
return this.content[CurPos].Selection_CheckParaContentPos(ContentPos, Depth + 1, bStart && this.Selection.End === CurPos, bEnd && CurPos === this.Selection.Start); return this.Content[CurPos].Selection_CheckParaContentPos(ContentPos, Depth + 1, bStart && this.Selection.End === CurPos, bEnd && CurPos === this.Selection.Start);
return false; return false;
}; };
...@@ -3734,7 +3761,7 @@ CMathContent.prototype.Check_NearestPos = function(ParaNearPos, Depth) ...@@ -3734,7 +3761,7 @@ CMathContent.prototype.Check_NearestPos = function(ParaNearPos, Depth)
ParaNearPos.Classes.push(this); ParaNearPos.Classes.push(this);
var CurPos = ParaNearPos.NearPos.ContentPos.Get(Depth); var CurPos = ParaNearPos.NearPos.ContentPos.Get(Depth);
this.content[CurPos].Check_NearestPos(ParaNearPos, Depth + 1); this.Content[CurPos].Check_NearestPos(ParaNearPos, Depth + 1);
}; };
CMathContent.prototype.private_SetNeedResize = function() CMathContent.prototype.private_SetNeedResize = function()
{ {
...@@ -3742,6 +3769,14 @@ CMathContent.prototype.private_SetNeedResize = function() ...@@ -3742,6 +3769,14 @@ CMathContent.prototype.private_SetNeedResize = function()
this.ParaMath.SetNeedResize(); this.ParaMath.SetNeedResize();
}; };
CMathContent.prototype.Is_CheckingNearestPos = ParaHyperlink.prototype.Is_CheckingNearestPos; CMathContent.prototype.Is_CheckingNearestPos = ParaHyperlink.prototype.Is_CheckingNearestPos;
CMathContent.prototype.Search = ParaHyperlink.prototype.Search;
CMathContent.prototype.Add_SearchResult = ParaHyperlink.prototype.Add_SearchResult;
CMathContent.prototype.Clear_SearchResults = ParaHyperlink.prototype.Clear_SearchResults;
CMathContent.prototype.Remove_SearchResult = ParaHyperlink.prototype.Remove_SearchResult;
CMathContent.prototype.Search_GetId = ParaHyperlink.prototype.Search_GetId;
CMathContent.prototype.Get_SelectionDirection = function() CMathContent.prototype.Get_SelectionDirection = function()
{ {
if (true !== this.Selection.Use) if (true !== this.Selection.Use)
...@@ -3752,17 +3787,17 @@ CMathContent.prototype.Get_SelectionDirection = function() ...@@ -3752,17 +3787,17 @@ CMathContent.prototype.Get_SelectionDirection = function()
else if (this.Selection.Start > this.Selection.End) else if (this.Selection.Start > this.Selection.End)
return -1; return -1;
return this.content[this.Selection.Start].Get_SelectionDirection(); return this.Content[this.Selection.Start].Get_SelectionDirection();
}; };
CMathContent.prototype.Cursor_MoveToStartPos = function() CMathContent.prototype.Cursor_MoveToStartPos = function()
{ {
this.CurPos = 0; this.CurPos = 0;
this.content[0].Cursor_MoveToStartPos(); this.Content[0].Cursor_MoveToStartPos();
}; };
CMathContent.prototype.Cursor_MoveToEndPos = function(SelectFromEnd) CMathContent.prototype.Cursor_MoveToEndPos = function(SelectFromEnd)
{ {
this.CurPos = this.content.length - 1; this.CurPos = this.Content.length - 1;
this.content[this.CurPos].Cursor_MoveToEndPos(SelectFromEnd); this.Content[this.CurPos].Cursor_MoveToEndPos(SelectFromEnd);
}; };
CMathContent.prototype.Process_AutoCorrect = function(ActionElement) CMathContent.prototype.Process_AutoCorrect = function(ActionElement)
{ {
...@@ -3771,10 +3806,10 @@ CMathContent.prototype.Process_AutoCorrect = function(ActionElement) ...@@ -3771,10 +3806,10 @@ CMathContent.prototype.Process_AutoCorrect = function(ActionElement)
var AutoCorrectEngine = new CMathAutoCorrectEngine(ActionElement); var AutoCorrectEngine = new CMathAutoCorrectEngine(ActionElement);
var nCount = this.content.length; var nCount = this.Content.length;
for (var nPos = 0; nPos < nCount; nPos++) for (var nPos = 0; nPos < nCount; nPos++)
{ {
var Element = this.content[nPos]; var Element = this.Content[nPos];
if (para_Math_Run === Element.Type) if (para_Math_Run === Element.Type)
Element.Get_TextForAutoCorrect(AutoCorrectEngine, nPos); Element.Get_TextForAutoCorrect(AutoCorrectEngine, nPos);
...@@ -3848,13 +3883,13 @@ CMathContent.prototype.Process_AutoCorrect = function(ActionElement) ...@@ -3848,13 +3883,13 @@ CMathContent.prototype.Process_AutoCorrect = function(ActionElement)
} }
this.CurPos = FirstElementPos + NewElementsCount + 1; this.CurPos = FirstElementPos + NewElementsCount + 1;
this.content[this.CurPos].Cursor_MoveToStartPos(); this.Content[this.CurPos].Cursor_MoveToStartPos();
if (true === bCursorStepRight) if (true === bCursorStepRight)
{ {
// TODO: Переделать через функцию в ране // TODO: Переделать через функцию в ране
if (this.content[this.CurPos].Content.length >= 1) if (this.Content[this.CurPos].Content.length >= 1)
this.content[this.CurPos].State.ContentPos = 1; this.Content[this.CurPos].State.ContentPos = 1;
} }
} }
else else
......
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