Commit 7aa2e268 authored by GoshaZotov's avatar GoshaZotov

fix bug 35913

parent b303baef
...@@ -2649,6 +2649,7 @@ ...@@ -2649,6 +2649,7 @@
pasteTextOnSheet: function(worksheet, text) pasteTextOnSheet: function(worksheet, text)
{ {
var t = this;
if(!text || (text && !text.length)) if(!text || (text && !text.length))
{ {
window['AscCommon'].g_clipboardBase.Paste_Process_End(); window['AscCommon'].g_clipboardBase.Paste_Process_End();
...@@ -2670,15 +2671,30 @@ ...@@ -2670,15 +2671,30 @@
} }
var Count = text.length; var Count = text.length;
for ( var Index = 0; Index < Count; Index++ )
{ var newParagraph = new Paragraph(isIntoShape.DrawingDocument, isIntoShape);
var selectedElements = new CSelectedContent();
var insertText = "";
for (var Index = 0; Index < Count; Index++) {
var _char = text.charAt(Index); var _char = text.charAt(Index);
if (" " == _char) var _charCode = text.charCodeAt(Index);
isIntoShape.AddToParagraph(new ParaSpace()); if(_charCode === 0x0A || Index === Count - 1){
else var newParaRun = new ParaRun();
isIntoShape.AddToParagraph(new ParaText(_char)); window['AscCommon'].addTextIntoRun(newParaRun, insertText);
newParagraph.Internal_Content_Add(newParagraph.Content.length - 1, newParaRun, false);
var selectedElement = new CSelectedElement();
selectedElement.Element = newParagraph;
selectedElements.Elements.push(selectedElement);
insertText = "";
newParagraph = new Paragraph(isIntoShape.DrawingDocument, isIntoShape);
} else{
insertText += _char;
}
} }
t._insertSelectedContentIntoShapeContent(worksheet, selectedElements, isIntoShape);
window['AscCommon'].g_clipboardBase.specialPasteButtonProps = {}; window['AscCommon'].g_clipboardBase.specialPasteButtonProps = {};
window['AscCommon'].g_clipboardBase.Paste_Process_End(); window['AscCommon'].g_clipboardBase.Paste_Process_End();
......
...@@ -2557,7 +2557,7 @@ PasteProcessor.prototype = ...@@ -2557,7 +2557,7 @@ PasteProcessor.prototype =
if(mathText && mathText.str) if(mathText && mathText.str)
{ {
var newParaRun = new ParaRun(); var newParaRun = new ParaRun();
this._addTextIntoRun(newParaRun, mathText.str); addTextIntoRun(newParaRun, mathText.str);
res = newParaRun; res = newParaRun;
} }
...@@ -2613,7 +2613,7 @@ PasteProcessor.prototype = ...@@ -2613,7 +2613,7 @@ PasteProcessor.prototype =
bIsAddTabBefore = true; bIsAddTabBefore = true;
} }
t._addTextIntoRun(newParaRun, value, bIsAddTabBefore, true); addTextIntoRun(newParaRun, value, bIsAddTabBefore, true);
newParagraph.Internal_Content_Add(newParagraph.Content.length - 1, newParaRun, false); newParagraph.Internal_Content_Add(newParagraph.Content.length - 1, newParaRun, false);
} }
...@@ -2649,7 +2649,7 @@ PasteProcessor.prototype = ...@@ -2649,7 +2649,7 @@ PasteProcessor.prototype =
var numberingText = this._getNumberingText(lvl, NumInfo, NumTextPr, lvl); var numberingText = this._getNumberingText(lvl, NumInfo, NumTextPr, lvl);
var newParaRun = new ParaRun(); var newParaRun = new ParaRun();
this._addTextIntoRun(newParaRun, numberingText, false, true, true); addTextIntoRun(newParaRun, numberingText, false, true, true);
paragraph.Internal_Content_Add(0, newParaRun, false); paragraph.Internal_Content_Add(0, newParaRun, false);
} }
}, },
...@@ -2825,53 +2825,6 @@ PasteProcessor.prototype = ...@@ -2825,53 +2825,6 @@ PasteProcessor.prototype =
return Char; return Char;
}, },
_addTextIntoRun: function(oCurRun, value, bIsAddTabBefore, dNotAddLastSpace, bIsAddTabAfter)
{
var diffContentIndex = 0;
if(bIsAddTabBefore){
diffContentIndex = 1;
oCurRun.Add_ToContent(0, new ParaTab(), false);
}
for(var k = 0, length = value.length; k < length; k++)
{
var nUnicode = null;
var nCharCode = value.charCodeAt(k);
if (AscCommon.isLeadingSurrogateChar(nCharCode)) {
if (k + 1 < length) {
k++;
var nTrailingChar = value.charCodeAt(k);
nUnicode = AscCommon.decodeSurrogateChar(nCharCode, nTrailingChar);
}
}
else
nUnicode = nCharCode;
var bIsSpace = true;
if (null != nUnicode) {
var Item;
if (0x20 !== nUnicode && 0xA0 !== nUnicode && 0x2009 !== nUnicode) {
Item = new ParaText();
Item.Set_CharCode(nUnicode);
bIsSpace = false;
}
else if(0x2009 === nUnicode){
Item = new ParaTab();
}
else
Item = new ParaSpace();
//add text
if(!(dNotAddLastSpace && k === value.length - 1 && bIsSpace)){
oCurRun.Add_ToContent(k + diffContentIndex, Item, false);
}
}
}
if(bIsAddTabAfter){
oCurRun.Add_ToContent(oCurRun.Content.length, new ParaTab(), false);
}
},
//***end special paste*** //***end special paste***
InsertInPlacePresentation: function(aNewContent) InsertInPlacePresentation: function(aNewContent)
...@@ -4429,7 +4382,7 @@ PasteProcessor.prototype = ...@@ -4429,7 +4382,7 @@ PasteProcessor.prototype =
var _charCode = text.charCodeAt(Index); var _charCode = text.charCodeAt(Index);
if(_charCode === 0x0A || Index === Count - 1){ if(_charCode === 0x0A || Index === Count - 1){
var newParaRun = new ParaRun(); var newParaRun = new ParaRun();
this._addTextIntoRun(newParaRun, insertText); addTextIntoRun(newParaRun, insertText);
newParagraph.Internal_Content_Add(newParagraph.Content.length - 1, newParaRun, false); newParagraph.Internal_Content_Add(newParagraph.Content.length - 1, newParaRun, false);
this.aContent.push(newParagraph); this.aContent.push(newParagraph);
...@@ -8652,6 +8605,54 @@ function Check_LoadingDataBeforePrepaste(_api, _fonts, _images, _callback) ...@@ -8652,6 +8605,54 @@ function Check_LoadingDataBeforePrepaste(_api, _fonts, _images, _callback)
_api.pre_Paste(aPrepeareFonts, _images, _callback); _api.pre_Paste(aPrepeareFonts, _images, _callback);
} }
function addTextIntoRun(oCurRun, value, bIsAddTabBefore, dNotAddLastSpace, bIsAddTabAfter)
{
var diffContentIndex = 0;
if(bIsAddTabBefore){
diffContentIndex = 1;
oCurRun.Add_ToContent(0, new ParaTab(), false);
}
for(var k = 0, length = value.length; k < length; k++)
{
var nUnicode = null;
var nCharCode = value.charCodeAt(k);
if (AscCommon.isLeadingSurrogateChar(nCharCode)) {
if (k + 1 < length) {
k++;
var nTrailingChar = value.charCodeAt(k);
nUnicode = AscCommon.decodeSurrogateChar(nCharCode, nTrailingChar);
}
}
else
nUnicode = nCharCode;
var bIsSpace = true;
if (null != nUnicode) {
var Item;
if (0x20 !== nUnicode && 0xA0 !== nUnicode && 0x2009 !== nUnicode) {
Item = new ParaText();
Item.Set_CharCode(nUnicode);
bIsSpace = false;
}
else if(0x2009 === nUnicode){
Item = new ParaTab();
}
else
Item = new ParaSpace();
//add text
if(!(dNotAddLastSpace && k === value.length - 1 && bIsSpace)){
oCurRun.Add_ToContent(k + diffContentIndex, Item, false);
}
}
}
if(bIsAddTabAfter){
oCurRun.Add_ToContent(oCurRun.Content.length, new ParaTab(), false);
}
}
function SpecialPasteShowOptions() function SpecialPasteShowOptions()
{ {
this.options = []; this.options = [];
...@@ -8680,6 +8681,8 @@ SpecialPasteShowOptions.prototype = { ...@@ -8680,6 +8681,8 @@ SpecialPasteShowOptions.prototype = {
window["AscCommon"].sendImgUrls = sendImgUrls; window["AscCommon"].sendImgUrls = sendImgUrls;
window["AscCommon"].PasteProcessor = PasteProcessor; window["AscCommon"].PasteProcessor = PasteProcessor;
window["AscCommon"].addTextIntoRun = addTextIntoRun;
window["AscCommon"].PasteElementsId = PasteElementsId; window["AscCommon"].PasteElementsId = PasteElementsId;
window["Asc"]["SpecialPasteShowOptions"] = window["Asc"].SpecialPasteShowOptions = SpecialPasteShowOptions; window["Asc"]["SpecialPasteShowOptions"] = window["Asc"].SpecialPasteShowOptions = SpecialPasteShowOptions;
......
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