Commit cef596e4 authored by Oleg.Korshul's avatar Oleg.Korshul Committed by Alexander.Trofimov

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@49595 954022d7-b5bf-4e40-9824-e11837661b57
parent 046c3bee
......@@ -22,6 +22,7 @@
}
window.USER_AGENT_SAFARI_MACOS = (navigator.userAgent.toLowerCase().indexOf('safari') > -1 && navigator.userAgent.toLowerCase().indexOf('mac') > -1) ? true : false;
window.GlobalPasteFlagCounter = 0;
var COPY_ELEMENT_ID = "SelectId";
var PASTE_ELEMENT_ID = "wrd_pastebin";
......@@ -1890,6 +1891,8 @@ function CanPaste(oDocument)
};
function Editor_Paste(api, bClean)
{
window.GlobalPasteFlagCounter = 1;
var oWordControl = api.WordControl;
oWordControl.bIsEventPaste = false;
var oDocument = oWordControl.m_oLogicDocument;
......@@ -1932,8 +1935,18 @@ function Editor_Paste(api, bClean)
}
}
//���� ���������� paste
window.setTimeout( function()
var func_timeout = function() {
if (window.USER_AGENT_SAFARI_MACOS)
{
if (window.GlobalPasteFlagCounter != 2)
{
window.setTimeout(func_timeout, 10);
return;
}
}
document.body.style.MozUserSelect = "none";
document.body.style["-khtml-user-select"] = "none";
document.body.style["-o-user-select"] = "none";
......@@ -1941,10 +1954,13 @@ function Editor_Paste(api, bClean)
document.body.style["-webkit-user-select"] = "none";
if(!oWordControl.bIsEventPaste)
{
Editor_Paste_Exec(api, pastebin);
}
else
pastebin.style.display = ELEMENT_DISPAY_STYLE;
}, 0 );
};
window.setTimeout( func_timeout, 0 );
};
function CopyPasteCorrectString(str)
{
......@@ -2301,6 +2317,8 @@ PasteProcessor.prototype =
this.oRecalcDocument.Recalculate();
this.oLogicDocument.Document_UpdateInterfaceState();
}
window.GlobalPasteFlagCounter = 0;
},
InsertInPlace : function(oDoc, aNewContent)
{
......@@ -4679,7 +4697,11 @@ function Editor_CopyPaste_Create(api)
ElemToSelect.onpaste = function(e){
//Editor_Paste(api, true);
if (window.GlobalPasteFlagCounter == 1)
{
Body_Paste(api,e);
window.GlobalPasteFlagCounter = 2;
}
};
var TIME_PREVIOS_ONBEFORE_EVENTS = new Date().getTime();
......
......@@ -525,6 +525,30 @@ function CFontInfo(sName, thumbnail, type, indexR, faceIndexR, indexI, faceIndex
return isNeed;
}
this.CheckFontLoadStylesNoLoad = function(global_loader)
{
var fonts = (FONT_TYPE_EMBEDDED == this.Type) ? global_loader.embeddedFontFiles : global_loader.fontFiles;
var _isNeed = false;
if ((-1 != this.indexR) && (fonts[this.indexR].CheckLoaded() === false))
{
_isNeed = true;
}
if ((-1 != this.indexI) && (fonts[this.indexI].CheckLoaded() === false))
{
_isNeed = true;
}
if ((-1 != this.indexB) && (fonts[this.indexB].CheckLoaded() === false))
{
_isNeed = true;
}
if ((-1 != this.indexBI) && (fonts[this.indexBI].CheckLoaded() === false))
{
_isNeed = true;
}
return _isNeed;
}
this.LoadFontsFromServer = function(global_loader)
{
var fonts = global_loader.fontFiles;
......
......@@ -329,6 +329,18 @@ var ASC_DOCS_API_USE_OPEN_SOURCE_FONTS_ONLY = false;
this._LoadFonts();
}
this.CheckFontsNeedLoading = function(_fonts)
{
for (var i in _fonts)
{
var info = this.fontInfos[this.map_font_index[_fonts[i].name]];
var _isNeed = info.CheckFontLoadStylesNoLoad(this);
if (_isNeed === true)
return true;
}
return false;
}
this.LoadDocumentFonts2 = function(_fonts)
{
// сначала заполняем массив this.fonts_loading объекстами fontinfo
......
......@@ -7762,7 +7762,22 @@ CDocument.prototype =
if ( false === this.Document_Is_SelectionLocked(changestype_Paragraph_Content) )
{
this.Create_NewHistoryPoint();
if (!window.USER_AGENT_SAFARI_MACOS)
{
Editor_Paste(this.DrawingDocument.m_oWordControl.m_oApi, true);
//не возвращаем true чтобы не было preventDefault
}
else
{
SafariIntervalFocus();
if (0 === window.GlobalPasteFlagCounter)
{
Editor_Paste(this.DrawingDocument.m_oWordControl.m_oApi, true);
//не возвращаем true чтобы не было preventDefault
}
}
}
//не возвращаем true чтобы не было preventDefault
}
......@@ -7994,10 +8009,23 @@ CDocument.prototype =
bRetValue = true;
}
else // Ctrl + V - paste
{
if (!window.USER_AGENT_SAFARI_MACOS)
{
Editor_Paste(this.DrawingDocument.m_oWordControl.m_oApi, true);
//не возвращаем true чтобы не было preventDefault
}
else
{
SafariIntervalFocus();
if (0 === window.GlobalPasteFlagCounter)
{
Editor_Paste(this.DrawingDocument.m_oWordControl.m_oApi, true);
//не возвращаем true чтобы не было preventDefault
}
}
}
}
}
else if ( e.KeyCode == 88 && false === editor.isViewMode && true === e.CtrlKey ) // Ctrl + X - cut
......
......@@ -6107,6 +6107,18 @@ asc_docs_api.prototype.pre_Paste = function(_fonts, _images, callback)
this.isPasteFonts_Images = true;
this.pasteCallback = callback;
this.pasteImageMap = _images;
var _count = 0;
for (var i in this.pasteImageMap)
++_count;
if (0 == _count && false === this.FontLoader.CheckFontsNeedLoading(_fonts))
{
// никаких евентов. ничего грузить не нужно. сделано для сафари под макОс.
// там при LongActions теряется фокус и вставляются пробелы
this.pasteCallback();
return;
}
this.FontLoader.LoadDocumentFonts2(_fonts);
}
......
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