TinyMCE: update to 4.6.7, changelog: https://www.tinymce.com/docs/changelog/#version467september182017.
Fixes #41996 #40956 Built from https://develop.svn.wordpress.org/trunk@41604 git-svn-id: http://core.svn.wordpress.org/trunk@41439 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
cb8173e053
commit
b32256701a
|
@ -81,7 +81,7 @@ var defineGlobal = function (id, ref) {
|
||||||
define(id, [], function () { return ref; });
|
define(id, [], function () { return ref; });
|
||||||
};
|
};
|
||||||
/*jsc
|
/*jsc
|
||||||
["tinymce.plugins.image.Plugin","tinymce.core.Env","tinymce.core.PluginManager","tinymce.core.util.JSON","tinymce.core.util.Tools","tinymce.core.util.XHR","global!tinymce.util.Tools.resolve"]
|
["tinymce.plugins.image.Plugin","tinymce.core.PluginManager","tinymce.core.util.Tools","tinymce.plugins.image.ui.Dialog","global!tinymce.util.Tools.resolve","global!document","global!Math","global!RegExp","tinymce.core.Env","tinymce.core.ui.Factory","tinymce.core.util.JSON","tinymce.core.util.XHR","tinymce.plugins.image.core.Uploader","tinymce.plugins.image.core.Utils","tinymce.core.util.Promise"]
|
||||||
jsc*/
|
jsc*/
|
||||||
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
/**
|
/**
|
||||||
|
@ -94,6 +94,49 @@ defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
'tinymce.core.PluginManager',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.PluginManager');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ResolveGlobal.js
|
||||||
|
*
|
||||||
|
* Released under LGPL License.
|
||||||
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
|
*
|
||||||
|
* License: http://www.tinymce.com/license
|
||||||
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
|
*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
'tinymce.core.util.Tools',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.util.Tools');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
defineGlobal("global!document", document);
|
||||||
|
defineGlobal("global!Math", Math);
|
||||||
|
defineGlobal("global!RegExp", RegExp);
|
||||||
|
/**
|
||||||
|
* ResolveGlobal.js
|
||||||
|
*
|
||||||
|
* Released under LGPL License.
|
||||||
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
|
*
|
||||||
|
* License: http://www.tinymce.com/license
|
||||||
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
|
*/
|
||||||
|
|
||||||
define(
|
define(
|
||||||
'tinymce.core.Env',
|
'tinymce.core.Env',
|
||||||
[
|
[
|
||||||
|
@ -115,12 +158,12 @@ define(
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define(
|
define(
|
||||||
'tinymce.core.PluginManager',
|
'tinymce.core.ui.Factory',
|
||||||
[
|
[
|
||||||
'global!tinymce.util.Tools.resolve'
|
'global!tinymce.util.Tools.resolve'
|
||||||
],
|
],
|
||||||
function (resolve) {
|
function (resolve) {
|
||||||
return resolve('tinymce.PluginManager');
|
return resolve('tinymce.ui.Factory');
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -155,12 +198,12 @@ define(
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define(
|
define(
|
||||||
'tinymce.core.util.Tools',
|
'tinymce.core.util.XHR',
|
||||||
[
|
[
|
||||||
'global!tinymce.util.Tools.resolve'
|
'global!tinymce.util.Tools.resolve'
|
||||||
],
|
],
|
||||||
function (resolve) {
|
function (resolve) {
|
||||||
return resolve('tinymce.util.Tools');
|
return resolve('tinymce.util.XHR');
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -175,17 +218,17 @@ define(
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define(
|
define(
|
||||||
'tinymce.core.util.XHR',
|
'tinymce.core.util.Promise',
|
||||||
[
|
[
|
||||||
'global!tinymce.util.Tools.resolve'
|
'global!tinymce.util.Tools.resolve'
|
||||||
],
|
],
|
||||||
function (resolve) {
|
function (resolve) {
|
||||||
return resolve('tinymce.util.XHR');
|
return resolve('tinymce.util.Promise');
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Plugin.js
|
* Uploader.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
|
@ -195,23 +238,123 @@ define(
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class contains all core logic for the image plugin.
|
* This is basically cut down version of tinymce.core.file.Uploader, which we could use directly
|
||||||
|
* if it wasn't marked as private.
|
||||||
*
|
*
|
||||||
* @class tinymce.image.Plugin
|
* @class tinymce.image.core.Uploader
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
define(
|
define(
|
||||||
'tinymce.plugins.image.Plugin',
|
'tinymce.plugins.image.core.Uploader',
|
||||||
[
|
[
|
||||||
'tinymce.core.Env',
|
'tinymce.core.util.Promise',
|
||||||
'tinymce.core.PluginManager',
|
|
||||||
'tinymce.core.util.JSON',
|
|
||||||
'tinymce.core.util.Tools',
|
'tinymce.core.util.Tools',
|
||||||
'tinymce.core.util.XHR'
|
'global!document'
|
||||||
],
|
],
|
||||||
function (Env, PluginManager, JSON, Tools, XHR) {
|
function (Promise, Tools, document) {
|
||||||
PluginManager.add('image', function (editor) {
|
return function (settings) {
|
||||||
function getImageSize(url, callback) {
|
var noop = function () {};
|
||||||
|
|
||||||
|
function pathJoin(path1, path2) {
|
||||||
|
if (path1) {
|
||||||
|
return path1.replace(/\/$/, '') + '/' + path2.replace(/^\//, '');
|
||||||
|
}
|
||||||
|
|
||||||
|
return path2;
|
||||||
|
}
|
||||||
|
|
||||||
|
function defaultHandler(blobInfo, success, failure, progress) {
|
||||||
|
var xhr, formData;
|
||||||
|
|
||||||
|
xhr = new XMLHttpRequest();
|
||||||
|
xhr.open('POST', settings.url);
|
||||||
|
xhr.withCredentials = settings.credentials;
|
||||||
|
|
||||||
|
xhr.upload.onprogress = function (e) {
|
||||||
|
progress(e.loaded / e.total * 100);
|
||||||
|
};
|
||||||
|
|
||||||
|
xhr.onerror = function () {
|
||||||
|
failure("Image upload failed due to a XHR Transport error. Code: " + xhr.status);
|
||||||
|
};
|
||||||
|
|
||||||
|
xhr.onload = function () {
|
||||||
|
var json;
|
||||||
|
|
||||||
|
if (xhr.status < 200 || xhr.status >= 300) {
|
||||||
|
failure("HTTP Error: " + xhr.status);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
json = JSON.parse(xhr.responseText);
|
||||||
|
|
||||||
|
if (!json || typeof json.location != "string") {
|
||||||
|
failure("Invalid JSON: " + xhr.responseText);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
success(pathJoin(settings.basePath, json.location));
|
||||||
|
};
|
||||||
|
|
||||||
|
formData = new FormData();
|
||||||
|
formData.append('file', blobInfo.blob(), blobInfo.filename());
|
||||||
|
|
||||||
|
xhr.send(formData);
|
||||||
|
}
|
||||||
|
|
||||||
|
function uploadBlob(blobInfo, handler) {
|
||||||
|
return new Promise(function (resolve, reject) {
|
||||||
|
try {
|
||||||
|
handler(blobInfo, resolve, reject, noop);
|
||||||
|
} catch (ex) {
|
||||||
|
reject(ex.message);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function isDefaultHandler(handler) {
|
||||||
|
return handler === defaultHandler;
|
||||||
|
}
|
||||||
|
|
||||||
|
function upload(blobInfo) {
|
||||||
|
return (!settings.url && isDefaultHandler(settings.handler)) ? Promise.reject("Upload url missng from the settings.") : uploadBlob(blobInfo, settings.handler);
|
||||||
|
}
|
||||||
|
|
||||||
|
settings = Tools.extend({
|
||||||
|
credentials: false,
|
||||||
|
handler: defaultHandler
|
||||||
|
}, settings);
|
||||||
|
|
||||||
|
return {
|
||||||
|
upload: upload
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
/**
|
||||||
|
* Utils.js
|
||||||
|
*
|
||||||
|
* Released under LGPL License.
|
||||||
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
|
*
|
||||||
|
* License: http://www.tinymce.com/license
|
||||||
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @class tinymce.image.core.Utils
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
'tinymce.plugins.image.core.Utils',
|
||||||
|
[
|
||||||
|
'tinymce.core.util.Tools',
|
||||||
|
'global!Math',
|
||||||
|
'global!document'
|
||||||
|
],
|
||||||
|
function (Tools, Math, document) {
|
||||||
|
|
||||||
|
var getImageSize = function (url, callback) {
|
||||||
var img = document.createElement('img');
|
var img = document.createElement('img');
|
||||||
|
|
||||||
function done(width, height) {
|
function done(width, height) {
|
||||||
|
@ -238,9 +381,10 @@ define(
|
||||||
|
|
||||||
document.body.appendChild(img);
|
document.body.appendChild(img);
|
||||||
img.src = url;
|
img.src = url;
|
||||||
}
|
};
|
||||||
|
|
||||||
function buildListItems(inputList, itemCallback, startItems) {
|
|
||||||
|
var buildListItems = function (inputList, itemCallback, startItems) {
|
||||||
function appendItems(values, output) {
|
function appendItems(values, output) {
|
||||||
output = output || [];
|
output = output || [];
|
||||||
|
|
||||||
|
@ -261,10 +405,99 @@ define(
|
||||||
}
|
}
|
||||||
|
|
||||||
return appendItems(inputList, startItems || []);
|
return appendItems(inputList, startItems || []);
|
||||||
}
|
};
|
||||||
|
|
||||||
|
var removePixelSuffix = function (value) {
|
||||||
|
if (value) {
|
||||||
|
value = value.replace(/px$/, '');
|
||||||
|
}
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
|
||||||
|
var addPixelSuffix = function (value) {
|
||||||
|
if (value.length > 0 && /^[0-9]+$/.test(value)) {
|
||||||
|
value += 'px';
|
||||||
|
}
|
||||||
|
return value;
|
||||||
|
};
|
||||||
|
|
||||||
|
var mergeMargins = function (css) {
|
||||||
|
if (css.margin) {
|
||||||
|
|
||||||
|
var splitMargin = css.margin.split(" ");
|
||||||
|
|
||||||
|
switch (splitMargin.length) {
|
||||||
|
case 1: //margin: toprightbottomleft;
|
||||||
|
css['margin-top'] = css['margin-top'] || splitMargin[0];
|
||||||
|
css['margin-right'] = css['margin-right'] || splitMargin[0];
|
||||||
|
css['margin-bottom'] = css['margin-bottom'] || splitMargin[0];
|
||||||
|
css['margin-left'] = css['margin-left'] || splitMargin[0];
|
||||||
|
break;
|
||||||
|
case 2: //margin: topbottom rightleft;
|
||||||
|
css['margin-top'] = css['margin-top'] || splitMargin[0];
|
||||||
|
css['margin-right'] = css['margin-right'] || splitMargin[1];
|
||||||
|
css['margin-bottom'] = css['margin-bottom'] || splitMargin[0];
|
||||||
|
css['margin-left'] = css['margin-left'] || splitMargin[1];
|
||||||
|
break;
|
||||||
|
case 3: //margin: top rightleft bottom;
|
||||||
|
css['margin-top'] = css['margin-top'] || splitMargin[0];
|
||||||
|
css['margin-right'] = css['margin-right'] || splitMargin[1];
|
||||||
|
css['margin-bottom'] = css['margin-bottom'] || splitMargin[2];
|
||||||
|
css['margin-left'] = css['margin-left'] || splitMargin[1];
|
||||||
|
break;
|
||||||
|
case 4: //margin: top right bottom left;
|
||||||
|
css['margin-top'] = css['margin-top'] || splitMargin[0];
|
||||||
|
css['margin-right'] = css['margin-right'] || splitMargin[1];
|
||||||
|
css['margin-bottom'] = css['margin-bottom'] || splitMargin[2];
|
||||||
|
css['margin-left'] = css['margin-left'] || splitMargin[3];
|
||||||
|
}
|
||||||
|
delete css.margin;
|
||||||
|
}
|
||||||
|
return css;
|
||||||
|
};
|
||||||
|
|
||||||
|
return {
|
||||||
|
getImageSize: getImageSize,
|
||||||
|
buildListItems: buildListItems,
|
||||||
|
removePixelSuffix: removePixelSuffix,
|
||||||
|
addPixelSuffix: addPixelSuffix,
|
||||||
|
mergeMargins: mergeMargins
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Dialog.js
|
||||||
|
*
|
||||||
|
* Released under LGPL License.
|
||||||
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
|
*
|
||||||
|
* License: http://www.tinymce.com/license
|
||||||
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @class tinymce.image.ui.Dialog
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
'tinymce.plugins.image.ui.Dialog',
|
||||||
|
[
|
||||||
|
'global!document',
|
||||||
|
'global!Math',
|
||||||
|
'global!RegExp',
|
||||||
|
'tinymce.core.Env',
|
||||||
|
'tinymce.core.ui.Factory',
|
||||||
|
'tinymce.core.util.JSON',
|
||||||
|
'tinymce.core.util.Tools',
|
||||||
|
'tinymce.core.util.XHR',
|
||||||
|
'tinymce.plugins.image.core.Uploader',
|
||||||
|
'tinymce.plugins.image.core.Utils'
|
||||||
|
],
|
||||||
|
function (document, Math, RegExp, Env, Factory, JSON, Tools, XHR, Uploader, Utils) {
|
||||||
|
|
||||||
|
return function (editor) {
|
||||||
function createImageList(callback) {
|
function createImageList(callback) {
|
||||||
return function () {
|
|
||||||
var imageList = editor.settings.image_list;
|
var imageList = editor.settings.image_list;
|
||||||
|
|
||||||
if (typeof imageList == "string") {
|
if (typeof imageList == "string") {
|
||||||
|
@ -279,12 +512,55 @@ define(
|
||||||
} else {
|
} else {
|
||||||
callback(imageList);
|
callback(imageList);
|
||||||
}
|
}
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function showDialog(imageList) {
|
function showDialog(imageList) {
|
||||||
var win, data = {}, dom = editor.dom, imgElm, figureElm;
|
var win, data = {}, imgElm, figureElm, dom = editor.dom, settings = editor.settings;
|
||||||
var width, height, imageListCtrl, classListCtrl, imageDimensions = editor.settings.image_dimensions !== false;
|
var width, height, imageListCtrl, classListCtrl, imageDimensions = settings.image_dimensions !== false;
|
||||||
|
|
||||||
|
|
||||||
|
function onFileInput() {
|
||||||
|
var Throbber = Factory.get('Throbber');
|
||||||
|
var throbber = new Throbber(win.getEl());
|
||||||
|
var file = this.value();
|
||||||
|
|
||||||
|
var uploader = new Uploader({
|
||||||
|
url: settings.images_upload_url,
|
||||||
|
basePath: settings.images_upload_base_path,
|
||||||
|
credentials: settings.images_upload_credentials,
|
||||||
|
handler: settings.images_upload_handler
|
||||||
|
});
|
||||||
|
|
||||||
|
// we do not need to add this to editors blobCache, so we fake bare minimum
|
||||||
|
var blobInfo = editor.editorUpload.blobCache.create({
|
||||||
|
blob: file,
|
||||||
|
name: file.name ? file.name.replace(/\.[^\.]+$/, '') : null, // strip extension
|
||||||
|
base64: '' // without this create() will throw exception
|
||||||
|
});
|
||||||
|
|
||||||
|
var finalize = function () {
|
||||||
|
throbber.hide();
|
||||||
|
URL.revokeObjectURL(blobInfo.blobUri()); // in theory we could fake blobUri too, but until it's legitimate, we have too revoke it manually
|
||||||
|
};
|
||||||
|
|
||||||
|
throbber.show();
|
||||||
|
|
||||||
|
return uploader.upload(blobInfo).then(function (url) {
|
||||||
|
var src = win.find('#src');
|
||||||
|
src.value(url);
|
||||||
|
win.find('tabpanel')[0].activateTab(0); // switch to General tab
|
||||||
|
src.fire('change'); // this will invoke onSrcChange (and any other handlers, if any).
|
||||||
|
finalize();
|
||||||
|
return url;
|
||||||
|
}, function (err) {
|
||||||
|
editor.windowManager.alert(err);
|
||||||
|
finalize();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function isTextBlock(node) {
|
||||||
|
return editor.schema.getTextBlockElements()[node.nodeName];
|
||||||
|
}
|
||||||
|
|
||||||
function recalcSize() {
|
function recalcSize() {
|
||||||
var widthCtrl, heightCtrl, newWidth, newHeight;
|
var widthCtrl, heightCtrl, newWidth, newHeight;
|
||||||
|
@ -319,8 +595,63 @@ define(
|
||||||
height = newHeight;
|
height = newHeight;
|
||||||
}
|
}
|
||||||
|
|
||||||
function onSubmitForm() {
|
function updateStyle() {
|
||||||
var figureElm, oldImg;
|
if (!editor.settings.image_advtab) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var data = win.toJSON(),
|
||||||
|
css = dom.parseStyle(data.style);
|
||||||
|
|
||||||
|
css = Utils.mergeMargins(css);
|
||||||
|
|
||||||
|
if (data.vspace) {
|
||||||
|
css['margin-top'] = css['margin-bottom'] = Utils.addPixelSuffix(data.vspace);
|
||||||
|
}
|
||||||
|
if (data.hspace) {
|
||||||
|
css['margin-left'] = css['margin-right'] = Utils.addPixelSuffix(data.hspace);
|
||||||
|
}
|
||||||
|
if (data.border) {
|
||||||
|
css['border-width'] = Utils.addPixelSuffix(data.border);
|
||||||
|
}
|
||||||
|
|
||||||
|
win.find('#style').value(dom.serializeStyle(dom.parseStyle(dom.serializeStyle(css))));
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateVSpaceHSpaceBorder() {
|
||||||
|
if (!editor.settings.image_advtab) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var data = win.toJSON(),
|
||||||
|
css = dom.parseStyle(data.style);
|
||||||
|
|
||||||
|
win.find('#vspace').value("");
|
||||||
|
win.find('#hspace').value("");
|
||||||
|
|
||||||
|
css = Utils.mergeMargins(css);
|
||||||
|
|
||||||
|
//Move opposite equal margins to vspace/hspace field
|
||||||
|
if ((css['margin-top'] && css['margin-bottom']) || (css['margin-right'] && css['margin-left'])) {
|
||||||
|
if (css['margin-top'] === css['margin-bottom']) {
|
||||||
|
win.find('#vspace').value(Utils.removePixelSuffix(css['margin-top']));
|
||||||
|
} else {
|
||||||
|
win.find('#vspace').value('');
|
||||||
|
}
|
||||||
|
if (css['margin-right'] === css['margin-left']) {
|
||||||
|
win.find('#hspace').value(Utils.removePixelSuffix(css['margin-right']));
|
||||||
|
} else {
|
||||||
|
win.find('#hspace').value('');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Move border-width
|
||||||
|
if (css['border-width']) {
|
||||||
|
win.find('#border').value(Utils.removePixelSuffix(css['border-width']));
|
||||||
|
}
|
||||||
|
|
||||||
|
win.find('#style').value(dom.serializeStyle(dom.parseStyle(dom.serializeStyle(css))));
|
||||||
|
}
|
||||||
|
|
||||||
function waitLoad(imgElm) {
|
function waitLoad(imgElm) {
|
||||||
function selectImage() {
|
function selectImage() {
|
||||||
|
@ -346,6 +677,9 @@ define(
|
||||||
imgElm.onerror = selectImage;
|
imgElm.onerror = selectImage;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function onSubmitForm() {
|
||||||
|
var figureElm, oldImg;
|
||||||
|
|
||||||
updateStyle();
|
updateStyle();
|
||||||
recalcSize();
|
recalcSize();
|
||||||
|
|
||||||
|
@ -387,9 +721,15 @@ define(
|
||||||
editor.undoManager.transact(function () {
|
editor.undoManager.transact(function () {
|
||||||
if (!data.src) {
|
if (!data.src) {
|
||||||
if (imgElm) {
|
if (imgElm) {
|
||||||
dom.remove(imgElm);
|
var elm = dom.is(imgElm.parentNode, 'figure.image') ? imgElm.parentNode : imgElm;
|
||||||
|
dom.remove(elm);
|
||||||
editor.focus();
|
editor.focus();
|
||||||
editor.nodeChanged();
|
editor.nodeChanged();
|
||||||
|
|
||||||
|
if (dom.isEmpty(editor.getBody())) {
|
||||||
|
editor.setContent('');
|
||||||
|
editor.selection.setCursorLocation();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
return;
|
||||||
|
@ -414,19 +754,19 @@ define(
|
||||||
if (data.caption === false) {
|
if (data.caption === false) {
|
||||||
if (dom.is(imgElm.parentNode, 'figure.image')) {
|
if (dom.is(imgElm.parentNode, 'figure.image')) {
|
||||||
figureElm = imgElm.parentNode;
|
figureElm = imgElm.parentNode;
|
||||||
|
dom.setAttrib(imgElm, 'contenteditable', null);
|
||||||
dom.insertAfter(imgElm, figureElm);
|
dom.insertAfter(imgElm, figureElm);
|
||||||
dom.remove(figureElm);
|
dom.remove(figureElm);
|
||||||
|
editor.selection.select(imgElm);
|
||||||
|
editor.nodeChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function isTextBlock(node) {
|
|
||||||
return editor.schema.getTextBlockElements()[node.nodeName];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (data.caption === true) {
|
if (data.caption === true) {
|
||||||
if (!dom.is(imgElm.parentNode, 'figure.image')) {
|
if (!dom.is(imgElm.parentNode, 'figure.image')) {
|
||||||
oldImg = imgElm;
|
oldImg = imgElm;
|
||||||
imgElm = imgElm.cloneNode(true);
|
imgElm = imgElm.cloneNode(true);
|
||||||
|
imgElm.contentEditable = true;
|
||||||
figureElm = dom.create('figure', { 'class': 'image' });
|
figureElm = dom.create('figure', { 'class': 'image' });
|
||||||
figureElm.appendChild(imgElm);
|
figureElm.appendChild(imgElm);
|
||||||
figureElm.appendChild(dom.create('figcaption', { contentEditable: true }, 'Caption'));
|
figureElm.appendChild(dom.create('figcaption', { contentEditable: true }, 'Caption'));
|
||||||
|
@ -449,15 +789,7 @@ define(
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function removePixelSuffix(value) {
|
function onSrcChange(e) {
|
||||||
if (value) {
|
|
||||||
value = value.replace(/px$/, '');
|
|
||||||
}
|
|
||||||
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
function srcChange(e) {
|
|
||||||
var srcURL, prependURL, absoluteURLPattern, meta = e.meta || {};
|
var srcURL, prependURL, absoluteURLPattern, meta = e.meta || {};
|
||||||
|
|
||||||
if (imageListCtrl) {
|
if (imageListCtrl) {
|
||||||
|
@ -480,7 +812,7 @@ define(
|
||||||
|
|
||||||
this.value(srcURL);
|
this.value(srcURL);
|
||||||
|
|
||||||
getImageSize(editor.documentBaseURI.toAbsolute(this.value()), function (data) {
|
Utils.getImageSize(editor.documentBaseURI.toAbsolute(this.value()), function (data) {
|
||||||
if (data.width && data.height && imageDimensions) {
|
if (data.width && data.height && imageDimensions) {
|
||||||
width = data.width;
|
width = data.width;
|
||||||
height = data.height;
|
height = data.height;
|
||||||
|
@ -528,7 +860,7 @@ define(
|
||||||
imageListCtrl = {
|
imageListCtrl = {
|
||||||
type: 'listbox',
|
type: 'listbox',
|
||||||
label: 'Image list',
|
label: 'Image list',
|
||||||
values: buildListItems(
|
values: Utils.buildListItems(
|
||||||
imageList,
|
imageList,
|
||||||
function (item) {
|
function (item) {
|
||||||
item.value = editor.convertURL(item.value || item.url, 'src');
|
item.value = editor.convertURL(item.value || item.url, 'src');
|
||||||
|
@ -557,7 +889,7 @@ define(
|
||||||
name: 'class',
|
name: 'class',
|
||||||
type: 'listbox',
|
type: 'listbox',
|
||||||
label: 'Class',
|
label: 'Class',
|
||||||
values: buildListItems(
|
values: Utils.buildListItems(
|
||||||
editor.settings.image_class_list,
|
editor.settings.image_class_list,
|
||||||
function (item) {
|
function (item) {
|
||||||
if (item.value) {
|
if (item.value) {
|
||||||
|
@ -578,7 +910,7 @@ define(
|
||||||
filetype: 'image',
|
filetype: 'image',
|
||||||
label: 'Source',
|
label: 'Source',
|
||||||
autofocus: true,
|
autofocus: true,
|
||||||
onchange: srcChange,
|
onchange: onSrcChange,
|
||||||
onbeforecall: onBeforeCall
|
onbeforecall: onBeforeCall
|
||||||
},
|
},
|
||||||
imageListCtrl
|
imageListCtrl
|
||||||
|
@ -615,137 +947,32 @@ define(
|
||||||
generalFormItems.push({ name: 'caption', type: 'checkbox', label: 'Caption' });
|
generalFormItems.push({ name: 'caption', type: 'checkbox', label: 'Caption' });
|
||||||
}
|
}
|
||||||
|
|
||||||
function mergeMargins(css) {
|
if (editor.settings.image_advtab || editor.settings.images_upload_url) {
|
||||||
if (css.margin) {
|
var body = [
|
||||||
|
{
|
||||||
var splitMargin = css.margin.split(" ");
|
title: 'General',
|
||||||
|
type: 'form',
|
||||||
switch (splitMargin.length) {
|
items: generalFormItems
|
||||||
case 1: //margin: toprightbottomleft;
|
|
||||||
css['margin-top'] = css['margin-top'] || splitMargin[0];
|
|
||||||
css['margin-right'] = css['margin-right'] || splitMargin[0];
|
|
||||||
css['margin-bottom'] = css['margin-bottom'] || splitMargin[0];
|
|
||||||
css['margin-left'] = css['margin-left'] || splitMargin[0];
|
|
||||||
break;
|
|
||||||
case 2: //margin: topbottom rightleft;
|
|
||||||
css['margin-top'] = css['margin-top'] || splitMargin[0];
|
|
||||||
css['margin-right'] = css['margin-right'] || splitMargin[1];
|
|
||||||
css['margin-bottom'] = css['margin-bottom'] || splitMargin[0];
|
|
||||||
css['margin-left'] = css['margin-left'] || splitMargin[1];
|
|
||||||
break;
|
|
||||||
case 3: //margin: top rightleft bottom;
|
|
||||||
css['margin-top'] = css['margin-top'] || splitMargin[0];
|
|
||||||
css['margin-right'] = css['margin-right'] || splitMargin[1];
|
|
||||||
css['margin-bottom'] = css['margin-bottom'] || splitMargin[2];
|
|
||||||
css['margin-left'] = css['margin-left'] || splitMargin[1];
|
|
||||||
break;
|
|
||||||
case 4: //margin: top right bottom left;
|
|
||||||
css['margin-top'] = css['margin-top'] || splitMargin[0];
|
|
||||||
css['margin-right'] = css['margin-right'] || splitMargin[1];
|
|
||||||
css['margin-bottom'] = css['margin-bottom'] || splitMargin[2];
|
|
||||||
css['margin-left'] = css['margin-left'] || splitMargin[3];
|
|
||||||
}
|
|
||||||
delete css.margin;
|
|
||||||
}
|
|
||||||
return css;
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateStyle() {
|
|
||||||
function addPixelSuffix(value) {
|
|
||||||
if (value.length > 0 && /^[0-9]+$/.test(value)) {
|
|
||||||
value += 'px';
|
|
||||||
}
|
|
||||||
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!editor.settings.image_advtab) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var data = win.toJSON(),
|
|
||||||
css = dom.parseStyle(data.style);
|
|
||||||
|
|
||||||
css = mergeMargins(css);
|
|
||||||
|
|
||||||
if (data.vspace) {
|
|
||||||
css['margin-top'] = css['margin-bottom'] = addPixelSuffix(data.vspace);
|
|
||||||
}
|
|
||||||
if (data.hspace) {
|
|
||||||
css['margin-left'] = css['margin-right'] = addPixelSuffix(data.hspace);
|
|
||||||
}
|
|
||||||
if (data.border) {
|
|
||||||
css['border-width'] = addPixelSuffix(data.border);
|
|
||||||
}
|
|
||||||
|
|
||||||
win.find('#style').value(dom.serializeStyle(dom.parseStyle(dom.serializeStyle(css))));
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateVSpaceHSpaceBorder() {
|
|
||||||
if (!editor.settings.image_advtab) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var data = win.toJSON(),
|
|
||||||
css = dom.parseStyle(data.style);
|
|
||||||
|
|
||||||
win.find('#vspace').value("");
|
|
||||||
win.find('#hspace').value("");
|
|
||||||
|
|
||||||
css = mergeMargins(css);
|
|
||||||
|
|
||||||
//Move opposite equal margins to vspace/hspace field
|
|
||||||
if ((css['margin-top'] && css['margin-bottom']) || (css['margin-right'] && css['margin-left'])) {
|
|
||||||
if (css['margin-top'] === css['margin-bottom']) {
|
|
||||||
win.find('#vspace').value(removePixelSuffix(css['margin-top']));
|
|
||||||
} else {
|
|
||||||
win.find('#vspace').value('');
|
|
||||||
}
|
|
||||||
if (css['margin-right'] === css['margin-left']) {
|
|
||||||
win.find('#hspace').value(removePixelSuffix(css['margin-right']));
|
|
||||||
} else {
|
|
||||||
win.find('#hspace').value('');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//Move border-width
|
|
||||||
if (css['border-width']) {
|
|
||||||
win.find('#border').value(removePixelSuffix(css['border-width']));
|
|
||||||
}
|
|
||||||
|
|
||||||
win.find('#style').value(dom.serializeStyle(dom.parseStyle(dom.serializeStyle(css))));
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
];
|
||||||
|
|
||||||
if (editor.settings.image_advtab) {
|
if (editor.settings.image_advtab) {
|
||||||
// Parse styles from img
|
// Parse styles from img
|
||||||
if (imgElm) {
|
if (imgElm) {
|
||||||
if (imgElm.style.marginLeft && imgElm.style.marginRight && imgElm.style.marginLeft === imgElm.style.marginRight) {
|
if (imgElm.style.marginLeft && imgElm.style.marginRight && imgElm.style.marginLeft === imgElm.style.marginRight) {
|
||||||
data.hspace = removePixelSuffix(imgElm.style.marginLeft);
|
data.hspace = Utils.removePixelSuffix(imgElm.style.marginLeft);
|
||||||
}
|
}
|
||||||
if (imgElm.style.marginTop && imgElm.style.marginBottom && imgElm.style.marginTop === imgElm.style.marginBottom) {
|
if (imgElm.style.marginTop && imgElm.style.marginBottom && imgElm.style.marginTop === imgElm.style.marginBottom) {
|
||||||
data.vspace = removePixelSuffix(imgElm.style.marginTop);
|
data.vspace = Utils.removePixelSuffix(imgElm.style.marginTop);
|
||||||
}
|
}
|
||||||
if (imgElm.style.borderWidth) {
|
if (imgElm.style.borderWidth) {
|
||||||
data.border = removePixelSuffix(imgElm.style.borderWidth);
|
data.border = Utils.removePixelSuffix(imgElm.style.borderWidth);
|
||||||
}
|
}
|
||||||
|
|
||||||
data.style = editor.dom.serializeStyle(editor.dom.parseStyle(editor.dom.getAttrib(imgElm, 'style')));
|
data.style = editor.dom.serializeStyle(editor.dom.parseStyle(editor.dom.getAttrib(imgElm, 'style')));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Advanced dialog shows general+advanced tabs
|
body.push({
|
||||||
win = editor.windowManager.open({
|
|
||||||
title: 'Insert/edit image',
|
|
||||||
data: data,
|
|
||||||
bodyType: 'tabpanel',
|
|
||||||
body: [
|
|
||||||
{
|
|
||||||
title: 'General',
|
|
||||||
type: 'form',
|
|
||||||
items: generalFormItems
|
|
||||||
},
|
|
||||||
|
|
||||||
{
|
|
||||||
title: 'Advanced',
|
title: 'Advanced',
|
||||||
type: 'form',
|
type: 'form',
|
||||||
pack: 'start',
|
pack: 'start',
|
||||||
|
@ -775,8 +1002,58 @@ define(
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
});
|
||||||
}
|
}
|
||||||
],
|
|
||||||
|
if (editor.settings.images_upload_url) {
|
||||||
|
var acceptExts = '.jpg,.jpeg,.png,.gif';
|
||||||
|
|
||||||
|
var uploadTab = {
|
||||||
|
title: 'Upload',
|
||||||
|
type: 'form',
|
||||||
|
layout: 'flex',
|
||||||
|
direction: 'column',
|
||||||
|
align: 'stretch',
|
||||||
|
padding: '20 20 20 20',
|
||||||
|
items: [
|
||||||
|
{
|
||||||
|
type: 'container',
|
||||||
|
layout: 'flex',
|
||||||
|
direction: 'column',
|
||||||
|
align: 'center',
|
||||||
|
spacing: 10,
|
||||||
|
items: [
|
||||||
|
{
|
||||||
|
text: "Browse for an image",
|
||||||
|
type: 'browsebutton',
|
||||||
|
accept: acceptExts,
|
||||||
|
onchange: onFileInput
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: 'OR',
|
||||||
|
type: 'label'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "Drop an image here",
|
||||||
|
type: 'dropzone',
|
||||||
|
accept: acceptExts,
|
||||||
|
height: 100,
|
||||||
|
onchange: onFileInput
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
body.push(uploadTab);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Advanced dialog shows general+advanced tabs
|
||||||
|
win = editor.windowManager.open({
|
||||||
|
title: 'Insert/edit image',
|
||||||
|
data: data,
|
||||||
|
bodyType: 'tabpanel',
|
||||||
|
body: body,
|
||||||
onSubmit: onSubmitForm
|
onSubmit: onSubmitForm
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
@ -790,6 +1067,43 @@ define(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function open() {
|
||||||
|
createImageList(showDialog);
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
open: open
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Plugin.js
|
||||||
|
*
|
||||||
|
* Released under LGPL License.
|
||||||
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
|
*
|
||||||
|
* License: http://www.tinymce.com/license
|
||||||
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class contains all core logic for the image plugin.
|
||||||
|
*
|
||||||
|
* @class tinymce.image.Plugin
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
'tinymce.plugins.image.Plugin',
|
||||||
|
[
|
||||||
|
'tinymce.core.PluginManager',
|
||||||
|
'tinymce.core.util.Tools',
|
||||||
|
'tinymce.plugins.image.ui.Dialog'
|
||||||
|
],
|
||||||
|
function (PluginManager, Tools, Dialog) {
|
||||||
|
PluginManager.add('image', function (editor) {
|
||||||
|
|
||||||
editor.on('preInit', function () {
|
editor.on('preInit', function () {
|
||||||
function hasImageClass(node) {
|
function hasImageClass(node) {
|
||||||
var className = node.attr('class');
|
var className = node.attr('class');
|
||||||
|
@ -810,6 +1124,7 @@ define(
|
||||||
if (hasImageClass(node)) {
|
if (hasImageClass(node)) {
|
||||||
node.attr('contenteditable', state ? 'false' : null);
|
node.attr('contenteditable', state ? 'false' : null);
|
||||||
Tools.each(node.getAll('figcaption'), toggleContentEditable);
|
Tools.each(node.getAll('figcaption'), toggleContentEditable);
|
||||||
|
Tools.each(node.getAll('img'), toggleContentEditable);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -822,19 +1137,19 @@ define(
|
||||||
editor.addButton('image', {
|
editor.addButton('image', {
|
||||||
icon: 'image',
|
icon: 'image',
|
||||||
tooltip: 'Insert/edit image',
|
tooltip: 'Insert/edit image',
|
||||||
onclick: createImageList(showDialog),
|
onclick: Dialog(editor).open,
|
||||||
stateSelector: 'img:not([data-mce-object],[data-mce-placeholder]),figure.image'
|
stateSelector: 'img:not([data-mce-object],[data-mce-placeholder]),figure.image'
|
||||||
});
|
});
|
||||||
|
|
||||||
editor.addMenuItem('image', {
|
editor.addMenuItem('image', {
|
||||||
icon: 'image',
|
icon: 'image',
|
||||||
text: 'Image',
|
text: 'Image',
|
||||||
onclick: createImageList(showDialog),
|
onclick: Dialog(editor).open,
|
||||||
context: 'insert',
|
context: 'insert',
|
||||||
prependToContext: true
|
prependToContext: true
|
||||||
});
|
});
|
||||||
|
|
||||||
editor.addCommand('mceImage', createImageList(showDialog));
|
editor.addCommand('mceImage', Dialog(editor).open);
|
||||||
});
|
});
|
||||||
|
|
||||||
return function () { };
|
return function () { };
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -286,22 +286,26 @@ define(
|
||||||
function (Tools, Settings, RegExp) {
|
function (Tools, Settings, RegExp) {
|
||||||
|
|
||||||
var toggleTargetRules = function (rel, isUnsafe) {
|
var toggleTargetRules = function (rel, isUnsafe) {
|
||||||
var rules = 'noopener';
|
var rules = ['noopener'];
|
||||||
|
var newRel = rel ? rel.split(/\s+/) : [];
|
||||||
|
|
||||||
|
var toString = function (rel) {
|
||||||
|
return Tools.trim(rel.sort().join(' '));
|
||||||
|
};
|
||||||
|
|
||||||
var addTargetRules = function (rel) {
|
var addTargetRules = function (rel) {
|
||||||
rel = removeTargetRules(rel);
|
rel = removeTargetRules(rel);
|
||||||
return rel ? [rel, rules].join(' ') : rules;
|
return rel.length ? rel.concat(rules) : rules;
|
||||||
};
|
};
|
||||||
|
|
||||||
var removeTargetRules = function (rel) {
|
var removeTargetRules = function (rel) {
|
||||||
var regExp = new RegExp('(' + rules.replace(' ', '|') + ')', 'g');
|
return rel.filter(function (val) {
|
||||||
if (rel) {
|
return Tools.inArray(rules, val) === -1;
|
||||||
rel = Tools.trim(rel.replace(regExp, ''));
|
});
|
||||||
}
|
|
||||||
return rel ? rel : null;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
return isUnsafe ? addTargetRules(rel) : removeTargetRules(rel);
|
newRel = isUnsafe ? addTargetRules(newRel) : removeTargetRules(newRel);
|
||||||
|
return newRel.length ? toString(newRel) : null;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -365,7 +369,7 @@ define(
|
||||||
title: data.title ? data.title : null
|
title: data.title ? data.title : null
|
||||||
};
|
};
|
||||||
|
|
||||||
if (Settings.allowUnsafeLinkTarget(editor.settings) === false) {
|
if (!Settings.hasRelList(editor.settings) && Settings.allowUnsafeLinkTarget(editor.settings) === false) {
|
||||||
linkAttrs.rel = toggleTargetRules(linkAttrs.rel, linkAttrs.target == '_blank');
|
linkAttrs.rel = toggleTargetRules(linkAttrs.rel, linkAttrs.target == '_blank');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -447,7 +451,8 @@ define(
|
||||||
hasLinks: hasLinks,
|
hasLinks: hasLinks,
|
||||||
isOnlyTextSelected: isOnlyTextSelected,
|
isOnlyTextSelected: isOnlyTextSelected,
|
||||||
getAnchorElement: getAnchorElement,
|
getAnchorElement: getAnchorElement,
|
||||||
getAnchorText: getAnchorText
|
getAnchorText: getAnchorText,
|
||||||
|
toggleTargetRules: toggleTargetRules
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
@ -691,7 +696,14 @@ define(
|
||||||
name: 'rel',
|
name: 'rel',
|
||||||
type: 'listbox',
|
type: 'listbox',
|
||||||
label: 'Rel',
|
label: 'Rel',
|
||||||
values: buildListItems(Settings.getRelList(editor.settings))
|
values: buildListItems(
|
||||||
|
Settings.getRelList(editor.settings),
|
||||||
|
function (item) {
|
||||||
|
if (Settings.allowUnsafeLinkTarget(editor.settings) === false) {
|
||||||
|
item.value = Utils.toggleTargetRules(item.value, data.target === '_blank');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -81,7 +81,7 @@ var defineGlobal = function (id, ref) {
|
||||||
define(id, [], function () { return ref; });
|
define(id, [], function () { return ref; });
|
||||||
};
|
};
|
||||||
/*jsc
|
/*jsc
|
||||||
["tinymce.plugins.lists.Plugin","tinymce.core.PluginManager","tinymce.core.util.Tools","tinymce.core.util.VK","tinymce.plugins.lists.actions.Indent","tinymce.plugins.lists.actions.Outdent","tinymce.plugins.lists.actions.ToggleList","tinymce.plugins.lists.core.Delete","tinymce.plugins.lists.core.NodeType","global!tinymce.util.Tools.resolve","tinymce.core.dom.DOMUtils","tinymce.plugins.lists.core.Bookmark","tinymce.plugins.lists.core.Selection","tinymce.plugins.lists.core.NormalizeLists","tinymce.plugins.lists.core.SplitList","tinymce.plugins.lists.core.TextBlock","tinymce.core.dom.BookmarkManager","tinymce.core.dom.RangeUtils","tinymce.core.dom.TreeWalker","tinymce.plugins.lists.core.Range","tinymce.core.Env"]
|
["tinymce.plugins.lists.Plugin","tinymce.core.PluginManager","tinymce.core.util.Tools","tinymce.core.util.VK","tinymce.plugins.lists.actions.Indent","tinymce.plugins.lists.actions.Outdent","tinymce.plugins.lists.actions.ToggleList","tinymce.plugins.lists.core.Delete","tinymce.plugins.lists.core.NodeType","tinymce.plugins.lists.core.Selection","global!tinymce.util.Tools.resolve","tinymce.core.dom.DOMUtils","tinymce.plugins.lists.core.Bookmark","tinymce.core.dom.DomQuery","tinymce.plugins.lists.core.NormalizeLists","tinymce.plugins.lists.core.SplitList","tinymce.plugins.lists.core.TextBlock","tinymce.core.dom.BookmarkManager","tinymce.core.dom.RangeUtils","tinymce.core.dom.TreeWalker","tinymce.plugins.lists.core.Range","tinymce.core.Env"]
|
||||||
jsc*/
|
jsc*/
|
||||||
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
/**
|
/**
|
||||||
|
@ -207,6 +207,10 @@ define(
|
||||||
return node && !!editor.schema.getTextBlockElements()[node.nodeName];
|
return node && !!editor.schema.getTextBlockElements()[node.nodeName];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var isBlock = function (node, blockElements) {
|
||||||
|
return node && node.nodeName in blockElements;
|
||||||
|
};
|
||||||
|
|
||||||
var isBogusBr = function (dom, node) {
|
var isBogusBr = function (dom, node) {
|
||||||
if (!isBr(node)) {
|
if (!isBr(node)) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -241,6 +245,7 @@ define(
|
||||||
isFirstChild: isFirstChild,
|
isFirstChild: isFirstChild,
|
||||||
isLastChild: isLastChild,
|
isLastChild: isLastChild,
|
||||||
isTextBlock: isTextBlock,
|
isTextBlock: isTextBlock,
|
||||||
|
isBlock: isBlock,
|
||||||
isBogusBr: isBogusBr,
|
isBogusBr: isBogusBr,
|
||||||
isEmpty: isEmpty,
|
isEmpty: isEmpty,
|
||||||
isChildOfBody: isChildOfBody
|
isChildOfBody: isChildOfBody
|
||||||
|
@ -451,6 +456,26 @@ define(
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ResolveGlobal.js
|
||||||
|
*
|
||||||
|
* Released under LGPL License.
|
||||||
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
|
*
|
||||||
|
* License: http://www.tinymce.com/license
|
||||||
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
|
*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
'tinymce.core.dom.DomQuery',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.dom.DomQuery');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Selection.js
|
* Selection.js
|
||||||
*
|
*
|
||||||
|
@ -464,17 +489,42 @@ define(
|
||||||
define(
|
define(
|
||||||
'tinymce.plugins.lists.core.Selection',
|
'tinymce.plugins.lists.core.Selection',
|
||||||
[
|
[
|
||||||
|
'tinymce.core.dom.DomQuery',
|
||||||
'tinymce.core.util.Tools',
|
'tinymce.core.util.Tools',
|
||||||
'tinymce.plugins.lists.core.NodeType'
|
'tinymce.plugins.lists.core.NodeType'
|
||||||
],
|
],
|
||||||
function (Tools, NodeType) {
|
function (DomQuery, Tools, NodeType) {
|
||||||
|
var getParentList = function (editor) {
|
||||||
|
return editor.dom.getParent(editor.selection.getStart(true), 'OL,UL,DL');
|
||||||
|
};
|
||||||
|
|
||||||
|
var getSelectedSubLists = function (editor) {
|
||||||
|
var parentList = getParentList(editor);
|
||||||
|
return Tools.grep(editor.selection.getSelectedBlocks(), function (elm) {
|
||||||
|
return NodeType.isListNode(elm) && parentList !== elm;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var findParentListItemsNodes = function (editor, elms) {
|
||||||
|
var listItemsElms = Tools.map(elms, function (elm) {
|
||||||
|
var parentLi = editor.dom.getParent(elm, 'li,dd,dt', editor.getBody());
|
||||||
|
|
||||||
|
return parentLi ? parentLi : elm;
|
||||||
|
});
|
||||||
|
|
||||||
|
return DomQuery.unique(listItemsElms);
|
||||||
|
};
|
||||||
|
|
||||||
var getSelectedListItems = function (editor) {
|
var getSelectedListItems = function (editor) {
|
||||||
return Tools.grep(editor.selection.getSelectedBlocks(), function (block) {
|
var selectedBlocks = editor.selection.getSelectedBlocks();
|
||||||
|
return Tools.grep(findParentListItemsNodes(editor, selectedBlocks), function (block) {
|
||||||
return NodeType.isListItemNode(block);
|
return NodeType.isListItemNode(block);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
getParentList: getParentList,
|
||||||
|
getSelectedSubLists: getSelectedSubLists,
|
||||||
getSelectedListItems: getSelectedListItems
|
getSelectedListItems: getSelectedListItems
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -682,9 +732,10 @@ define(
|
||||||
'tinymce.plugins.lists.core.TextBlock',
|
'tinymce.plugins.lists.core.TextBlock',
|
||||||
[
|
[
|
||||||
'tinymce.core.dom.DOMUtils',
|
'tinymce.core.dom.DOMUtils',
|
||||||
'tinymce.core.Env'
|
'tinymce.core.Env',
|
||||||
|
'tinymce.plugins.lists.core.NodeType'
|
||||||
],
|
],
|
||||||
function (DOMUtils, Env) {
|
function (DOMUtils, Env, NodeType) {
|
||||||
var DOM = DOMUtils.DOM;
|
var DOM = DOMUtils.DOM;
|
||||||
|
|
||||||
var createNewTextBlock = function (editor, contentNode, blockName) {
|
var createNewTextBlock = function (editor, contentNode, blockName) {
|
||||||
|
@ -702,8 +753,10 @@ define(
|
||||||
DOM.setAttribs(textBlock, editor.settings.forced_root_block_attrs);
|
DOM.setAttribs(textBlock, editor.settings.forced_root_block_attrs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!NodeType.isBlock(contentNode.firstChild, blockElements)) {
|
||||||
fragment.appendChild(textBlock);
|
fragment.appendChild(textBlock);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (contentNode) {
|
if (contentNode) {
|
||||||
while ((node = contentNode.firstChild)) {
|
while ((node = contentNode.firstChild)) {
|
||||||
|
@ -713,7 +766,7 @@ define(
|
||||||
hasContentNode = true;
|
hasContentNode = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (blockElements[nodeName]) {
|
if (NodeType.isBlock(node, blockElements)) {
|
||||||
fragment.appendChild(node);
|
fragment.appendChild(node);
|
||||||
textBlock = null;
|
textBlock = null;
|
||||||
} else {
|
} else {
|
||||||
|
@ -1230,17 +1283,40 @@ define(
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
var toggleList = function (editor, listName, detail) {
|
var updateList = function (dom, list, listName, detail) {
|
||||||
var parentList = editor.dom.getParent(editor.selection.getStart(), 'OL,UL,DL');
|
if (list.nodeName !== listName) {
|
||||||
|
var newList = dom.rename(list, listName);
|
||||||
|
updateListWithDetails(dom, newList, detail);
|
||||||
|
} else {
|
||||||
|
updateListWithDetails(dom, list, detail);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
detail = detail ? detail : {};
|
var toggleMultipleLists = function (editor, parentList, lists, listName, detail) {
|
||||||
|
if (parentList.nodeName === listName && !hasListStyleDetail(detail)) {
|
||||||
|
removeList(editor, listName);
|
||||||
|
} else {
|
||||||
|
var bookmark = Bookmark.createBookmark(editor.selection.getRng(true));
|
||||||
|
|
||||||
|
Tools.each([parentList].concat(lists), function (elm) {
|
||||||
|
updateList(editor.dom, elm, listName, detail);
|
||||||
|
});
|
||||||
|
|
||||||
|
editor.selection.setRng(Bookmark.resolveBookmark(bookmark));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var hasListStyleDetail = function (detail) {
|
||||||
|
return 'list-style-type' in detail;
|
||||||
|
};
|
||||||
|
|
||||||
|
var toggleSingleList = function (editor, parentList, listName, detail) {
|
||||||
if (parentList === editor.getBody()) {
|
if (parentList === editor.getBody()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (parentList) {
|
if (parentList) {
|
||||||
if (parentList.nodeName === listName) {
|
if (parentList.nodeName === listName && !hasListStyleDetail(detail)) {
|
||||||
removeList(editor, listName);
|
removeList(editor, listName);
|
||||||
} else {
|
} else {
|
||||||
var bookmark = Bookmark.createBookmark(editor.selection.getRng(true));
|
var bookmark = Bookmark.createBookmark(editor.selection.getRng(true));
|
||||||
|
@ -1253,6 +1329,19 @@ define(
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var toggleList = function (editor, listName, detail) {
|
||||||
|
var parentList = Selection.getParentList(editor);
|
||||||
|
var selectedSubLists = Selection.getSelectedSubLists(editor);
|
||||||
|
|
||||||
|
detail = detail ? detail : {};
|
||||||
|
|
||||||
|
if (parentList && selectedSubLists.length > 0) {
|
||||||
|
toggleMultipleLists(editor, parentList, selectedSubLists, listName, detail);
|
||||||
|
} else {
|
||||||
|
toggleSingleList(editor, parentList, listName, detail);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
return {
|
return {
|
||||||
toggleList: toggleList,
|
toggleList: toggleList,
|
||||||
removeList: removeList,
|
removeList: removeList,
|
||||||
|
@ -1343,6 +1432,30 @@ define(
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var hasOnlyOneBlockChild = function (dom, elm) {
|
||||||
|
var childNodes = elm.childNodes;
|
||||||
|
return childNodes.length === 1 && !NodeType.isListNode(childNodes[0]) && dom.isBlock(childNodes[0]);
|
||||||
|
};
|
||||||
|
|
||||||
|
var unwrapSingleBlockChild = function (dom, elm) {
|
||||||
|
if (hasOnlyOneBlockChild(dom, elm)) {
|
||||||
|
dom.remove(elm.firstChild, true);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var moveChildren = function (dom, fromElm, toElm) {
|
||||||
|
var node, targetElm;
|
||||||
|
|
||||||
|
targetElm = hasOnlyOneBlockChild(dom, toElm) ? toElm.firstChild : toElm;
|
||||||
|
unwrapSingleBlockChild(dom, fromElm);
|
||||||
|
|
||||||
|
if (!NodeType.isEmpty(dom, fromElm, true)) {
|
||||||
|
while ((node = fromElm.firstChild)) {
|
||||||
|
targetElm.appendChild(node);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
var mergeLiElements = function (dom, fromElm, toElm) {
|
var mergeLiElements = function (dom, fromElm, toElm) {
|
||||||
var node, listNode, ul = fromElm.parentNode;
|
var node, listNode, ul = fromElm.parentNode;
|
||||||
|
|
||||||
|
@ -1369,11 +1482,7 @@ define(
|
||||||
dom.$(toElm).empty();
|
dom.$(toElm).empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!NodeType.isEmpty(dom, fromElm, true)) {
|
moveChildren(dom, fromElm, toElm);
|
||||||
while ((node = fromElm.firstChild)) {
|
|
||||||
toElm.appendChild(node);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (listNode) {
|
if (listNode) {
|
||||||
toElm.appendChild(listNode);
|
toElm.appendChild(listNode);
|
||||||
|
@ -1386,6 +1495,30 @@ define(
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var mergeIntoEmptyLi = function (editor, fromLi, toLi) {
|
||||||
|
editor.dom.$(toLi).empty();
|
||||||
|
mergeLiElements(editor.dom, fromLi, toLi);
|
||||||
|
editor.selection.setCursorLocation(toLi);
|
||||||
|
};
|
||||||
|
|
||||||
|
var mergeForward = function (editor, rng, fromLi, toLi) {
|
||||||
|
var dom = editor.dom;
|
||||||
|
|
||||||
|
if (dom.isEmpty(toLi)) {
|
||||||
|
mergeIntoEmptyLi(editor, fromLi, toLi);
|
||||||
|
} else {
|
||||||
|
var bookmark = Bookmark.createBookmark(rng);
|
||||||
|
mergeLiElements(dom, fromLi, toLi);
|
||||||
|
editor.selection.setRng(Bookmark.resolveBookmark(bookmark));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var mergeBackward = function (editor, rng, fromLi, toLi) {
|
||||||
|
var bookmark = Bookmark.createBookmark(rng);
|
||||||
|
mergeLiElements(editor.dom, fromLi, toLi);
|
||||||
|
editor.selection.setRng(Bookmark.resolveBookmark(bookmark));
|
||||||
|
};
|
||||||
|
|
||||||
var backspaceDeleteFromListToListCaret = function (editor, isForward) {
|
var backspaceDeleteFromListToListCaret = function (editor, isForward) {
|
||||||
var dom = editor.dom, selection = editor.selection;
|
var dom = editor.dom, selection = editor.selection;
|
||||||
var li = dom.getParent(selection.getStart(), 'LI'), ul, rng, otherLi;
|
var li = dom.getParent(selection.getStart(), 'LI'), ul, rng, otherLi;
|
||||||
|
@ -1400,16 +1533,12 @@ define(
|
||||||
otherLi = dom.getParent(findNextCaretContainer(editor, rng, isForward), 'LI');
|
otherLi = dom.getParent(findNextCaretContainer(editor, rng, isForward), 'LI');
|
||||||
|
|
||||||
if (otherLi && otherLi !== li) {
|
if (otherLi && otherLi !== li) {
|
||||||
var bookmark = Bookmark.createBookmark(rng);
|
|
||||||
|
|
||||||
if (isForward) {
|
if (isForward) {
|
||||||
mergeLiElements(dom, otherLi, li);
|
mergeForward(editor, rng, otherLi, li);
|
||||||
} else {
|
} else {
|
||||||
mergeLiElements(dom, li, otherLi);
|
mergeBackward(editor, rng, li, otherLi);
|
||||||
}
|
}
|
||||||
|
|
||||||
editor.selection.setRng(Bookmark.resolveBookmark(bookmark));
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
} else if (!otherLi) {
|
} else if (!otherLi) {
|
||||||
if (!isForward && ToggleList.removeList(editor, ul.nodeName)) {
|
if (!isForward && ToggleList.removeList(editor, ul.nodeName)) {
|
||||||
|
@ -1421,6 +1550,15 @@ define(
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var removeBlock = function (dom, block) {
|
||||||
|
var parentBlock = dom.getParent(block.parentNode, dom.isBlock);
|
||||||
|
|
||||||
|
dom.remove(block);
|
||||||
|
if (parentBlock && dom.isEmpty(parentBlock)) {
|
||||||
|
dom.remove(parentBlock);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
var backspaceDeleteIntoListCaret = function (editor, isForward) {
|
var backspaceDeleteIntoListCaret = function (editor, isForward) {
|
||||||
var dom = editor.dom;
|
var dom = editor.dom;
|
||||||
var block = dom.getParent(editor.selection.getStart(), dom.isBlock);
|
var block = dom.getParent(editor.selection.getStart(), dom.isBlock);
|
||||||
|
@ -1431,7 +1569,7 @@ define(
|
||||||
|
|
||||||
if (otherLi) {
|
if (otherLi) {
|
||||||
editor.undoManager.transact(function () {
|
editor.undoManager.transact(function () {
|
||||||
dom.remove(block);
|
removeBlock(dom, block);
|
||||||
ToggleList.mergeWithAdjacentLists(dom, otherLi.parentNode);
|
ToggleList.mergeWithAdjacentLists(dom, otherLi.parentNode);
|
||||||
editor.selection.select(otherLi, true);
|
editor.selection.select(otherLi, true);
|
||||||
editor.selection.collapse(isForward);
|
editor.selection.collapse(isForward);
|
||||||
|
@ -1509,9 +1647,10 @@ define(
|
||||||
'tinymce.plugins.lists.actions.Outdent',
|
'tinymce.plugins.lists.actions.Outdent',
|
||||||
'tinymce.plugins.lists.actions.ToggleList',
|
'tinymce.plugins.lists.actions.ToggleList',
|
||||||
'tinymce.plugins.lists.core.Delete',
|
'tinymce.plugins.lists.core.Delete',
|
||||||
'tinymce.plugins.lists.core.NodeType'
|
'tinymce.plugins.lists.core.NodeType',
|
||||||
|
'tinymce.plugins.lists.core.Selection'
|
||||||
],
|
],
|
||||||
function (PluginManager, Tools, VK, Indent, Outdent, ToggleList, Delete, NodeType) {
|
function (PluginManager, Tools, VK, Indent, Outdent, ToggleList, Delete, NodeType, Selection) {
|
||||||
var queryListCommandState = function (editor, listName) {
|
var queryListCommandState = function (editor, listName) {
|
||||||
return function () {
|
return function () {
|
||||||
var parentList = editor.dom.getParent(editor.selection.getStart(), 'UL,OL,DL');
|
var parentList = editor.dom.getParent(editor.selection.getStart(), 'UL,OL,DL');
|
||||||
|
@ -1617,15 +1756,8 @@ define(
|
||||||
var ctrl = e.control;
|
var ctrl = e.control;
|
||||||
|
|
||||||
editor.on('nodechange', function () {
|
editor.on('nodechange', function () {
|
||||||
var blocks = editor.selection.getSelectedBlocks();
|
var listItemBlocks = Selection.getSelectedListItems(editor);
|
||||||
var disable = false;
|
var disable = listItemBlocks.length > 0 && NodeType.isFirstChild(listItemBlocks[0]);
|
||||||
|
|
||||||
for (var i = 0, l = blocks.length; !disable && i < l; i++) {
|
|
||||||
var tag = blocks[i].nodeName;
|
|
||||||
|
|
||||||
disable = (tag === 'LI' && NodeType.isFirstChild(blocks[i]) || tag === 'UL' || tag === 'OL' || tag === 'DD');
|
|
||||||
}
|
|
||||||
|
|
||||||
ctrl.disabled(disable);
|
ctrl.disabled(disable);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
|
@ -1 +1 @@
|
||||||
.mce-content-body .mce-reset{margin:0;padding:0;border:0;outline:0;vertical-align:top;background:transparent;text-decoration:none;color:black;font-family:Arial;font-size:11px;text-shadow:none;float:none;position:static;width:auto;height:auto;white-space:nowrap;cursor:inherit;line-height:normal;font-weight:normal;text-align:left;-webkit-tap-highlight-color:transparent;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box;direction:ltr;max-width:none}.mce-object{border:1px dotted #3A3A3A;background:#D5D5D5 url(img/object.gif) no-repeat center}.mce-preview-object{display:inline-block;position:relative;margin:0 2px 0 2px;line-height:0;border:1px solid gray}.mce-preview-object[data-mce-selected="2"] .mce-shim{display:none}.mce-preview-object .mce-shim{position:absolute;top:0;left:0;width:100%;height:100%;background:url()}figure.align-left{float:left}figure.align-right{float:right}figure.image.align-center{display:table;margin-left:auto;margin-right:auto}figure.image{display:inline-block;border:1px solid gray;margin:0 2px 0 1px;background:#f5f2f0}figure.image img{margin:8px 8px 0 8px}figure.image figcaption{margin:6px 8px 6px 8px;text-align:center}.mce-toc{border:1px solid gray}.mce-toc h2{margin:4px}.mce-toc li{list-style-type:none}.mce-pagebreak{cursor:default;display:block;border:0;width:100%;height:5px;border:1px dashed #666;margin-top:15px;page-break-before:always}@media print{.mce-pagebreak{border:0}}.mce-item-anchor{cursor:default;display:inline-block;-webkit-user-select:all;-webkit-user-modify:read-only;-moz-user-select:all;-moz-user-modify:read-only;user-select:all;user-modify:read-only;width:9px !important;height:9px !important;border:1px dotted #3A3A3A;background:#D5D5D5 url(img/anchor.gif) no-repeat center}.mce-nbsp,.mce-shy{background:#AAA}.mce-shy::after{content:'-'}.mce-match-marker{background:#AAA;color:#fff}.mce-match-marker-selected{background:#3399ff;color:#fff}.mce-spellchecker-word{border-bottom:2px solid #F00;cursor:default}.mce-spellchecker-grammar{border-bottom:2px solid #008000;cursor:default}.mce-item-table,.mce-item-table td,.mce-item-table th,.mce-item-table caption{border:1px dashed #BBB}td[data-mce-selected],th[data-mce-selected]{background-color:#3399ff !important}.mce-edit-focus{outline:1px dotted #333}.mce-resize-bar-dragging{background-color:blue;opacity:.25;filter:alpha(opacity=25);zoom:1}.mce-content-body p,.mce-content-body div,.mce-content-body h1,.mce-content-body h2,.mce-content-body h3,.mce-content-body h4,.mce-content-body h5,.mce-content-body h6{line-height:1.2em}.mce-content-body *[contentEditable=false] *[contentEditable=true]:focus{outline:2px solid #2d8ac7}.mce-content-body *[contentEditable=false] *[contentEditable=true]:hover{outline:2px solid #7ACAFF}.mce-content-body *[contentEditable=false][data-mce-selected]{outline:2px solid #2d8ac7}.mce-content-body a[data-mce-selected],.mce-content-body code[data-mce-selected]{background:#bfe6ff}.mce-content-body hr{cursor:default}
|
.word-wrap{word-wrap:break-word;-ms-word-break:break-all;word-break:break-all;word-break:break-word;-ms-hyphens:auto;-moz-hyphens:auto;-webkit-hyphens:auto;hyphens:auto}.mce-content-body .mce-reset{margin:0;padding:0;border:0;outline:0;vertical-align:top;background:transparent;text-decoration:none;color:black;font-family:Arial;font-size:11px;text-shadow:none;float:none;position:static;width:auto;height:auto;white-space:nowrap;cursor:inherit;line-height:normal;font-weight:normal;text-align:left;-webkit-tap-highlight-color:transparent;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box;direction:ltr;max-width:none}.mce-object{border:1px dotted #3A3A3A;background:#D5D5D5 url(img/object.gif) no-repeat center}.mce-preview-object{display:inline-block;position:relative;margin:0 2px 0 2px;line-height:0;border:1px solid gray}.mce-preview-object[data-mce-selected="2"] .mce-shim{display:none}.mce-preview-object .mce-shim{position:absolute;top:0;left:0;width:100%;height:100%;background:url()}figure.align-left{float:left}figure.align-right{float:right}figure.image.align-center{display:table;margin-left:auto;margin-right:auto}figure.image{display:inline-block;border:1px solid gray;margin:0 2px 0 1px;background:#f5f2f0}figure.image img{margin:8px 8px 0 8px}figure.image figcaption{margin:6px 8px 6px 8px;text-align:center}.mce-toc{border:1px solid gray}.mce-toc h2{margin:4px}.mce-toc li{list-style-type:none}.mce-pagebreak{cursor:default;display:block;border:0;width:100%;height:5px;border:1px dashed #666;margin-top:15px;page-break-before:always}@media print{.mce-pagebreak{border:0}}.mce-item-anchor{cursor:default;display:inline-block;-webkit-user-select:all;-webkit-user-modify:read-only;-moz-user-select:all;-moz-user-modify:read-only;user-select:all;user-modify:read-only;width:9px !important;height:9px !important;border:1px dotted #3A3A3A;background:#D5D5D5 url(img/anchor.gif) no-repeat center}.mce-nbsp,.mce-shy{background:#AAA}.mce-shy::after{content:'-'}.mce-match-marker{background:#AAA;color:#fff}.mce-match-marker-selected{background:#3399ff;color:#fff}.mce-spellchecker-word{border-bottom:2px solid #F00;cursor:default}.mce-spellchecker-grammar{border-bottom:2px solid #008000;cursor:default}.mce-item-table,.mce-item-table td,.mce-item-table th,.mce-item-table caption{border:1px dashed #BBB}td[data-mce-selected],th[data-mce-selected]{background-color:#3399ff !important}.mce-edit-focus{outline:1px dotted #333}.mce-resize-bar-dragging{background-color:blue;opacity:.25;filter:alpha(opacity=25);zoom:1}.mce-content-body *[contentEditable=false] *[contentEditable=true]:focus{outline:2px solid #2d8ac7}.mce-content-body *[contentEditable=false] *[contentEditable=true]:hover{outline:2px solid #7ACAFF}.mce-content-body *[contentEditable=false][data-mce-selected]{outline:2px solid #2d8ac7}.mce-content-body a[data-mce-selected],.mce-content-body code[data-mce-selected],.mce-content-body b[data-mce-selected],.mce-content-body i[data-mce-selected],.mce-content-body em[data-mce-selected],.mce-content-body strong[data-mce-selected],.mce-content-body sup[data-mce-selected],.mce-content-body sub[data-mce-selected]{background:#bfe6ff}.mce-content-body hr{cursor:default}.mce-content-body{line-height:1.3}
|
|
@ -1 +1 @@
|
||||||
body{background-color:#FFFFFF;color:#000000;font-family:Verdana,Arial,Helvetica,sans-serif;font-size:14px;scrollbar-3dlight-color:#F0F0EE;scrollbar-arrow-color:#676662;scrollbar-base-color:#F0F0EE;scrollbar-darkshadow-color:#DDDDDD;scrollbar-face-color:#E0E0DD;scrollbar-highlight-color:#F0F0EE;scrollbar-shadow-color:#F0F0EE;scrollbar-track-color:#F5F5F5}td,th{font-family:Verdana,Arial,Helvetica,sans-serif;font-size:14px}.mce-content-body .mce-reset{margin:0;padding:0;border:0;outline:0;vertical-align:top;background:transparent;text-decoration:none;color:black;font-family:Arial;font-size:11px;text-shadow:none;float:none;position:static;width:auto;height:auto;white-space:nowrap;cursor:inherit;line-height:normal;font-weight:normal;text-align:left;-webkit-tap-highlight-color:transparent;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box;direction:ltr;max-width:none}.mce-object{border:1px dotted #3A3A3A;background:#D5D5D5 url(img/object.gif) no-repeat center}.mce-preview-object{display:inline-block;position:relative;margin:0 2px 0 2px;line-height:0;border:1px solid gray}.mce-preview-object[data-mce-selected="2"] .mce-shim{display:none}.mce-preview-object .mce-shim{position:absolute;top:0;left:0;width:100%;height:100%;background:url()}figure.align-left{float:left}figure.align-right{float:right}figure.image.align-center{display:table;margin-left:auto;margin-right:auto}figure.image{display:inline-block;border:1px solid gray;margin:0 2px 0 1px;background:#f5f2f0}figure.image img{margin:8px 8px 0 8px}figure.image figcaption{margin:6px 8px 6px 8px;text-align:center}.mce-toc{border:1px solid gray}.mce-toc h2{margin:4px}.mce-toc li{list-style-type:none}.mce-pagebreak{cursor:default;display:block;border:0;width:100%;height:5px;border:1px dashed #666;margin-top:15px;page-break-before:always}@media print{.mce-pagebreak{border:0}}.mce-item-anchor{cursor:default;display:inline-block;-webkit-user-select:all;-webkit-user-modify:read-only;-moz-user-select:all;-moz-user-modify:read-only;user-select:all;user-modify:read-only;width:9px !important;height:9px !important;border:1px dotted #3A3A3A;background:#D5D5D5 url(img/anchor.gif) no-repeat center}.mce-nbsp,.mce-shy{background:#AAA}.mce-shy::after{content:'-'}.mce-match-marker{background:#AAA;color:#fff}.mce-match-marker-selected{background:#3399ff;color:#fff}.mce-spellchecker-word{border-bottom:2px solid #F00;cursor:default}.mce-spellchecker-grammar{border-bottom:2px solid #008000;cursor:default}.mce-item-table,.mce-item-table td,.mce-item-table th,.mce-item-table caption{border:1px dashed #BBB}td[data-mce-selected],th[data-mce-selected]{background-color:#3399ff !important}.mce-edit-focus{outline:1px dotted #333}.mce-resize-bar-dragging{background-color:blue;opacity:.25;filter:alpha(opacity=25);zoom:1}.mce-content-body p,.mce-content-body div,.mce-content-body h1,.mce-content-body h2,.mce-content-body h3,.mce-content-body h4,.mce-content-body h5,.mce-content-body h6{line-height:1.2em}.mce-content-body *[contentEditable=false] *[contentEditable=true]:focus{outline:2px solid #2d8ac7}.mce-content-body *[contentEditable=false] *[contentEditable=true]:hover{outline:2px solid #7ACAFF}.mce-content-body *[contentEditable=false][data-mce-selected]{outline:2px solid #2d8ac7}.mce-content-body a[data-mce-selected],.mce-content-body code[data-mce-selected]{background:#bfe6ff}.mce-content-body hr{cursor:default}
|
body{background-color:#FFFFFF;color:#000000;font-family:Verdana,Arial,Helvetica,sans-serif;font-size:14px;line-height:1.3;scrollbar-3dlight-color:#F0F0EE;scrollbar-arrow-color:#676662;scrollbar-base-color:#F0F0EE;scrollbar-darkshadow-color:#DDDDDD;scrollbar-face-color:#E0E0DD;scrollbar-highlight-color:#F0F0EE;scrollbar-shadow-color:#F0F0EE;scrollbar-track-color:#F5F5F5}td,th{font-family:Verdana,Arial,Helvetica,sans-serif;font-size:14px}.word-wrap{word-wrap:break-word;-ms-word-break:break-all;word-break:break-all;word-break:break-word;-ms-hyphens:auto;-moz-hyphens:auto;-webkit-hyphens:auto;hyphens:auto}.mce-content-body .mce-reset{margin:0;padding:0;border:0;outline:0;vertical-align:top;background:transparent;text-decoration:none;color:black;font-family:Arial;font-size:11px;text-shadow:none;float:none;position:static;width:auto;height:auto;white-space:nowrap;cursor:inherit;line-height:normal;font-weight:normal;text-align:left;-webkit-tap-highlight-color:transparent;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box;direction:ltr;max-width:none}.mce-object{border:1px dotted #3A3A3A;background:#D5D5D5 url(img/object.gif) no-repeat center}.mce-preview-object{display:inline-block;position:relative;margin:0 2px 0 2px;line-height:0;border:1px solid gray}.mce-preview-object[data-mce-selected="2"] .mce-shim{display:none}.mce-preview-object .mce-shim{position:absolute;top:0;left:0;width:100%;height:100%;background:url()}figure.align-left{float:left}figure.align-right{float:right}figure.image.align-center{display:table;margin-left:auto;margin-right:auto}figure.image{display:inline-block;border:1px solid gray;margin:0 2px 0 1px;background:#f5f2f0}figure.image img{margin:8px 8px 0 8px}figure.image figcaption{margin:6px 8px 6px 8px;text-align:center}.mce-toc{border:1px solid gray}.mce-toc h2{margin:4px}.mce-toc li{list-style-type:none}.mce-pagebreak{cursor:default;display:block;border:0;width:100%;height:5px;border:1px dashed #666;margin-top:15px;page-break-before:always}@media print{.mce-pagebreak{border:0}}.mce-item-anchor{cursor:default;display:inline-block;-webkit-user-select:all;-webkit-user-modify:read-only;-moz-user-select:all;-moz-user-modify:read-only;user-select:all;user-modify:read-only;width:9px !important;height:9px !important;border:1px dotted #3A3A3A;background:#D5D5D5 url(img/anchor.gif) no-repeat center}.mce-nbsp,.mce-shy{background:#AAA}.mce-shy::after{content:'-'}.mce-match-marker{background:#AAA;color:#fff}.mce-match-marker-selected{background:#3399ff;color:#fff}.mce-spellchecker-word{border-bottom:2px solid #F00;cursor:default}.mce-spellchecker-grammar{border-bottom:2px solid #008000;cursor:default}.mce-item-table,.mce-item-table td,.mce-item-table th,.mce-item-table caption{border:1px dashed #BBB}td[data-mce-selected],th[data-mce-selected]{background-color:#3399ff !important}.mce-edit-focus{outline:1px dotted #333}.mce-resize-bar-dragging{background-color:blue;opacity:.25;filter:alpha(opacity=25);zoom:1}.mce-content-body *[contentEditable=false] *[contentEditable=true]:focus{outline:2px solid #2d8ac7}.mce-content-body *[contentEditable=false] *[contentEditable=true]:hover{outline:2px solid #7ACAFF}.mce-content-body *[contentEditable=false][data-mce-selected]{outline:2px solid #2d8ac7}.mce-content-body a[data-mce-selected],.mce-content-body code[data-mce-selected],.mce-content-body b[data-mce-selected],.mce-content-body i[data-mce-selected],.mce-content-body em[data-mce-selected],.mce-content-body strong[data-mce-selected],.mce-content-body sup[data-mce-selected],.mce-content-body sub[data-mce-selected]{background:#bfe6ff}.mce-content-body hr{cursor:default}
|
File diff suppressed because one or more lines are too long
|
@ -21,18 +21,6 @@ body {
|
||||||
word-wrap: break-word; /* Old syntax */
|
word-wrap: break-word; /* Old syntax */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Changed in 4.6.0, see https://core.trac.wordpress.org/ticket/40743 */
|
|
||||||
.mce-content-body p,
|
|
||||||
.mce-content-body div,
|
|
||||||
.mce-content-body h1,
|
|
||||||
.mce-content-body h2,
|
|
||||||
.mce-content-body h3,
|
|
||||||
.mce-content-body h4,
|
|
||||||
.mce-content-body h5,
|
|
||||||
.mce-content-body h6 {
|
|
||||||
line-height: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
body.rtl {
|
body.rtl {
|
||||||
font-family: Tahoma, "Times New Roman", "Bitstream Charter", Times, serif;
|
font-family: Tahoma, "Times New Roman", "Bitstream Charter", Times, serif;
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,7 +81,7 @@ var defineGlobal = function (id, ref) {
|
||||||
define(id, [], function () { return ref; });
|
define(id, [], function () { return ref; });
|
||||||
};
|
};
|
||||||
/*jsc
|
/*jsc
|
||||||
["tinymce.themes.inlite.Theme","tinymce.core.ThemeManager","tinymce.core.ui.Api","tinymce.core.util.Delay","tinymce.themes.inlite.alien.Arr","tinymce.themes.inlite.alien.EditorSettings","tinymce.themes.inlite.core.ElementMatcher","tinymce.themes.inlite.core.Matcher","tinymce.themes.inlite.core.PredicateId","tinymce.themes.inlite.core.SelectionMatcher","tinymce.themes.inlite.core.SkinLoader","tinymce.themes.inlite.ui.Buttons","tinymce.themes.inlite.ui.Panel","global!tinymce.util.Tools.resolve","tinymce.themes.inlite.alien.Type","tinymce.themes.inlite.core.Measure","tinymce.core.util.Tools","tinymce.core.EditorManager","tinymce.core.dom.DOMUtils","tinymce.core.ui.Factory","tinymce.themes.inlite.ui.Toolbar","tinymce.themes.inlite.ui.Forms","tinymce.themes.inlite.core.Layout","tinymce.themes.inlite.file.Conversions","tinymce.themes.inlite.file.Picker","tinymce.themes.inlite.core.Actions","tinymce.core.geom.Rect","tinymce.themes.inlite.core.Convert","tinymce.core.util.Promise","tinymce.themes.inlite.alien.Uuid","tinymce.themes.inlite.alien.Unlink","tinymce.themes.inlite.core.UrlType","tinymce.themes.inlite.alien.Bookmark","tinymce.core.dom.TreeWalker","tinymce.core.dom.RangeUtils"]
|
["tinymce.themes.inlite.Theme","tinymce.core.ThemeManager","tinymce.core.ui.Api","tinymce.core.util.Delay","tinymce.themes.inlite.alien.Arr","tinymce.themes.inlite.alien.EditorSettings","tinymce.themes.inlite.core.ElementMatcher","tinymce.themes.inlite.core.Matcher","tinymce.themes.inlite.core.PredicateId","tinymce.themes.inlite.core.SelectionMatcher","tinymce.themes.inlite.core.SkinLoader","tinymce.themes.inlite.ui.Buttons","tinymce.themes.inlite.ui.Panel","global!tinymce.util.Tools.resolve","tinymce.themes.inlite.alien.Type","tinymce.themes.inlite.core.Measure","tinymce.core.util.Tools","tinymce.core.EditorManager","tinymce.core.dom.DOMUtils","tinymce.core.ui.Factory","tinymce.themes.inlite.ui.Toolbar","tinymce.themes.inlite.ui.Forms","tinymce.themes.inlite.core.Layout","tinymce.themes.inlite.file.Conversions","tinymce.themes.inlite.file.Picker","tinymce.themes.inlite.core.Actions","tinymce.themes.inlite.core.Convert","tinymce.core.util.Promise","tinymce.themes.inlite.alien.Uuid","tinymce.themes.inlite.alien.Unlink","tinymce.themes.inlite.core.UrlType","tinymce.core.geom.Rect","tinymce.themes.inlite.alien.Bookmark","tinymce.core.dom.TreeWalker","tinymce.core.dom.RangeUtils"]
|
||||||
jsc*/
|
jsc*/
|
||||||
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
/**
|
/**
|
||||||
|
@ -359,26 +359,6 @@ define(
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
|
||||||
* ResolveGlobal.js
|
|
||||||
*
|
|
||||||
* Released under LGPL License.
|
|
||||||
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
|
||||||
*
|
|
||||||
* License: http://www.tinymce.com/license
|
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
|
||||||
*/
|
|
||||||
|
|
||||||
define(
|
|
||||||
'tinymce.core.geom.Rect',
|
|
||||||
[
|
|
||||||
'global!tinymce.util.Tools.resolve'
|
|
||||||
],
|
|
||||||
function (resolve) {
|
|
||||||
return resolve('tinymce.geom.Rect');
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert.js
|
* Convert.js
|
||||||
*
|
*
|
||||||
|
@ -435,10 +415,9 @@ define(
|
||||||
'tinymce.themes.inlite.core.Measure',
|
'tinymce.themes.inlite.core.Measure',
|
||||||
[
|
[
|
||||||
'tinymce.core.dom.DOMUtils',
|
'tinymce.core.dom.DOMUtils',
|
||||||
'tinymce.core.geom.Rect',
|
|
||||||
'tinymce.themes.inlite.core.Convert'
|
'tinymce.themes.inlite.core.Convert'
|
||||||
],
|
],
|
||||||
function (DOMUtils, Rect, Convert) {
|
function (DOMUtils, Convert) {
|
||||||
var toAbsolute = function (rect) {
|
var toAbsolute = function (rect) {
|
||||||
var vp = DOMUtils.DOM.getViewPort();
|
var vp = DOMUtils.DOM.getViewPort();
|
||||||
|
|
||||||
|
@ -1468,6 +1447,26 @@ define(
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ResolveGlobal.js
|
||||||
|
*
|
||||||
|
* Released under LGPL License.
|
||||||
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
|
*
|
||||||
|
* License: http://www.tinymce.com/license
|
||||||
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
|
*/
|
||||||
|
|
||||||
|
define(
|
||||||
|
'tinymce.core.geom.Rect',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.geom.Rect');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Layout.js
|
* Layout.js
|
||||||
*
|
*
|
||||||
|
@ -1499,8 +1498,15 @@ define(
|
||||||
var calcByPositions = function (testPositions1, testPositions2, targetRect, contentAreaRect, panelRect) {
|
var calcByPositions = function (testPositions1, testPositions2, targetRect, contentAreaRect, panelRect) {
|
||||||
var relPos, relRect, outputPanelRect;
|
var relPos, relRect, outputPanelRect;
|
||||||
|
|
||||||
relPos = Rect.findBestRelativePosition(panelRect, targetRect, contentAreaRect, testPositions1);
|
var paddedContentRect = {
|
||||||
targetRect = Rect.clamp(targetRect, contentAreaRect);
|
x: contentAreaRect.x,
|
||||||
|
y: contentAreaRect.y,
|
||||||
|
w: contentAreaRect.w + (contentAreaRect.w < (panelRect.w + targetRect.w) ? panelRect.w : 0),
|
||||||
|
h: contentAreaRect.h + (contentAreaRect.h < (panelRect.h + targetRect.h) ? panelRect.h : 0)
|
||||||
|
};
|
||||||
|
|
||||||
|
relPos = Rect.findBestRelativePosition(panelRect, targetRect, paddedContentRect, testPositions1);
|
||||||
|
targetRect = Rect.clamp(targetRect, paddedContentRect);
|
||||||
|
|
||||||
if (relPos) {
|
if (relPos) {
|
||||||
relRect = Rect.relativePosition(panelRect, targetRect, relPos);
|
relRect = Rect.relativePosition(panelRect, targetRect, relPos);
|
||||||
|
@ -1508,9 +1514,10 @@ define(
|
||||||
return result(outputPanelRect, relPos);
|
return result(outputPanelRect, relPos);
|
||||||
}
|
}
|
||||||
|
|
||||||
targetRect = Rect.intersect(contentAreaRect, targetRect);
|
targetRect = Rect.intersect(paddedContentRect, targetRect);
|
||||||
if (targetRect) {
|
if (targetRect) {
|
||||||
relPos = Rect.findBestRelativePosition(panelRect, targetRect, contentAreaRect, testPositions2);
|
relPos = Rect.findBestRelativePosition(panelRect, targetRect, paddedContentRect, testPositions2);
|
||||||
|
|
||||||
if (relPos) {
|
if (relPos) {
|
||||||
relRect = Rect.relativePosition(panelRect, targetRect, relPos);
|
relRect = Rect.relativePosition(panelRect, targetRect, relPos);
|
||||||
outputPanelRect = moveTo(panelRect, relRect);
|
outputPanelRect = moveTo(panelRect, relRect);
|
||||||
|
@ -1536,8 +1543,8 @@ define(
|
||||||
|
|
||||||
var calc = function (targetRect, contentAreaRect, panelRect) {
|
var calc = function (targetRect, contentAreaRect, panelRect) {
|
||||||
return calcByPositions(
|
return calcByPositions(
|
||||||
['tc-bc', 'bc-tc', 'tl-bl', 'bl-tl', 'tr-br', 'br-tr'],
|
['tc-bc', 'bc-tc', 'tl-bl', 'bl-tl', 'tr-br', 'br-tr', 'cr-cl', 'cl-cr'],
|
||||||
['bc-tc', 'bl-tl', 'br-tr'],
|
['bc-tc', 'bl-tl', 'br-tr', 'cr-cl'],
|
||||||
targetRect,
|
targetRect,
|
||||||
contentAreaRect,
|
contentAreaRect,
|
||||||
panelRect
|
panelRect
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -53,7 +53,7 @@ var tinyMCEPopup = {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Setup local DOM
|
// Setup local DOM
|
||||||
self.dom = self.editor.windowManager.createInstance('tinymce.plugins.dom.DOMUtils', document, {
|
self.dom = self.editor.windowManager.createInstance('tinymce.dom.DOMUtils', document, {
|
||||||
ownEvents: true,
|
ownEvents: true,
|
||||||
proxy: tinyMCEPopup._eventProxy
|
proxy: tinyMCEPopup._eventProxy
|
||||||
});
|
});
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -12,7 +12,7 @@
|
||||||
|
|
||||||
function MCTabs() {
|
function MCTabs() {
|
||||||
this.settings = [];
|
this.settings = [];
|
||||||
this.onChange = tinyMCEPopup.editor.windowManager.createInstance('tinymce.plugins.util.Dispatcher');
|
this.onChange = tinyMCEPopup.editor.windowManager.createInstance('tinymce.util.Dispatcher');
|
||||||
}
|
}
|
||||||
|
|
||||||
MCTabs.prototype.init = function (settings) {
|
MCTabs.prototype.init = function (settings) {
|
||||||
|
@ -155,7 +155,7 @@ tinyMCEPopup.onInit.add(function () {
|
||||||
dom.setAttrib(a, 'tabindex', '-1');
|
dom.setAttrib(a, 'tabindex', '-1');
|
||||||
});
|
});
|
||||||
|
|
||||||
/*keyNav = tinyMCEPopup.editor.windowManager.createInstance('tinymce.plugins.ui.KeyboardNavigation', {
|
/*keyNav = tinyMCEPopup.editor.windowManager.createInstance('tinymce.ui.KeyboardNavigation', {
|
||||||
root: tabContainerElm,
|
root: tabContainerElm,
|
||||||
items: items,
|
items: items,
|
||||||
onAction: action,
|
onAction: action,
|
||||||
|
|
Binary file not shown.
|
@ -4,7 +4,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '4.9-alpha-41603';
|
$wp_version = '4.9-alpha-41604';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
@ -18,7 +18,7 @@ $wp_db_version = 38590;
|
||||||
*
|
*
|
||||||
* @global string $tinymce_version
|
* @global string $tinymce_version
|
||||||
*/
|
*/
|
||||||
$tinymce_version = '4603-20170530';
|
$tinymce_version = '4607-20170918';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the required PHP version
|
* Holds the required PHP version
|
||||||
|
|
Loading…
Reference in New Issue