Commit 130b2763 authored by alexey.musinov's avatar alexey.musinov

Merge branch 'develop' of https://github.com/ONLYOFFICE/sdkjs into develop

parents 1442522b dc7592e6
...@@ -598,7 +598,6 @@ window['AscFonts'].CFontManager = function CFontManager() { ...@@ -598,7 +598,6 @@ window['AscFonts'].CFontManager = function CFontManager() {
this.Initialize = function(){}; this.Initialize = function(){};
this.ClearFontsRasterCache = function(){}; this.ClearFontsRasterCache = function(){};
}; };
window["use_native_fonts_only"] = true;
// FT_Common // FT_Common
function _FT_Common() { function _FT_Common() {
......
...@@ -3108,9 +3108,7 @@ PasteProcessor.prototype = ...@@ -3108,9 +3108,7 @@ PasteProcessor.prototype =
} }
else if(base64FromExcel)//вставляем в презентации из таблиц else if(base64FromExcel)//вставляем в презентации из таблиц
{ {
History.TurnOff(); var excelContent = AscFormat.ExecuteNoHistory(this._readFromBinaryExcel, this, [base64FromExcel]);
var excelContent = this._readFromBinaryExcel(base64FromExcel);
History.TurnOn();
var aContentExcel = excelContent.workbook; var aContentExcel = excelContent.workbook;
var aPastedImages = excelContent.arrImages; var aPastedImages = excelContent.arrImages;
...@@ -3118,22 +3116,6 @@ PasteProcessor.prototype = ...@@ -3118,22 +3116,6 @@ PasteProcessor.prototype =
//если есть шейпы, то вставляем их из excel //если есть шейпы, то вставляем их из excel
if(aContentExcel && aContentExcel.aWorksheets && aContentExcel.aWorksheets[0] && aContentExcel.aWorksheets[0].Drawings && aContentExcel.aWorksheets[0].Drawings.length) if(aContentExcel && aContentExcel.aWorksheets && aContentExcel.aWorksheets[0] && aContentExcel.aWorksheets[0].Drawings && aContentExcel.aWorksheets[0].Drawings.length)
{ {
var arr_shapes = aContentExcel.aWorksheets[0].Drawings;
var shape;
var aImagesToDownload = [];
for(var i = 0; i < aPastedImages.length; i++)
{
aImagesToDownload.push(aPastedImages[i].Url);
}
var aContent = {aPastedImages: aPastedImages, images: aImagesToDownload};
//var arrTransforms = objects.arrTransforms;
var presentation = editor.WordControl.m_oLogicDocument;
oThis = this;
var font_map = {};
var paste_callback = function() var paste_callback = function()
{ {
if(false == oThis.bNested) if(false == oThis.bNested)
...@@ -3157,6 +3139,29 @@ PasteProcessor.prototype = ...@@ -3157,6 +3139,29 @@ PasteProcessor.prototype =
presentation.Check_CursorMoveRight(); presentation.Check_CursorMoveRight();
presentation.Document_UpdateInterfaceState(); presentation.Document_UpdateInterfaceState();
} }
};
var arr_shapes = aContentExcel.aWorksheets[0].Drawings;
var aImagesToDownload = [];
for(var i = 0; i < aPastedImages.length; i++)
{
aImagesToDownload.push(aPastedImages[i].Url);
}
var aContent = {aPastedImages: aPastedImages, images: aImagesToDownload};
//var arrTransforms = objects.arrTransforms;
var presentation = editor.WordControl.m_oLogicDocument;
oThis = this;
//fonts
var font_map = {};
for(var i = 0; i < arr_shapes.length; ++i)
{
var shape = arr_shapes[i].graphicObject;
shape.getAllFonts(font_map);
} }
var fonts = []; var fonts = [];
...@@ -3164,10 +3169,9 @@ PasteProcessor.prototype = ...@@ -3164,10 +3169,9 @@ PasteProcessor.prototype =
for(var i in font_map) for(var i in font_map)
fonts.push(new CFont(i, 0, "", 0)); fonts.push(new CFont(i, 0, "", 0));
//images
var images = aContent.images; var images = aContent.images;
var arrImages = aContent.aPastedImages; var arrImages = aContent.aPastedImages;
var oObjectsForDownload = GetObjectsForImageDownload(arrImages); var oObjectsForDownload = GetObjectsForImageDownload(arrImages);
if(oObjectsForDownload.aUrls.length > 0) if(oObjectsForDownload.aUrls.length > 0)
{ {
...@@ -3192,8 +3196,68 @@ PasteProcessor.prototype = ...@@ -3192,8 +3196,68 @@ PasteProcessor.prototype =
return; return;
} }
else
{
var presentationSelectedContent = new PresentationSelectedContent();
presentationSelectedContent.DocContent = new CSelectedContent();
var aContent = AscFormat.ExecuteNoHistory(this._convertExcelBinary, this, [excelContent]);
var elements = [], selectedElement, element, drawings = [], pDrawings = [], drawingCopyObject;
var defaultTableStyleId = presentation.DefaultTableStyleId;
for(var i = 0; i < aContent.content.length; ++i)
{
selectedElement = new CSelectedElement();
element = aContent.content[i];
if(type_Table == element.GetType())//table
{
//TODO переделать количество строк и ширину
var W = 100;
var Rows = 3;
var graphic_frame = new CGraphicFrame();
graphic_frame.setSpPr(new AscFormat.CSpPr());
graphic_frame.spPr.setParent(graphic_frame);
graphic_frame.spPr.setXfrm(new AscFormat.CXfrm());
graphic_frame.spPr.xfrm.setParent(graphic_frame.spPr);
graphic_frame.spPr.xfrm.setOffX((this.oDocument.Width - W)/2);
graphic_frame.spPr.xfrm.setOffY(this.oDocument.Height/5);
graphic_frame.spPr.xfrm.setExtX(W);
graphic_frame.spPr.xfrm.setExtY(7.478268771701388 * Rows);
graphic_frame.setNvSpPr(new AscFormat.UniNvPr());
element = this._convertTableToPPTX(element);
graphic_frame.setGraphicObject(element.Copy(graphic_frame));
graphic_frame.graphicObject.Set_TableStyle(defaultTableStyleId);
drawingCopyObject = new DrawingCopyObject();
drawingCopyObject.Drawing = graphic_frame;
pDrawings.push(drawingCopyObject);
}
}
presentationSelectedContent.Drawings = pDrawings;
var presentation = editor.WordControl.m_oLogicDocument;
//вставка
var paste_callback = function()
{
if(false == oThis.bNested)
{
presentation.Insert_Content(presentationSelectedContent);
presentation.Recalculate();
presentation.Check_CursorMoveRight();
presentation.Document_UpdateInterfaceState();
}
} }
oThis.api.pre_Paste(aContent.content.fonts, null, paste_callback);
return;
} }
}
}
this.oRootNode = node; this.oRootNode = node;
this._Prepeare(node, this._Prepeare(node,
function(){ function(){
......
...@@ -673,6 +673,16 @@ CFootnotesController.prototype.private_GetFootnotesLogicRange = function(oFootno ...@@ -673,6 +673,16 @@ CFootnotesController.prototype.private_GetFootnotesLogicRange = function(oFootno
{ {
return this.LogicDocument.Get_FootnotesList(oFootnote1, oFootnote2); return this.LogicDocument.Get_FootnotesList(oFootnote1, oFootnote2);
}; };
CFootnotesController.prototype.private_GetSelectionArray = function()
{
if (true !== this.Selection.Use || 0 === this.Selection.Direction)
return [this.CurFootnote];
if (1 === this.Selection.Direction)
return this.private_GetFootnotesLogicRange(this.Selection.Start.Footnote, this.Selection.End.Footnote);
else
return this.private_GetFootnotesLogicRange(this.Selection.End.Footnote, this.Selection.Start.Footnote);
};
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Controller area // Controller area
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
...@@ -1801,83 +1811,136 @@ CFootnotesController.prototype.DrawSelectionOnPage = function(PageAbs) ...@@ -1801,83 +1811,136 @@ CFootnotesController.prototype.DrawSelectionOnPage = function(PageAbs)
}; };
CFootnotesController.prototype.GetSelectionBounds = function() CFootnotesController.prototype.GetSelectionBounds = function()
{ {
// TODO: Доделать селект и курсор
return null;
};
CFootnotesController.prototype.IsMovingTableBorder = function()
{
// TODO: Доделать селект и курсор
if (true === this.Selection.Use) if (true === this.Selection.Use)
{ {
if (0 === this.Selection.Direction)
{
return this.CurFootnote.Get_SelectionBounds();
}
else if (1 === this.Selection.Direction)
{
var Result = {};
Result.Start = this.Selection.Start.Footnote.Get_SelectionBounds().Start;
Result.End = this.Selection.End.Footnote.Get_SelectionBounds().End;
Result.Direction = 1;
return Result;
} }
else else
{ {
if (null !== this.CurFootnote) var Result = {};
return this.CurFootnote.Selection_Is_TableBorderMove(); Result.Start = this.Selection.End.Footnote.Get_SelectionBounds().Start;
Result.End = this.Selection.Start.Footnote.Get_SelectionBounds().End;
Result.Direction = -1;
return Result;
}
} }
return null;
};
CFootnotesController.prototype.IsMovingTableBorder = function()
{
if (true !== this.private_IsOnFootnoteSelected())
return false; return false;
return this.CurFootnote.Selection_Is_TableBorderMove();
}; };
CFootnotesController.prototype.CheckPosInSelection = function(X, Y, PageAbs, NearPos) CFootnotesController.prototype.CheckPosInSelection = function(X, Y, PageAbs, NearPos)
{ {
// TODO: Доделать селект и курсор // TODO: Доделать с NearPos
if (true === this.Selection.Use)
{ var oResult = this.private_GetFootnoteByXY(X, Y, PageAbs);
} if (oResult)
else
{ {
if (null !== this.CurFootnote) var oFootnote = oResult.Footnote;
return this.CurFootnote.Selection_Check(X, Y, PageAbs, NearPos); var PageRel = oFootnote.GetRelaitivePageIndex(PageAbs);
return oFootnote.Selection_Check(X, Y, PageRel, NearPos);
} }
return false; return false;
}; };
CFootnotesController.prototype.SelectAll = function() CFootnotesController.prototype.SelectAll = function(nDirection)
{ {
// TODO: Доделать селект и курсор var arrFootnotes = this.private_GetFootnotesLogicRange(null, null);
if (true === this.Selection.Use) if (!arrFootnotes || arrFootnotes.length <= 0)
return;
if (1 === arrFootnotes.length)
{
var oFootnote = arrFootnotes[0];
this.Selection.Use = true;
this.Selection.Start.Footnote = oFootnote;
this.Selection.End.Footnote = oFootnote;
this.CurFootnote = oFootnote;
this.Selection.Footnotes = {};
this.Selection.Direction = 0;
this.Selection.Footnotes[oFootnote.Get_Id()] = oFootnote;
oFootnote.Select_All(nDirection);
}
else
{
var StartFootnote, EndFootnote;
if (nDirection < 0)
{ {
StartFootnote = arrFootnotes[arrFootnotes.length - 1];
EndFootnote = arrFootnotes[0];
this.Selection.Direction = -1;
} }
else else
{ {
if (null !== this.CurFootnote) StartFootnote = arrFootnotes[0];
this.CurFootnote.Select_All(); EndFootnote = arrFootnotes[arrFootnotes.length - 1];
this.Selection.Direction = -1;
}
this.Selection.Use = true;
this.Selection.Start.Footnote = StartFootnote;
this.Selection.End.Footnote = EndFootnote;
this.CurFootnote = EndFootnote;
this.Selection.Footnotes = {};
for (var nPos = 0, nCount = arrFootnotes.length; nPos < nCount; ++nPos)
{
var oFootnote = arrFootnotes[nPos];
oFootnote.Select_All(nDirection);
this.Selection.Footnotes[oFootnote.Get_Id()] = oFootnote;
}
} }
}; };
CFootnotesController.prototype.GetSelectedContent = function(SelectedContent) CFootnotesController.prototype.GetSelectedContent = function(SelectedContent)
{ {
// TODO: Доделать селект и курсор if (true !== this.Selection.Use)
if (true === this.Selection.Use) return;
if (0 === this.Selection.Direction)
{ {
this.CurFootnote.Get_SelectedContent(SelectedContent);
} }
else else
{ {
if (null !== this.CurFootnote) var arrFootnotes = this.private_GetSelectionArray();
this.CurFootnote.Get_SelectedContent(SelectedContent); for (var nPos = 0, nCount = arrFootnotes.length; nPos < nCount; ++nPos)
{
arrFootnotes[nPos].Get_SelectedContent(SelectedContent);
}
} }
}; };
CFootnotesController.prototype.UpdateCursorType = function(X, Y, PageAbs, MouseEvent) CFootnotesController.prototype.UpdateCursorType = function(X, Y, PageAbs, MouseEvent)
{ {
// TODO: Доделать селект и курсор var oResult = this.private_GetFootnoteByXY(X, Y, PageAbs);
if (true === this.Selection.Use) if (oResult)
{
}
else
{ {
if (null !== this.CurFootnote) var oFootnote = oResult.Footnote;
this.CurFootnote.Update_CursorType(X, Y, PageAbs, MouseEvent); var PageRel = oFootnote.GetRelaitivePageIndex(PageAbs);
oFootnote.Update_CursorType(X, Y, PageRel, MouseEvent);
} }
}; };
CFootnotesController.prototype.PasteFormatting = function(TextPr, ParaPr) CFootnotesController.prototype.PasteFormatting = function(TextPr, ParaPr)
{ {
// TODO: Доделать селект и курсор for (var sId in this.Selection.Footnotes)
if (true === this.Selection.Use)
{
}
else
{ {
if (null !== this.CurFootnote) this.Selection.Footnotes[sId].Paragraph_Format_Paste(TextPr, ParaPr, true);
this.CurFootnote.Paragraph_Format_Paste(TextPr, ParaPr, true);
} }
}; };
CFootnotesController.prototype.IsSelectionUse = function() CFootnotesController.prototype.IsSelectionUse = function()
...@@ -1886,23 +1949,49 @@ CFootnotesController.prototype.IsSelectionUse = function() ...@@ -1886,23 +1949,49 @@ CFootnotesController.prototype.IsSelectionUse = function()
}; };
CFootnotesController.prototype.IsTextSelectionUse = function() CFootnotesController.prototype.IsTextSelectionUse = function()
{ {
// TODO: Реализовать if (true !== this.Selection.Use)
return false; return false;
if (0 === this.Selection.Direction)
return this.CurFootnote.Is_TextSelectionUse();
return true;
}; };
CFootnotesController.prototype.GetCurPosXY = function() CFootnotesController.prototype.GetCurPosXY = function()
{ {
// TODO: Реализовать if (this.CurFootnote)
return this.CurFootnote.Get_CurPosXY();
return {X : 0, Y : 0}; return {X : 0, Y : 0};
}; };
CFootnotesController.prototype.GetSelectedText = function(bClearText) CFootnotesController.prototype.GetSelectedText = function(bClearText)
{ {
// TODO: Реализовать if (true === bClearText)
return ""; {
if (true !== this.Selection.Use || 0 !== this.Selection.Direction)
return null;
return this.CurFootnote.Get_SelectedText(true);
}
else
{
var sResult = "";
var arrFootnotes = this.private_GetSelectionArray();
for (var nPos = 0, nCount = arrFootnotes.length; nPos < nCount; ++nPos)
{
var sTempResult = arrFootnotes[nPos].Get_SelectedText(false);
if (null == sTempResult)
return null;
sResult += sTempResult;
}
return sResult;
}
}; };
CFootnotesController.prototype.GetCurrentParagraph = function() CFootnotesController.prototype.GetCurrentParagraph = function()
{ {
// TODO: Реализовать return this.CurFootnote.Get_CurrentParagraph();
return null;
}; };
CFootnotesController.prototype.GetSelectedElementsInfo = function(oInfo) CFootnotesController.prototype.GetSelectedElementsInfo = function(oInfo)
{ {
...@@ -1913,45 +2002,85 @@ CFootnotesController.prototype.GetSelectedElementsInfo = function(oInfo) ...@@ -1913,45 +2002,85 @@ CFootnotesController.prototype.GetSelectedElementsInfo = function(oInfo)
}; };
CFootnotesController.prototype.AddTableRow = function(bBefore) CFootnotesController.prototype.AddTableRow = function(bBefore)
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return;
this.CurFootnote.Table_AddRow(bBefore);
}; };
CFootnotesController.prototype.AddTableCol = function(bBefore) CFootnotesController.prototype.AddTableCol = function(bBefore)
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return;
this.CurFootnote.Table_AddCol(bBefore);
}; };
CFootnotesController.prototype.RemoveTableRow = function() CFootnotesController.prototype.RemoveTableRow = function()
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return;
this.CurFootnote.Table_RemoveRow();
}; };
CFootnotesController.prototype.RemoveTableCol = function() CFootnotesController.prototype.RemoveTableCol = function()
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return;
this.CurFootnote.Table_RemoveCol();
}; };
CFootnotesController.prototype.MergeTableCells = function() CFootnotesController.prototype.MergeTableCells = function()
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return;
this.CurFootnote.Table_MergeCells();
}; };
CFootnotesController.prototype.SplitTableCells = function(Cols, Rows) CFootnotesController.prototype.SplitTableCells = function(Cols, Rows)
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return;
this.CurFootnote.Table_SplitCell(Cols, Rows);
}; };
CFootnotesController.prototype.RemoveTable = function() CFootnotesController.prototype.RemoveTable = function()
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return;
this.CurFootnote.Table_RemoveTable();
}; };
CFootnotesController.prototype.SelectTable = function(Type) CFootnotesController.prototype.SelectTable = function(Type)
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return;
this.RemoveSelection();
this.CurFootnote.Table_Select(Type);
if (true === this.CurFootnote.Is_SelectionUse())
{
this.Selection.Use = true;
this.Selection.Start.Footnote = this.CurFootnote;
this.Selection.End.Footnote = this.CurFootnote;
this.Selection.Footnotes = {};
this.Selection.Direction = 0;
this.Selection.Footnotes[this.CurFootnote.Get_Id()] = this.CurFootnote;
}
}; };
CFootnotesController.prototype.CanMergeTableCells = function() CFootnotesController.prototype.CanMergeTableCells = function()
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return false; return false;
return this.CurFootnote.Table_CheckMerge();
}; };
CFootnotesController.prototype.CanSplitTableCells = function() CFootnotesController.prototype.CanSplitTableCells = function()
{ {
// TODO: Реализовать if (false === this.private_CheckFootnotesSelectionBeforeAction())
return false; return false;
return this.CurFootnote.Table_CheckSplit();
}; };
CFootnotesController.prototype.UpdateInterfaceState = function() CFootnotesController.prototype.UpdateInterfaceState = 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