TinyMCE: update to 4.0.28. Also includes 43fff5b453. Part-props avryl for the patch on #27941, fixes #28391, #27941.

Built from https://develop.svn.wordpress.org/trunk@28606


git-svn-id: http://core.svn.wordpress.org/trunk@28430 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Andrew Ozz 2014-05-29 00:59:15 +00:00
parent fa38396998
commit c4243e53d0
11 changed files with 130 additions and 80 deletions

View File

@ -98,17 +98,25 @@ tinymce.PluginManager.add('image', function(editor) {
} }
function buildImageList() { function buildImageList() {
var imageListItems = [{text: 'None', value: ''}]; function appendItems(values, output) {
output = output || [];
tinymce.each(imageList, function(image) { tinymce.each(values, function(value) {
imageListItems.push({ var item = {text: value.text || value.title};
text: image.text || image.title,
value: editor.convertURL(image.value || image.url, 'src'), if (value.menu) {
menu: image.menu item.menu = appendItems(value.menu);
} else {
item.value = editor.convertURL(value.value || value.url, 'src');
}
output.push(item);
}); });
});
return imageListItems; return output;
}
return appendItems(imageList, [{text: 'None', value: ''}]);
} }
function recalcSize() { function recalcSize() {
@ -284,7 +292,7 @@ tinymce.PluginManager.add('image', function(editor) {
altCtrl.value(e.control.text()); altCtrl.value(e.control.text());
} }
win.find('#src').value(e.control.value()); win.find('#src').value(e.control.value()).fire('change');
}, },
onPostRender: function() { onPostRender: function() {
imageListCtrl = this; imageListCtrl = this;

File diff suppressed because one or more lines are too long

View File

@ -175,9 +175,27 @@ define("tinymce/pasteplugin/Utils", [
return text; return text;
} }
/**
* Trims the specified HTML by removing all WebKit fragments, all elements wrapping the body trailing BR elements etc.
*
* @param {String} html Html string to trim contents on.
* @return {String} Html contents that got trimmed.
*/
function trimHtml(html) {
html = filter(html, [
/^[\s\S]*<body[^>]*>\s*|\s*<\/body[^>]*>[\s\S]*$/g, // Remove anything but the contents within the BODY element
/<!--StartFragment-->|<!--EndFragment-->/g, // Inner fragments (tables from excel on mac)
[/<span class="Apple-converted-space">\u00a0<\/span>/g, '\u00a0'], // WebKit &nbsp;
/<br>$/i // Trailing BR elements
]);
return html;
}
return { return {
filter: filter, filter: filter,
innerText: innerText innerText: innerText,
trimHtml: trimHtml
}; };
}); });
@ -248,7 +266,7 @@ define("tinymce/pasteplugin/Clipboard", [
} }
if (!args.isDefaultPrevented()) { if (!args.isDefaultPrevented()) {
editor.insertContent(html); editor.insertContent(html, {merge: editor.settings.paste_merge_formats !== false});
} }
} }
} }
@ -382,7 +400,6 @@ define("tinymce/pasteplugin/Clipboard", [
} }
} }
keyboardPastePlainTextState = false;
pasteBinElm = lastRng = null; pasteBinElm = lastRng = null;
} }
@ -492,6 +509,18 @@ define("tinymce/pasteplugin/Clipboard", [
} }
} }
/**
* Chrome on Andoid doesn't support proper clipboard access so we have no choice but to allow the browser default behavior.
*
* @param {Event} e Paste event object to check if it contains any data.
* @return {Boolean} true/false if the clipboard is empty or not.
*/
function isBrokenAndoidClipboardEvent(e) {
var clipboardData = e.clipboardData;
return navigator.userAgent.indexOf('Android') != -1 && clipboardData && clipboardData.items && clipboardData.items.length === 0;
}
function getCaretRangeFromEvent(e) { function getCaretRangeFromEvent(e) {
var doc = editor.getDoc(), rng; var doc = editor.getDoc(), rng;
@ -511,16 +540,22 @@ define("tinymce/pasteplugin/Clipboard", [
return mimeType in clipboardContent && clipboardContent[mimeType].length > 0; return mimeType in clipboardContent && clipboardContent[mimeType].length > 0;
} }
function isKeyboardPasteEvent(e) {
return (VK.metaKeyPressed(e) && e.keyCode == 86) || (e.shiftKey && e.keyCode == 45);
}
function registerEventHandlers() { function registerEventHandlers() {
editor.on('keydown', function(e) { editor.on('keydown', function(e) {
if (e.isDefaultPrevented()) {
return;
}
// Ctrl+V or Shift+Insert // Ctrl+V or Shift+Insert
if ((VK.metaKeyPressed(e) && e.keyCode == 86) || (e.shiftKey && e.keyCode == 45)) { if (isKeyboardPasteEvent(e) && !e.isDefaultPrevented()) {
keyboardPastePlainTextState = e.shiftKey && e.keyCode == 86; keyboardPastePlainTextState = e.shiftKey && e.keyCode == 86;
// Edge case on Safari on Mac where it doesn't handle Cmd+Shift+V correctly
// it fires the keydown but no paste or keyup so we are left with a paste bin
if (keyboardPastePlainTextState && Env.webkit && navigator.userAgent.indexOf('Version/') != -1) {
return;
}
// Prevent undoManager keydown handler from making an undo level with the pastebin in it // Prevent undoManager keydown handler from making an undo level with the pastebin in it
e.stopImmediatePropagation(); e.stopImmediatePropagation();
@ -539,12 +574,21 @@ define("tinymce/pasteplugin/Clipboard", [
} }
}); });
editor.on('keyup', function(e) {
// Ctrl+V or Shift+Insert
if (isKeyboardPasteEvent(e) && !e.isDefaultPrevented()) {
removePasteBin();
}
});
editor.on('paste', function(e) { editor.on('paste', function(e) {
var clipboardContent = getClipboardContent(e); var clipboardContent = getClipboardContent(e);
var isKeyBoardPaste = new Date().getTime() - keyboardPasteTimeStamp < 1000; var isKeyBoardPaste = new Date().getTime() - keyboardPasteTimeStamp < 1000;
var plainTextMode = self.pasteFormat == "text" || keyboardPastePlainTextState; var plainTextMode = self.pasteFormat == "text" || keyboardPastePlainTextState;
if (e.isDefaultPrevented()) { keyboardPastePlainTextState = false;
if (e.isDefaultPrevented() || isBrokenAndoidClipboardEvent(e)) {
removePasteBin(); removePasteBin();
return; return;
} }
@ -572,41 +616,56 @@ define("tinymce/pasteplugin/Clipboard", [
} }
setTimeout(function() { setTimeout(function() {
var html = getPasteBinHtml(); var content;
// Grab HTML from Clipboard API or paste bin as a fallback
if (hasContentType(clipboardContent, 'text/html')) {
content = clipboardContent['text/html'];
} else {
content = getPasteBinHtml();
// If paste bin is empty try using plain text mode
// since that is better than nothing right
if (content == pasteBinDefaultContent) {
plainTextMode = true;
}
}
content = Utils.trimHtml(getPasteBinHtml());
// WebKit has a nice bug where it clones the paste bin if you paste from for example notepad // WebKit has a nice bug where it clones the paste bin if you paste from for example notepad
// so we need to force plain text mode in this case
if (pasteBinElm && pasteBinElm.firstChild && pasteBinElm.firstChild.id === 'mcepastebin') { if (pasteBinElm && pasteBinElm.firstChild && pasteBinElm.firstChild.id === 'mcepastebin') {
plainTextMode = true; plainTextMode = true;
} }
removePasteBin(); removePasteBin();
// Always use pastebin HTML if it's available since it contains Word contents // Grab plain text from Clipboard API or convert existing HTML to plain text
if (!plainTextMode && isKeyBoardPaste && html && html != pasteBinDefaultContent) { if (plainTextMode) {
clipboardContent['text/html'] = html; // Use plain text contents from Clipboard API unless the HTML contains paragraphs then
} // we should convert the HTML to plain text since works better when pasting HTML/Word contents as plain text
if (hasContentType(clipboardContent, 'text/plain') && content.indexOf('</p>') == -1) {
if (html == pasteBinDefaultContent || !isKeyBoardPaste) { content = clipboardContent['text/plain'];
html = clipboardContent['text/html'] || clipboardContent['text/plain'] || pasteBinDefaultContent; } else {
content = Utils.innerText(content);
if (html == pasteBinDefaultContent) {
if (!isKeyBoardPaste) {
editor.windowManager.alert('Please use Ctrl+V/Cmd+V keyboard shortcuts to paste contents.');
}
return;
} }
} }
// Force plain text mode if we only got a text/plain content type // If the content is the paste bin default HTML then it was
if (!hasContentType(clipboardContent, 'text/html') && hasContentType(clipboardContent, 'text/plain')) { // impossible to get the cliboard data out.
plainTextMode = true; if (content == pasteBinDefaultContent) {
if (!isKeyBoardPaste) {
editor.windowManager.alert('Please use Ctrl+V/Cmd+V keyboard shortcuts to paste contents.');
}
return;
} }
if (plainTextMode) { if (plainTextMode) {
pasteText(clipboardContent['text/plain'] || Utils.innerText(html)); pasteText(content);
} else { } else {
pasteHtml(html); pasteHtml(content);
} }
}, 0); }, 0);
}); });
@ -673,9 +732,12 @@ define("tinymce/pasteplugin/Clipboard", [
}); });
}); });
// Fix for #6504 we need to remove the paste bin on IE if the user paste in a file editor.on('BeforeAddUndo', function(e) {
editor.on('PreProcess', function() { // Remove pastebin HTML incase it should be added to an undo
editor.dom.remove(editor.dom.get('mcepastebin')); // level for example when you paste a file on older IE
if (e.level.content) {
e.level.content = e.level.content.replace(/<div id="?mcepastebin"?[^>]+>%MCEPASTEBIN%<\/div>/gi, '');
}
}); });
}; };
}); });
@ -1104,26 +1166,6 @@ define("tinymce/pasteplugin/Quirks", [
}); });
} }
/**
* Removes WebKit fragment comments and converted-space spans.
*
* This:
* <!--StartFragment-->a<span class="Apple-converted-space">&nbsp;</span>b<!--EndFragment-->
*
* Becomes:
* a&nbsp;b
*/
function removeWebKitFragments(html) {
html = Utils.filter(html, [
/^[\s\S]*<body[^>]*>\s*<!--StartFragment-->|<!--EndFragment-->\s*<\/body[^>]*>[\s\S]*$/g, // WebKit fragment body
/<!--StartFragment-->|<!--EndFragment-->/g, // Inner fragments (tables from excel on mac)
[/<span class="Apple-converted-space">\u00a0<\/span>/g, '\u00a0'], // WebKit &nbsp;
/<br>$/i // Traling BR elements
]);
return html;
}
/** /**
* Removes BR elements after block elements. IE9 has a nasty bug where it puts a BR element after each * Removes BR elements after block elements. IE9 has a nasty bug where it puts a BR element after each
* block element when pasting from word. This removes those elements. * block element when pasting from word. This removes those elements.
@ -1243,7 +1285,6 @@ define("tinymce/pasteplugin/Quirks", [
// Sniff browsers and apply fixes since we can't feature detect // Sniff browsers and apply fixes since we can't feature detect
if (Env.webkit) { if (Env.webkit) {
addPreProcessFilter(removeWebKitStyles); addPreProcessFilter(removeWebKitStyles);
addPreProcessFilter(removeWebKitFragments);
} }
if (Env.ie) { if (Env.ie) {

File diff suppressed because one or more lines are too long

View File

@ -342,7 +342,7 @@ tinymce.PluginManager.add( 'wordpress', function( editor ) {
editor.on( 'SaveContent', function( e ) { editor.on( 'SaveContent', function( e ) {
// If editor is hidden, we just want the textarea's value to be saved // If editor is hidden, we just want the textarea's value to be saved
if ( ! editor.inline && ! tinymce.DOM.isHidden( editor.id ) ) { if ( ! editor.inline && editor.isHidden() ) {
e.content = e.element.value; e.content = e.element.value;
return; return;
} }

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -18,7 +18,7 @@ $wp_db_version = 27916;
* *
* @global string $tinymce_version * @global string $tinymce_version
*/ */
$tinymce_version = '4026-20140523'; $tinymce_version = '4028-20140528';
/** /**
* Holds the required PHP version * Holds the required PHP version