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

Обработка клавиш вправо/влево в формулах.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@52621 954022d7-b5bf-4e40-9824-e11837661b57
parent b9b01da5
...@@ -8412,7 +8412,9 @@ CDocument.prototype = ...@@ -8412,7 +8412,9 @@ CDocument.prototype =
//не возвращаем true чтобы не было preventDefault //не возвращаем true чтобы не было preventDefault
} }
} }
else if ( e.KeyCode == 69 && false === editor.isViewMode && true === e.CtrlKey ) // Ctrl + E - переключение прилегания параграфа между center и left else if ( e.KeyCode == 69 && false === editor.isViewMode && true === e.CtrlKey ) // Ctrl + E + ...
{
if ( true !== e.AltKey ) // Ctrl + E - переключение прилегания параграфа между center и left
{ {
var ParaPr = this.Get_Paragraph_ParaPr(); var ParaPr = this.Get_Paragraph_ParaPr();
if ( null != ParaPr ) if ( null != ParaPr )
...@@ -8426,6 +8428,19 @@ CDocument.prototype = ...@@ -8426,6 +8428,19 @@ CDocument.prototype =
bRetValue = true; bRetValue = true;
} }
} }
else // Ctrl + Alt + E - добавляем знак евро €
{
if ( false === this.Document_Is_SelectionLocked(changestype_Paragraph_Content) )
{
this.Create_NewHistoryPoint();
this.DrawingDocument.TargetStart();
this.DrawingDocument.TargetShow();
this.Paragraph_Add( new ParaText( "" ) );
}
bRetValue = true;
}
}
else if ( e.KeyCode == 73 && false === editor.isViewMode && true === e.CtrlKey ) // Ctrl + I - делаем текст наклонным else if ( e.KeyCode == 73 && false === editor.isViewMode && true === e.CtrlKey ) // Ctrl + I - делаем текст наклонным
{ {
var TextPr = this.Get_Paragraph_TextPr(); var TextPr = this.Get_Paragraph_TextPr();
......
...@@ -5347,7 +5347,7 @@ Paragraph.prototype = ...@@ -5347,7 +5347,7 @@ Paragraph.prototype =
// nCount - количество удаляемых элементов, > 0 удаляем элементы после курсора // nCount - количество удаляемых элементов, > 0 удаляем элементы после курсора
// < 0 удаляем элементы до курсора // < 0 удаляем элементы до курсора
// bOnlyText - true: удаляем только текст и пробелы, false - Удаляем любые элементы // bOnlyText - true: удаляем только текст и пробелы, false - Удаляем любые элементы
Remove : function(nCount, bOnlyText) Remove : function(nCount, bOnlyText, bRemoveOnlySelection, bOnAddText)
{ {
this.Internal_Remove_CollaborativeMarks(true); this.Internal_Remove_CollaborativeMarks(true);
...@@ -5358,16 +5358,45 @@ Paragraph.prototype = ...@@ -5358,16 +5358,45 @@ Paragraph.prototype =
{ {
var StartPos = this.Selection.StartPos; var StartPos = this.Selection.StartPos;
var EndPos = this.Selection.EndPos; var EndPos = this.Selection.EndPos;
var StartPos2 = this.Selection.StartPos2;
var EndPos2 = this.Selection.EndPos2;
if ( StartPos > EndPos ) if ( StartPos > EndPos )
{ {
var Temp = EndPos; var Temp = EndPos;
EndPos = StartPos; EndPos = StartPos;
StartPos = Temp; StartPos = Temp;
var Temp2 = EndPos2;
EndPos2 = StartPos2;
StartPos2 = Temp2;
} }
if ( EndPos >= this.Content.length - 1 ) if ( EndPos >= this.Content.length - 1 )
{ {
var CurPos2 = -1;
if ( undefined !== this.Content[StartPos2] && para_Math === this.Content[StartPos2].Type )
{
if ( false === this.Content[StartPos2].Remove(nCount, bOnAddText) )
{
// Нам нужно удалить данный элемент
this.Internal_Content_Remove( StartPos2, 1 );
if ( StartPos > StartPos2 )
StartPos--;
if ( EndPos > StartPos2 )
EndPos--;
}
else
{
// Нам нужно удалить данный элемент
if ( StartPos === StartPos2 )
StartPos++;
CurPos2 = StartPos2;
}
}
for ( var Index = StartPos; Index < this.Content.length - 2; Index++ ) for ( var Index = StartPos; Index < this.Content.length - 2; Index++ )
{ {
var Item = this.Content[Index]; var Item = this.Content[Index];
...@@ -5396,6 +5425,7 @@ Paragraph.prototype = ...@@ -5396,6 +5425,7 @@ Paragraph.prototype =
StartPos = Temp; StartPos = Temp;
} }
this.CurPos.ContentPos2 = StartPos2;
this.Set_ContentPos( StartPos, true, -1 ); this.Set_ContentPos( StartPos, true, -1 );
if ( null != Hyper_start ) if ( null != Hyper_start )
...@@ -5409,6 +5439,58 @@ Paragraph.prototype = ...@@ -5409,6 +5439,58 @@ Paragraph.prototype =
} }
else else
{ {
var CurPos2 = -1;
if ( undefined !== this.Content[EndPos2] && para_Math === this.Content[EndPos2].Type )
{
if ( false === this.Content[EndPos2].Remove(nCount, bOnAddText) )
{
// Нам нужно удалить данный элемент
this.Internal_Content_Remove( EndPos2, 1 );
}
else
{
if ( StartPos2 === EndPos2 )
CurPos2 = StartPos2;
}
if ( EndPos > EndPos2 )
EndPos--;
}
if ( undefined !== this.Content[StartPos2] && para_Math === this.Content[StartPos2].Type && StartPos2 !== EndPos2 )
{
if ( false === this.Content[EndPos2].Remove(nCount, bOnAddText) )
{
// Нам нужно удалить данный элемент
this.Internal_Content_Remove( EndPos2, 1 );
if ( StartPos > StartPos2 )
StartPos--;
if ( EndPos > StartPos2 )
EndPos--;
}
else
{
if ( StartPos === StartPos2 )
StartPos++;
if ( EndPos === StartPos2 )
EndPos--;
CurPos2 = StartPos2;
}
}
if ( EndPos <= StartPos )
{
this.CurPos.ContentPos2 = CurPos2;
this.Set_ContentPos( StartPos, true, -1 );
return true;
}
var Hyper_start = this.Check_Hyperlink2( StartPos ); var Hyper_start = this.Check_Hyperlink2( StartPos );
var Hyper_end = this.Check_Hyperlink2( EndPos ); var Hyper_end = this.Check_Hyperlink2( EndPos );
...@@ -5443,6 +5525,7 @@ Paragraph.prototype = ...@@ -5443,6 +5525,7 @@ Paragraph.prototype =
if ( null != LastTextPr ) if ( null != LastTextPr )
this.Internal_Content_Add( StartPos, new ParaTextPr( LastTextPr.Value ) ); this.Internal_Content_Add( StartPos, new ParaTextPr( LastTextPr.Value ) );
this.CurPos.ContentPos2 = CurPos2;
this.Set_ContentPos( StartPos, true, -1 ); this.Set_ContentPos( StartPos, true, -1 );
if ( Hyper_start != Hyper_end ) if ( Hyper_start != Hyper_end )
...@@ -5501,6 +5584,33 @@ Paragraph.prototype = ...@@ -5501,6 +5584,33 @@ Paragraph.prototype =
{ {
var Line = this.Content; var Line = this.Content;
var CurPos = this.CurPos.ContentPos; var CurPos = this.CurPos.ContentPos;
var CurPos2 = this.CurPos.ContentPos2;
var MathItem = this.Content[CurPos2];
if ( undefined !== MathItem && para_Math === MathItem.Type )
{
if ( false != MathItem.Remove(1) )
{
// TODO: тут надо проверить, не остался ли данный элемент пустым
// После удаления в математическом элементе может остаться выделение
if ( true === MathItem.Selection_IsUse() && false === MathItem.Selection_IsEmpty() )
{
this.Selection.Use = true;
this.Selection.Start = false;
this.Selection.StartPos = CurPos2;
this.Selection.EndPos = CurPos2 + 1;
this.Selection.StartPos2 = CurPos2;
this.Selection.EndPos2 = CurPos2;
this.Document_SetThisElementCurrent();
}
return true;
}
CurPos = CurPos2;
}
if ( !bOnlyText ) if ( !bOnlyText )
{ {
...@@ -5585,6 +5695,34 @@ Paragraph.prototype = ...@@ -5585,6 +5695,34 @@ Paragraph.prototype =
{ {
var Line = this.Content; var Line = this.Content;
var CurPos = this.CurPos.ContentPos; var CurPos = this.CurPos.ContentPos;
var CurPos2 = this.CurPos.ContentPos2;
var MathItem = this.Content[CurPos2];
if ( undefined !== MathItem && para_Math === MathItem.Type )
{
if ( false != MathItem.Remove(-1) )
{
// TODO: тут надо проверить, не остался ли данный элемент пустым
// После удаления в математическом элементе может остаться выделение
if ( true === MathItem.Selection_IsUse() && false === MathItem.Selection_IsEmpty() )
{
this.Selection.Use = true;
this.Selection.Start = false;
this.Selection.StartPos = CurPos2;
this.Selection.EndPos = CurPos2 + 1;
this.Selection.StartPos2 = CurPos2;
this.Selection.EndPos2 = CurPos2;
this.Document_SetThisElementCurrent();
}
return true;
}
CurPos = CurPos2 + 1;
}
if ( !bOnlyText ) if ( !bOnlyText )
{ {
...@@ -5793,6 +5931,7 @@ Paragraph.prototype = ...@@ -5793,6 +5931,7 @@ Paragraph.prototype =
Add : function(Item) Add : function(Item)
{ {
var CurPos = this.CurPos.ContentPos; var CurPos = this.CurPos.ContentPos;
var CurPos2 = this.CurPos.ContentPos2;
if ( "undefined" != typeof(Item.Parent) ) if ( "undefined" != typeof(Item.Parent) )
Item.Parent = this; Item.Parent = this;
...@@ -5800,13 +5939,13 @@ Paragraph.prototype = ...@@ -5800,13 +5939,13 @@ Paragraph.prototype =
switch (Item.Type) switch (Item.Type)
{ {
case para_Text: case para_Text:
{
this.Internal_Content_Add( CurPos, Item );
break;
}
case para_Space: case para_Space:
{ {
if ( undefined !== this.Content[CurPos2] && para_Math === this.Content[CurPos2].Type )
this.Content[CurPos2].Add( Item );
else
this.Internal_Content_Add( CurPos, Item ); this.Internal_Content_Add( CurPos, Item );
break; break;
} }
case para_TextPr: case para_TextPr:
...@@ -6766,18 +6905,21 @@ Paragraph.prototype = ...@@ -6766,18 +6905,21 @@ Paragraph.prototype =
{ {
this.Selection.Use = false; this.Selection.Use = false;
this.Set_ContentPos( this.Internal_GetStartPos(), true, -1 ); this.Set_ContentPos( this.Internal_GetStartPos(), true, -1 );
this.CurPos.ContentPos2 = -1;
}, },
Cursor_MoveToEndPos : function() Cursor_MoveToEndPos : function()
{ {
this.Selection.Use = false; this.Selection.Use = false;
this.Set_ContentPos( this.Internal_GetEndPos(), true, -1 ); this.Set_ContentPos( this.Internal_GetEndPos(), true, -1 );
this.CurPos.ContentPos2 = -1;
}, },
Cursor_MoveToNearPos : function(NearPos) Cursor_MoveToNearPos : function(NearPos)
{ {
this.Selection.Use = false; this.Selection.Use = false;
this.Set_ContentPos( NearPos.ContentPos, true, -1 ); this.Set_ContentPos( NearPos.ContentPos, true, -1 );
this.CurPos.ContentPos2 = -1;
}, },
Cursor_MoveUp_To_LastRow : function(X, Y, AddToSelect) Cursor_MoveUp_To_LastRow : function(X, Y, AddToSelect)
...@@ -6938,6 +7080,21 @@ Paragraph.prototype = ...@@ -6938,6 +7080,21 @@ Paragraph.prototype =
return this.Selection.Use; return this.Selection.Use;
}, },
Internal_SelectMath : function(Pos)
{
if ( undefined === this.Content[Pos] || para_Math != this.Content[Pos].Type )
return;
this.Selection.Use = true;
this.Selection.Start = false;
this.Selection.StartPos = Pos;
this.Selection.EndPos = Pos + 1;
this.Selection.StartPos2 = Pos;
this.Selection.EndPos2 = Pos;
this.Document_SetThisElementCurrent();
},
// Функция определяет начальную позицию курсора в параграфе // Функция определяет начальную позицию курсора в параграфе
Internal_GetStartPos : function() Internal_GetStartPos : function()
{ {
...@@ -6974,17 +7131,39 @@ Paragraph.prototype = ...@@ -6974,17 +7131,39 @@ Paragraph.prototype =
// В случае селекта, убираем селект и перемещаем курсор в начало селекта // В случае селекта, убираем селект и перемещаем курсор в начало селекта
var StartPos = this.Selection.StartPos; var StartPos = this.Selection.StartPos;
var EndPos = this.Selection.EndPos; var EndPos = this.Selection.EndPos;
var StartPos = this.Selection.StartPos;
var EndPos = this.Selection.EndPos;
var StartPos2 = this.Selection.StartPos2;
var EndPos2 = this.Selection.EndPos2;
if ( StartPos > EndPos ) if ( StartPos > EndPos )
{ {
var Temp = EndPos; var Temp = EndPos;
EndPos = StartPos; EndPos = StartPos;
StartPos = Temp; StartPos = Temp;
var Temp2 = EndPos2;
EndPos2 = StartPos2;
StartPos2 = Temp2;
} }
this.Selection_Remove(); this.Selection_Remove();
if ( undefined != this.Content[StartPos2] && para_Math === this.Content[StartPos2].Type )
{
this.Set_ContentPos( StartPos, true, -1 ); this.Set_ContentPos( StartPos, true, -1 );
return; this.CurPos.ContentPos2 = StartPos2;
if ( true === this.Content[StartPos2].Cursor_MoveLeft(AddToSelect, Word) )
{
if ( true === this.Content[StartPos2].Selection_IsUse() && false === this.Content[StartPos2].Selection_IsEmpty() )
this.Internal_SelectMath( StartPos2 );
}
}
else
this.Set_ContentPos( StartPos, true, -1 );
return true;
} }
} }
...@@ -7048,6 +7227,24 @@ Paragraph.prototype = ...@@ -7048,6 +7227,24 @@ Paragraph.prototype =
} }
else else
{ {
var CurPos2 = this.CurPos.ContentPos2;
var MathItem = this.Content[CurPos2];
if ( undefined !== MathItem && para_Math === MathItem.Type )
{
if ( true === MathItem.Cursor_MoveLeft(false, Word) )
{
if ( true === MathItem.Selection_IsUse() && false === MathItem.Selection_IsEmpty() )
this.Internal_SelectMath( CurPos2 );
return true;
}
else
{
this.CurPos.ContentPos = CurPos2 + 1;
this.CurPos.ContensPos2 = -1;
}
}
var oPos; var oPos;
if ( true != Word ) if ( true != Word )
...@@ -7058,6 +7255,15 @@ Paragraph.prototype = ...@@ -7058,6 +7255,15 @@ Paragraph.prototype =
if ( oPos.Found ) if ( oPos.Found )
{ {
this.Set_ContentPos( oPos.LetterPos, true, -1 ); this.Set_ContentPos( oPos.LetterPos, true, -1 );
if ( para_Math === oPos.Type )
{
this.CurPos.ContentPos2 = oPos.LetterPos;
this.Content[oPos.LetterPos].Cursor_MoveToEndPos();
}
else
this.CurPos.ContentPos2 = -1;
return true; return true;
} }
else else
...@@ -7231,16 +7437,36 @@ Paragraph.prototype = ...@@ -7231,16 +7437,36 @@ Paragraph.prototype =
// В случае селекта, убираем селект и перемещаем курсор в конец селекта // В случае селекта, убираем селект и перемещаем курсор в конец селекта
var StartPos = this.Selection.StartPos; var StartPos = this.Selection.StartPos;
var EndPos = this.Selection.EndPos; var EndPos = this.Selection.EndPos;
var StartPos2 = this.Selection.StartPos2;
var EndPos2 = this.Selection.EndPos2;
if ( StartPos > EndPos ) if ( StartPos > EndPos )
{ {
var Temp = EndPos; var Temp = EndPos;
EndPos = StartPos; EndPos = StartPos;
StartPos = Temp; StartPos = Temp;
var Temp2 = EndPos2;
EndPos2 = StartPos2;
StartPos2 = Temp2;
} }
this.Selection_Remove(); this.Selection_Remove();
if ( undefined != this.Content[EndPos2] && para_Math === this.Content[EndPos2].Type )
{
this.Set_ContentPos( Math.max( CursorPos_min, Math.min( EndPos, CursorPos_max ) ), true, -1 );
this.CurPos.ContentPos2 = EndPos2;
if ( true === this.Content[EndPos2].Cursor_MoveRight(AddToSelect, Word) )
{
if ( true === this.Content[EndPos2].Selection_IsUse() && false === this.Content[EndPos2].Selection_IsEmpty() )
this.Internal_SelectMath( EndPos2 );
}
}
else
this.Set_ContentPos( Math.max( CursorPos_min, Math.min( EndPos, CursorPos_max ) ), true, -1 ); this.Set_ContentPos( Math.max( CursorPos_min, Math.min( EndPos, CursorPos_max ) ), true, -1 );
return true; return true;
} }
} }
...@@ -7304,11 +7530,29 @@ Paragraph.prototype = ...@@ -7304,11 +7530,29 @@ Paragraph.prototype =
} }
else else
{ {
var CurPos2 = this.CurPos.ContentPos2;
var MathItem = this.Content[CurPos2];
if ( undefined !== MathItem && para_Math === MathItem.Type )
{
if ( true === MathItem.Cursor_MoveRight(false, Word) )
{
if ( true === MathItem.Selection_IsUse() && false === MathItem.Selection_IsEmpty() )
this.Internal_SelectMath( CurPos2 );
return true;
}
else
{
this.CurPos.ContentPos = CurPos2;
this.CurPos.ContentPos2 = -1;
}
}
var oPos; var oPos;
if ( true != Word ) if ( true != Word )
{ {
oPos = this.Internal_FindForward( this.CurPos.ContentPos, [para_PageNum, para_Drawing, para_Tab, para_Text, para_Space, para_NewLine] ); oPos = this.Internal_FindForward( this.CurPos.ContentPos, [para_PageNum, para_Drawing, para_Tab, para_Text, para_Space, para_NewLine, para_Math] );
if ( oPos.Found ) if ( oPos.Found )
oPos.LetterPos++; oPos.LetterPos++;
} }
...@@ -7318,6 +7562,15 @@ Paragraph.prototype = ...@@ -7318,6 +7562,15 @@ Paragraph.prototype =
if ( oPos.Found ) if ( oPos.Found )
{ {
this.Set_ContentPos( oPos.LetterPos, true, -1 ); this.Set_ContentPos( oPos.LetterPos, true, -1 );
if ( para_Math === oPos.Type )
{
this.CurPos.ContentPos2 = oPos.LetterPos - 1;
this.Content[oPos.LetterPos - 1].Cursor_MoveToStartPos();
}
else
this.CurPos.ContentPos2 = -1;
return true; return true;
} }
else else
......
...@@ -7556,9 +7556,23 @@ ParaMath.prototype = ...@@ -7556,9 +7556,23 @@ ParaMath.prototype =
return true; return true;
}, },
Add : function(Item)
{
var Type = Item.Type;
if ( para_Text === Type )
this.Math.AddLetter( Item.Value.charCodeAt(0) );
else if ( para_Space === Type )
this.Math.AddLetter( 0x0020 );
},
Remove : function(Order, bOnAddText)
{
return this.Math.Remove(Order, bOnAddText);
},
RecalculateCurPos : function() RecalculateCurPos : function()
{ {
console.log("RecalculateCurPos");
this.Math.UpdateCursor(); this.Math.UpdateCursor();
}, },
...@@ -7592,6 +7606,11 @@ ParaMath.prototype = ...@@ -7592,6 +7606,11 @@ ParaMath.prototype =
return this.Math.Selection_IsEmpty(); return this.Math.Selection_IsEmpty();
}, },
Selection_IsUse : function()
{
return true;
},
Selection_Remove : function() Selection_Remove : function()
{ {
...@@ -7599,9 +7618,25 @@ ParaMath.prototype = ...@@ -7599,9 +7618,25 @@ ParaMath.prototype =
Selection_Check : function(X, Y, Page_Abs) Selection_Check : function(X, Y, Page_Abs)
{ {
var check = this.Math.Selection_Check(X, Y); return this.Math.Selection_Check(X, Y);
console.log("Selection_Check: "+ check); },
return check;
Cursor_MoveLeft : function(bShiftKey, bCtrlKey)
{
return this.Math.Cursor_MoveLeft(bShiftKey, bCtrlKey);
},
Cursor_MoveRight : function(bShiftKey, bCtrlKey)
{
return this.Math.Cursor_MoveRight(bShiftKey, bCtrlKey);
},
Cursor_MoveToStartPos : function()
{
},
Cursor_MoveToEndPos : function()
{
}, },
Copy : function() Copy : function()
......
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