TinyMCE: update to 4.6.0. Has many new features and bug fixes, changelog: https://www.tinymce.com/docs/changelog/#version460-may42017.
Fixes #40690. git-svn-id: https://develop.svn.wordpress.org/trunk@40583 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
491f14540e
commit
f4d3513802
@ -705,6 +705,12 @@ $_old_files = array(
|
|||||||
'wp-includes/theme-compat/comments-popup.php',
|
'wp-includes/theme-compat/comments-popup.php',
|
||||||
// 4.6
|
// 4.6
|
||||||
'wp-admin/includes/class-wp-automatic-upgrader.php', // Wrong file name, see #37628.
|
'wp-admin/includes/class-wp-automatic-upgrader.php', // Wrong file name, see #37628.
|
||||||
|
// 4.8
|
||||||
|
'wp-includes/js/tinymce/plugins/media/moxieplayer.swf',
|
||||||
|
'wp-includes/js/tinymce/skins/lightgray/fonts/readme.md',
|
||||||
|
'wp-includes/js/tinymce/skins/lightgray/fonts/tinymce-small.json',
|
||||||
|
'wp-includes/js/tinymce/skins/lightgray/fonts/tinymce.json',
|
||||||
|
'wp-includes/js/tinymce/skins/lightgray/skin.ie7.min.css',
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -947,6 +947,7 @@ final class _WP_Editors {
|
|||||||
'cache_suffix' => 'wp-mce-' . $tinymce_version,
|
'cache_suffix' => 'wp-mce-' . $tinymce_version,
|
||||||
'resize' => 'vertical',
|
'resize' => 'vertical',
|
||||||
'menubar' => false,
|
'menubar' => false,
|
||||||
|
'branding' => false,
|
||||||
|
|
||||||
// Limit the preview styles in the menu/toolbar
|
// Limit the preview styles in the menu/toolbar
|
||||||
'preview_styles' => 'font-family font-size font-weight font-style text-decoration text-transform',
|
'preview_styles' => 'font-family font-size font-weight font-style text-decoration text-transform',
|
||||||
@ -1039,6 +1040,9 @@ final class _WP_Editors {
|
|||||||
'Name' => _x( 'Name', 'Name of link anchor (TinyMCE)' ),
|
'Name' => _x( 'Name', 'Name of link anchor (TinyMCE)' ),
|
||||||
'Anchor' => _x( 'Anchor', 'Link anchor (TinyMCE)' ),
|
'Anchor' => _x( 'Anchor', 'Link anchor (TinyMCE)' ),
|
||||||
'Anchors' => _x( 'Anchors', 'Link anchors (TinyMCE)' ),
|
'Anchors' => _x( 'Anchors', 'Link anchors (TinyMCE)' ),
|
||||||
|
'Id should start with a letter, followed only by letters, numbers, dashes, dots, colons or underscores.' =>
|
||||||
|
__( 'Id should start with a letter, followed only by letters, numbers, dashes, dots, colons or underscores.' ),
|
||||||
|
'Id' => _x( 'Id', 'Id for link anchor (TinyMCE)' ),
|
||||||
|
|
||||||
// Fullpage plugin
|
// Fullpage plugin
|
||||||
'Document properties' => __( 'Document properties' ),
|
'Document properties' => __( 'Document properties' ),
|
||||||
@ -1050,6 +1054,7 @@ final class _WP_Editors {
|
|||||||
'Author' => __( 'Author' ),
|
'Author' => __( 'Author' ),
|
||||||
|
|
||||||
// Media, image plugins
|
// Media, image plugins
|
||||||
|
'Image' => __( 'Image' ),
|
||||||
'Insert/edit image' => array( __( 'Insert/edit image' ), 'accessM' ),
|
'Insert/edit image' => array( __( 'Insert/edit image' ), 'accessM' ),
|
||||||
'General' => __( 'General' ),
|
'General' => __( 'General' ),
|
||||||
'Advanced' => __( 'Advanced' ),
|
'Advanced' => __( 'Advanced' ),
|
||||||
@ -1061,8 +1066,13 @@ final class _WP_Editors {
|
|||||||
'Style' => __( 'Style' ),
|
'Style' => __( 'Style' ),
|
||||||
'Dimensions' => __( 'Dimensions' ),
|
'Dimensions' => __( 'Dimensions' ),
|
||||||
'Insert image' => __( 'Insert image' ),
|
'Insert image' => __( 'Insert image' ),
|
||||||
|
'Date/time' => __( 'Date/time' ),
|
||||||
'Insert date/time' => __( 'Insert date/time' ),
|
'Insert date/time' => __( 'Insert date/time' ),
|
||||||
'Insert/edit video' => __( 'Insert/edit video' ),
|
'Table of Contents' => __( 'Table of Contents' ),
|
||||||
|
'Insert/Edit code sample' => __( 'Insert/edit code sample' ),
|
||||||
|
'Language' => __( 'Language' ),
|
||||||
|
'Media' => __( 'Media' ),
|
||||||
|
'Insert/edit media' => __( 'Insert/edit media' ),
|
||||||
'Poster' => __( 'Poster' ),
|
'Poster' => __( 'Poster' ),
|
||||||
'Alternative source' => __( 'Alternative source' ),
|
'Alternative source' => __( 'Alternative source' ),
|
||||||
'Paste your embed code below:' => __( 'Paste your embed code below:' ),
|
'Paste your embed code below:' => __( 'Paste your embed code below:' ),
|
||||||
@ -1087,10 +1097,26 @@ final class _WP_Editors {
|
|||||||
'Insert/edit link' => array( __( 'Insert/edit link' ), 'metaK' ),
|
'Insert/edit link' => array( __( 'Insert/edit link' ), 'metaK' ),
|
||||||
'Remove link' => array( __( 'Remove link' ), 'accessS' ),
|
'Remove link' => array( __( 'Remove link' ), 'accessS' ),
|
||||||
|
|
||||||
|
// Link plugin
|
||||||
|
'Link' => __( 'Link' ),
|
||||||
|
'Insert link' => __( 'Insert link' ),
|
||||||
|
'Insert/edit link' => __( 'Insert/edit link' ),
|
||||||
|
'Target' => __( 'Target' ),
|
||||||
|
'New window' => __( 'New window' ),
|
||||||
|
'Text to display' => __( 'Text to display' ),
|
||||||
|
'Url' => __( 'URL' ),
|
||||||
|
'The URL you entered seems to be an email address. Do you want to add the required mailto: prefix?' =>
|
||||||
|
__( 'The URL you entered seems to be an email address. Do you want to add the required mailto: prefix?' ),
|
||||||
|
'The URL you entered seems to be an external link. Do you want to add the required http:// prefix?' =>
|
||||||
|
__( 'The URL you entered seems to be an external link. Do you want to add the required http:// prefix?' ),
|
||||||
|
|
||||||
'Color' => __( 'Color' ),
|
'Color' => __( 'Color' ),
|
||||||
'Custom color' => __( 'Custom color' ),
|
'Custom color' => __( 'Custom color' ),
|
||||||
'Custom...' => _x( 'Custom...', 'label for custom color' ), // no ellipsis
|
'Custom...' => _x( 'Custom...', 'label for custom color' ), // no ellipsis
|
||||||
'No color' => __( 'No color' ),
|
'No color' => __( 'No color' ),
|
||||||
|
'R' => _x( 'R', 'Short for red in RGB' ),
|
||||||
|
'G' => _x( 'G', 'Short for green in RGB' ),
|
||||||
|
'B' => _x( 'B', 'Short for blue in RGB' ),
|
||||||
|
|
||||||
// Spelling, search/replace plugins
|
// Spelling, search/replace plugins
|
||||||
'Could not find the specified string.' => __( 'Could not find the specified string.' ),
|
'Could not find the specified string.' => __( 'Could not find the specified string.' ),
|
||||||
@ -1235,16 +1261,27 @@ final class _WP_Editors {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/*
|
||||||
* Link plugin (not included):
|
Imagetools plugin (not included):
|
||||||
* Insert link
|
'Edit image' => __( 'Edit image' ),
|
||||||
* Target
|
'Image options' => __( 'Image options' ),
|
||||||
* New window
|
'Back' => __( 'Back' ),
|
||||||
* Text to display
|
'Invert' => __( 'Invert' ),
|
||||||
* The URL you entered seems to be an email address. Do you want to add the required mailto: prefix?
|
'Flip horizontally' => __( 'Flip horizontally' ),
|
||||||
* The URL you entered seems to be an external link. Do you want to add the required http:\/\/ prefix?
|
'Flip vertically' => __( 'Flip vertically' ),
|
||||||
* Url
|
'Crop' => __( 'Crop' ),
|
||||||
*/
|
'Orientation' => __( 'Orientation' ),
|
||||||
|
'Resize' => __( 'Resize' ),
|
||||||
|
'Rotate clockwise' => __( 'Rotate clockwise' ),
|
||||||
|
'Rotate counterclockwise' => __( 'Rotate counterclockwise' ),
|
||||||
|
'Sharpen' => __( 'Sharpen' ),
|
||||||
|
'Brightness' => __( 'Brightness' ),
|
||||||
|
'Color levels' => __( 'Color levels' ),
|
||||||
|
'Contrast' => __( 'Contrast' ),
|
||||||
|
'Gamma' => __( 'Gamma' ),
|
||||||
|
'Zoom in' => __( 'Zoom in' ),
|
||||||
|
'Zoom out' => __( 'Zoom out' ),
|
||||||
|
*/
|
||||||
|
|
||||||
return self::$translation;
|
return self::$translation;
|
||||||
}
|
}
|
||||||
@ -1456,6 +1493,11 @@ final class _WP_Editors {
|
|||||||
var init, id, $wrap;
|
var init, id, $wrap;
|
||||||
|
|
||||||
if ( typeof tinymce !== 'undefined' ) {
|
if ( typeof tinymce !== 'undefined' ) {
|
||||||
|
if ( tinymce.Env.ie && tinymce.Env.ie < 11 ) {
|
||||||
|
tinymce.$( '.wp-editor-wrap ' ).removeClass( 'tmce-active' ).addClass( 'html-active' );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
for ( id in tinyMCEPreInit.mceInit ) {
|
for ( id in tinyMCEPreInit.mceInit ) {
|
||||||
init = tinyMCEPreInit.mceInit[id];
|
init = tinyMCEPreInit.mceInit[id];
|
||||||
$wrap = tinymce.$( '#wp-' + id + '-wrap' );
|
$wrap = tinymce.$( '#wp-' + id + '-wrap' );
|
||||||
|
@ -2988,7 +2988,9 @@ function user_can_richedit() {
|
|||||||
if ( get_user_option( 'rich_editing' ) == 'true' || ! is_user_logged_in() ) { // default to 'true' for logged out users
|
if ( get_user_option( 'rich_editing' ) == 'true' || ! is_user_logged_in() ) { // default to 'true' for logged out users
|
||||||
if ( $is_safari ) {
|
if ( $is_safari ) {
|
||||||
$wp_rich_edit = ! wp_is_mobile() || ( preg_match( '!AppleWebKit/(\d+)!', $_SERVER['HTTP_USER_AGENT'], $match ) && intval( $match[1] ) >= 534 );
|
$wp_rich_edit = ! wp_is_mobile() || ( preg_match( '!AppleWebKit/(\d+)!', $_SERVER['HTTP_USER_AGENT'], $match ) && intval( $match[1] ) >= 534 );
|
||||||
} elseif ( $is_gecko || $is_chrome || $is_IE || $is_edge || ( $is_opera && !wp_is_mobile() ) ) {
|
} elseif ( $is_IE ) {
|
||||||
|
$wp_rich_edit = ( strpos( $_SERVER['HTTP_USER_AGENT'], 'MSIE ' ) === false );
|
||||||
|
} elseif ( $is_gecko || $is_chrome || $is_edge || ( $is_opera && !wp_is_mobile() ) ) {
|
||||||
$wp_rich_edit = true;
|
$wp_rich_edit = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
GNU LESSER GENERAL PUBLIC LICENSE
|
GNU LESSER GENERAL PUBLIC LICENSE
|
||||||
Version 2.1, February 1999
|
Version 2.1, February 1999
|
||||||
|
|
||||||
Copyright (C) 1991, 1999 Free Software Foundation, Inc.
|
Copyright (C) 1991, 1999 Free Software Foundation, Inc.
|
||||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
@ -10,7 +10,7 @@
|
|||||||
as the successor of the GNU Library Public License, version 2, hence
|
as the successor of the GNU Library Public License, version 2, hence
|
||||||
the version number 2.1.]
|
the version number 2.1.]
|
||||||
|
|
||||||
Preamble
|
Preamble
|
||||||
|
|
||||||
The licenses for most software are designed to take away your
|
The licenses for most software are designed to take away your
|
||||||
freedom to share and change it. By contrast, the GNU General Public
|
freedom to share and change it. By contrast, the GNU General Public
|
||||||
@ -112,7 +112,7 @@ modification follow. Pay close attention to the difference between a
|
|||||||
former contains code derived from the library, whereas the latter must
|
former contains code derived from the library, whereas the latter must
|
||||||
be combined with the library in order to run.
|
be combined with the library in order to run.
|
||||||
|
|
||||||
GNU LESSER GENERAL PUBLIC LICENSE
|
GNU LESSER GENERAL PUBLIC LICENSE
|
||||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
0. This License Agreement applies to any software library or other
|
0. This License Agreement applies to any software library or other
|
||||||
@ -432,7 +432,7 @@ decision will be guided by the two goals of preserving the free status
|
|||||||
of all derivatives of our free software and of promoting the sharing
|
of all derivatives of our free software and of promoting the sharing
|
||||||
and reuse of software generally.
|
and reuse of software generally.
|
||||||
|
|
||||||
NO WARRANTY
|
NO WARRANTY
|
||||||
|
|
||||||
15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
|
15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
|
||||||
WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
|
WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
|
||||||
@ -455,7 +455,7 @@ FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
|
|||||||
SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
|
SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
|
||||||
DAMAGES.
|
DAMAGES.
|
||||||
|
|
||||||
END OF TERMS AND CONDITIONS
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
How to Apply These Terms to Your New Libraries
|
How to Apply These Terms to Your New Libraries
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
@ -1,112 +1,255 @@
|
|||||||
|
(function () {
|
||||||
|
|
||||||
|
var defs = {}; // id -> {dependencies, definition, instance (possibly undefined)}
|
||||||
|
|
||||||
|
// Used when there is no 'main' module.
|
||||||
|
// The name is probably (hopefully) unique so minification removes for releases.
|
||||||
|
var register_3795 = function (id) {
|
||||||
|
var module = dem(id);
|
||||||
|
var fragments = id.split('.');
|
||||||
|
var target = Function('return this;')();
|
||||||
|
for (var i = 0; i < fragments.length - 1; ++i) {
|
||||||
|
if (target[fragments[i]] === undefined)
|
||||||
|
target[fragments[i]] = {};
|
||||||
|
target = target[fragments[i]];
|
||||||
|
}
|
||||||
|
target[fragments[fragments.length - 1]] = module;
|
||||||
|
};
|
||||||
|
|
||||||
|
var instantiate = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
var dependencies = actual.deps;
|
||||||
|
var definition = actual.defn;
|
||||||
|
var len = dependencies.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances[i] = dem(dependencies[i]);
|
||||||
|
var defResult = definition.apply(null, instances);
|
||||||
|
if (defResult === undefined)
|
||||||
|
throw 'module [' + id + '] returned undefined';
|
||||||
|
actual.instance = defResult;
|
||||||
|
};
|
||||||
|
|
||||||
|
var def = function (id, dependencies, definition) {
|
||||||
|
if (typeof id !== 'string')
|
||||||
|
throw 'module id must be a string';
|
||||||
|
else if (dependencies === undefined)
|
||||||
|
throw 'no dependencies for ' + id;
|
||||||
|
else if (definition === undefined)
|
||||||
|
throw 'no definition function for ' + id;
|
||||||
|
defs[id] = {
|
||||||
|
deps: dependencies,
|
||||||
|
defn: definition,
|
||||||
|
instance: undefined
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var dem = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
if (actual === undefined)
|
||||||
|
throw 'module [' + id + '] was undefined';
|
||||||
|
else if (actual.instance === undefined)
|
||||||
|
instantiate(id);
|
||||||
|
return actual.instance;
|
||||||
|
};
|
||||||
|
|
||||||
|
var req = function (ids, callback) {
|
||||||
|
var len = ids.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances.push(dem(ids[i]));
|
||||||
|
callback.apply(null, callback);
|
||||||
|
};
|
||||||
|
|
||||||
|
var ephox = {};
|
||||||
|
|
||||||
|
ephox.bolt = {
|
||||||
|
module: {
|
||||||
|
api: {
|
||||||
|
define: def,
|
||||||
|
require: req,
|
||||||
|
demand: dem
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var define = def;
|
||||||
|
var require = req;
|
||||||
|
var demand = dem;
|
||||||
|
// this helps with minificiation when using a lot of global references
|
||||||
|
var defineGlobal = function (id, ref) {
|
||||||
|
define(id, [], function () { return ref; });
|
||||||
|
};
|
||||||
|
/*jsc
|
||||||
|
["tinymce.plugins.colorpicker.Plugin","tinymce.core.PluginManager","tinymce.core.util.Color","global!tinymce.util.Tools.resolve"]
|
||||||
|
jsc*/
|
||||||
|
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
/**
|
/**
|
||||||
* plugin.js
|
* ResolveGlobal.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*global tinymce:true */
|
define(
|
||||||
|
'tinymce.core.PluginManager',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.PluginManager');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
tinymce.PluginManager.add('colorpicker', function(editor) {
|
/**
|
||||||
function colorPickerCallback(callback, value) {
|
* ResolveGlobal.js
|
||||||
function setColor(value) {
|
*
|
||||||
var color = new tinymce.util.Color(value), rgb = color.toRgb();
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
win.fromJSON({
|
define(
|
||||||
r: rgb.r,
|
'tinymce.core.util.Color',
|
||||||
g: rgb.g,
|
[
|
||||||
b: rgb.b,
|
'global!tinymce.util.Tools.resolve'
|
||||||
hex: color.toHex().substr(1)
|
],
|
||||||
});
|
function (resolve) {
|
||||||
|
return resolve('tinymce.util.Color');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
showPreview(color.toHex());
|
/**
|
||||||
}
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
function showPreview(hexColor) {
|
/**
|
||||||
win.find('#preview')[0].getEl().style.background = hexColor;
|
* This class contains all core logic for the colorpicker plugin.
|
||||||
}
|
*
|
||||||
|
* @class tinymce.colorpicker.Plugin
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
'tinymce.plugins.colorpicker.Plugin',
|
||||||
|
[
|
||||||
|
'tinymce.core.PluginManager',
|
||||||
|
'tinymce.core.util.Color'
|
||||||
|
],
|
||||||
|
function (PluginManager, Color) {
|
||||||
|
PluginManager.add('colorpicker', function (editor) {
|
||||||
|
function colorPickerCallback(callback, value) {
|
||||||
|
function setColor(value) {
|
||||||
|
var color = new Color(value), rgb = color.toRgb();
|
||||||
|
|
||||||
var win = editor.windowManager.open({
|
win.fromJSON({
|
||||||
title: 'Color',
|
r: rgb.r,
|
||||||
items: {
|
g: rgb.g,
|
||||||
type: 'container',
|
b: rgb.b,
|
||||||
layout: 'flex',
|
hex: color.toHex().substr(1)
|
||||||
direction: 'row',
|
});
|
||||||
align: 'stretch',
|
|
||||||
padding: 5,
|
|
||||||
spacing: 10,
|
|
||||||
items: [
|
|
||||||
{
|
|
||||||
type: 'colorpicker',
|
|
||||||
value: value,
|
|
||||||
onchange: function() {
|
|
||||||
var rgb = this.rgb();
|
|
||||||
|
|
||||||
if (win) {
|
showPreview(color.toHex());
|
||||||
win.find('#r').value(rgb.r);
|
}
|
||||||
win.find('#g').value(rgb.g);
|
|
||||||
win.find('#b').value(rgb.b);
|
|
||||||
win.find('#hex').value(this.value().substr(1));
|
|
||||||
showPreview(this.value());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
type: 'form',
|
|
||||||
padding: 0,
|
|
||||||
labelGap: 5,
|
|
||||||
defaults: {
|
|
||||||
type: 'textbox',
|
|
||||||
size: 7,
|
|
||||||
value: '0',
|
|
||||||
flex: 1,
|
|
||||||
spellcheck: false,
|
|
||||||
onchange: function() {
|
|
||||||
var colorPickerCtrl = win.find('colorpicker')[0];
|
|
||||||
var name, value;
|
|
||||||
|
|
||||||
name = this.name();
|
function showPreview(hexColor) {
|
||||||
value = this.value();
|
win.find('#preview')[0].getEl().style.background = hexColor;
|
||||||
|
}
|
||||||
|
|
||||||
if (name == "hex") {
|
var win = editor.windowManager.open({
|
||||||
value = '#' + value;
|
title: 'Color',
|
||||||
setColor(value);
|
items: {
|
||||||
colorPickerCtrl.value(value);
|
type: 'container',
|
||||||
return;
|
layout: 'flex',
|
||||||
}
|
direction: 'row',
|
||||||
|
align: 'stretch',
|
||||||
|
padding: 5,
|
||||||
|
spacing: 10,
|
||||||
|
items: [
|
||||||
|
{
|
||||||
|
type: 'colorpicker',
|
||||||
|
value: value,
|
||||||
|
onchange: function () {
|
||||||
|
var rgb = this.rgb();
|
||||||
|
|
||||||
value = {
|
if (win) {
|
||||||
r: win.find('#r').value(),
|
win.find('#r').value(rgb.r);
|
||||||
g: win.find('#g').value(),
|
win.find('#g').value(rgb.g);
|
||||||
b: win.find('#b').value()
|
win.find('#b').value(rgb.b);
|
||||||
};
|
win.find('#hex').value(this.value().substr(1));
|
||||||
|
showPreview(this.value());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: 'form',
|
||||||
|
padding: 0,
|
||||||
|
labelGap: 5,
|
||||||
|
defaults: {
|
||||||
|
type: 'textbox',
|
||||||
|
size: 7,
|
||||||
|
value: '0',
|
||||||
|
flex: 1,
|
||||||
|
spellcheck: false,
|
||||||
|
onchange: function () {
|
||||||
|
var colorPickerCtrl = win.find('colorpicker')[0];
|
||||||
|
var name, value;
|
||||||
|
|
||||||
colorPickerCtrl.value(value);
|
name = this.name();
|
||||||
setColor(value);
|
value = this.value();
|
||||||
}
|
|
||||||
},
|
|
||||||
items: [
|
|
||||||
{name: 'r', label: 'R', autofocus: 1},
|
|
||||||
{name: 'g', label: 'G'},
|
|
||||||
{name: 'b', label: 'B'},
|
|
||||||
{name: 'hex', label: '#', value: '000000'},
|
|
||||||
{name: 'preview', type: 'container', border: 1}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
onSubmit: function() {
|
|
||||||
callback('#' + this.toJSON().hex);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
setColor(value);
|
if (name == "hex") {
|
||||||
}
|
value = '#' + value;
|
||||||
|
setColor(value);
|
||||||
|
colorPickerCtrl.value(value);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (!editor.settings.color_picker_callback) {
|
value = {
|
||||||
editor.settings.color_picker_callback = colorPickerCallback;
|
r: win.find('#r').value(),
|
||||||
}
|
g: win.find('#g').value(),
|
||||||
});
|
b: win.find('#b').value()
|
||||||
|
};
|
||||||
|
|
||||||
|
colorPickerCtrl.value(value);
|
||||||
|
setColor(value);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
items: [
|
||||||
|
{ name: 'r', label: 'R', autofocus: 1 },
|
||||||
|
{ name: 'g', label: 'G' },
|
||||||
|
{ name: 'b', label: 'B' },
|
||||||
|
{ name: 'hex', label: '#', value: '000000' },
|
||||||
|
{ name: 'preview', type: 'container', border: 1 }
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
onSubmit: function () {
|
||||||
|
callback('#' + this.toJSON().hex);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
setColor(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!editor.settings.color_picker_callback) {
|
||||||
|
editor.settings.color_picker_callback = colorPickerCallback;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return function () { };
|
||||||
|
}
|
||||||
|
);
|
||||||
|
dem('tinymce.plugins.colorpicker.Plugin')();
|
||||||
|
})();
|
||||||
|
@ -1 +1 @@
|
|||||||
tinymce.PluginManager.add("colorpicker",function(e){function t(t,n){function r(e){var t=new tinymce.util.Color(e),n=t.toRgb();o.fromJSON({r:n.r,g:n.g,b:n.b,hex:t.toHex().substr(1)}),i(t.toHex())}function i(e){o.find("#preview")[0].getEl().style.background=e}var o=e.windowManager.open({title:"Color",items:{type:"container",layout:"flex",direction:"row",align:"stretch",padding:5,spacing:10,items:[{type:"colorpicker",value:n,onchange:function(){var e=this.rgb();o&&(o.find("#r").value(e.r),o.find("#g").value(e.g),o.find("#b").value(e.b),o.find("#hex").value(this.value().substr(1)),i(this.value()))}},{type:"form",padding:0,labelGap:5,defaults:{type:"textbox",size:7,value:"0",flex:1,spellcheck:!1,onchange:function(){var e,t,n=o.find("colorpicker")[0];return e=this.name(),t=this.value(),"hex"==e?(t="#"+t,r(t),void n.value(t)):(t={r:o.find("#r").value(),g:o.find("#g").value(),b:o.find("#b").value()},n.value(t),void r(t))}},items:[{name:"r",label:"R",autofocus:1},{name:"g",label:"G"},{name:"b",label:"B"},{name:"hex",label:"#",value:"000000"},{name:"preview",type:"container",border:1}]}]},onSubmit:function(){t("#"+this.toJSON().hex)}});r(n)}e.settings.color_picker_callback||(e.settings.color_picker_callback=t)});
|
!function(){var a={},b=function(b){for(var c=a[b],e=c.deps,f=c.defn,g=e.length,h=new Array(g),i=0;i<g;++i)h[i]=d(e[i]);var j=f.apply(null,h);if(void 0===j)throw"module ["+b+"] returned undefined";c.instance=j},c=function(b,c,d){if("string"!=typeof b)throw"module id must be a string";if(void 0===c)throw"no dependencies for "+b;if(void 0===d)throw"no definition function for "+b;a[b]={deps:c,defn:d,instance:void 0}},d=function(c){var d=a[c];if(void 0===d)throw"module ["+c+"] was undefined";return void 0===d.instance&&b(c),d.instance},e=function(a,b){for(var c=a.length,e=new Array(c),f=0;f<c;++f)e.push(d(a[f]));b.apply(null,b)},f={};f.bolt={module:{api:{define:c,require:e,demand:d}}};var g=c,h=function(a,b){g(a,[],function(){return b})};h("3",tinymce.util.Tools.resolve),g("1",["3"],function(a){return a("tinymce.PluginManager")}),g("2",["3"],function(a){return a("tinymce.util.Color")}),g("0",["1","2"],function(a,b){return a.add("colorpicker",function(a){function c(c,d){function e(a){var c=new b(a),d=c.toRgb();g.fromJSON({r:d.r,g:d.g,b:d.b,hex:c.toHex().substr(1)}),f(c.toHex())}function f(a){g.find("#preview")[0].getEl().style.background=a}var g=a.windowManager.open({title:"Color",items:{type:"container",layout:"flex",direction:"row",align:"stretch",padding:5,spacing:10,items:[{type:"colorpicker",value:d,onchange:function(){var a=this.rgb();g&&(g.find("#r").value(a.r),g.find("#g").value(a.g),g.find("#b").value(a.b),g.find("#hex").value(this.value().substr(1)),f(this.value()))}},{type:"form",padding:0,labelGap:5,defaults:{type:"textbox",size:7,value:"0",flex:1,spellcheck:!1,onchange:function(){var a,b,c=g.find("colorpicker")[0];return a=this.name(),b=this.value(),"hex"==a?(b="#"+b,e(b),void c.value(b)):(b={r:g.find("#r").value(),g:g.find("#g").value(),b:g.find("#b").value()},c.value(b),void e(b))}},items:[{name:"r",label:"R",autofocus:1},{name:"g",label:"G"},{name:"b",label:"B"},{name:"hex",label:"#",value:"000000"},{name:"preview",type:"container",border:1}]}]},onSubmit:function(){c("#"+this.toJSON().hex)}});e(d)}a.settings.color_picker_callback||(a.settings.color_picker_callback=c)}),function(){}}),d("0")()}();
|
@ -2,7 +2,7 @@
|
|||||||
* plugin.js
|
* plugin.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
@ -19,288 +19,301 @@
|
|||||||
* - No editor.onEvent
|
* - No editor.onEvent
|
||||||
* - Can't cancel execCommands with beforeExecCommand
|
* - Can't cancel execCommands with beforeExecCommand
|
||||||
*/
|
*/
|
||||||
(function(tinymce) {
|
(function (tinymce) {
|
||||||
var reported;
|
var reported;
|
||||||
|
|
||||||
function noop() {
|
function noop() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function log(apiCall) {
|
function log(apiCall) {
|
||||||
if (!reported && window && window.console) {
|
if (!reported && window && window.console) {
|
||||||
reported = true;
|
reported = true;
|
||||||
console.log("Deprecated TinyMCE API call: " + apiCall);
|
console.log("Deprecated TinyMCE API call: " + apiCall);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function Dispatcher(target, newEventName, argsMap, defaultScope) {
|
function Dispatcher(target, newEventName, argsMap, defaultScope) {
|
||||||
target = target || this;
|
target = target || this;
|
||||||
|
var cbs = [];
|
||||||
|
|
||||||
if (!newEventName) {
|
if (!newEventName) {
|
||||||
this.add = this.addToTop = this.remove = this.dispatch = noop;
|
this.add = this.addToTop = this.remove = this.dispatch = noop;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.add = function(callback, scope, prepend) {
|
this.add = function (callback, scope, prepend) {
|
||||||
log('<target>.on' + newEventName + ".add(..)");
|
log('<target>.on' + newEventName + ".add(..)");
|
||||||
|
|
||||||
// Convert callback({arg1:x, arg2:x}) -> callback(arg1, arg2)
|
// Convert callback({arg1:x, arg2:x}) -> callback(arg1, arg2)
|
||||||
function patchedEventCallback(e) {
|
function patchedEventCallback(e) {
|
||||||
var callbackArgs = [];
|
var callbackArgs = [];
|
||||||
|
|
||||||
if (typeof argsMap == "string") {
|
if (typeof argsMap == "string") {
|
||||||
argsMap = argsMap.split(" ");
|
argsMap = argsMap.split(" ");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (argsMap && typeof argsMap != "function") {
|
if (argsMap && typeof argsMap != "function") {
|
||||||
for (var i = 0; i < argsMap.length; i++) {
|
for (var i = 0; i < argsMap.length; i++) {
|
||||||
callbackArgs.push(e[argsMap[i]]);
|
callbackArgs.push(e[argsMap[i]]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (typeof argsMap == "function") {
|
if (typeof argsMap == "function") {
|
||||||
callbackArgs = argsMap(newEventName, e, target);
|
callbackArgs = argsMap(newEventName, e, target);
|
||||||
if (!callbackArgs) {
|
if (!callbackArgs) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!argsMap) {
|
if (!argsMap) {
|
||||||
callbackArgs = [e];
|
callbackArgs = [e];
|
||||||
}
|
}
|
||||||
|
|
||||||
callbackArgs.unshift(defaultScope || target);
|
callbackArgs.unshift(defaultScope || target);
|
||||||
|
|
||||||
if (callback.apply(scope || defaultScope || target, callbackArgs) === false) {
|
if (callback.apply(scope || defaultScope || target, callbackArgs) === false) {
|
||||||
e.stopImmediatePropagation();
|
e.stopImmediatePropagation();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
target.on(newEventName, patchedEventCallback, prepend);
|
target.on(newEventName, patchedEventCallback, prepend);
|
||||||
|
|
||||||
return patchedEventCallback;
|
var handlers = {
|
||||||
};
|
original: callback,
|
||||||
|
patched: patchedEventCallback
|
||||||
|
};
|
||||||
|
|
||||||
this.addToTop = function(callback, scope) {
|
cbs.push(handlers);
|
||||||
this.add(callback, scope, true);
|
return patchedEventCallback;
|
||||||
};
|
};
|
||||||
|
|
||||||
this.remove = function(callback) {
|
this.addToTop = function (callback, scope) {
|
||||||
return target.off(newEventName, callback);
|
this.add(callback, scope, true);
|
||||||
};
|
};
|
||||||
|
|
||||||
this.dispatch = function() {
|
this.remove = function (callback) {
|
||||||
target.fire(newEventName);
|
cbs.forEach(function (item, i) {
|
||||||
|
if (item.original === callback) {
|
||||||
|
cbs.splice(i, 1);
|
||||||
|
return target.off(newEventName, item.patched);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
return true;
|
return target.off(newEventName, callback);
|
||||||
};
|
};
|
||||||
}
|
|
||||||
|
|
||||||
tinymce.util.Dispatcher = Dispatcher;
|
this.dispatch = function () {
|
||||||
tinymce.onBeforeUnload = new Dispatcher(tinymce, "BeforeUnload");
|
target.fire(newEventName);
|
||||||
tinymce.onAddEditor = new Dispatcher(tinymce, "AddEditor", "editor");
|
return true;
|
||||||
tinymce.onRemoveEditor = new Dispatcher(tinymce, "RemoveEditor", "editor");
|
};
|
||||||
|
}
|
||||||
|
|
||||||
tinymce.util.Cookie = {
|
tinymce.util.Dispatcher = Dispatcher;
|
||||||
get: noop, getHash: noop, remove: noop, set: noop, setHash: noop
|
tinymce.onBeforeUnload = new Dispatcher(tinymce, "BeforeUnload");
|
||||||
};
|
tinymce.onAddEditor = new Dispatcher(tinymce, "AddEditor", "editor");
|
||||||
|
tinymce.onRemoveEditor = new Dispatcher(tinymce, "RemoveEditor", "editor");
|
||||||
|
|
||||||
function patchEditor(editor) {
|
tinymce.util.Cookie = {
|
||||||
|
get: noop, getHash: noop, remove: noop, set: noop, setHash: noop
|
||||||
|
};
|
||||||
|
|
||||||
function translate(str) {
|
function patchEditor(editor) {
|
||||||
var prefix = editor.settings.language || "en";
|
|
||||||
var prefixedStr = [prefix, str].join('.');
|
|
||||||
var translatedStr = tinymce.i18n.translate(prefixedStr);
|
|
||||||
|
|
||||||
return prefixedStr !== translatedStr ? translatedStr : tinymce.i18n.translate(str);
|
function translate(str) {
|
||||||
}
|
var prefix = editor.settings.language || "en";
|
||||||
|
var prefixedStr = [prefix, str].join('.');
|
||||||
|
var translatedStr = tinymce.i18n.translate(prefixedStr);
|
||||||
|
|
||||||
function patchEditorEvents(oldEventNames, argsMap) {
|
return prefixedStr !== translatedStr ? translatedStr : tinymce.i18n.translate(str);
|
||||||
tinymce.each(oldEventNames.split(" "), function(oldName) {
|
}
|
||||||
editor["on" + oldName] = new Dispatcher(editor, oldName, argsMap);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function convertUndoEventArgs(type, event, target) {
|
function patchEditorEvents(oldEventNames, argsMap) {
|
||||||
return [
|
tinymce.each(oldEventNames.split(" "), function (oldName) {
|
||||||
event.level,
|
editor["on" + oldName] = new Dispatcher(editor, oldName, argsMap);
|
||||||
target
|
});
|
||||||
];
|
}
|
||||||
}
|
|
||||||
|
|
||||||
function filterSelectionEvents(needsSelection) {
|
function convertUndoEventArgs(type, event, target) {
|
||||||
return function(type, e) {
|
return [
|
||||||
if ((!e.selection && !needsSelection) || e.selection == needsSelection) {
|
event.level,
|
||||||
return [e];
|
target
|
||||||
}
|
];
|
||||||
};
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (editor.controlManager) {
|
function filterSelectionEvents(needsSelection) {
|
||||||
return;
|
return function (type, e) {
|
||||||
}
|
if ((!e.selection && !needsSelection) || e.selection == needsSelection) {
|
||||||
|
return [e];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
function cmNoop() {
|
if (editor.controlManager) {
|
||||||
var obj = {}, methods = 'add addMenu addSeparator collapse createMenu destroy displayColor expand focus ' +
|
return;
|
||||||
'getLength hasMenus hideMenu isActive isCollapsed isDisabled isRendered isSelected mark ' +
|
}
|
||||||
'postRender remove removeAll renderHTML renderMenu renderNode renderTo select selectByIndex ' +
|
|
||||||
'setActive setAriaProperty setColor setDisabled setSelected setState showMenu update';
|
|
||||||
|
|
||||||
log('editor.controlManager.*');
|
function cmNoop() {
|
||||||
|
var obj = {}, methods = 'add addMenu addSeparator collapse createMenu destroy displayColor expand focus ' +
|
||||||
|
'getLength hasMenus hideMenu isActive isCollapsed isDisabled isRendered isSelected mark ' +
|
||||||
|
'postRender remove removeAll renderHTML renderMenu renderNode renderTo select selectByIndex ' +
|
||||||
|
'setActive setAriaProperty setColor setDisabled setSelected setState showMenu update';
|
||||||
|
|
||||||
function _noop() {
|
log('editor.controlManager.*');
|
||||||
return cmNoop();
|
|
||||||
}
|
|
||||||
|
|
||||||
tinymce.each(methods.split(' '), function(method) {
|
function _noop() {
|
||||||
obj[method] = _noop;
|
return cmNoop();
|
||||||
});
|
}
|
||||||
|
|
||||||
return obj;
|
tinymce.each(methods.split(' '), function (method) {
|
||||||
}
|
obj[method] = _noop;
|
||||||
|
});
|
||||||
|
|
||||||
editor.controlManager = {
|
return obj;
|
||||||
buttons: {},
|
}
|
||||||
|
|
||||||
setDisabled: function(name, state) {
|
editor.controlManager = {
|
||||||
log("controlManager.setDisabled(..)");
|
buttons: {},
|
||||||
|
|
||||||
if (this.buttons[name]) {
|
setDisabled: function (name, state) {
|
||||||
this.buttons[name].disabled(state);
|
log("controlManager.setDisabled(..)");
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
setActive: function(name, state) {
|
if (this.buttons[name]) {
|
||||||
log("controlManager.setActive(..)");
|
this.buttons[name].disabled(state);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
if (this.buttons[name]) {
|
setActive: function (name, state) {
|
||||||
this.buttons[name].active(state);
|
log("controlManager.setActive(..)");
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
onAdd: new Dispatcher(),
|
if (this.buttons[name]) {
|
||||||
onPostRender: new Dispatcher(),
|
this.buttons[name].active(state);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
add: function(obj) {
|
onAdd: new Dispatcher(),
|
||||||
return obj;
|
onPostRender: new Dispatcher(),
|
||||||
},
|
|
||||||
createButton: cmNoop,
|
|
||||||
createColorSplitButton: cmNoop,
|
|
||||||
createControl: cmNoop,
|
|
||||||
createDropMenu: cmNoop,
|
|
||||||
createListBox: cmNoop,
|
|
||||||
createMenuButton: cmNoop,
|
|
||||||
createSeparator: cmNoop,
|
|
||||||
createSplitButton: cmNoop,
|
|
||||||
createToolbar: cmNoop,
|
|
||||||
createToolbarGroup: cmNoop,
|
|
||||||
destroy: noop,
|
|
||||||
get: noop,
|
|
||||||
setControlType: cmNoop
|
|
||||||
};
|
|
||||||
|
|
||||||
patchEditorEvents("PreInit BeforeRenderUI PostRender Load Init Remove Activate Deactivate", "editor");
|
add: function (obj) {
|
||||||
patchEditorEvents("Click MouseUp MouseDown DblClick KeyDown KeyUp KeyPress ContextMenu Paste Submit Reset");
|
return obj;
|
||||||
patchEditorEvents("BeforeExecCommand ExecCommand", "command ui value args"); // args.terminate not supported
|
},
|
||||||
patchEditorEvents("PreProcess PostProcess LoadContent SaveContent Change");
|
createButton: cmNoop,
|
||||||
patchEditorEvents("BeforeSetContent BeforeGetContent SetContent GetContent", filterSelectionEvents(false));
|
createColorSplitButton: cmNoop,
|
||||||
patchEditorEvents("SetProgressState", "state time");
|
createControl: cmNoop,
|
||||||
patchEditorEvents("VisualAid", "element hasVisual");
|
createDropMenu: cmNoop,
|
||||||
patchEditorEvents("Undo Redo", convertUndoEventArgs);
|
createListBox: cmNoop,
|
||||||
|
createMenuButton: cmNoop,
|
||||||
|
createSeparator: cmNoop,
|
||||||
|
createSplitButton: cmNoop,
|
||||||
|
createToolbar: cmNoop,
|
||||||
|
createToolbarGroup: cmNoop,
|
||||||
|
destroy: noop,
|
||||||
|
get: noop,
|
||||||
|
setControlType: cmNoop
|
||||||
|
};
|
||||||
|
|
||||||
patchEditorEvents("NodeChange", function(type, e) {
|
patchEditorEvents("PreInit BeforeRenderUI PostRender Load Init Remove Activate Deactivate", "editor");
|
||||||
return [
|
patchEditorEvents("Click MouseUp MouseDown DblClick KeyDown KeyUp KeyPress ContextMenu Paste Submit Reset");
|
||||||
editor.controlManager,
|
patchEditorEvents("BeforeExecCommand ExecCommand", "command ui value args"); // args.terminate not supported
|
||||||
e.element,
|
patchEditorEvents("PreProcess PostProcess LoadContent SaveContent Change");
|
||||||
editor.selection.isCollapsed(),
|
patchEditorEvents("BeforeSetContent BeforeGetContent SetContent GetContent", filterSelectionEvents(false));
|
||||||
e
|
patchEditorEvents("SetProgressState", "state time");
|
||||||
];
|
patchEditorEvents("VisualAid", "element hasVisual");
|
||||||
});
|
patchEditorEvents("Undo Redo", convertUndoEventArgs);
|
||||||
|
|
||||||
var originalAddButton = editor.addButton;
|
patchEditorEvents("NodeChange", function (type, e) {
|
||||||
editor.addButton = function(name, settings) {
|
return [
|
||||||
var originalOnPostRender;
|
editor.controlManager,
|
||||||
|
e.element,
|
||||||
|
editor.selection.isCollapsed(),
|
||||||
|
e
|
||||||
|
];
|
||||||
|
});
|
||||||
|
|
||||||
function patchedPostRender() {
|
var originalAddButton = editor.addButton;
|
||||||
editor.controlManager.buttons[name] = this;
|
editor.addButton = function (name, settings) {
|
||||||
|
var originalOnPostRender;
|
||||||
|
|
||||||
if (originalOnPostRender) {
|
function patchedPostRender() {
|
||||||
return originalOnPostRender.apply(this, arguments);
|
editor.controlManager.buttons[name] = this;
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (var key in settings) {
|
if (originalOnPostRender) {
|
||||||
if (key.toLowerCase() === "onpostrender") {
|
return originalOnPostRender.apply(this, arguments);
|
||||||
originalOnPostRender = settings[key];
|
}
|
||||||
settings.onPostRender = patchedPostRender;
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!originalOnPostRender) {
|
for (var key in settings) {
|
||||||
settings.onPostRender = patchedPostRender;
|
if (key.toLowerCase() === "onpostrender") {
|
||||||
}
|
originalOnPostRender = settings[key];
|
||||||
|
settings.onPostRender = patchedPostRender;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (settings.title) {
|
if (!originalOnPostRender) {
|
||||||
settings.title = translate(settings.title);
|
settings.onPostRender = patchedPostRender;
|
||||||
}
|
}
|
||||||
|
|
||||||
return originalAddButton.call(this, name, settings);
|
if (settings.title) {
|
||||||
};
|
settings.title = translate(settings.title);
|
||||||
|
}
|
||||||
|
|
||||||
editor.on('init', function() {
|
return originalAddButton.call(this, name, settings);
|
||||||
var undoManager = editor.undoManager, selection = editor.selection;
|
};
|
||||||
|
|
||||||
undoManager.onUndo = new Dispatcher(editor, "Undo", convertUndoEventArgs, null, undoManager);
|
editor.on('init', function () {
|
||||||
undoManager.onRedo = new Dispatcher(editor, "Redo", convertUndoEventArgs, null, undoManager);
|
var undoManager = editor.undoManager, selection = editor.selection;
|
||||||
undoManager.onBeforeAdd = new Dispatcher(editor, "BeforeAddUndo", null, undoManager);
|
|
||||||
undoManager.onAdd = new Dispatcher(editor, "AddUndo", null, undoManager);
|
|
||||||
|
|
||||||
selection.onBeforeGetContent = new Dispatcher(editor, "BeforeGetContent", filterSelectionEvents(true), selection);
|
undoManager.onUndo = new Dispatcher(editor, "Undo", convertUndoEventArgs, null, undoManager);
|
||||||
selection.onGetContent = new Dispatcher(editor, "GetContent", filterSelectionEvents(true), selection);
|
undoManager.onRedo = new Dispatcher(editor, "Redo", convertUndoEventArgs, null, undoManager);
|
||||||
selection.onBeforeSetContent = new Dispatcher(editor, "BeforeSetContent", filterSelectionEvents(true), selection);
|
undoManager.onBeforeAdd = new Dispatcher(editor, "BeforeAddUndo", null, undoManager);
|
||||||
selection.onSetContent = new Dispatcher(editor, "SetContent", filterSelectionEvents(true), selection);
|
undoManager.onAdd = new Dispatcher(editor, "AddUndo", null, undoManager);
|
||||||
});
|
|
||||||
|
|
||||||
editor.on('BeforeRenderUI', function() {
|
selection.onBeforeGetContent = new Dispatcher(editor, "BeforeGetContent", filterSelectionEvents(true), selection);
|
||||||
var windowManager = editor.windowManager;
|
selection.onGetContent = new Dispatcher(editor, "GetContent", filterSelectionEvents(true), selection);
|
||||||
|
selection.onBeforeSetContent = new Dispatcher(editor, "BeforeSetContent", filterSelectionEvents(true), selection);
|
||||||
|
selection.onSetContent = new Dispatcher(editor, "SetContent", filterSelectionEvents(true), selection);
|
||||||
|
});
|
||||||
|
|
||||||
windowManager.onOpen = new Dispatcher();
|
editor.on('BeforeRenderUI', function () {
|
||||||
windowManager.onClose = new Dispatcher();
|
var windowManager = editor.windowManager;
|
||||||
windowManager.createInstance = function(className, a, b, c, d, e) {
|
|
||||||
log("windowManager.createInstance(..)");
|
|
||||||
|
|
||||||
var constr = tinymce.resolve(className);
|
windowManager.onOpen = new Dispatcher();
|
||||||
return new constr(a, b, c, d, e);
|
windowManager.onClose = new Dispatcher();
|
||||||
};
|
windowManager.createInstance = function (className, a, b, c, d, e) {
|
||||||
});
|
log("windowManager.createInstance(..)");
|
||||||
}
|
|
||||||
|
|
||||||
tinymce.on('SetupEditor', patchEditor);
|
var constr = tinymce.resolve(className);
|
||||||
tinymce.PluginManager.add("compat3x", patchEditor);
|
return new constr(a, b, c, d, e);
|
||||||
|
};
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
tinymce.addI18n = function(prefix, o) {
|
tinymce.on('SetupEditor', patchEditor);
|
||||||
var I18n = tinymce.util.I18n, each = tinymce.each;
|
tinymce.PluginManager.add("compat3x", patchEditor);
|
||||||
|
|
||||||
if (typeof prefix == "string" && prefix.indexOf('.') === -1) {
|
tinymce.addI18n = function (prefix, o) {
|
||||||
I18n.add(prefix, o);
|
var I18n = tinymce.util.I18n, each = tinymce.each;
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!tinymce.is(prefix, 'string')) {
|
if (typeof prefix == "string" && prefix.indexOf('.') === -1) {
|
||||||
each(prefix, function(o, lc) {
|
I18n.add(prefix, o);
|
||||||
each(o, function(o, g) {
|
return;
|
||||||
each(o, function(o, k) {
|
}
|
||||||
if (g === 'common') {
|
|
||||||
I18n.data[lc + '.' + k] = o;
|
if (!tinymce.is(prefix, 'string')) {
|
||||||
} else {
|
each(prefix, function (o, lc) {
|
||||||
I18n.data[lc + '.' + g + '.' + k] = o;
|
each(o, function (o, g) {
|
||||||
}
|
each(o, function (o, k) {
|
||||||
});
|
if (g === 'common') {
|
||||||
});
|
I18n.data[lc + '.' + k] = o;
|
||||||
});
|
} else {
|
||||||
} else {
|
I18n.data[lc + '.' + g + '.' + k] = o;
|
||||||
each(o, function(o, k) {
|
}
|
||||||
I18n.data[prefix + '.' + k] = o;
|
});
|
||||||
});
|
});
|
||||||
}
|
});
|
||||||
};
|
} else {
|
||||||
|
each(o, function (o, k) {
|
||||||
|
I18n.data[prefix + '.' + k] = o;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
})(tinymce);
|
})(tinymce);
|
||||||
|
@ -1 +1 @@
|
|||||||
!function(e){function t(){}function n(e){!o&&window&&window.console&&(o=!0,console.log("Deprecated TinyMCE API call: "+e))}function r(e,r,i,o){return e=e||this,r?(this.add=function(t,a,s){function l(n){var s=[];if("string"==typeof i&&(i=i.split(" ")),i&&"function"!=typeof i)for(var l=0;l<i.length;l++)s.push(n[i[l]]);("function"!=typeof i||(s=i(r,n,e)))&&(i||(s=[n]),s.unshift(o||e),t.apply(a||o||e,s)===!1&&n.stopImmediatePropagation())}return n("<target>.on"+r+".add(..)"),e.on(r,l,s),l},this.addToTop=function(e,t){this.add(e,t,!0)},this.remove=function(t){return e.off(r,t)},void(this.dispatch=function(){return e.fire(r),!0})):void(this.add=this.addToTop=this.remove=this.dispatch=t)}function i(i){function o(t){var n=i.settings.language||"en",r=[n,t].join("."),o=e.i18n.translate(r);return r!==o?o:e.i18n.translate(t)}function a(t,n){e.each(t.split(" "),function(e){i["on"+e]=new r(i,e,n)})}function s(e,t,n){return[t.level,n]}function l(e){return function(t,n){if(!n.selection&&!e||n.selection==e)return[n]}}function u(){function t(){return u()}var r={},i="add addMenu addSeparator collapse createMenu destroy displayColor expand focus getLength hasMenus hideMenu isActive isCollapsed isDisabled isRendered isSelected mark postRender remove removeAll renderHTML renderMenu renderNode renderTo select selectByIndex setActive setAriaProperty setColor setDisabled setSelected setState showMenu update";return n("editor.controlManager.*"),e.each(i.split(" "),function(e){r[e]=t}),r}if(!i.controlManager){i.controlManager={buttons:{},setDisabled:function(e,t){n("controlManager.setDisabled(..)"),this.buttons[e]&&this.buttons[e].disabled(t)},setActive:function(e,t){n("controlManager.setActive(..)"),this.buttons[e]&&this.buttons[e].active(t)},onAdd:new r,onPostRender:new r,add:function(e){return e},createButton:u,createColorSplitButton:u,createControl:u,createDropMenu:u,createListBox:u,createMenuButton:u,createSeparator:u,createSplitButton:u,createToolbar:u,createToolbarGroup:u,destroy:t,get:t,setControlType:u},a("PreInit BeforeRenderUI PostRender Load Init Remove Activate Deactivate","editor"),a("Click MouseUp MouseDown DblClick KeyDown KeyUp KeyPress ContextMenu Paste Submit Reset"),a("BeforeExecCommand ExecCommand","command ui value args"),a("PreProcess PostProcess LoadContent SaveContent Change"),a("BeforeSetContent BeforeGetContent SetContent GetContent",l(!1)),a("SetProgressState","state time"),a("VisualAid","element hasVisual"),a("Undo Redo",s),a("NodeChange",function(e,t){return[i.controlManager,t.element,i.selection.isCollapsed(),t]});var c=i.addButton;i.addButton=function(e,t){function n(){if(i.controlManager.buttons[e]=this,r)return r.apply(this,arguments)}var r;for(var a in t)"onpostrender"===a.toLowerCase()&&(r=t[a],t.onPostRender=n);return r||(t.onPostRender=n),t.title&&(t.title=o(t.title)),c.call(this,e,t)},i.on("init",function(){var e=i.undoManager,t=i.selection;e.onUndo=new r(i,"Undo",s,null,e),e.onRedo=new r(i,"Redo",s,null,e),e.onBeforeAdd=new r(i,"BeforeAddUndo",null,e),e.onAdd=new r(i,"AddUndo",null,e),t.onBeforeGetContent=new r(i,"BeforeGetContent",l(!0),t),t.onGetContent=new r(i,"GetContent",l(!0),t),t.onBeforeSetContent=new r(i,"BeforeSetContent",l(!0),t),t.onSetContent=new r(i,"SetContent",l(!0),t)}),i.on("BeforeRenderUI",function(){var t=i.windowManager;t.onOpen=new r,t.onClose=new r,t.createInstance=function(t,r,i,o,a,s){n("windowManager.createInstance(..)");var l=e.resolve(t);return new l(r,i,o,a,s)}})}}var o;e.util.Dispatcher=r,e.onBeforeUnload=new r(e,"BeforeUnload"),e.onAddEditor=new r(e,"AddEditor","editor"),e.onRemoveEditor=new r(e,"RemoveEditor","editor"),e.util.Cookie={get:t,getHash:t,remove:t,set:t,setHash:t},e.on("SetupEditor",i),e.PluginManager.add("compat3x",i),e.addI18n=function(t,n){var r=e.util.I18n,i=e.each;return"string"==typeof t&&t.indexOf(".")===-1?void r.add(t,n):void(e.is(t,"string")?i(n,function(e,n){r.data[t+"."+n]=e}):i(t,function(e,t){i(e,function(e,n){i(e,function(e,i){"common"===n?r.data[t+"."+i]=e:r.data[t+"."+n+"."+i]=e})})}))}}(tinymce);
|
!function(a){function b(){}function c(a){!f&&window&&window.console&&(f=!0,console.log("Deprecated TinyMCE API call: "+a))}function d(a,d,e,f){a=a||this;var g=[];return d?(this.add=function(b,h,i){function j(c){var g=[];if("string"==typeof e&&(e=e.split(" ")),e&&"function"!=typeof e)for(var i=0;i<e.length;i++)g.push(c[e[i]]);("function"!=typeof e||(g=e(d,c,a)))&&(e||(g=[c]),g.unshift(f||a),b.apply(h||f||a,g)===!1&&c.stopImmediatePropagation())}c("<target>.on"+d+".add(..)"),a.on(d,j,i);var k={original:b,patched:j};return g.push(k),j},this.addToTop=function(a,b){this.add(a,b,!0)},this.remove=function(b){return g.forEach(function(c,e){if(c.original===b)return g.splice(e,1),a.off(d,c.patched)}),a.off(d,b)},void(this.dispatch=function(){return a.fire(d),!0})):void(this.add=this.addToTop=this.remove=this.dispatch=b)}function e(e){function f(b){var c=e.settings.language||"en",d=[c,b].join("."),f=a.i18n.translate(d);return d!==f?f:a.i18n.translate(b)}function g(b,c){a.each(b.split(" "),function(a){e["on"+a]=new d(e,a,c)})}function h(a,b,c){return[b.level,c]}function i(a){return function(b,c){if(!c.selection&&!a||c.selection==a)return[c]}}function j(){function b(){return j()}var d={},e="add addMenu addSeparator collapse createMenu destroy displayColor expand focus getLength hasMenus hideMenu isActive isCollapsed isDisabled isRendered isSelected mark postRender remove removeAll renderHTML renderMenu renderNode renderTo select selectByIndex setActive setAriaProperty setColor setDisabled setSelected setState showMenu update";return c("editor.controlManager.*"),a.each(e.split(" "),function(a){d[a]=b}),d}if(!e.controlManager){e.controlManager={buttons:{},setDisabled:function(a,b){c("controlManager.setDisabled(..)"),this.buttons[a]&&this.buttons[a].disabled(b)},setActive:function(a,b){c("controlManager.setActive(..)"),this.buttons[a]&&this.buttons[a].active(b)},onAdd:new d,onPostRender:new d,add:function(a){return a},createButton:j,createColorSplitButton:j,createControl:j,createDropMenu:j,createListBox:j,createMenuButton:j,createSeparator:j,createSplitButton:j,createToolbar:j,createToolbarGroup:j,destroy:b,get:b,setControlType:j},g("PreInit BeforeRenderUI PostRender Load Init Remove Activate Deactivate","editor"),g("Click MouseUp MouseDown DblClick KeyDown KeyUp KeyPress ContextMenu Paste Submit Reset"),g("BeforeExecCommand ExecCommand","command ui value args"),g("PreProcess PostProcess LoadContent SaveContent Change"),g("BeforeSetContent BeforeGetContent SetContent GetContent",i(!1)),g("SetProgressState","state time"),g("VisualAid","element hasVisual"),g("Undo Redo",h),g("NodeChange",function(a,b){return[e.controlManager,b.element,e.selection.isCollapsed(),b]});var k=e.addButton;e.addButton=function(a,b){function c(){if(e.controlManager.buttons[a]=this,d)return d.apply(this,arguments)}var d;for(var g in b)"onpostrender"===g.toLowerCase()&&(d=b[g],b.onPostRender=c);return d||(b.onPostRender=c),b.title&&(b.title=f(b.title)),k.call(this,a,b)},e.on("init",function(){var a=e.undoManager,b=e.selection;a.onUndo=new d(e,"Undo",h,null,a),a.onRedo=new d(e,"Redo",h,null,a),a.onBeforeAdd=new d(e,"BeforeAddUndo",null,a),a.onAdd=new d(e,"AddUndo",null,a),b.onBeforeGetContent=new d(e,"BeforeGetContent",i(!0),b),b.onGetContent=new d(e,"GetContent",i(!0),b),b.onBeforeSetContent=new d(e,"BeforeSetContent",i(!0),b),b.onSetContent=new d(e,"SetContent",i(!0),b)}),e.on("BeforeRenderUI",function(){var b=e.windowManager;b.onOpen=new d,b.onClose=new d,b.createInstance=function(b,d,e,f,g,h){c("windowManager.createInstance(..)");var i=a.resolve(b);return new i(d,e,f,g,h)}})}}var f;a.util.Dispatcher=d,a.onBeforeUnload=new d(a,"BeforeUnload"),a.onAddEditor=new d(a,"AddEditor","editor"),a.onRemoveEditor=new d(a,"RemoveEditor","editor"),a.util.Cookie={get:b,getHash:b,remove:b,set:b,setHash:b},a.on("SetupEditor",e),a.PluginManager.add("compat3x",e),a.addI18n=function(b,c){var d=a.util.I18n,e=a.each;return"string"==typeof b&&b.indexOf(".")===-1?void d.add(b,c):void(a.is(b,"string")?e(c,function(a,c){d.data[b+"."+c]=a}):e(b,function(a,b){e(a,function(a,c){e(a,function(a,e){"common"===c?d.data[b+"."+e]=a:d.data[b+"."+c+"."+e]=a})})}))}}(tinymce);
|
@ -1,64 +1,207 @@
|
|||||||
|
(function () {
|
||||||
|
|
||||||
|
var defs = {}; // id -> {dependencies, definition, instance (possibly undefined)}
|
||||||
|
|
||||||
|
// Used when there is no 'main' module.
|
||||||
|
// The name is probably (hopefully) unique so minification removes for releases.
|
||||||
|
var register_3795 = function (id) {
|
||||||
|
var module = dem(id);
|
||||||
|
var fragments = id.split('.');
|
||||||
|
var target = Function('return this;')();
|
||||||
|
for (var i = 0; i < fragments.length - 1; ++i) {
|
||||||
|
if (target[fragments[i]] === undefined)
|
||||||
|
target[fragments[i]] = {};
|
||||||
|
target = target[fragments[i]];
|
||||||
|
}
|
||||||
|
target[fragments[fragments.length - 1]] = module;
|
||||||
|
};
|
||||||
|
|
||||||
|
var instantiate = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
var dependencies = actual.deps;
|
||||||
|
var definition = actual.defn;
|
||||||
|
var len = dependencies.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances[i] = dem(dependencies[i]);
|
||||||
|
var defResult = definition.apply(null, instances);
|
||||||
|
if (defResult === undefined)
|
||||||
|
throw 'module [' + id + '] returned undefined';
|
||||||
|
actual.instance = defResult;
|
||||||
|
};
|
||||||
|
|
||||||
|
var def = function (id, dependencies, definition) {
|
||||||
|
if (typeof id !== 'string')
|
||||||
|
throw 'module id must be a string';
|
||||||
|
else if (dependencies === undefined)
|
||||||
|
throw 'no dependencies for ' + id;
|
||||||
|
else if (definition === undefined)
|
||||||
|
throw 'no definition function for ' + id;
|
||||||
|
defs[id] = {
|
||||||
|
deps: dependencies,
|
||||||
|
defn: definition,
|
||||||
|
instance: undefined
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var dem = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
if (actual === undefined)
|
||||||
|
throw 'module [' + id + '] was undefined';
|
||||||
|
else if (actual.instance === undefined)
|
||||||
|
instantiate(id);
|
||||||
|
return actual.instance;
|
||||||
|
};
|
||||||
|
|
||||||
|
var req = function (ids, callback) {
|
||||||
|
var len = ids.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances.push(dem(ids[i]));
|
||||||
|
callback.apply(null, callback);
|
||||||
|
};
|
||||||
|
|
||||||
|
var ephox = {};
|
||||||
|
|
||||||
|
ephox.bolt = {
|
||||||
|
module: {
|
||||||
|
api: {
|
||||||
|
define: def,
|
||||||
|
require: req,
|
||||||
|
demand: dem
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var define = def;
|
||||||
|
var require = req;
|
||||||
|
var demand = dem;
|
||||||
|
// this helps with minificiation when using a lot of global references
|
||||||
|
var defineGlobal = function (id, ref) {
|
||||||
|
define(id, [], function () { return ref; });
|
||||||
|
};
|
||||||
|
/*jsc
|
||||||
|
["tinymce.plugins.directionality.Plugin","tinymce.core.PluginManager","tinymce.core.util.Tools","global!tinymce.util.Tools.resolve"]
|
||||||
|
jsc*/
|
||||||
|
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
/**
|
/**
|
||||||
* plugin.js
|
* ResolveGlobal.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*global tinymce:true */
|
define(
|
||||||
|
'tinymce.core.PluginManager',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.PluginManager');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
tinymce.PluginManager.add('directionality', function(editor) {
|
/**
|
||||||
function setDir(dir) {
|
* ResolveGlobal.js
|
||||||
var dom = editor.dom, curDir, blocks = editor.selection.getSelectedBlocks();
|
*
|
||||||
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
if (blocks.length) {
|
define(
|
||||||
curDir = dom.getAttrib(blocks[0], "dir");
|
'tinymce.core.util.Tools',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.util.Tools');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
tinymce.each(blocks, function(block) {
|
/**
|
||||||
// Add dir to block if the parent block doesn't already have that dir
|
* Plugin.js
|
||||||
if (!dom.getParent(block.parentNode, "*[dir='" + dir + "']", dom.getRoot())) {
|
*
|
||||||
if (curDir != dir) {
|
* Released under LGPL License.
|
||||||
dom.setAttrib(block, "dir", dir);
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
} else {
|
*
|
||||||
dom.setAttrib(block, "dir", null);
|
* License: http://www.tinymce.com/license
|
||||||
}
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
}
|
*/
|
||||||
});
|
|
||||||
|
|
||||||
editor.nodeChanged();
|
/**
|
||||||
}
|
* This class contains all core logic for the directionality plugin.
|
||||||
}
|
*
|
||||||
|
* @class tinymce.directionality.Plugin
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
'tinymce.plugins.directionality.Plugin',
|
||||||
|
[
|
||||||
|
'tinymce.core.PluginManager',
|
||||||
|
'tinymce.core.util.Tools'
|
||||||
|
],
|
||||||
|
function (PluginManager, Tools) {
|
||||||
|
PluginManager.add('directionality', function (editor) {
|
||||||
|
function setDir(dir) {
|
||||||
|
var dom = editor.dom, curDir, blocks = editor.selection.getSelectedBlocks();
|
||||||
|
|
||||||
function generateSelector(dir) {
|
if (blocks.length) {
|
||||||
var selector = [];
|
curDir = dom.getAttrib(blocks[0], "dir");
|
||||||
|
|
||||||
tinymce.each('h1 h2 h3 h4 h5 h6 div p'.split(' '), function(name) {
|
Tools.each(blocks, function (block) {
|
||||||
selector.push(name + '[dir=' + dir + ']');
|
// Add dir to block if the parent block doesn't already have that dir
|
||||||
});
|
if (!dom.getParent(block.parentNode, "*[dir='" + dir + "']", dom.getRoot())) {
|
||||||
|
if (curDir != dir) {
|
||||||
|
dom.setAttrib(block, "dir", dir);
|
||||||
|
} else {
|
||||||
|
dom.setAttrib(block, "dir", null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
return selector.join(',');
|
editor.nodeChanged();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
editor.addCommand('mceDirectionLTR', function() {
|
function generateSelector(dir) {
|
||||||
setDir("ltr");
|
var selector = [];
|
||||||
});
|
|
||||||
|
|
||||||
editor.addCommand('mceDirectionRTL', function() {
|
Tools.each('h1 h2 h3 h4 h5 h6 div p'.split(' '), function (name) {
|
||||||
setDir("rtl");
|
selector.push(name + '[dir=' + dir + ']');
|
||||||
});
|
});
|
||||||
|
|
||||||
editor.addButton('ltr', {
|
return selector.join(',');
|
||||||
title: 'Left to right',
|
}
|
||||||
cmd: 'mceDirectionLTR',
|
|
||||||
stateSelector: generateSelector('ltr')
|
|
||||||
});
|
|
||||||
|
|
||||||
editor.addButton('rtl', {
|
editor.addCommand('mceDirectionLTR', function () {
|
||||||
title: 'Right to left',
|
setDir("ltr");
|
||||||
cmd: 'mceDirectionRTL',
|
});
|
||||||
stateSelector: generateSelector('rtl')
|
|
||||||
});
|
editor.addCommand('mceDirectionRTL', function () {
|
||||||
});
|
setDir("rtl");
|
||||||
|
});
|
||||||
|
|
||||||
|
editor.addButton('ltr', {
|
||||||
|
title: 'Left to right',
|
||||||
|
cmd: 'mceDirectionLTR',
|
||||||
|
stateSelector: generateSelector('ltr')
|
||||||
|
});
|
||||||
|
|
||||||
|
editor.addButton('rtl', {
|
||||||
|
title: 'Right to left',
|
||||||
|
cmd: 'mceDirectionRTL',
|
||||||
|
stateSelector: generateSelector('rtl')
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
return function () { };
|
||||||
|
}
|
||||||
|
);
|
||||||
|
dem('tinymce.plugins.directionality.Plugin')();
|
||||||
|
})();
|
||||||
|
@ -1 +1 @@
|
|||||||
tinymce.PluginManager.add("directionality",function(e){function t(t){var n,r=e.dom,i=e.selection.getSelectedBlocks();i.length&&(n=r.getAttrib(i[0],"dir"),tinymce.each(i,function(e){r.getParent(e.parentNode,"*[dir='"+t+"']",r.getRoot())||(n!=t?r.setAttrib(e,"dir",t):r.setAttrib(e,"dir",null))}),e.nodeChanged())}function n(e){var t=[];return tinymce.each("h1 h2 h3 h4 h5 h6 div p".split(" "),function(n){t.push(n+"[dir="+e+"]")}),t.join(",")}e.addCommand("mceDirectionLTR",function(){t("ltr")}),e.addCommand("mceDirectionRTL",function(){t("rtl")}),e.addButton("ltr",{title:"Left to right",cmd:"mceDirectionLTR",stateSelector:n("ltr")}),e.addButton("rtl",{title:"Right to left",cmd:"mceDirectionRTL",stateSelector:n("rtl")})});
|
!function(){var a={},b=function(b){for(var c=a[b],e=c.deps,f=c.defn,g=e.length,h=new Array(g),i=0;i<g;++i)h[i]=d(e[i]);var j=f.apply(null,h);if(void 0===j)throw"module ["+b+"] returned undefined";c.instance=j},c=function(b,c,d){if("string"!=typeof b)throw"module id must be a string";if(void 0===c)throw"no dependencies for "+b;if(void 0===d)throw"no definition function for "+b;a[b]={deps:c,defn:d,instance:void 0}},d=function(c){var d=a[c];if(void 0===d)throw"module ["+c+"] was undefined";return void 0===d.instance&&b(c),d.instance},e=function(a,b){for(var c=a.length,e=new Array(c),f=0;f<c;++f)e.push(d(a[f]));b.apply(null,b)},f={};f.bolt={module:{api:{define:c,require:e,demand:d}}};var g=c,h=function(a,b){g(a,[],function(){return b})};h("3",tinymce.util.Tools.resolve),g("1",["3"],function(a){return a("tinymce.PluginManager")}),g("2",["3"],function(a){return a("tinymce.util.Tools")}),g("0",["1","2"],function(a,b){return a.add("directionality",function(a){function c(c){var d,e=a.dom,f=a.selection.getSelectedBlocks();f.length&&(d=e.getAttrib(f[0],"dir"),b.each(f,function(a){e.getParent(a.parentNode,"*[dir='"+c+"']",e.getRoot())||(d!=c?e.setAttrib(a,"dir",c):e.setAttrib(a,"dir",null))}),a.nodeChanged())}function d(a){var c=[];return b.each("h1 h2 h3 h4 h5 h6 div p".split(" "),function(b){c.push(b+"[dir="+a+"]")}),c.join(",")}a.addCommand("mceDirectionLTR",function(){c("ltr")}),a.addCommand("mceDirectionRTL",function(){c("rtl")}),a.addButton("ltr",{title:"Left to right",cmd:"mceDirectionLTR",stateSelector:d("ltr")}),a.addButton("rtl",{title:"Right to left",cmd:"mceDirectionRTL",stateSelector:d("rtl")})}),function(){}}),d("0")()}();
|
@ -1,154 +1,299 @@
|
|||||||
|
(function () {
|
||||||
|
|
||||||
|
var defs = {}; // id -> {dependencies, definition, instance (possibly undefined)}
|
||||||
|
|
||||||
|
// Used when there is no 'main' module.
|
||||||
|
// The name is probably (hopefully) unique so minification removes for releases.
|
||||||
|
var register_3795 = function (id) {
|
||||||
|
var module = dem(id);
|
||||||
|
var fragments = id.split('.');
|
||||||
|
var target = Function('return this;')();
|
||||||
|
for (var i = 0; i < fragments.length - 1; ++i) {
|
||||||
|
if (target[fragments[i]] === undefined)
|
||||||
|
target[fragments[i]] = {};
|
||||||
|
target = target[fragments[i]];
|
||||||
|
}
|
||||||
|
target[fragments[fragments.length - 1]] = module;
|
||||||
|
};
|
||||||
|
|
||||||
|
var instantiate = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
var dependencies = actual.deps;
|
||||||
|
var definition = actual.defn;
|
||||||
|
var len = dependencies.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances[i] = dem(dependencies[i]);
|
||||||
|
var defResult = definition.apply(null, instances);
|
||||||
|
if (defResult === undefined)
|
||||||
|
throw 'module [' + id + '] returned undefined';
|
||||||
|
actual.instance = defResult;
|
||||||
|
};
|
||||||
|
|
||||||
|
var def = function (id, dependencies, definition) {
|
||||||
|
if (typeof id !== 'string')
|
||||||
|
throw 'module id must be a string';
|
||||||
|
else if (dependencies === undefined)
|
||||||
|
throw 'no dependencies for ' + id;
|
||||||
|
else if (definition === undefined)
|
||||||
|
throw 'no definition function for ' + id;
|
||||||
|
defs[id] = {
|
||||||
|
deps: dependencies,
|
||||||
|
defn: definition,
|
||||||
|
instance: undefined
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var dem = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
if (actual === undefined)
|
||||||
|
throw 'module [' + id + '] was undefined';
|
||||||
|
else if (actual.instance === undefined)
|
||||||
|
instantiate(id);
|
||||||
|
return actual.instance;
|
||||||
|
};
|
||||||
|
|
||||||
|
var req = function (ids, callback) {
|
||||||
|
var len = ids.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances.push(dem(ids[i]));
|
||||||
|
callback.apply(null, callback);
|
||||||
|
};
|
||||||
|
|
||||||
|
var ephox = {};
|
||||||
|
|
||||||
|
ephox.bolt = {
|
||||||
|
module: {
|
||||||
|
api: {
|
||||||
|
define: def,
|
||||||
|
require: req,
|
||||||
|
demand: dem
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var define = def;
|
||||||
|
var require = req;
|
||||||
|
var demand = dem;
|
||||||
|
// this helps with minificiation when using a lot of global references
|
||||||
|
var defineGlobal = function (id, ref) {
|
||||||
|
define(id, [], function () { return ref; });
|
||||||
|
};
|
||||||
|
/*jsc
|
||||||
|
["tinymce.plugins.fullscreen.Plugin","tinymce.core.dom.DOMUtils","tinymce.core.PluginManager","global!tinymce.util.Tools.resolve"]
|
||||||
|
jsc*/
|
||||||
|
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
/**
|
/**
|
||||||
* plugin.js
|
* ResolveGlobal.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*global tinymce:true */
|
define(
|
||||||
|
'tinymce.core.dom.DOMUtils',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.dom.DOMUtils');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
tinymce.PluginManager.add('fullscreen', function(editor) {
|
/**
|
||||||
var fullscreenState = false, DOM = tinymce.DOM, iframeWidth, iframeHeight, resizeHandler;
|
* ResolveGlobal.js
|
||||||
var containerWidth, containerHeight, scrollPos;
|
*
|
||||||
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
if (editor.settings.inline) {
|
define(
|
||||||
return;
|
'tinymce.core.PluginManager',
|
||||||
}
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.PluginManager');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
function getWindowSize() {
|
/**
|
||||||
var w, h, win = window, doc = document;
|
* Plugin.js
|
||||||
var body = doc.body;
|
*
|
||||||
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
// Old IE
|
/**
|
||||||
if (body.offsetWidth) {
|
* This class contains all core logic for the fullscreen plugin.
|
||||||
w = body.offsetWidth;
|
*
|
||||||
h = body.offsetHeight;
|
* @class tinymce.fullscreen.Plugin
|
||||||
}
|
* @private
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
'tinymce.plugins.fullscreen.Plugin',
|
||||||
|
[
|
||||||
|
'tinymce.core.dom.DOMUtils',
|
||||||
|
'tinymce.core.PluginManager'
|
||||||
|
],
|
||||||
|
function (DOMUtils, PluginManager) {
|
||||||
|
var DOM = DOMUtils.DOM;
|
||||||
|
|
||||||
// Modern browsers
|
PluginManager.add('fullscreen', function (editor) {
|
||||||
if (win.innerWidth && win.innerHeight) {
|
var fullscreenState = false, iframeWidth, iframeHeight, resizeHandler;
|
||||||
w = win.innerWidth;
|
var containerWidth, containerHeight, scrollPos;
|
||||||
h = win.innerHeight;
|
|
||||||
}
|
|
||||||
|
|
||||||
return {w: w, h: h};
|
if (editor.settings.inline) {
|
||||||
}
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
function getScrollPos() {
|
function getWindowSize() {
|
||||||
var vp = tinymce.DOM.getViewPort();
|
var w, h, win = window, doc = document;
|
||||||
|
var body = doc.body;
|
||||||
|
|
||||||
return {
|
// Old IE
|
||||||
x: vp.x,
|
if (body.offsetWidth) {
|
||||||
y: vp.y
|
w = body.offsetWidth;
|
||||||
};
|
h = body.offsetHeight;
|
||||||
}
|
}
|
||||||
|
|
||||||
function setScrollPos(pos) {
|
// Modern browsers
|
||||||
scrollTo(pos.x, pos.y);
|
if (win.innerWidth && win.innerHeight) {
|
||||||
}
|
w = win.innerWidth;
|
||||||
|
h = win.innerHeight;
|
||||||
|
}
|
||||||
|
|
||||||
function toggleFullscreen() {
|
return { w: w, h: h };
|
||||||
var body = document.body, documentElement = document.documentElement, editorContainerStyle;
|
}
|
||||||
var editorContainer, iframe, iframeStyle;
|
|
||||||
|
|
||||||
function resize() {
|
function getScrollPos() {
|
||||||
DOM.setStyle(iframe, 'height', getWindowSize().h - (editorContainer.clientHeight - iframe.clientHeight));
|
var vp = DOM.getViewPort();
|
||||||
}
|
|
||||||
|
|
||||||
fullscreenState = !fullscreenState;
|
return {
|
||||||
|
x: vp.x,
|
||||||
|
y: vp.y
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
editorContainer = editor.getContainer();
|
function setScrollPos(pos) {
|
||||||
editorContainerStyle = editorContainer.style;
|
window.scrollTo(pos.x, pos.y);
|
||||||
iframe = editor.getContentAreaContainer().firstChild;
|
}
|
||||||
iframeStyle = iframe.style;
|
|
||||||
|
|
||||||
if (fullscreenState) {
|
function toggleFullscreen() {
|
||||||
scrollPos = getScrollPos();
|
var body = document.body, documentElement = document.documentElement, editorContainerStyle;
|
||||||
iframeWidth = iframeStyle.width;
|
var editorContainer, iframe, iframeStyle;
|
||||||
iframeHeight = iframeStyle.height;
|
|
||||||
iframeStyle.width = iframeStyle.height = '100%';
|
|
||||||
containerWidth = editorContainerStyle.width;
|
|
||||||
containerHeight = editorContainerStyle.height;
|
|
||||||
editorContainerStyle.width = editorContainerStyle.height = '';
|
|
||||||
|
|
||||||
DOM.addClass(body, 'mce-fullscreen');
|
function resize() {
|
||||||
DOM.addClass(documentElement, 'mce-fullscreen');
|
DOM.setStyle(iframe, 'height', getWindowSize().h - (editorContainer.clientHeight - iframe.clientHeight));
|
||||||
DOM.addClass(editorContainer, 'mce-fullscreen');
|
}
|
||||||
|
|
||||||
DOM.bind(window, 'resize', resize);
|
fullscreenState = !fullscreenState;
|
||||||
resize();
|
|
||||||
resizeHandler = resize;
|
|
||||||
} else {
|
|
||||||
iframeStyle.width = iframeWidth;
|
|
||||||
iframeStyle.height = iframeHeight;
|
|
||||||
|
|
||||||
if (containerWidth) {
|
editorContainer = editor.getContainer();
|
||||||
editorContainerStyle.width = containerWidth;
|
editorContainerStyle = editorContainer.style;
|
||||||
}
|
iframe = editor.getContentAreaContainer().firstChild;
|
||||||
|
iframeStyle = iframe.style;
|
||||||
|
|
||||||
if (containerHeight) {
|
if (fullscreenState) {
|
||||||
editorContainerStyle.height = containerHeight;
|
scrollPos = getScrollPos();
|
||||||
}
|
iframeWidth = iframeStyle.width;
|
||||||
|
iframeHeight = iframeStyle.height;
|
||||||
|
iframeStyle.width = iframeStyle.height = '100%';
|
||||||
|
containerWidth = editorContainerStyle.width;
|
||||||
|
containerHeight = editorContainerStyle.height;
|
||||||
|
editorContainerStyle.width = editorContainerStyle.height = '';
|
||||||
|
|
||||||
DOM.removeClass(body, 'mce-fullscreen');
|
DOM.addClass(body, 'mce-fullscreen');
|
||||||
DOM.removeClass(documentElement, 'mce-fullscreen');
|
DOM.addClass(documentElement, 'mce-fullscreen');
|
||||||
DOM.removeClass(editorContainer, 'mce-fullscreen');
|
DOM.addClass(editorContainer, 'mce-fullscreen');
|
||||||
DOM.unbind(window, 'resize', resizeHandler);
|
|
||||||
setScrollPos(scrollPos);
|
|
||||||
}
|
|
||||||
|
|
||||||
editor.fire('FullscreenStateChanged', {state: fullscreenState});
|
DOM.bind(window, 'resize', resize);
|
||||||
}
|
resize();
|
||||||
|
resizeHandler = resize;
|
||||||
|
} else {
|
||||||
|
iframeStyle.width = iframeWidth;
|
||||||
|
iframeStyle.height = iframeHeight;
|
||||||
|
|
||||||
editor.on('init', function() {
|
if (containerWidth) {
|
||||||
editor.addShortcut('Ctrl+Shift+F', '', toggleFullscreen);
|
editorContainerStyle.width = containerWidth;
|
||||||
});
|
}
|
||||||
|
|
||||||
editor.on('remove', function() {
|
if (containerHeight) {
|
||||||
if (resizeHandler) {
|
editorContainerStyle.height = containerHeight;
|
||||||
DOM.unbind(window, 'resize', resizeHandler);
|
}
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
editor.addCommand('mceFullScreen', toggleFullscreen);
|
DOM.removeClass(body, 'mce-fullscreen');
|
||||||
|
DOM.removeClass(documentElement, 'mce-fullscreen');
|
||||||
|
DOM.removeClass(editorContainer, 'mce-fullscreen');
|
||||||
|
DOM.unbind(window, 'resize', resizeHandler);
|
||||||
|
setScrollPos(scrollPos);
|
||||||
|
}
|
||||||
|
|
||||||
editor.addMenuItem('fullscreen', {
|
editor.fire('FullscreenStateChanged', { state: fullscreenState });
|
||||||
text: 'Fullscreen',
|
}
|
||||||
shortcut: 'Ctrl+Shift+F',
|
|
||||||
selectable: true,
|
|
||||||
onClick: function() {
|
|
||||||
toggleFullscreen();
|
|
||||||
editor.focus();
|
|
||||||
},
|
|
||||||
onPostRender: function() {
|
|
||||||
var self = this;
|
|
||||||
|
|
||||||
editor.on('FullscreenStateChanged', function(e) {
|
editor.on('init', function () {
|
||||||
self.active(e.state);
|
editor.addShortcut('Ctrl+Shift+F', '', toggleFullscreen);
|
||||||
});
|
});
|
||||||
},
|
|
||||||
context: 'view'
|
|
||||||
});
|
|
||||||
|
|
||||||
editor.addButton('fullscreen', {
|
editor.on('remove', function () {
|
||||||
tooltip: 'Fullscreen',
|
if (resizeHandler) {
|
||||||
shortcut: 'Ctrl+Shift+F',
|
DOM.unbind(window, 'resize', resizeHandler);
|
||||||
onClick: toggleFullscreen,
|
}
|
||||||
onPostRender: function() {
|
});
|
||||||
var self = this;
|
|
||||||
|
|
||||||
editor.on('FullscreenStateChanged', function(e) {
|
editor.addCommand('mceFullScreen', toggleFullscreen);
|
||||||
self.active(e.state);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return {
|
editor.addMenuItem('fullscreen', {
|
||||||
isFullscreen: function() {
|
text: 'Fullscreen',
|
||||||
return fullscreenState;
|
shortcut: 'Ctrl+Shift+F',
|
||||||
}
|
selectable: true,
|
||||||
};
|
onClick: function () {
|
||||||
});
|
toggleFullscreen();
|
||||||
|
editor.focus();
|
||||||
|
},
|
||||||
|
onPostRender: function () {
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
editor.on('FullscreenStateChanged', function (e) {
|
||||||
|
self.active(e.state);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
context: 'view'
|
||||||
|
});
|
||||||
|
|
||||||
|
editor.addButton('fullscreen', {
|
||||||
|
tooltip: 'Fullscreen',
|
||||||
|
shortcut: 'Ctrl+Shift+F',
|
||||||
|
onClick: toggleFullscreen,
|
||||||
|
onPostRender: function () {
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
editor.on('FullscreenStateChanged', function (e) {
|
||||||
|
self.active(e.state);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return {
|
||||||
|
isFullscreen: function () {
|
||||||
|
return fullscreenState;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
return function () { };
|
||||||
|
}
|
||||||
|
);
|
||||||
|
dem('tinymce.plugins.fullscreen.Plugin')();
|
||||||
|
})();
|
||||||
|
@ -1 +1 @@
|
|||||||
tinymce.PluginManager.add("fullscreen",function(e){function t(){var e,t,n=window,r=document,i=r.body;return i.offsetWidth&&(e=i.offsetWidth,t=i.offsetHeight),n.innerWidth&&n.innerHeight&&(e=n.innerWidth,t=n.innerHeight),{w:e,h:t}}function n(){var e=tinymce.DOM.getViewPort();return{x:e.x,y:e.y}}function r(e){scrollTo(e.x,e.y)}function i(){function i(){f.setStyle(m,"height",t().h-(h.clientHeight-m.clientHeight))}var p,h,m,g,v=document.body,y=document.documentElement;d=!d,h=e.getContainer(),p=h.style,m=e.getContentAreaContainer().firstChild,g=m.style,d?(c=n(),o=g.width,a=g.height,g.width=g.height="100%",l=p.width,u=p.height,p.width=p.height="",f.addClass(v,"mce-fullscreen"),f.addClass(y,"mce-fullscreen"),f.addClass(h,"mce-fullscreen"),f.bind(window,"resize",i),i(),s=i):(g.width=o,g.height=a,l&&(p.width=l),u&&(p.height=u),f.removeClass(v,"mce-fullscreen"),f.removeClass(y,"mce-fullscreen"),f.removeClass(h,"mce-fullscreen"),f.unbind(window,"resize",s),r(c)),e.fire("FullscreenStateChanged",{state:d})}var o,a,s,l,u,c,d=!1,f=tinymce.DOM;if(!e.settings.inline)return e.on("init",function(){e.addShortcut("Ctrl+Shift+F","",i)}),e.on("remove",function(){s&&f.unbind(window,"resize",s)}),e.addCommand("mceFullScreen",i),e.addMenuItem("fullscreen",{text:"Fullscreen",shortcut:"Ctrl+Shift+F",selectable:!0,onClick:function(){i(),e.focus()},onPostRender:function(){var t=this;e.on("FullscreenStateChanged",function(e){t.active(e.state)})},context:"view"}),e.addButton("fullscreen",{tooltip:"Fullscreen",shortcut:"Ctrl+Shift+F",onClick:i,onPostRender:function(){var t=this;e.on("FullscreenStateChanged",function(e){t.active(e.state)})}}),{isFullscreen:function(){return d}}});
|
!function(){var a={},b=function(b){for(var c=a[b],e=c.deps,f=c.defn,g=e.length,h=new Array(g),i=0;i<g;++i)h[i]=d(e[i]);var j=f.apply(null,h);if(void 0===j)throw"module ["+b+"] returned undefined";c.instance=j},c=function(b,c,d){if("string"!=typeof b)throw"module id must be a string";if(void 0===c)throw"no dependencies for "+b;if(void 0===d)throw"no definition function for "+b;a[b]={deps:c,defn:d,instance:void 0}},d=function(c){var d=a[c];if(void 0===d)throw"module ["+c+"] was undefined";return void 0===d.instance&&b(c),d.instance},e=function(a,b){for(var c=a.length,e=new Array(c),f=0;f<c;++f)e.push(d(a[f]));b.apply(null,b)},f={};f.bolt={module:{api:{define:c,require:e,demand:d}}};var g=c,h=function(a,b){g(a,[],function(){return b})};h("3",tinymce.util.Tools.resolve),g("1",["3"],function(a){return a("tinymce.dom.DOMUtils")}),g("2",["3"],function(a){return a("tinymce.PluginManager")}),g("0",["1","2"],function(a,b){var c=a.DOM;return b.add("fullscreen",function(a){function b(){var a,b,c=window,d=document,e=d.body;return e.offsetWidth&&(a=e.offsetWidth,b=e.offsetHeight),c.innerWidth&&c.innerHeight&&(a=c.innerWidth,b=c.innerHeight),{w:a,h:b}}function d(){var a=c.getViewPort();return{x:a.x,y:a.y}}function e(a){window.scrollTo(a.x,a.y)}function f(){function f(){c.setStyle(p,"height",b().h-(o.clientHeight-p.clientHeight))}var n,o,p,q,r=document.body,s=document.documentElement;m=!m,o=a.getContainer(),n=o.style,p=a.getContentAreaContainer().firstChild,q=p.style,m?(l=d(),g=q.width,h=q.height,q.width=q.height="100%",j=n.width,k=n.height,n.width=n.height="",c.addClass(r,"mce-fullscreen"),c.addClass(s,"mce-fullscreen"),c.addClass(o,"mce-fullscreen"),c.bind(window,"resize",f),f(),i=f):(q.width=g,q.height=h,j&&(n.width=j),k&&(n.height=k),c.removeClass(r,"mce-fullscreen"),c.removeClass(s,"mce-fullscreen"),c.removeClass(o,"mce-fullscreen"),c.unbind(window,"resize",i),e(l)),a.fire("FullscreenStateChanged",{state:m})}var g,h,i,j,k,l,m=!1;if(!a.settings.inline)return a.on("init",function(){a.addShortcut("Ctrl+Shift+F","",f)}),a.on("remove",function(){i&&c.unbind(window,"resize",i)}),a.addCommand("mceFullScreen",f),a.addMenuItem("fullscreen",{text:"Fullscreen",shortcut:"Ctrl+Shift+F",selectable:!0,onClick:function(){f(),a.focus()},onPostRender:function(){var b=this;a.on("FullscreenStateChanged",function(a){b.active(a.state)})},context:"view"}),a.addButton("fullscreen",{tooltip:"Fullscreen",shortcut:"Ctrl+Shift+F",onClick:f,onPostRender:function(){var b=this;a.on("FullscreenStateChanged",function(a){b.active(a.state)})}}),{isFullscreen:function(){return m}}}),function(){}}),d("0")()}();
|
@ -1,30 +1,152 @@
|
|||||||
|
(function () {
|
||||||
|
|
||||||
|
var defs = {}; // id -> {dependencies, definition, instance (possibly undefined)}
|
||||||
|
|
||||||
|
// Used when there is no 'main' module.
|
||||||
|
// The name is probably (hopefully) unique so minification removes for releases.
|
||||||
|
var register_3795 = function (id) {
|
||||||
|
var module = dem(id);
|
||||||
|
var fragments = id.split('.');
|
||||||
|
var target = Function('return this;')();
|
||||||
|
for (var i = 0; i < fragments.length - 1; ++i) {
|
||||||
|
if (target[fragments[i]] === undefined)
|
||||||
|
target[fragments[i]] = {};
|
||||||
|
target = target[fragments[i]];
|
||||||
|
}
|
||||||
|
target[fragments[fragments.length - 1]] = module;
|
||||||
|
};
|
||||||
|
|
||||||
|
var instantiate = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
var dependencies = actual.deps;
|
||||||
|
var definition = actual.defn;
|
||||||
|
var len = dependencies.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances[i] = dem(dependencies[i]);
|
||||||
|
var defResult = definition.apply(null, instances);
|
||||||
|
if (defResult === undefined)
|
||||||
|
throw 'module [' + id + '] returned undefined';
|
||||||
|
actual.instance = defResult;
|
||||||
|
};
|
||||||
|
|
||||||
|
var def = function (id, dependencies, definition) {
|
||||||
|
if (typeof id !== 'string')
|
||||||
|
throw 'module id must be a string';
|
||||||
|
else if (dependencies === undefined)
|
||||||
|
throw 'no dependencies for ' + id;
|
||||||
|
else if (definition === undefined)
|
||||||
|
throw 'no definition function for ' + id;
|
||||||
|
defs[id] = {
|
||||||
|
deps: dependencies,
|
||||||
|
defn: definition,
|
||||||
|
instance: undefined
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var dem = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
if (actual === undefined)
|
||||||
|
throw 'module [' + id + '] was undefined';
|
||||||
|
else if (actual.instance === undefined)
|
||||||
|
instantiate(id);
|
||||||
|
return actual.instance;
|
||||||
|
};
|
||||||
|
|
||||||
|
var req = function (ids, callback) {
|
||||||
|
var len = ids.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances.push(dem(ids[i]));
|
||||||
|
callback.apply(null, callback);
|
||||||
|
};
|
||||||
|
|
||||||
|
var ephox = {};
|
||||||
|
|
||||||
|
ephox.bolt = {
|
||||||
|
module: {
|
||||||
|
api: {
|
||||||
|
define: def,
|
||||||
|
require: req,
|
||||||
|
demand: dem
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var define = def;
|
||||||
|
var require = req;
|
||||||
|
var demand = dem;
|
||||||
|
// this helps with minificiation when using a lot of global references
|
||||||
|
var defineGlobal = function (id, ref) {
|
||||||
|
define(id, [], function () { return ref; });
|
||||||
|
};
|
||||||
|
/*jsc
|
||||||
|
["tinymce.plugins.hr.Plugin","tinymce.core.PluginManager","global!tinymce.util.Tools.resolve"]
|
||||||
|
jsc*/
|
||||||
|
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
/**
|
/**
|
||||||
* plugin.js
|
* ResolveGlobal.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*global tinymce:true */
|
define(
|
||||||
|
'tinymce.core.PluginManager',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.PluginManager');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
tinymce.PluginManager.add('hr', function(editor) {
|
/**
|
||||||
editor.addCommand('InsertHorizontalRule', function() {
|
* Plugin.js
|
||||||
editor.execCommand('mceInsertContent', false, '<hr />');
|
*
|
||||||
});
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
editor.addButton('hr', {
|
/**
|
||||||
icon: 'hr',
|
* This class contains all core logic for the hr plugin.
|
||||||
tooltip: 'Horizontal line',
|
*
|
||||||
cmd: 'InsertHorizontalRule'
|
* @class tinymce.hr.Plugin
|
||||||
});
|
* @private
|
||||||
|
*/
|
||||||
|
define(
|
||||||
|
'tinymce.plugins.hr.Plugin',
|
||||||
|
[
|
||||||
|
'tinymce.core.PluginManager'
|
||||||
|
],
|
||||||
|
function (PluginManager) {
|
||||||
|
PluginManager.add('hr', function (editor) {
|
||||||
|
editor.addCommand('InsertHorizontalRule', function () {
|
||||||
|
editor.execCommand('mceInsertContent', false, '<hr />');
|
||||||
|
});
|
||||||
|
|
||||||
editor.addMenuItem('hr', {
|
editor.addButton('hr', {
|
||||||
icon: 'hr',
|
icon: 'hr',
|
||||||
text: 'Horizontal line',
|
tooltip: 'Horizontal line',
|
||||||
cmd: 'InsertHorizontalRule',
|
cmd: 'InsertHorizontalRule'
|
||||||
context: 'insert'
|
});
|
||||||
});
|
|
||||||
});
|
editor.addMenuItem('hr', {
|
||||||
|
icon: 'hr',
|
||||||
|
text: 'Horizontal line',
|
||||||
|
cmd: 'InsertHorizontalRule',
|
||||||
|
context: 'insert'
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
return function () { };
|
||||||
|
}
|
||||||
|
);
|
||||||
|
dem('tinymce.plugins.hr.Plugin')();
|
||||||
|
})();
|
||||||
|
@ -1 +1 @@
|
|||||||
tinymce.PluginManager.add("hr",function(e){e.addCommand("InsertHorizontalRule",function(){e.execCommand("mceInsertContent",!1,"<hr />")}),e.addButton("hr",{icon:"hr",tooltip:"Horizontal line",cmd:"InsertHorizontalRule"}),e.addMenuItem("hr",{icon:"hr",text:"Horizontal line",cmd:"InsertHorizontalRule",context:"insert"})});
|
!function(){var a={},b=function(b){for(var c=a[b],e=c.deps,f=c.defn,g=e.length,h=new Array(g),i=0;i<g;++i)h[i]=d(e[i]);var j=f.apply(null,h);if(void 0===j)throw"module ["+b+"] returned undefined";c.instance=j},c=function(b,c,d){if("string"!=typeof b)throw"module id must be a string";if(void 0===c)throw"no dependencies for "+b;if(void 0===d)throw"no definition function for "+b;a[b]={deps:c,defn:d,instance:void 0}},d=function(c){var d=a[c];if(void 0===d)throw"module ["+c+"] was undefined";return void 0===d.instance&&b(c),d.instance},e=function(a,b){for(var c=a.length,e=new Array(c),f=0;f<c;++f)e.push(d(a[f]));b.apply(null,b)},f={};f.bolt={module:{api:{define:c,require:e,demand:d}}};var g=c,h=function(a,b){g(a,[],function(){return b})};h("2",tinymce.util.Tools.resolve),g("1",["2"],function(a){return a("tinymce.PluginManager")}),g("0",["1"],function(a){return a.add("hr",function(a){a.addCommand("InsertHorizontalRule",function(){a.execCommand("mceInsertContent",!1,"<hr />")}),a.addButton("hr",{icon:"hr",tooltip:"Horizontal line",cmd:"InsertHorizontalRule"}),a.addMenuItem("hr",{icon:"hr",text:"Horizontal line",cmd:"InsertHorizontalRule",context:"insert"})}),function(){}}),d("0")()}();
|
File diff suppressed because it is too large
Load Diff
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
Binary file not shown.
File diff suppressed because it is too large
Load Diff
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,120 +1,348 @@
|
|||||||
|
(function () {
|
||||||
|
|
||||||
|
var defs = {}; // id -> {dependencies, definition, instance (possibly undefined)}
|
||||||
|
|
||||||
|
// Used when there is no 'main' module.
|
||||||
|
// The name is probably (hopefully) unique so minification removes for releases.
|
||||||
|
var register_3795 = function (id) {
|
||||||
|
var module = dem(id);
|
||||||
|
var fragments = id.split('.');
|
||||||
|
var target = Function('return this;')();
|
||||||
|
for (var i = 0; i < fragments.length - 1; ++i) {
|
||||||
|
if (target[fragments[i]] === undefined)
|
||||||
|
target[fragments[i]] = {};
|
||||||
|
target = target[fragments[i]];
|
||||||
|
}
|
||||||
|
target[fragments[fragments.length - 1]] = module;
|
||||||
|
};
|
||||||
|
|
||||||
|
var instantiate = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
var dependencies = actual.deps;
|
||||||
|
var definition = actual.defn;
|
||||||
|
var len = dependencies.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances[i] = dem(dependencies[i]);
|
||||||
|
var defResult = definition.apply(null, instances);
|
||||||
|
if (defResult === undefined)
|
||||||
|
throw 'module [' + id + '] returned undefined';
|
||||||
|
actual.instance = defResult;
|
||||||
|
};
|
||||||
|
|
||||||
|
var def = function (id, dependencies, definition) {
|
||||||
|
if (typeof id !== 'string')
|
||||||
|
throw 'module id must be a string';
|
||||||
|
else if (dependencies === undefined)
|
||||||
|
throw 'no dependencies for ' + id;
|
||||||
|
else if (definition === undefined)
|
||||||
|
throw 'no definition function for ' + id;
|
||||||
|
defs[id] = {
|
||||||
|
deps: dependencies,
|
||||||
|
defn: definition,
|
||||||
|
instance: undefined
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var dem = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
if (actual === undefined)
|
||||||
|
throw 'module [' + id + '] was undefined';
|
||||||
|
else if (actual.instance === undefined)
|
||||||
|
instantiate(id);
|
||||||
|
return actual.instance;
|
||||||
|
};
|
||||||
|
|
||||||
|
var req = function (ids, callback) {
|
||||||
|
var len = ids.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances.push(dem(ids[i]));
|
||||||
|
callback.apply(null, callback);
|
||||||
|
};
|
||||||
|
|
||||||
|
var ephox = {};
|
||||||
|
|
||||||
|
ephox.bolt = {
|
||||||
|
module: {
|
||||||
|
api: {
|
||||||
|
define: def,
|
||||||
|
require: req,
|
||||||
|
demand: dem
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var define = def;
|
||||||
|
var require = req;
|
||||||
|
var demand = dem;
|
||||||
|
// this helps with minificiation when using a lot of global references
|
||||||
|
var defineGlobal = function (id, ref) {
|
||||||
|
define(id, [], function () { return ref; });
|
||||||
|
};
|
||||||
|
/*jsc
|
||||||
|
["tinymce.plugins.tabfocus.Plugin","tinymce.core.PluginManager","tinymce.core.dom.DOMUtils","tinymce.core.util.Tools","tinymce.core.EditorManager","tinymce.core.util.Delay","tinymce.core.Env","global!tinymce.util.Tools.resolve"]
|
||||||
|
jsc*/
|
||||||
|
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
/**
|
/**
|
||||||
* plugin.js
|
* ResolveGlobal.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*global tinymce:true */
|
define(
|
||||||
|
'tinymce.core.PluginManager',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.PluginManager');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
tinymce.PluginManager.add('tabfocus', function(editor) {
|
/**
|
||||||
var DOM = tinymce.DOM, each = tinymce.each, explode = tinymce.explode;
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
function tabCancel(e) {
|
define(
|
||||||
if (e.keyCode === 9 && !e.ctrlKey && !e.altKey && !e.metaKey) {
|
'tinymce.core.dom.DOMUtils',
|
||||||
e.preventDefault();
|
[
|
||||||
}
|
'global!tinymce.util.Tools.resolve'
|
||||||
}
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.dom.DOMUtils');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
function tabHandler(e) {
|
/**
|
||||||
var x, el, v, i;
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
if (e.keyCode !== 9 || e.ctrlKey || e.altKey || e.metaKey || e.isDefaultPrevented()) {
|
define(
|
||||||
return;
|
'tinymce.core.util.Tools',
|
||||||
}
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.util.Tools');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
function find(direction) {
|
/**
|
||||||
el = DOM.select(':input:enabled,*[tabindex]:not(iframe)');
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
function canSelectRecursive(e) {
|
define(
|
||||||
return e.nodeName === "BODY" || (e.type != 'hidden' &&
|
'tinymce.core.EditorManager',
|
||||||
e.style.display != "none" &&
|
[
|
||||||
e.style.visibility != "hidden" && canSelectRecursive(e.parentNode));
|
'global!tinymce.util.Tools.resolve'
|
||||||
}
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.EditorManager');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
function canSelect(el) {
|
/**
|
||||||
return /INPUT|TEXTAREA|BUTTON/.test(el.tagName) && tinymce.get(e.id) && el.tabIndex != -1 && canSelectRecursive(el);
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
each(el, function(e, i) {
|
define(
|
||||||
if (e.id == editor.id) {
|
'tinymce.core.util.Delay',
|
||||||
x = i;
|
[
|
||||||
return false;
|
'global!tinymce.util.Tools.resolve'
|
||||||
}
|
],
|
||||||
});
|
function (resolve) {
|
||||||
if (direction > 0) {
|
return resolve('tinymce.util.Delay');
|
||||||
for (i = x + 1; i < el.length; i++) {
|
}
|
||||||
if (canSelect(el[i])) {
|
);
|
||||||
return el[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for (i = x - 1; i >= 0; i--) {
|
|
||||||
if (canSelect(el[i])) {
|
|
||||||
return el[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
/**
|
||||||
}
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
v = explode(editor.getParam('tab_focus', editor.getParam('tabfocus_elements', ':prev,:next')));
|
define(
|
||||||
|
'tinymce.core.Env',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.Env');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
if (v.length == 1) {
|
/**
|
||||||
v[1] = v[0];
|
* Plugin.js
|
||||||
v[0] = ':prev';
|
*
|
||||||
}
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
// Find element to focus
|
/**
|
||||||
if (e.shiftKey) {
|
* This class contains all core logic for the code plugin.
|
||||||
if (v[0] == ':prev') {
|
*
|
||||||
el = find(-1);
|
* @class tinymce.tabfocus.Plugin
|
||||||
} else {
|
* @private
|
||||||
el = DOM.get(v[0]);
|
*/
|
||||||
}
|
define(
|
||||||
} else {
|
'tinymce.plugins.tabfocus.Plugin',
|
||||||
if (v[1] == ':next') {
|
[
|
||||||
el = find(1);
|
'tinymce.core.PluginManager',
|
||||||
} else {
|
'tinymce.core.dom.DOMUtils',
|
||||||
el = DOM.get(v[1]);
|
'tinymce.core.util.Tools',
|
||||||
}
|
'tinymce.core.EditorManager',
|
||||||
}
|
'tinymce.core.util.Delay',
|
||||||
|
'tinymce.core.Env'
|
||||||
|
],
|
||||||
|
function (PluginManager, DOMUtils, Tools, EditorManager, Delay, Env) {
|
||||||
|
PluginManager.add('tabfocus', function (editor) {
|
||||||
|
var DOM = DOMUtils.DOM;
|
||||||
|
|
||||||
if (el) {
|
function tabCancel(e) {
|
||||||
var focusEditor = tinymce.get(el.id || el.name);
|
if (e.keyCode === 9 && !e.ctrlKey && !e.altKey && !e.metaKey) {
|
||||||
|
e.preventDefault();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (el.id && focusEditor) {
|
function tabHandler(e) {
|
||||||
focusEditor.focus();
|
var x, el, v, i;
|
||||||
} else {
|
|
||||||
tinymce.util.Delay.setTimeout(function() {
|
|
||||||
if (!tinymce.Env.webkit) {
|
|
||||||
window.focus();
|
|
||||||
}
|
|
||||||
|
|
||||||
el.focus();
|
if (e.keyCode !== 9 || e.ctrlKey || e.altKey || e.metaKey || e.isDefaultPrevented()) {
|
||||||
}, 10);
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
e.preventDefault();
|
function find(direction) {
|
||||||
}
|
el = DOM.select(':input:enabled,*[tabindex]:not(iframe)');
|
||||||
}
|
|
||||||
|
|
||||||
editor.on('init', function() {
|
function canSelectRecursive(e) {
|
||||||
if (editor.inline) {
|
return e.nodeName === "BODY" || (e.type != 'hidden' &&
|
||||||
// Remove default tabIndex in inline mode
|
e.style.display != "none" &&
|
||||||
tinymce.DOM.setAttrib(editor.getBody(), 'tabIndex', null);
|
e.style.visibility != "hidden" && canSelectRecursive(e.parentNode));
|
||||||
}
|
}
|
||||||
|
|
||||||
editor.on('keyup', tabCancel);
|
function canSelect(el) {
|
||||||
|
return /INPUT|TEXTAREA|BUTTON/.test(el.tagName) && EditorManager.get(e.id) && el.tabIndex != -1 && canSelectRecursive(el);
|
||||||
|
}
|
||||||
|
|
||||||
if (tinymce.Env.gecko) {
|
Tools.each(el, function (e, i) {
|
||||||
editor.on('keypress keydown', tabHandler);
|
if (e.id == editor.id) {
|
||||||
} else {
|
x = i;
|
||||||
editor.on('keydown', tabHandler);
|
return false;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
if (direction > 0) {
|
||||||
|
for (i = x + 1; i < el.length; i++) {
|
||||||
|
if (canSelect(el[i])) {
|
||||||
|
return el[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (i = x - 1; i >= 0; i--) {
|
||||||
|
if (canSelect(el[i])) {
|
||||||
|
return el[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
v = Tools.explode(editor.getParam('tab_focus', editor.getParam('tabfocus_elements', ':prev,:next')));
|
||||||
|
|
||||||
|
if (v.length == 1) {
|
||||||
|
v[1] = v[0];
|
||||||
|
v[0] = ':prev';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find element to focus
|
||||||
|
if (e.shiftKey) {
|
||||||
|
if (v[0] == ':prev') {
|
||||||
|
el = find(-1);
|
||||||
|
} else {
|
||||||
|
el = DOM.get(v[0]);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (v[1] == ':next') {
|
||||||
|
el = find(1);
|
||||||
|
} else {
|
||||||
|
el = DOM.get(v[1]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (el) {
|
||||||
|
var focusEditor = EditorManager.get(el.id || el.name);
|
||||||
|
|
||||||
|
if (el.id && focusEditor) {
|
||||||
|
focusEditor.focus();
|
||||||
|
} else {
|
||||||
|
Delay.setTimeout(function () {
|
||||||
|
if (!Env.webkit) {
|
||||||
|
window.focus();
|
||||||
|
}
|
||||||
|
|
||||||
|
el.focus();
|
||||||
|
}, 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
e.preventDefault();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
editor.on('init', function () {
|
||||||
|
if (editor.inline) {
|
||||||
|
// Remove default tabIndex in inline mode
|
||||||
|
DOM.setAttrib(editor.getBody(), 'tabIndex', null);
|
||||||
|
}
|
||||||
|
|
||||||
|
editor.on('keyup', tabCancel);
|
||||||
|
|
||||||
|
if (Env.gecko) {
|
||||||
|
editor.on('keypress keydown', tabHandler);
|
||||||
|
} else {
|
||||||
|
editor.on('keydown', tabHandler);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
return function () { };
|
||||||
|
}
|
||||||
|
);
|
||||||
|
dem('tinymce.plugins.tabfocus.Plugin')();
|
||||||
|
})();
|
||||||
|
@ -1 +1 @@
|
|||||||
tinymce.PluginManager.add("tabfocus",function(e){function t(e){9!==e.keyCode||e.ctrlKey||e.altKey||e.metaKey||e.preventDefault()}function n(t){function n(n){function o(e){return"BODY"===e.nodeName||"hidden"!=e.type&&"none"!=e.style.display&&"hidden"!=e.style.visibility&&o(e.parentNode)}function l(e){return/INPUT|TEXTAREA|BUTTON/.test(e.tagName)&&tinymce.get(t.id)&&e.tabIndex!=-1&&o(e)}if(s=r.select(":input:enabled,*[tabindex]:not(iframe)"),i(s,function(t,n){if(t.id==e.id)return a=n,!1}),n>0){for(u=a+1;u<s.length;u++)if(l(s[u]))return s[u]}else for(u=a-1;u>=0;u--)if(l(s[u]))return s[u];return null}var a,s,l,u;if(!(9!==t.keyCode||t.ctrlKey||t.altKey||t.metaKey||t.isDefaultPrevented())&&(l=o(e.getParam("tab_focus",e.getParam("tabfocus_elements",":prev,:next"))),1==l.length&&(l[1]=l[0],l[0]=":prev"),s=t.shiftKey?":prev"==l[0]?n(-1):r.get(l[0]):":next"==l[1]?n(1):r.get(l[1]))){var c=tinymce.get(s.id||s.name);s.id&&c?c.focus():tinymce.util.Delay.setTimeout(function(){tinymce.Env.webkit||window.focus(),s.focus()},10),t.preventDefault()}}var r=tinymce.DOM,i=tinymce.each,o=tinymce.explode;e.on("init",function(){e.inline&&tinymce.DOM.setAttrib(e.getBody(),"tabIndex",null),e.on("keyup",t),tinymce.Env.gecko?e.on("keypress keydown",n):e.on("keydown",n)})});
|
!function(){var a={},b=function(b){for(var c=a[b],e=c.deps,f=c.defn,g=e.length,h=new Array(g),i=0;i<g;++i)h[i]=d(e[i]);var j=f.apply(null,h);if(void 0===j)throw"module ["+b+"] returned undefined";c.instance=j},c=function(b,c,d){if("string"!=typeof b)throw"module id must be a string";if(void 0===c)throw"no dependencies for "+b;if(void 0===d)throw"no definition function for "+b;a[b]={deps:c,defn:d,instance:void 0}},d=function(c){var d=a[c];if(void 0===d)throw"module ["+c+"] was undefined";return void 0===d.instance&&b(c),d.instance},e=function(a,b){for(var c=a.length,e=new Array(c),f=0;f<c;++f)e.push(d(a[f]));b.apply(null,b)},f={};f.bolt={module:{api:{define:c,require:e,demand:d}}};var g=c,h=function(a,b){g(a,[],function(){return b})};h("7",tinymce.util.Tools.resolve),g("1",["7"],function(a){return a("tinymce.PluginManager")}),g("2",["7"],function(a){return a("tinymce.dom.DOMUtils")}),g("3",["7"],function(a){return a("tinymce.util.Tools")}),g("4",["7"],function(a){return a("tinymce.EditorManager")}),g("5",["7"],function(a){return a("tinymce.util.Delay")}),g("6",["7"],function(a){return a("tinymce.Env")}),g("0",["1","2","3","4","5","6"],function(a,b,c,d,e,f){return a.add("tabfocus",function(a){function g(a){9!==a.keyCode||a.ctrlKey||a.altKey||a.metaKey||a.preventDefault()}function h(b){function g(e){function f(a){return"BODY"===a.nodeName||"hidden"!=a.type&&"none"!=a.style.display&&"hidden"!=a.style.visibility&&f(a.parentNode)}function g(a){return/INPUT|TEXTAREA|BUTTON/.test(a.tagName)&&d.get(b.id)&&a.tabIndex!=-1&&f(a)}if(j=i.select(":input:enabled,*[tabindex]:not(iframe)"),c.each(j,function(b,c){if(b.id==a.id)return h=c,!1}),e>0){for(l=h+1;l<j.length;l++)if(g(j[l]))return j[l]}else for(l=h-1;l>=0;l--)if(g(j[l]))return j[l];return null}var h,j,k,l;if(!(9!==b.keyCode||b.ctrlKey||b.altKey||b.metaKey||b.isDefaultPrevented())&&(k=c.explode(a.getParam("tab_focus",a.getParam("tabfocus_elements",":prev,:next"))),1==k.length&&(k[1]=k[0],k[0]=":prev"),j=b.shiftKey?":prev"==k[0]?g(-1):i.get(k[0]):":next"==k[1]?g(1):i.get(k[1]))){var m=d.get(j.id||j.name);j.id&&m?m.focus():e.setTimeout(function(){f.webkit||window.focus(),j.focus()},10),b.preventDefault()}}var i=b.DOM;a.on("init",function(){a.inline&&i.setAttrib(a.getBody(),"tabIndex",null),a.on("keyup",g),f.gecko?a.on("keypress keydown",h):a.on("keydown",h)})}),function(){}}),d("0")()}();
|
@ -1,297 +1,483 @@
|
|||||||
|
(function () {
|
||||||
|
|
||||||
|
var defs = {}; // id -> {dependencies, definition, instance (possibly undefined)}
|
||||||
|
|
||||||
|
// Used when there is no 'main' module.
|
||||||
|
// The name is probably (hopefully) unique so minification removes for releases.
|
||||||
|
var register_3795 = function (id) {
|
||||||
|
var module = dem(id);
|
||||||
|
var fragments = id.split('.');
|
||||||
|
var target = Function('return this;')();
|
||||||
|
for (var i = 0; i < fragments.length - 1; ++i) {
|
||||||
|
if (target[fragments[i]] === undefined)
|
||||||
|
target[fragments[i]] = {};
|
||||||
|
target = target[fragments[i]];
|
||||||
|
}
|
||||||
|
target[fragments[fragments.length - 1]] = module;
|
||||||
|
};
|
||||||
|
|
||||||
|
var instantiate = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
var dependencies = actual.deps;
|
||||||
|
var definition = actual.defn;
|
||||||
|
var len = dependencies.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances[i] = dem(dependencies[i]);
|
||||||
|
var defResult = definition.apply(null, instances);
|
||||||
|
if (defResult === undefined)
|
||||||
|
throw 'module [' + id + '] returned undefined';
|
||||||
|
actual.instance = defResult;
|
||||||
|
};
|
||||||
|
|
||||||
|
var def = function (id, dependencies, definition) {
|
||||||
|
if (typeof id !== 'string')
|
||||||
|
throw 'module id must be a string';
|
||||||
|
else if (dependencies === undefined)
|
||||||
|
throw 'no dependencies for ' + id;
|
||||||
|
else if (definition === undefined)
|
||||||
|
throw 'no definition function for ' + id;
|
||||||
|
defs[id] = {
|
||||||
|
deps: dependencies,
|
||||||
|
defn: definition,
|
||||||
|
instance: undefined
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var dem = function (id) {
|
||||||
|
var actual = defs[id];
|
||||||
|
if (actual === undefined)
|
||||||
|
throw 'module [' + id + '] was undefined';
|
||||||
|
else if (actual.instance === undefined)
|
||||||
|
instantiate(id);
|
||||||
|
return actual.instance;
|
||||||
|
};
|
||||||
|
|
||||||
|
var req = function (ids, callback) {
|
||||||
|
var len = ids.length;
|
||||||
|
var instances = new Array(len);
|
||||||
|
for (var i = 0; i < len; ++i)
|
||||||
|
instances.push(dem(ids[i]));
|
||||||
|
callback.apply(null, callback);
|
||||||
|
};
|
||||||
|
|
||||||
|
var ephox = {};
|
||||||
|
|
||||||
|
ephox.bolt = {
|
||||||
|
module: {
|
||||||
|
api: {
|
||||||
|
define: def,
|
||||||
|
require: req,
|
||||||
|
demand: dem
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var define = def;
|
||||||
|
var require = req;
|
||||||
|
var demand = dem;
|
||||||
|
// this helps with minificiation when using a lot of global references
|
||||||
|
var defineGlobal = function (id, ref) {
|
||||||
|
define(id, [], function () { return ref; });
|
||||||
|
};
|
||||||
|
/*jsc
|
||||||
|
["tinymce.plugins.textcolor.Plugin","tinymce.core.dom.DOMUtils","tinymce.core.PluginManager","tinymce.core.util.I18n","tinymce.core.util.Tools","global!tinymce.util.Tools.resolve"]
|
||||||
|
jsc*/
|
||||||
|
defineGlobal("global!tinymce.util.Tools.resolve", tinymce.util.Tools.resolve);
|
||||||
/**
|
/**
|
||||||
* plugin.js
|
* ResolveGlobal.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*global tinymce:true */
|
define(
|
||||||
/*eslint consistent-this:0 */
|
'tinymce.core.dom.DOMUtils',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.dom.DOMUtils');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
tinymce.PluginManager.add('textcolor', function(editor) {
|
/**
|
||||||
var cols, rows;
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
rows = {
|
define(
|
||||||
forecolor: editor.settings.forecolor_rows || editor.settings.textcolor_rows || 5,
|
'tinymce.core.PluginManager',
|
||||||
backcolor: editor.settings.backcolor_rows || editor.settings.textcolor_rows || 5
|
[
|
||||||
};
|
'global!tinymce.util.Tools.resolve'
|
||||||
cols = {
|
],
|
||||||
forecolor: editor.settings.forecolor_cols || editor.settings.textcolor_cols || 8,
|
function (resolve) {
|
||||||
backcolor: editor.settings.backcolor_cols || editor.settings.textcolor_cols || 8
|
return resolve('tinymce.PluginManager');
|
||||||
};
|
}
|
||||||
|
);
|
||||||
|
|
||||||
function getCurrentColor(format) {
|
/**
|
||||||
var color;
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
editor.dom.getParents(editor.selection.getStart(), function(elm) {
|
define(
|
||||||
var value;
|
'tinymce.core.util.I18n',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.util.I18n');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
if ((value = elm.style[format == 'forecolor' ? 'color' : 'background-color'])) {
|
/**
|
||||||
color = value;
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
return color;
|
define(
|
||||||
}
|
'tinymce.core.util.Tools',
|
||||||
|
[
|
||||||
|
'global!tinymce.util.Tools.resolve'
|
||||||
|
],
|
||||||
|
function (resolve) {
|
||||||
|
return resolve('tinymce.util.Tools');
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
function mapColors(type) {
|
/**
|
||||||
var i, colors = [], colorMap;
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
colorMap = [
|
/**
|
||||||
"000000", "Black",
|
* This class contains all core logic for the code plugin.
|
||||||
"993300", "Burnt orange",
|
*
|
||||||
"333300", "Dark olive",
|
* @class tinymce.textcolor.Plugin
|
||||||
"003300", "Dark green",
|
* @private
|
||||||
"003366", "Dark azure",
|
*/
|
||||||
"000080", "Navy Blue",
|
define(
|
||||||
"333399", "Indigo",
|
'tinymce.plugins.textcolor.Plugin',
|
||||||
"333333", "Very dark gray",
|
[
|
||||||
"800000", "Maroon",
|
'tinymce.core.dom.DOMUtils',
|
||||||
"FF6600", "Orange",
|
'tinymce.core.PluginManager',
|
||||||
"808000", "Olive",
|
'tinymce.core.util.I18n',
|
||||||
"008000", "Green",
|
'tinymce.core.util.Tools'
|
||||||
"008080", "Teal",
|
],
|
||||||
"0000FF", "Blue",
|
function (DOMUtils, PluginManager, I18n, Tools) {
|
||||||
"666699", "Grayish blue",
|
var translate = I18n.translate;
|
||||||
"808080", "Gray",
|
|
||||||
"FF0000", "Red",
|
|
||||||
"FF9900", "Amber",
|
|
||||||
"99CC00", "Yellow green",
|
|
||||||
"339966", "Sea green",
|
|
||||||
"33CCCC", "Turquoise",
|
|
||||||
"3366FF", "Royal blue",
|
|
||||||
"800080", "Purple",
|
|
||||||
"999999", "Medium gray",
|
|
||||||
"FF00FF", "Magenta",
|
|
||||||
"FFCC00", "Gold",
|
|
||||||
"FFFF00", "Yellow",
|
|
||||||
"00FF00", "Lime",
|
|
||||||
"00FFFF", "Aqua",
|
|
||||||
"00CCFF", "Sky blue",
|
|
||||||
"993366", "Red violet",
|
|
||||||
"FFFFFF", "White",
|
|
||||||
"FF99CC", "Pink",
|
|
||||||
"FFCC99", "Peach",
|
|
||||||
"FFFF99", "Light yellow",
|
|
||||||
"CCFFCC", "Pale green",
|
|
||||||
"CCFFFF", "Pale cyan",
|
|
||||||
"99CCFF", "Light sky blue",
|
|
||||||
"CC99FF", "Plum"
|
|
||||||
];
|
|
||||||
|
|
||||||
colorMap = editor.settings.textcolor_map || colorMap;
|
PluginManager.add('textcolor', function (editor) {
|
||||||
colorMap = editor.settings[type + '_map'] || colorMap;
|
var cols, rows;
|
||||||
|
|
||||||
for (i = 0; i < colorMap.length; i += 2) {
|
rows = {
|
||||||
colors.push({
|
forecolor: editor.settings.forecolor_rows || editor.settings.textcolor_rows || 5,
|
||||||
text: colorMap[i + 1],
|
backcolor: editor.settings.backcolor_rows || editor.settings.textcolor_rows || 5
|
||||||
color: '#' + colorMap[i]
|
};
|
||||||
});
|
cols = {
|
||||||
}
|
forecolor: editor.settings.forecolor_cols || editor.settings.textcolor_cols || 8,
|
||||||
|
backcolor: editor.settings.backcolor_cols || editor.settings.textcolor_cols || 8
|
||||||
|
};
|
||||||
|
|
||||||
return colors;
|
function getCurrentColor(format) {
|
||||||
}
|
var color;
|
||||||
|
|
||||||
function renderColorPicker() {
|
editor.dom.getParents(editor.selection.getStart(), function (elm) {
|
||||||
var ctrl = this, colors, color, html, last, x, y, i, id = ctrl._id, count = 0, type;
|
var value;
|
||||||
|
|
||||||
type = ctrl.settings.origin;
|
if ((value = elm.style[format == 'forecolor' ? 'color' : 'background-color'])) {
|
||||||
|
color = value;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
function getColorCellHtml(color, title) {
|
return color;
|
||||||
var isNoColor = color == 'transparent';
|
}
|
||||||
|
|
||||||
return (
|
function mapColors(type) {
|
||||||
'<td class="mce-grid-cell' + (isNoColor ? ' mce-colorbtn-trans' : '') + '">' +
|
var i, colors = [], colorMap;
|
||||||
'<div id="' + id + '-' + (count++) + '"' +
|
|
||||||
' data-mce-color="' + (color ? color : '') + '"' +
|
|
||||||
' role="option"' +
|
|
||||||
' tabIndex="-1"' +
|
|
||||||
' style="' + (color ? 'background-color: ' + color : '') + '"' +
|
|
||||||
' title="' + tinymce.translate(title) + '">' +
|
|
||||||
(isNoColor ? '×' : '') +
|
|
||||||
'</div>' +
|
|
||||||
'</td>'
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
colors = mapColors(type);
|
colorMap = [
|
||||||
colors.push({
|
"000000", "Black",
|
||||||
text: tinymce.translate("No color"),
|
"993300", "Burnt orange",
|
||||||
color: "transparent"
|
"333300", "Dark olive",
|
||||||
});
|
"003300", "Dark green",
|
||||||
|
"003366", "Dark azure",
|
||||||
|
"000080", "Navy Blue",
|
||||||
|
"333399", "Indigo",
|
||||||
|
"333333", "Very dark gray",
|
||||||
|
"800000", "Maroon",
|
||||||
|
"FF6600", "Orange",
|
||||||
|
"808000", "Olive",
|
||||||
|
"008000", "Green",
|
||||||
|
"008080", "Teal",
|
||||||
|
"0000FF", "Blue",
|
||||||
|
"666699", "Grayish blue",
|
||||||
|
"808080", "Gray",
|
||||||
|
"FF0000", "Red",
|
||||||
|
"FF9900", "Amber",
|
||||||
|
"99CC00", "Yellow green",
|
||||||
|
"339966", "Sea green",
|
||||||
|
"33CCCC", "Turquoise",
|
||||||
|
"3366FF", "Royal blue",
|
||||||
|
"800080", "Purple",
|
||||||
|
"999999", "Medium gray",
|
||||||
|
"FF00FF", "Magenta",
|
||||||
|
"FFCC00", "Gold",
|
||||||
|
"FFFF00", "Yellow",
|
||||||
|
"00FF00", "Lime",
|
||||||
|
"00FFFF", "Aqua",
|
||||||
|
"00CCFF", "Sky blue",
|
||||||
|
"993366", "Red violet",
|
||||||
|
"FFFFFF", "White",
|
||||||
|
"FF99CC", "Pink",
|
||||||
|
"FFCC99", "Peach",
|
||||||
|
"FFFF99", "Light yellow",
|
||||||
|
"CCFFCC", "Pale green",
|
||||||
|
"CCFFFF", "Pale cyan",
|
||||||
|
"99CCFF", "Light sky blue",
|
||||||
|
"CC99FF", "Plum"
|
||||||
|
];
|
||||||
|
|
||||||
html = '<table class="mce-grid mce-grid-border mce-colorbutton-grid" role="list" cellspacing="0"><tbody>';
|
colorMap = editor.settings.textcolor_map || colorMap;
|
||||||
last = colors.length - 1;
|
colorMap = editor.settings[type + '_map'] || colorMap;
|
||||||
|
|
||||||
for (y = 0; y < rows[type]; y++) {
|
for (i = 0; i < colorMap.length; i += 2) {
|
||||||
html += '<tr>';
|
colors.push({
|
||||||
|
text: colorMap[i + 1],
|
||||||
|
color: '#' + colorMap[i]
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
for (x = 0; x < cols[type]; x++) {
|
return colors;
|
||||||
i = y * cols[type] + x;
|
}
|
||||||
|
|
||||||
if (i > last) {
|
function renderColorPicker() {
|
||||||
html += '<td></td>';
|
var self = this, colors, color, html, last, x, y, i, id = self._id, count = 0, type;
|
||||||
} else {
|
|
||||||
color = colors[i];
|
|
||||||
html += getColorCellHtml(color.color, color.text);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
html += '</tr>';
|
type = self.settings.origin;
|
||||||
}
|
|
||||||
|
|
||||||
if (editor.settings.color_picker_callback) {
|
function getColorCellHtml(color, title) {
|
||||||
html += (
|
var isNoColor = color == 'transparent';
|
||||||
'<tr>' +
|
|
||||||
'<td colspan="' + cols[type] + '" class="mce-custom-color-btn">' +
|
|
||||||
'<div id="' + id + '-c" class="mce-widget mce-btn mce-btn-small mce-btn-flat" ' +
|
|
||||||
'role="button" tabindex="-1" aria-labelledby="' + id + '-c" style="width: 100%">' +
|
|
||||||
'<button type="button" role="presentation" tabindex="-1">' + tinymce.translate('Custom...') + '</button>' +
|
|
||||||
'</div>' +
|
|
||||||
'</td>' +
|
|
||||||
'</tr>'
|
|
||||||
);
|
|
||||||
|
|
||||||
html += '<tr>';
|
return (
|
||||||
|
'<td class="mce-grid-cell' + (isNoColor ? ' mce-colorbtn-trans' : '') + '">' +
|
||||||
|
'<div id="' + id + '-' + (count++) + '"' +
|
||||||
|
' data-mce-color="' + (color ? color : '') + '"' +
|
||||||
|
' role="option"' +
|
||||||
|
' tabIndex="-1"' +
|
||||||
|
' style="' + (color ? 'background-color: ' + color : '') + '"' +
|
||||||
|
' title="' + translate(title) + '">' +
|
||||||
|
(isNoColor ? '×' : '') +
|
||||||
|
'</div>' +
|
||||||
|
'</td>'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
for (x = 0; x < cols[type]; x++) {
|
colors = mapColors(type);
|
||||||
html += getColorCellHtml('', 'Custom color');
|
colors.push({
|
||||||
}
|
text: translate("No color"),
|
||||||
|
color: "transparent"
|
||||||
|
});
|
||||||
|
|
||||||
html += '</tr>';
|
html = '<table class="mce-grid mce-grid-border mce-colorbutton-grid" role="list" cellspacing="0"><tbody>';
|
||||||
}
|
last = colors.length - 1;
|
||||||
|
|
||||||
html += '</tbody></table>';
|
for (y = 0; y < rows[type]; y++) {
|
||||||
|
html += '<tr>';
|
||||||
|
|
||||||
return html;
|
for (x = 0; x < cols[type]; x++) {
|
||||||
}
|
i = y * cols[type] + x;
|
||||||
|
|
||||||
function applyFormat(format, value) {
|
if (i > last) {
|
||||||
editor.undoManager.transact(function() {
|
html += '<td></td>';
|
||||||
editor.focus();
|
} else {
|
||||||
editor.formatter.apply(format, {value: value});
|
color = colors[i];
|
||||||
editor.nodeChanged();
|
html += getColorCellHtml(color.color, color.text);
|
||||||
});
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function removeFormat(format) {
|
html += '</tr>';
|
||||||
editor.undoManager.transact(function() {
|
}
|
||||||
editor.focus();
|
|
||||||
editor.formatter.remove(format, {value: null}, null, true);
|
|
||||||
editor.nodeChanged();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function onPanelClick(e) {
|
if (editor.settings.color_picker_callback) {
|
||||||
var buttonCtrl = this.parent(), value, type;
|
html += (
|
||||||
|
'<tr>' +
|
||||||
|
'<td colspan="' + cols[type] + '" class="mce-custom-color-btn">' +
|
||||||
|
'<div id="' + id + '-c" class="mce-widget mce-btn mce-btn-small mce-btn-flat" ' +
|
||||||
|
'role="button" tabindex="-1" aria-labelledby="' + id + '-c" style="width: 100%">' +
|
||||||
|
'<button type="button" role="presentation" tabindex="-1">' + translate('Custom...') + '</button>' +
|
||||||
|
'</div>' +
|
||||||
|
'</td>' +
|
||||||
|
'</tr>'
|
||||||
|
);
|
||||||
|
|
||||||
type = buttonCtrl.settings.origin;
|
html += '<tr>';
|
||||||
|
|
||||||
function selectColor(value) {
|
for (x = 0; x < cols[type]; x++) {
|
||||||
buttonCtrl.hidePanel();
|
html += getColorCellHtml('', 'Custom color');
|
||||||
buttonCtrl.color(value);
|
}
|
||||||
applyFormat(buttonCtrl.settings.format, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
function resetColor() {
|
html += '</tr>';
|
||||||
buttonCtrl.hidePanel();
|
}
|
||||||
buttonCtrl.resetColor();
|
|
||||||
removeFormat(buttonCtrl.settings.format);
|
|
||||||
}
|
|
||||||
|
|
||||||
function setDivColor(div, value) {
|
html += '</tbody></table>';
|
||||||
div.style.background = value;
|
|
||||||
div.setAttribute('data-mce-color', value);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (tinymce.DOM.getParent(e.target, '.mce-custom-color-btn')) {
|
return html;
|
||||||
buttonCtrl.hidePanel();
|
}
|
||||||
|
|
||||||
editor.settings.color_picker_callback.call(editor, function(value) {
|
function applyFormat(format, value) {
|
||||||
var tableElm = buttonCtrl.panel.getEl().getElementsByTagName('table')[0];
|
editor.undoManager.transact(function () {
|
||||||
var customColorCells, div, i;
|
editor.focus();
|
||||||
|
editor.formatter.apply(format, { value: value });
|
||||||
|
editor.nodeChanged();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
customColorCells = tinymce.map(tableElm.rows[tableElm.rows.length - 1].childNodes, function(elm) {
|
function removeFormat(format) {
|
||||||
return elm.firstChild;
|
editor.undoManager.transact(function () {
|
||||||
});
|
editor.focus();
|
||||||
|
editor.formatter.remove(format, { value: null }, null, true);
|
||||||
|
editor.nodeChanged();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
for (i = 0; i < customColorCells.length; i++) {
|
function onPanelClick(e) {
|
||||||
div = customColorCells[i];
|
var buttonCtrl = this.parent(), value, type;
|
||||||
if (!div.getAttribute('data-mce-color')) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Shift colors to the right
|
type = buttonCtrl.settings.origin;
|
||||||
// TODO: Might need to be the left on RTL
|
|
||||||
if (i == cols[type]) {
|
|
||||||
for (i = 0; i < cols[type] - 1; i++) {
|
|
||||||
setDivColor(customColorCells[i], customColorCells[i + 1].getAttribute('data-mce-color'));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
setDivColor(div, value);
|
function selectColor(value) {
|
||||||
selectColor(value);
|
buttonCtrl.hidePanel();
|
||||||
}, getCurrentColor(buttonCtrl.settings.format));
|
buttonCtrl.color(value);
|
||||||
}
|
applyFormat(buttonCtrl.settings.format, value);
|
||||||
|
}
|
||||||
|
|
||||||
value = e.target.getAttribute('data-mce-color');
|
function resetColor() {
|
||||||
if (value) {
|
buttonCtrl.hidePanel();
|
||||||
if (this.lastId) {
|
buttonCtrl.resetColor();
|
||||||
document.getElementById(this.lastId).setAttribute('aria-selected', false);
|
removeFormat(buttonCtrl.settings.format);
|
||||||
}
|
}
|
||||||
|
|
||||||
e.target.setAttribute('aria-selected', true);
|
function setDivColor(div, value) {
|
||||||
this.lastId = e.target.id;
|
div.style.background = value;
|
||||||
|
div.setAttribute('data-mce-color', value);
|
||||||
|
}
|
||||||
|
|
||||||
if (value == 'transparent') {
|
if (DOMUtils.DOM.getParent(e.target, '.mce-custom-color-btn')) {
|
||||||
resetColor();
|
buttonCtrl.hidePanel();
|
||||||
} else {
|
|
||||||
selectColor(value);
|
|
||||||
}
|
|
||||||
} else if (value !== null) {
|
|
||||||
buttonCtrl.hidePanel();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function onButtonClick() {
|
editor.settings.color_picker_callback.call(editor, function (value) {
|
||||||
var self = this;
|
var tableElm = buttonCtrl.panel.getEl().getElementsByTagName('table')[0];
|
||||||
|
var customColorCells, div, i;
|
||||||
|
|
||||||
if (self._color) {
|
customColorCells = Tools.map(tableElm.rows[tableElm.rows.length - 1].childNodes, function (elm) {
|
||||||
applyFormat(self.settings.format, self._color);
|
return elm.firstChild;
|
||||||
} else {
|
});
|
||||||
removeFormat(self.settings.format);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
editor.addButton('forecolor', {
|
for (i = 0; i < customColorCells.length; i++) {
|
||||||
type: 'colorbutton',
|
div = customColorCells[i];
|
||||||
tooltip: 'Text color',
|
if (!div.getAttribute('data-mce-color')) {
|
||||||
format: 'forecolor',
|
break;
|
||||||
panel: {
|
}
|
||||||
origin: 'forecolor',
|
}
|
||||||
role: 'application',
|
|
||||||
ariaRemember: true,
|
|
||||||
html: renderColorPicker,
|
|
||||||
onclick: onPanelClick
|
|
||||||
},
|
|
||||||
onclick: onButtonClick
|
|
||||||
});
|
|
||||||
|
|
||||||
editor.addButton('backcolor', {
|
// Shift colors to the right
|
||||||
type: 'colorbutton',
|
// TODO: Might need to be the left on RTL
|
||||||
tooltip: 'Background color',
|
if (i == cols[type]) {
|
||||||
format: 'hilitecolor',
|
for (i = 0; i < cols[type] - 1; i++) {
|
||||||
panel: {
|
setDivColor(customColorCells[i], customColorCells[i + 1].getAttribute('data-mce-color'));
|
||||||
origin: 'backcolor',
|
}
|
||||||
role: 'application',
|
}
|
||||||
ariaRemember: true,
|
|
||||||
html: renderColorPicker,
|
setDivColor(div, value);
|
||||||
onclick: onPanelClick
|
selectColor(value);
|
||||||
},
|
}, getCurrentColor(buttonCtrl.settings.format));
|
||||||
onclick: onButtonClick
|
}
|
||||||
});
|
|
||||||
});
|
value = e.target.getAttribute('data-mce-color');
|
||||||
|
if (value) {
|
||||||
|
if (this.lastId) {
|
||||||
|
document.getElementById(this.lastId).setAttribute('aria-selected', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
e.target.setAttribute('aria-selected', true);
|
||||||
|
this.lastId = e.target.id;
|
||||||
|
|
||||||
|
if (value == 'transparent') {
|
||||||
|
resetColor();
|
||||||
|
} else {
|
||||||
|
selectColor(value);
|
||||||
|
}
|
||||||
|
} else if (value !== null) {
|
||||||
|
buttonCtrl.hidePanel();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function onButtonClick() {
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
if (self._color) {
|
||||||
|
applyFormat(self.settings.format, self._color);
|
||||||
|
} else {
|
||||||
|
removeFormat(self.settings.format);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
editor.addButton('forecolor', {
|
||||||
|
type: 'colorbutton',
|
||||||
|
tooltip: 'Text color',
|
||||||
|
format: 'forecolor',
|
||||||
|
panel: {
|
||||||
|
origin: 'forecolor',
|
||||||
|
role: 'application',
|
||||||
|
ariaRemember: true,
|
||||||
|
html: renderColorPicker,
|
||||||
|
onclick: onPanelClick
|
||||||
|
},
|
||||||
|
onclick: onButtonClick
|
||||||
|
});
|
||||||
|
|
||||||
|
editor.addButton('backcolor', {
|
||||||
|
type: 'colorbutton',
|
||||||
|
tooltip: 'Background color',
|
||||||
|
format: 'hilitecolor',
|
||||||
|
panel: {
|
||||||
|
origin: 'backcolor',
|
||||||
|
role: 'application',
|
||||||
|
ariaRemember: true,
|
||||||
|
html: renderColorPicker,
|
||||||
|
onclick: onPanelClick
|
||||||
|
},
|
||||||
|
onclick: onButtonClick
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
return function () { };
|
||||||
|
}
|
||||||
|
);
|
||||||
|
dem('tinymce.plugins.textcolor.Plugin')();
|
||||||
|
})();
|
||||||
|
File diff suppressed because one or more lines are too long
@ -682,6 +682,7 @@ tinymce.PluginManager.add( 'wordpress', function( editor ) {
|
|||||||
mceIframe = document.getElementById( editor.id + '_ifr' ),
|
mceIframe = document.getElementById( editor.id + '_ifr' ),
|
||||||
mceToolbar,
|
mceToolbar,
|
||||||
mceStatusbar,
|
mceStatusbar,
|
||||||
|
namesAdded,
|
||||||
wpStatusbar;
|
wpStatusbar;
|
||||||
|
|
||||||
if ( container ) {
|
if ( container ) {
|
||||||
@ -699,7 +700,7 @@ tinymce.PluginManager.add( 'wordpress', function( editor ) {
|
|||||||
buttonGroup;
|
buttonGroup;
|
||||||
|
|
||||||
each( buttons, function( item ) {
|
each( buttons, function( item ) {
|
||||||
var itemName;
|
var itemName, ui, name;
|
||||||
|
|
||||||
function bindSelectorChanged() {
|
function bindSelectorChanged() {
|
||||||
var selection = editor.selection;
|
var selection = editor.selection;
|
||||||
@ -767,6 +768,19 @@ tinymce.PluginManager.add( 'wordpress', function( editor ) {
|
|||||||
|
|
||||||
buttonGroup = null;
|
buttonGroup = null;
|
||||||
} else {
|
} else {
|
||||||
|
// Add the new WP* types to the factory
|
||||||
|
if ( ! namesAdded ) {
|
||||||
|
ui = tinymce.ui;
|
||||||
|
|
||||||
|
for ( name in ui ) {
|
||||||
|
if ( name.toLowerCase().indexOf( 'wp' ) === 0 ) {
|
||||||
|
Factory.add( name, ui[name] );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
namesAdded = true;
|
||||||
|
}
|
||||||
|
|
||||||
if ( ! buttonGroup ) {
|
if ( ! buttonGroup ) {
|
||||||
buttonGroup = {
|
buttonGroup = {
|
||||||
type: 'buttongroup',
|
type: 'buttongroup',
|
||||||
|
@ -92,13 +92,7 @@
|
|||||||
} );
|
} );
|
||||||
|
|
||||||
// Replace any new markers nodes with views.
|
// Replace any new markers nodes with views.
|
||||||
editor.on( 'setcontent', function( event ) {
|
editor.on( 'setcontent', function() {
|
||||||
if ( event.load && ! event.initial && editor.quirks.refreshContentEditable ) {
|
|
||||||
// Make sure there is a selection in Gecko browsers.
|
|
||||||
// Or it will refresh the content internally which resets the iframes.
|
|
||||||
editor.quirks.refreshContentEditable();
|
|
||||||
}
|
|
||||||
|
|
||||||
wp.mce.views.render();
|
wp.mce.views.render();
|
||||||
} );
|
} );
|
||||||
|
|
||||||
|
@ -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:'-'}hr{cursor:default}.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-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-resize-bar-dragging{background-color:blue;opacity:.25;filter:alpha(opacity=25);zoom: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}
|
@ -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:'-'}hr{cursor:default}.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-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-resize-bar-dragging{background-color:blue;opacity:.25;filter:alpha(opacity=25);zoom: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}
|
@ -1 +0,0 @@
|
|||||||
Icons are generated and provided by the http://icomoon.io service.
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
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 it is too large
Load Diff
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
1006
src/wp-includes/js/tinymce/tiny_mce_popup.js
vendored
1006
src/wp-includes/js/tinymce/tiny_mce_popup.js
vendored
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
29
src/wp-includes/js/tinymce/tinymce.min.js
vendored
29
src/wp-includes/js/tinymce/tinymce.min.js
vendored
File diff suppressed because one or more lines are too long
@ -2,69 +2,71 @@
|
|||||||
* editable_selects.js
|
* editable_selects.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
var TinyMCE_EditableSelects = {
|
var TinyMCE_EditableSelects = {
|
||||||
editSelectElm : null,
|
editSelectElm : null,
|
||||||
|
|
||||||
init : function() {
|
init : function () {
|
||||||
var nl = document.getElementsByTagName("select"), i, d = document, o;
|
var nl = document.getElementsByTagName("select"), i, d = document, o;
|
||||||
|
|
||||||
for (i=0; i<nl.length; i++) {
|
for (i = 0; i < nl.length; i++) {
|
||||||
if (nl[i].className.indexOf('mceEditableSelect') != -1) {
|
if (nl[i].className.indexOf('mceEditableSelect') != -1) {
|
||||||
o = new Option(tinyMCEPopup.editor.translate('value'), '__mce_add_custom__');
|
o = new Option(tinyMCEPopup.editor.translate('value'), '__mce_add_custom__');
|
||||||
|
|
||||||
o.className = 'mceAddSelectValue';
|
o.className = 'mceAddSelectValue';
|
||||||
|
|
||||||
nl[i].options[nl[i].options.length] = o;
|
nl[i].options[nl[i].options.length] = o;
|
||||||
nl[i].onchange = TinyMCE_EditableSelects.onChangeEditableSelect;
|
nl[i].onchange = TinyMCE_EditableSelects.onChangeEditableSelect;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
onChangeEditableSelect : function(e) {
|
onChangeEditableSelect : function (e) {
|
||||||
var d = document, ne, se = window.event ? window.event.srcElement : e.target;
|
var d = document, ne, se = window.event ? window.event.srcElement : e.target;
|
||||||
|
|
||||||
if (se.options[se.selectedIndex].value == '__mce_add_custom__') {
|
if (se.options[se.selectedIndex].value == '__mce_add_custom__') {
|
||||||
ne = d.createElement("input");
|
ne = d.createElement("input");
|
||||||
ne.id = se.id + "_custom";
|
ne.id = se.id + "_custom";
|
||||||
ne.name = se.name + "_custom";
|
ne.name = se.name + "_custom";
|
||||||
ne.type = "text";
|
ne.type = "text";
|
||||||
|
|
||||||
ne.style.width = se.offsetWidth + 'px';
|
ne.style.width = se.offsetWidth + 'px';
|
||||||
se.parentNode.insertBefore(ne, se);
|
se.parentNode.insertBefore(ne, se);
|
||||||
se.style.display = 'none';
|
se.style.display = 'none';
|
||||||
ne.focus();
|
ne.focus();
|
||||||
ne.onblur = TinyMCE_EditableSelects.onBlurEditableSelectInput;
|
ne.onblur = TinyMCE_EditableSelects.onBlurEditableSelectInput;
|
||||||
ne.onkeydown = TinyMCE_EditableSelects.onKeyDown;
|
ne.onkeydown = TinyMCE_EditableSelects.onKeyDown;
|
||||||
TinyMCE_EditableSelects.editSelectElm = se;
|
TinyMCE_EditableSelects.editSelectElm = se;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
onBlurEditableSelectInput : function() {
|
onBlurEditableSelectInput : function () {
|
||||||
var se = TinyMCE_EditableSelects.editSelectElm;
|
var se = TinyMCE_EditableSelects.editSelectElm;
|
||||||
|
|
||||||
if (se) {
|
if (se) {
|
||||||
if (se.previousSibling.value != '') {
|
if (se.previousSibling.value != '') {
|
||||||
addSelectValue(document.forms[0], se.id, se.previousSibling.value, se.previousSibling.value);
|
addSelectValue(document.forms[0], se.id, se.previousSibling.value, se.previousSibling.value);
|
||||||
selectByValue(document.forms[0], se.id, se.previousSibling.value);
|
selectByValue(document.forms[0], se.id, se.previousSibling.value);
|
||||||
} else
|
} else {
|
||||||
selectByValue(document.forms[0], se.id, '');
|
selectByValue(document.forms[0], se.id, '');
|
||||||
|
}
|
||||||
|
|
||||||
se.style.display = 'inline';
|
se.style.display = 'inline';
|
||||||
se.parentNode.removeChild(se.previousSibling);
|
se.parentNode.removeChild(se.previousSibling);
|
||||||
TinyMCE_EditableSelects.editSelectElm = null;
|
TinyMCE_EditableSelects.editSelectElm = null;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
onKeyDown : function(e) {
|
onKeyDown : function (e) {
|
||||||
e = e || window.event;
|
e = e || window.event;
|
||||||
|
|
||||||
if (e.keyCode == 13)
|
if (e.keyCode == 13) {
|
||||||
TinyMCE_EditableSelects.onBlurEditableSelectInput();
|
TinyMCE_EditableSelects.onBlurEditableSelectInput();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* form_utils.js
|
* form_utils.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
@ -11,200 +11,212 @@
|
|||||||
var themeBaseURL = tinyMCEPopup.editor.baseURI.toAbsolute('themes/' + tinyMCEPopup.getParam("theme"));
|
var themeBaseURL = tinyMCEPopup.editor.baseURI.toAbsolute('themes/' + tinyMCEPopup.getParam("theme"));
|
||||||
|
|
||||||
function getColorPickerHTML(id, target_form_element) {
|
function getColorPickerHTML(id, target_form_element) {
|
||||||
var h = "", dom = tinyMCEPopup.dom;
|
var h = "", dom = tinyMCEPopup.dom;
|
||||||
|
|
||||||
if (label = dom.select('label[for=' + target_form_element + ']')[0]) {
|
if (label = dom.select('label[for=' + target_form_element + ']')[0]) {
|
||||||
label.id = label.id || dom.uniqueId();
|
label.id = label.id || dom.uniqueId();
|
||||||
}
|
}
|
||||||
|
|
||||||
h += '<a role="button" aria-labelledby="' + id + '_label" id="' + id + '_link" href="javascript:;" onclick="tinyMCEPopup.pickColor(event,\'' + target_form_element +'\');" onmousedown="return false;" class="pickcolor">';
|
h += '<a role="button" aria-labelledby="' + id + '_label" id="' + id + '_link" href="javascript:;" onclick="tinyMCEPopup.pickColor(event,\'' + target_form_element + '\');" onmousedown="return false;" class="pickcolor">';
|
||||||
h += '<span id="' + id + '" title="' + tinyMCEPopup.getLang('browse') + '"> <span id="' + id + '_label" class="mceVoiceLabel mceIconOnly" style="display:none;">' + tinyMCEPopup.getLang('browse') + '</span></span></a>';
|
h += '<span id="' + id + '" title="' + tinyMCEPopup.getLang('browse') + '"> <span id="' + id + '_label" class="mceVoiceLabel mceIconOnly" style="display:none;">' + tinyMCEPopup.getLang('browse') + '</span></span></a>';
|
||||||
|
|
||||||
return h;
|
return h;
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateColor(img_id, form_element_id) {
|
function updateColor(img_id, form_element_id) {
|
||||||
document.getElementById(img_id).style.backgroundColor = document.forms[0].elements[form_element_id].value;
|
document.getElementById(img_id).style.backgroundColor = document.forms[0].elements[form_element_id].value;
|
||||||
}
|
}
|
||||||
|
|
||||||
function setBrowserDisabled(id, state) {
|
function setBrowserDisabled(id, state) {
|
||||||
var img = document.getElementById(id);
|
var img = document.getElementById(id);
|
||||||
var lnk = document.getElementById(id + "_link");
|
var lnk = document.getElementById(id + "_link");
|
||||||
|
|
||||||
if (lnk) {
|
if (lnk) {
|
||||||
if (state) {
|
if (state) {
|
||||||
lnk.setAttribute("realhref", lnk.getAttribute("href"));
|
lnk.setAttribute("realhref", lnk.getAttribute("href"));
|
||||||
lnk.removeAttribute("href");
|
lnk.removeAttribute("href");
|
||||||
tinyMCEPopup.dom.addClass(img, 'disabled');
|
tinyMCEPopup.dom.addClass(img, 'disabled');
|
||||||
} else {
|
} else {
|
||||||
if (lnk.getAttribute("realhref"))
|
if (lnk.getAttribute("realhref")) {
|
||||||
lnk.setAttribute("href", lnk.getAttribute("realhref"));
|
lnk.setAttribute("href", lnk.getAttribute("realhref"));
|
||||||
|
}
|
||||||
|
|
||||||
tinyMCEPopup.dom.removeClass(img, 'disabled');
|
tinyMCEPopup.dom.removeClass(img, 'disabled');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function getBrowserHTML(id, target_form_element, type, prefix) {
|
function getBrowserHTML(id, target_form_element, type, prefix) {
|
||||||
var option = prefix + "_" + type + "_browser_callback", cb, html;
|
var option = prefix + "_" + type + "_browser_callback", cb, html;
|
||||||
|
|
||||||
cb = tinyMCEPopup.getParam(option, tinyMCEPopup.getParam("file_browser_callback"));
|
cb = tinyMCEPopup.getParam(option, tinyMCEPopup.getParam("file_browser_callback"));
|
||||||
|
|
||||||
if (!cb)
|
if (!cb) {
|
||||||
return "";
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
html = "";
|
html = "";
|
||||||
html += '<a id="' + id + '_link" href="javascript:openBrowser(\'' + id + '\',\'' + target_form_element + '\', \'' + type + '\',\'' + option + '\');" onmousedown="return false;" class="browse">';
|
html += '<a id="' + id + '_link" href="javascript:openBrowser(\'' + id + '\',\'' + target_form_element + '\', \'' + type + '\',\'' + option + '\');" onmousedown="return false;" class="browse">';
|
||||||
html += '<span id="' + id + '" title="' + tinyMCEPopup.getLang('browse') + '"> </span></a>';
|
html += '<span id="' + id + '" title="' + tinyMCEPopup.getLang('browse') + '"> </span></a>';
|
||||||
|
|
||||||
return html;
|
return html;
|
||||||
}
|
}
|
||||||
|
|
||||||
function openBrowser(img_id, target_form_element, type, option) {
|
function openBrowser(img_id, target_form_element, type, option) {
|
||||||
var img = document.getElementById(img_id);
|
var img = document.getElementById(img_id);
|
||||||
|
|
||||||
if (img.className != "mceButtonDisabled")
|
if (img.className != "mceButtonDisabled") {
|
||||||
tinyMCEPopup.openBrowser(target_form_element, type, option);
|
tinyMCEPopup.openBrowser(target_form_element, type, option);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function selectByValue(form_obj, field_name, value, add_custom, ignore_case) {
|
function selectByValue(form_obj, field_name, value, add_custom, ignore_case) {
|
||||||
if (!form_obj || !form_obj.elements[field_name])
|
if (!form_obj || !form_obj.elements[field_name]) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (!value)
|
if (!value) {
|
||||||
value = "";
|
value = "";
|
||||||
|
}
|
||||||
|
|
||||||
var sel = form_obj.elements[field_name];
|
var sel = form_obj.elements[field_name];
|
||||||
|
|
||||||
var found = false;
|
var found = false;
|
||||||
for (var i=0; i<sel.options.length; i++) {
|
for (var i = 0; i < sel.options.length; i++) {
|
||||||
var option = sel.options[i];
|
var option = sel.options[i];
|
||||||
|
|
||||||
if (option.value == value || (ignore_case && option.value.toLowerCase() == value.toLowerCase())) {
|
if (option.value == value || (ignore_case && option.value.toLowerCase() == value.toLowerCase())) {
|
||||||
option.selected = true;
|
option.selected = true;
|
||||||
found = true;
|
found = true;
|
||||||
} else
|
} else {
|
||||||
option.selected = false;
|
option.selected = false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!found && add_custom && value != '') {
|
if (!found && add_custom && value != '') {
|
||||||
var option = new Option(value, value);
|
var option = new Option(value, value);
|
||||||
option.selected = true;
|
option.selected = true;
|
||||||
sel.options[sel.options.length] = option;
|
sel.options[sel.options.length] = option;
|
||||||
sel.selectedIndex = sel.options.length - 1;
|
sel.selectedIndex = sel.options.length - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return found;
|
return found;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getSelectValue(form_obj, field_name) {
|
function getSelectValue(form_obj, field_name) {
|
||||||
var elm = form_obj.elements[field_name];
|
var elm = form_obj.elements[field_name];
|
||||||
|
|
||||||
if (elm == null || elm.options == null || elm.selectedIndex === -1)
|
if (elm == null || elm.options == null || elm.selectedIndex === -1) {
|
||||||
return "";
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
return elm.options[elm.selectedIndex].value;
|
return elm.options[elm.selectedIndex].value;
|
||||||
}
|
}
|
||||||
|
|
||||||
function addSelectValue(form_obj, field_name, name, value) {
|
function addSelectValue(form_obj, field_name, name, value) {
|
||||||
var s = form_obj.elements[field_name];
|
var s = form_obj.elements[field_name];
|
||||||
var o = new Option(name, value);
|
var o = new Option(name, value);
|
||||||
s.options[s.options.length] = o;
|
s.options[s.options.length] = o;
|
||||||
}
|
}
|
||||||
|
|
||||||
function addClassesToList(list_id, specific_option) {
|
function addClassesToList(list_id, specific_option) {
|
||||||
// Setup class droplist
|
// Setup class droplist
|
||||||
var styleSelectElm = document.getElementById(list_id);
|
var styleSelectElm = document.getElementById(list_id);
|
||||||
var styles = tinyMCEPopup.getParam('theme_advanced_styles', false);
|
var styles = tinyMCEPopup.getParam('theme_advanced_styles', false);
|
||||||
styles = tinyMCEPopup.getParam(specific_option, styles);
|
styles = tinyMCEPopup.getParam(specific_option, styles);
|
||||||
|
|
||||||
if (styles) {
|
if (styles) {
|
||||||
var stylesAr = styles.split(';');
|
var stylesAr = styles.split(';');
|
||||||
|
|
||||||
for (var i=0; i<stylesAr.length; i++) {
|
for (var i = 0; i < stylesAr.length; i++) {
|
||||||
if (stylesAr != "") {
|
if (stylesAr != "") {
|
||||||
var key, value;
|
var key, value;
|
||||||
|
|
||||||
key = stylesAr[i].split('=')[0];
|
key = stylesAr[i].split('=')[0];
|
||||||
value = stylesAr[i].split('=')[1];
|
value = stylesAr[i].split('=')[1];
|
||||||
|
|
||||||
styleSelectElm.options[styleSelectElm.length] = new Option(key, value);
|
styleSelectElm.options[styleSelectElm.length] = new Option(key, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/*tinymce.each(tinyMCEPopup.editor.dom.getClasses(), function(o) {
|
/*tinymce.each(tinyMCEPopup.editor.dom.getClasses(), function(o) {
|
||||||
styleSelectElm.options[styleSelectElm.length] = new Option(o.title || o['class'], o['class']);
|
styleSelectElm.options[styleSelectElm.length] = new Option(o.title || o['class'], o['class']);
|
||||||
});*/
|
});*/
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function isVisible(element_id) {
|
function isVisible(element_id) {
|
||||||
var elm = document.getElementById(element_id);
|
var elm = document.getElementById(element_id);
|
||||||
|
|
||||||
return elm && elm.style.display != "none";
|
return elm && elm.style.display != "none";
|
||||||
}
|
}
|
||||||
|
|
||||||
function convertRGBToHex(col) {
|
function convertRGBToHex(col) {
|
||||||
var re = new RegExp("rgb\\s*\\(\\s*([0-9]+).*,\\s*([0-9]+).*,\\s*([0-9]+).*\\)", "gi");
|
var re = new RegExp("rgb\\s*\\(\\s*([0-9]+).*,\\s*([0-9]+).*,\\s*([0-9]+).*\\)", "gi");
|
||||||
|
|
||||||
var rgb = col.replace(re, "$1,$2,$3").split(',');
|
var rgb = col.replace(re, "$1,$2,$3").split(',');
|
||||||
if (rgb.length == 3) {
|
if (rgb.length == 3) {
|
||||||
r = parseInt(rgb[0]).toString(16);
|
r = parseInt(rgb[0]).toString(16);
|
||||||
g = parseInt(rgb[1]).toString(16);
|
g = parseInt(rgb[1]).toString(16);
|
||||||
b = parseInt(rgb[2]).toString(16);
|
b = parseInt(rgb[2]).toString(16);
|
||||||
|
|
||||||
r = r.length == 1 ? '0' + r : r;
|
r = r.length == 1 ? '0' + r : r;
|
||||||
g = g.length == 1 ? '0' + g : g;
|
g = g.length == 1 ? '0' + g : g;
|
||||||
b = b.length == 1 ? '0' + b : b;
|
b = b.length == 1 ? '0' + b : b;
|
||||||
|
|
||||||
return "#" + r + g + b;
|
return "#" + r + g + b;
|
||||||
}
|
}
|
||||||
|
|
||||||
return col;
|
return col;
|
||||||
}
|
}
|
||||||
|
|
||||||
function convertHexToRGB(col) {
|
function convertHexToRGB(col) {
|
||||||
if (col.indexOf('#') != -1) {
|
if (col.indexOf('#') != -1) {
|
||||||
col = col.replace(new RegExp('[^0-9A-F]', 'gi'), '');
|
col = col.replace(new RegExp('[^0-9A-F]', 'gi'), '');
|
||||||
|
|
||||||
r = parseInt(col.substring(0, 2), 16);
|
r = parseInt(col.substring(0, 2), 16);
|
||||||
g = parseInt(col.substring(2, 4), 16);
|
g = parseInt(col.substring(2, 4), 16);
|
||||||
b = parseInt(col.substring(4, 6), 16);
|
b = parseInt(col.substring(4, 6), 16);
|
||||||
|
|
||||||
return "rgb(" + r + "," + g + "," + b + ")";
|
return "rgb(" + r + "," + g + "," + b + ")";
|
||||||
}
|
}
|
||||||
|
|
||||||
return col;
|
return col;
|
||||||
}
|
}
|
||||||
|
|
||||||
function trimSize(size) {
|
function trimSize(size) {
|
||||||
return size.replace(/([0-9\.]+)(px|%|in|cm|mm|em|ex|pt|pc)/i, '$1$2');
|
return size.replace(/([0-9\.]+)(px|%|in|cm|mm|em|ex|pt|pc)/i, '$1$2');
|
||||||
}
|
}
|
||||||
|
|
||||||
function getCSSSize(size) {
|
function getCSSSize(size) {
|
||||||
size = trimSize(size);
|
size = trimSize(size);
|
||||||
|
|
||||||
if (size == "")
|
if (size == "") {
|
||||||
return "";
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
// Add px
|
// Add px
|
||||||
if (/^[0-9]+$/.test(size))
|
if (/^[0-9]+$/.test(size)) {
|
||||||
size += 'px';
|
size += 'px';
|
||||||
// Sanity check, IE doesn't like broken values
|
}
|
||||||
else if (!(/^[0-9\.]+(px|%|in|cm|mm|em|ex|pt|pc)$/i.test(size)))
|
// Sanity check, IE doesn't like broken values
|
||||||
return "";
|
else if (!(/^[0-9\.]+(px|%|in|cm|mm|em|ex|pt|pc)$/i.test(size))) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getStyle(elm, attrib, style) {
|
function getStyle(elm, attrib, style) {
|
||||||
var val = tinyMCEPopup.dom.getAttrib(elm, attrib);
|
var val = tinyMCEPopup.dom.getAttrib(elm, attrib);
|
||||||
|
|
||||||
if (val != '')
|
if (val != '') {
|
||||||
return '' + val;
|
return '' + val;
|
||||||
|
}
|
||||||
|
|
||||||
if (typeof(style) == 'undefined')
|
if (typeof (style) == 'undefined') {
|
||||||
style = attrib;
|
style = attrib;
|
||||||
|
}
|
||||||
|
|
||||||
return tinyMCEPopup.dom.getStyle(elm, style);
|
return tinyMCEPopup.dom.getStyle(elm, style);
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* mctabs.js
|
* mctabs.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
@ -11,154 +11,158 @@
|
|||||||
/*jshint globals: tinyMCEPopup */
|
/*jshint globals: tinyMCEPopup */
|
||||||
|
|
||||||
function MCTabs() {
|
function MCTabs() {
|
||||||
this.settings = [];
|
this.settings = [];
|
||||||
this.onChange = tinyMCEPopup.editor.windowManager.createInstance('tinymce.util.Dispatcher');
|
this.onChange = tinyMCEPopup.editor.windowManager.createInstance('tinymce.plugins.util.Dispatcher');
|
||||||
|
}
|
||||||
|
|
||||||
|
MCTabs.prototype.init = function (settings) {
|
||||||
|
this.settings = settings;
|
||||||
};
|
};
|
||||||
|
|
||||||
MCTabs.prototype.init = function(settings) {
|
MCTabs.prototype.getParam = function (name, default_value) {
|
||||||
this.settings = settings;
|
var value = null;
|
||||||
|
|
||||||
|
value = (typeof (this.settings[name]) == "undefined") ? default_value : this.settings[name];
|
||||||
|
|
||||||
|
// Fix bool values
|
||||||
|
if (value == "true" || value == "false") {
|
||||||
|
return (value == "true");
|
||||||
|
}
|
||||||
|
|
||||||
|
return value;
|
||||||
};
|
};
|
||||||
|
|
||||||
MCTabs.prototype.getParam = function(name, default_value) {
|
MCTabs.prototype.showTab = function (tab) {
|
||||||
var value = null;
|
tab.className = 'current';
|
||||||
|
tab.setAttribute("aria-selected", true);
|
||||||
value = (typeof(this.settings[name]) == "undefined") ? default_value : this.settings[name];
|
tab.setAttribute("aria-expanded", true);
|
||||||
|
tab.tabIndex = 0;
|
||||||
// Fix bool values
|
|
||||||
if (value == "true" || value == "false")
|
|
||||||
return (value == "true");
|
|
||||||
|
|
||||||
return value;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
MCTabs.prototype.showTab =function(tab){
|
MCTabs.prototype.hideTab = function (tab) {
|
||||||
tab.className = 'current';
|
var t = this;
|
||||||
tab.setAttribute("aria-selected", true);
|
|
||||||
tab.setAttribute("aria-expanded", true);
|
tab.className = '';
|
||||||
tab.tabIndex = 0;
|
tab.setAttribute("aria-selected", false);
|
||||||
|
tab.setAttribute("aria-expanded", false);
|
||||||
|
tab.tabIndex = -1;
|
||||||
};
|
};
|
||||||
|
|
||||||
MCTabs.prototype.hideTab =function(tab){
|
MCTabs.prototype.showPanel = function (panel) {
|
||||||
var t=this;
|
panel.className = 'current';
|
||||||
|
panel.setAttribute("aria-hidden", false);
|
||||||
tab.className = '';
|
|
||||||
tab.setAttribute("aria-selected", false);
|
|
||||||
tab.setAttribute("aria-expanded", false);
|
|
||||||
tab.tabIndex = -1;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
MCTabs.prototype.showPanel = function(panel) {
|
MCTabs.prototype.hidePanel = function (panel) {
|
||||||
panel.className = 'current';
|
panel.className = 'panel';
|
||||||
panel.setAttribute("aria-hidden", false);
|
panel.setAttribute("aria-hidden", true);
|
||||||
};
|
};
|
||||||
|
|
||||||
MCTabs.prototype.hidePanel = function(panel) {
|
MCTabs.prototype.getPanelForTab = function (tabElm) {
|
||||||
panel.className = 'panel';
|
return tinyMCEPopup.dom.getAttrib(tabElm, "aria-controls");
|
||||||
panel.setAttribute("aria-hidden", true);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
MCTabs.prototype.getPanelForTab = function(tabElm) {
|
MCTabs.prototype.displayTab = function (tab_id, panel_id, avoid_focus) {
|
||||||
return tinyMCEPopup.dom.getAttrib(tabElm, "aria-controls");
|
var panelElm, panelContainerElm, tabElm, tabContainerElm, selectionClass, nodes, i, t = this;
|
||||||
|
|
||||||
|
tabElm = document.getElementById(tab_id);
|
||||||
|
|
||||||
|
if (panel_id === undefined) {
|
||||||
|
panel_id = t.getPanelForTab(tabElm);
|
||||||
|
}
|
||||||
|
|
||||||
|
panelElm = document.getElementById(panel_id);
|
||||||
|
panelContainerElm = panelElm ? panelElm.parentNode : null;
|
||||||
|
tabContainerElm = tabElm ? tabElm.parentNode : null;
|
||||||
|
selectionClass = t.getParam('selection_class', 'current');
|
||||||
|
|
||||||
|
if (tabElm && tabContainerElm) {
|
||||||
|
nodes = tabContainerElm.childNodes;
|
||||||
|
|
||||||
|
// Hide all other tabs
|
||||||
|
for (i = 0; i < nodes.length; i++) {
|
||||||
|
if (nodes[i].nodeName == "LI") {
|
||||||
|
t.hideTab(nodes[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Show selected tab
|
||||||
|
t.showTab(tabElm);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (panelElm && panelContainerElm) {
|
||||||
|
nodes = panelContainerElm.childNodes;
|
||||||
|
|
||||||
|
// Hide all other panels
|
||||||
|
for (i = 0; i < nodes.length; i++) {
|
||||||
|
if (nodes[i].nodeName == "DIV") {
|
||||||
|
t.hidePanel(nodes[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!avoid_focus) {
|
||||||
|
tabElm.focus();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Show selected panel
|
||||||
|
t.showPanel(panelElm);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
MCTabs.prototype.displayTab = function(tab_id, panel_id, avoid_focus) {
|
MCTabs.prototype.getAnchor = function () {
|
||||||
var panelElm, panelContainerElm, tabElm, tabContainerElm, selectionClass, nodes, i, t = this;
|
var pos, url = document.location.href;
|
||||||
|
|
||||||
tabElm = document.getElementById(tab_id);
|
if ((pos = url.lastIndexOf('#')) != -1) {
|
||||||
|
return url.substring(pos + 1);
|
||||||
|
}
|
||||||
|
|
||||||
if (panel_id === undefined) {
|
return "";
|
||||||
panel_id = t.getPanelForTab(tabElm);
|
|
||||||
}
|
|
||||||
|
|
||||||
panelElm= document.getElementById(panel_id);
|
|
||||||
panelContainerElm = panelElm ? panelElm.parentNode : null;
|
|
||||||
tabContainerElm = tabElm ? tabElm.parentNode : null;
|
|
||||||
selectionClass = t.getParam('selection_class', 'current');
|
|
||||||
|
|
||||||
if (tabElm && tabContainerElm) {
|
|
||||||
nodes = tabContainerElm.childNodes;
|
|
||||||
|
|
||||||
// Hide all other tabs
|
|
||||||
for (i = 0; i < nodes.length; i++) {
|
|
||||||
if (nodes[i].nodeName == "LI") {
|
|
||||||
t.hideTab(nodes[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Show selected tab
|
|
||||||
t.showTab(tabElm);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (panelElm && panelContainerElm) {
|
|
||||||
nodes = panelContainerElm.childNodes;
|
|
||||||
|
|
||||||
// Hide all other panels
|
|
||||||
for (i = 0; i < nodes.length; i++) {
|
|
||||||
if (nodes[i].nodeName == "DIV")
|
|
||||||
t.hidePanel(nodes[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!avoid_focus) {
|
|
||||||
tabElm.focus();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Show selected panel
|
|
||||||
t.showPanel(panelElm);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
MCTabs.prototype.getAnchor = function() {
|
|
||||||
var pos, url = document.location.href;
|
|
||||||
|
|
||||||
if ((pos = url.lastIndexOf('#')) != -1)
|
|
||||||
return url.substring(pos + 1);
|
|
||||||
|
|
||||||
return "";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
//Global instance
|
//Global instance
|
||||||
var mcTabs = new MCTabs();
|
var mcTabs = new MCTabs();
|
||||||
|
|
||||||
tinyMCEPopup.onInit.add(function() {
|
tinyMCEPopup.onInit.add(function () {
|
||||||
var tinymce = tinyMCEPopup.getWin().tinymce, dom = tinyMCEPopup.dom, each = tinymce.each;
|
var tinymce = tinyMCEPopup.getWin().tinymce, dom = tinyMCEPopup.dom, each = tinymce.each;
|
||||||
|
|
||||||
each(dom.select('div.tabs'), function(tabContainerElm) {
|
each(dom.select('div.tabs'), function (tabContainerElm) {
|
||||||
//var keyNav;
|
//var keyNav;
|
||||||
|
|
||||||
dom.setAttrib(tabContainerElm, "role", "tablist");
|
dom.setAttrib(tabContainerElm, "role", "tablist");
|
||||||
|
|
||||||
var items = tinyMCEPopup.dom.select('li', tabContainerElm);
|
var items = tinyMCEPopup.dom.select('li', tabContainerElm);
|
||||||
var action = function(id) {
|
var action = function (id) {
|
||||||
mcTabs.displayTab(id, mcTabs.getPanelForTab(id));
|
mcTabs.displayTab(id, mcTabs.getPanelForTab(id));
|
||||||
mcTabs.onChange.dispatch(id);
|
mcTabs.onChange.dispatch(id);
|
||||||
};
|
};
|
||||||
|
|
||||||
each(items, function(item) {
|
each(items, function (item) {
|
||||||
dom.setAttrib(item, 'role', 'tab');
|
dom.setAttrib(item, 'role', 'tab');
|
||||||
dom.bind(item, 'click', function(evt) {
|
dom.bind(item, 'click', function (evt) {
|
||||||
action(item.id);
|
action(item.id);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
dom.bind(dom.getRoot(), 'keydown', function(evt) {
|
dom.bind(dom.getRoot(), 'keydown', function (evt) {
|
||||||
if (evt.keyCode === 9 && evt.ctrlKey && !evt.altKey) { // Tab
|
if (evt.keyCode === 9 && evt.ctrlKey && !evt.altKey) { // Tab
|
||||||
//keyNav.moveFocus(evt.shiftKey ? -1 : 1);
|
//keyNav.moveFocus(evt.shiftKey ? -1 : 1);
|
||||||
tinymce.dom.Event.cancel(evt);
|
tinymce.dom.Event.cancel(evt);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
each(dom.select('a', tabContainerElm), function(a) {
|
each(dom.select('a', tabContainerElm), function (a) {
|
||||||
dom.setAttrib(a, 'tabindex', '-1');
|
dom.setAttrib(a, 'tabindex', '-1');
|
||||||
});
|
});
|
||||||
|
|
||||||
/*keyNav = tinyMCEPopup.editor.windowManager.createInstance('tinymce.ui.KeyboardNavigation', {
|
/*keyNav = tinyMCEPopup.editor.windowManager.createInstance('tinymce.plugins.ui.KeyboardNavigation', {
|
||||||
root: tabContainerElm,
|
root: tabContainerElm,
|
||||||
items: items,
|
items: items,
|
||||||
onAction: action,
|
onAction: action,
|
||||||
actOnFocus: true,
|
actOnFocus: true,
|
||||||
enableLeftRight: true,
|
enableLeftRight: true,
|
||||||
enableUpDown: true
|
enableUpDown: true
|
||||||
}, tinyMCEPopup.dom);*/
|
}, tinyMCEPopup.dom);*/
|
||||||
});
|
}
|
||||||
|
);
|
||||||
});
|
});
|
@ -2,251 +2,266 @@
|
|||||||
* validate.js
|
* validate.js
|
||||||
*
|
*
|
||||||
* Released under LGPL License.
|
* Released under LGPL License.
|
||||||
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
* Copyright (c) 1999-2017 Ephox Corp. All rights reserved
|
||||||
*
|
*
|
||||||
* License: http://www.tinymce.com/license
|
* License: http://www.tinymce.com/license
|
||||||
* Contributing: http://www.tinymce.com/contributing
|
* Contributing: http://www.tinymce.com/contributing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
// String validation:
|
// String validation:
|
||||||
|
|
||||||
if (!Validator.isEmail('myemail'))
|
if (!Validator.isEmail('myemail'))
|
||||||
alert('Invalid email.');
|
alert('Invalid email.');
|
||||||
|
|
||||||
// Form validation:
|
// Form validation:
|
||||||
|
|
||||||
var f = document.forms['myform'];
|
var f = document.forms['myform'];
|
||||||
|
|
||||||
if (!Validator.isEmail(f.myemail))
|
if (!Validator.isEmail(f.myemail))
|
||||||
alert('Invalid email.');
|
alert('Invalid email.');
|
||||||
*/
|
*/
|
||||||
|
|
||||||
var Validator = {
|
var Validator = {
|
||||||
isEmail : function(s) {
|
isEmail : function (s) {
|
||||||
return this.test(s, '^[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+@[-!#$%&\'*+\\/0-9=?A-Z^_`a-z{|}~]+\.[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+$');
|
return this.test(s, '^[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+@[-!#$%&\'*+\\/0-9=?A-Z^_`a-z{|}~]+\.[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+$');
|
||||||
},
|
},
|
||||||
|
|
||||||
isAbsUrl : function(s) {
|
isAbsUrl : function (s) {
|
||||||
return this.test(s, '^(news|telnet|nttp|file|http|ftp|https)://[-A-Za-z0-9\\.]+\\/?.*$');
|
return this.test(s, '^(news|telnet|nttp|file|http|ftp|https)://[-A-Za-z0-9\\.]+\\/?.*$');
|
||||||
},
|
},
|
||||||
|
|
||||||
isSize : function(s) {
|
isSize : function (s) {
|
||||||
return this.test(s, '^[0-9.]+(%|in|cm|mm|em|ex|pt|pc|px)?$');
|
return this.test(s, '^[0-9.]+(%|in|cm|mm|em|ex|pt|pc|px)?$');
|
||||||
},
|
},
|
||||||
|
|
||||||
isId : function(s) {
|
isId : function (s) {
|
||||||
return this.test(s, '^[A-Za-z_]([A-Za-z0-9_])*$');
|
return this.test(s, '^[A-Za-z_]([A-Za-z0-9_])*$');
|
||||||
},
|
},
|
||||||
|
|
||||||
isEmpty : function(s) {
|
isEmpty : function (s) {
|
||||||
var nl, i;
|
var nl, i;
|
||||||
|
|
||||||
if (s.nodeName == 'SELECT' && s.selectedIndex < 1)
|
if (s.nodeName == 'SELECT' && s.selectedIndex < 1) {
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if (s.type == 'checkbox' && !s.checked)
|
if (s.type == 'checkbox' && !s.checked) {
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if (s.type == 'radio') {
|
if (s.type == 'radio') {
|
||||||
for (i=0, nl = s.form.elements; i<nl.length; i++) {
|
for (i = 0, nl = s.form.elements; i < nl.length; i++) {
|
||||||
if (nl[i].type == "radio" && nl[i].name == s.name && nl[i].checked)
|
if (nl[i].type == "radio" && nl[i].name == s.name && nl[i].checked) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new RegExp('^\\s*$').test(s.nodeType == 1 ? s.value : s);
|
return new RegExp('^\\s*$').test(s.nodeType == 1 ? s.value : s);
|
||||||
},
|
},
|
||||||
|
|
||||||
isNumber : function(s, d) {
|
isNumber : function (s, d) {
|
||||||
return !isNaN(s.nodeType == 1 ? s.value : s) && (!d || !this.test(s, '^-?[0-9]*\\.[0-9]*$'));
|
return !isNaN(s.nodeType == 1 ? s.value : s) && (!d || !this.test(s, '^-?[0-9]*\\.[0-9]*$'));
|
||||||
},
|
},
|
||||||
|
|
||||||
test : function(s, p) {
|
test : function (s, p) {
|
||||||
s = s.nodeType == 1 ? s.value : s;
|
s = s.nodeType == 1 ? s.value : s;
|
||||||
|
|
||||||
return s == '' || new RegExp(p).test(s);
|
return s == '' || new RegExp(p).test(s);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
var AutoValidator = {
|
var AutoValidator = {
|
||||||
settings : {
|
settings : {
|
||||||
id_cls : 'id',
|
id_cls : 'id',
|
||||||
int_cls : 'int',
|
int_cls : 'int',
|
||||||
url_cls : 'url',
|
url_cls : 'url',
|
||||||
number_cls : 'number',
|
number_cls : 'number',
|
||||||
email_cls : 'email',
|
email_cls : 'email',
|
||||||
size_cls : 'size',
|
size_cls : 'size',
|
||||||
required_cls : 'required',
|
required_cls : 'required',
|
||||||
invalid_cls : 'invalid',
|
invalid_cls : 'invalid',
|
||||||
min_cls : 'min',
|
min_cls : 'min',
|
||||||
max_cls : 'max'
|
max_cls : 'max'
|
||||||
},
|
},
|
||||||
|
|
||||||
init : function(s) {
|
init : function (s) {
|
||||||
var n;
|
var n;
|
||||||
|
|
||||||
for (n in s)
|
for (n in s) {
|
||||||
this.settings[n] = s[n];
|
this.settings[n] = s[n];
|
||||||
},
|
}
|
||||||
|
},
|
||||||
|
|
||||||
validate : function(f) {
|
validate : function (f) {
|
||||||
var i, nl, s = this.settings, c = 0;
|
var i, nl, s = this.settings, c = 0;
|
||||||
|
|
||||||
nl = this.tags(f, 'label');
|
nl = this.tags(f, 'label');
|
||||||
for (i=0; i<nl.length; i++) {
|
for (i = 0; i < nl.length; i++) {
|
||||||
this.removeClass(nl[i], s.invalid_cls);
|
this.removeClass(nl[i], s.invalid_cls);
|
||||||
nl[i].setAttribute('aria-invalid', false);
|
nl[i].setAttribute('aria-invalid', false);
|
||||||
}
|
}
|
||||||
|
|
||||||
c += this.validateElms(f, 'input');
|
c += this.validateElms(f, 'input');
|
||||||
c += this.validateElms(f, 'select');
|
c += this.validateElms(f, 'select');
|
||||||
c += this.validateElms(f, 'textarea');
|
c += this.validateElms(f, 'textarea');
|
||||||
|
|
||||||
return c == 3;
|
return c == 3;
|
||||||
},
|
},
|
||||||
|
|
||||||
invalidate : function(n) {
|
invalidate : function (n) {
|
||||||
this.mark(n.form, n);
|
this.mark(n.form, n);
|
||||||
},
|
},
|
||||||
|
|
||||||
getErrorMessages : function(f) {
|
getErrorMessages : function (f) {
|
||||||
var nl, i, s = this.settings, field, msg, values, messages = [], ed = tinyMCEPopup.editor;
|
var nl, i, s = this.settings, field, msg, values, messages = [], ed = tinyMCEPopup.editor;
|
||||||
nl = this.tags(f, "label");
|
nl = this.tags(f, "label");
|
||||||
for (i=0; i<nl.length; i++) {
|
for (i = 0; i < nl.length; i++) {
|
||||||
if (this.hasClass(nl[i], s.invalid_cls)) {
|
if (this.hasClass(nl[i], s.invalid_cls)) {
|
||||||
field = document.getElementById(nl[i].getAttribute("for"));
|
field = document.getElementById(nl[i].getAttribute("for"));
|
||||||
values = { field: nl[i].textContent };
|
values = { field: nl[i].textContent };
|
||||||
if (this.hasClass(field, s.min_cls, true)) {
|
if (this.hasClass(field, s.min_cls, true)) {
|
||||||
message = ed.getLang('invalid_data_min');
|
message = ed.getLang('invalid_data_min');
|
||||||
values.min = this.getNum(field, s.min_cls);
|
values.min = this.getNum(field, s.min_cls);
|
||||||
} else if (this.hasClass(field, s.number_cls)) {
|
} else if (this.hasClass(field, s.number_cls)) {
|
||||||
message = ed.getLang('invalid_data_number');
|
message = ed.getLang('invalid_data_number');
|
||||||
} else if (this.hasClass(field, s.size_cls)) {
|
} else if (this.hasClass(field, s.size_cls)) {
|
||||||
message = ed.getLang('invalid_data_size');
|
message = ed.getLang('invalid_data_size');
|
||||||
} else {
|
} else {
|
||||||
message = ed.getLang('invalid_data');
|
message = ed.getLang('invalid_data');
|
||||||
}
|
}
|
||||||
|
|
||||||
message = message.replace(/{\#([^}]+)\}/g, function(a, b) {
|
message = message.replace(/{\#([^}]+)\}/g, function (a, b) {
|
||||||
return values[b] || '{#' + b + '}';
|
return values[b] || '{#' + b + '}';
|
||||||
});
|
});
|
||||||
messages.push(message);
|
messages.push(message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return messages;
|
return messages;
|
||||||
},
|
},
|
||||||
|
|
||||||
reset : function(e) {
|
reset : function (e) {
|
||||||
var t = ['label', 'input', 'select', 'textarea'];
|
var t = ['label', 'input', 'select', 'textarea'];
|
||||||
var i, j, nl, s = this.settings;
|
var i, j, nl, s = this.settings;
|
||||||
|
|
||||||
if (e == null)
|
if (e == null) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
for (i=0; i<t.length; i++) {
|
for (i = 0; i < t.length; i++) {
|
||||||
nl = this.tags(e.form ? e.form : e, t[i]);
|
nl = this.tags(e.form ? e.form : e, t[i]);
|
||||||
for (j=0; j<nl.length; j++) {
|
for (j = 0; j < nl.length; j++) {
|
||||||
this.removeClass(nl[j], s.invalid_cls);
|
this.removeClass(nl[j], s.invalid_cls);
|
||||||
nl[j].setAttribute('aria-invalid', false);
|
nl[j].setAttribute('aria-invalid', false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
validateElms : function(f, e) {
|
validateElms : function (f, e) {
|
||||||
var nl, i, n, s = this.settings, st = true, va = Validator, v;
|
var nl, i, n, s = this.settings, st = true, va = Validator, v;
|
||||||
|
|
||||||
nl = this.tags(f, e);
|
nl = this.tags(f, e);
|
||||||
for (i=0; i<nl.length; i++) {
|
for (i = 0; i < nl.length; i++) {
|
||||||
n = nl[i];
|
n = nl[i];
|
||||||
|
|
||||||
this.removeClass(n, s.invalid_cls);
|
this.removeClass(n, s.invalid_cls);
|
||||||
|
|
||||||
if (this.hasClass(n, s.required_cls) && va.isEmpty(n))
|
if (this.hasClass(n, s.required_cls) && va.isEmpty(n)) {
|
||||||
st = this.mark(f, n);
|
st = this.mark(f, n);
|
||||||
|
}
|
||||||
|
|
||||||
if (this.hasClass(n, s.number_cls) && !va.isNumber(n))
|
if (this.hasClass(n, s.number_cls) && !va.isNumber(n)) {
|
||||||
st = this.mark(f, n);
|
st = this.mark(f, n);
|
||||||
|
}
|
||||||
|
|
||||||
if (this.hasClass(n, s.int_cls) && !va.isNumber(n, true))
|
if (this.hasClass(n, s.int_cls) && !va.isNumber(n, true)) {
|
||||||
st = this.mark(f, n);
|
st = this.mark(f, n);
|
||||||
|
}
|
||||||
|
|
||||||
if (this.hasClass(n, s.url_cls) && !va.isAbsUrl(n))
|
if (this.hasClass(n, s.url_cls) && !va.isAbsUrl(n)) {
|
||||||
st = this.mark(f, n);
|
st = this.mark(f, n);
|
||||||
|
}
|
||||||
|
|
||||||
if (this.hasClass(n, s.email_cls) && !va.isEmail(n))
|
if (this.hasClass(n, s.email_cls) && !va.isEmail(n)) {
|
||||||
st = this.mark(f, n);
|
st = this.mark(f, n);
|
||||||
|
}
|
||||||
|
|
||||||
if (this.hasClass(n, s.size_cls) && !va.isSize(n))
|
if (this.hasClass(n, s.size_cls) && !va.isSize(n)) {
|
||||||
st = this.mark(f, n);
|
st = this.mark(f, n);
|
||||||
|
}
|
||||||
|
|
||||||
if (this.hasClass(n, s.id_cls) && !va.isId(n))
|
if (this.hasClass(n, s.id_cls) && !va.isId(n)) {
|
||||||
st = this.mark(f, n);
|
st = this.mark(f, n);
|
||||||
|
}
|
||||||
|
|
||||||
if (this.hasClass(n, s.min_cls, true)) {
|
if (this.hasClass(n, s.min_cls, true)) {
|
||||||
v = this.getNum(n, s.min_cls);
|
v = this.getNum(n, s.min_cls);
|
||||||
|
|
||||||
if (isNaN(v) || parseInt(n.value) < parseInt(v))
|
if (isNaN(v) || parseInt(n.value) < parseInt(v)) {
|
||||||
st = this.mark(f, n);
|
st = this.mark(f, n);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (this.hasClass(n, s.max_cls, true)) {
|
if (this.hasClass(n, s.max_cls, true)) {
|
||||||
v = this.getNum(n, s.max_cls);
|
v = this.getNum(n, s.max_cls);
|
||||||
|
|
||||||
if (isNaN(v) || parseInt(n.value) > parseInt(v))
|
if (isNaN(v) || parseInt(n.value) > parseInt(v)) {
|
||||||
st = this.mark(f, n);
|
st = this.mark(f, n);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return st;
|
return st;
|
||||||
},
|
},
|
||||||
|
|
||||||
hasClass : function(n, c, d) {
|
hasClass : function (n, c, d) {
|
||||||
return new RegExp('\\b' + c + (d ? '[0-9]+' : '') + '\\b', 'g').test(n.className);
|
return new RegExp('\\b' + c + (d ? '[0-9]+' : '') + '\\b', 'g').test(n.className);
|
||||||
},
|
},
|
||||||
|
|
||||||
getNum : function(n, c) {
|
getNum : function (n, c) {
|
||||||
c = n.className.match(new RegExp('\\b' + c + '([0-9]+)\\b', 'g'))[0];
|
c = n.className.match(new RegExp('\\b' + c + '([0-9]+)\\b', 'g'))[0];
|
||||||
c = c.replace(/[^0-9]/g, '');
|
c = c.replace(/[^0-9]/g, '');
|
||||||
|
|
||||||
return c;
|
return c;
|
||||||
},
|
},
|
||||||
|
|
||||||
addClass : function(n, c, b) {
|
addClass : function (n, c, b) {
|
||||||
var o = this.removeClass(n, c);
|
var o = this.removeClass(n, c);
|
||||||
n.className = b ? c + (o != '' ? (' ' + o) : '') : (o != '' ? (o + ' ') : '') + c;
|
n.className = b ? c + (o != '' ? (' ' + o) : '') : (o != '' ? (o + ' ') : '') + c;
|
||||||
},
|
},
|
||||||
|
|
||||||
removeClass : function(n, c) {
|
removeClass : function (n, c) {
|
||||||
c = n.className.replace(new RegExp("(^|\\s+)" + c + "(\\s+|$)"), ' ');
|
c = n.className.replace(new RegExp("(^|\\s+)" + c + "(\\s+|$)"), ' ');
|
||||||
return n.className = c != ' ' ? c : '';
|
return n.className = c != ' ' ? c : '';
|
||||||
},
|
},
|
||||||
|
|
||||||
tags : function(f, s) {
|
tags : function (f, s) {
|
||||||
return f.getElementsByTagName(s);
|
return f.getElementsByTagName(s);
|
||||||
},
|
},
|
||||||
|
|
||||||
mark : function(f, n) {
|
mark : function (f, n) {
|
||||||
var s = this.settings;
|
var s = this.settings;
|
||||||
|
|
||||||
this.addClass(n, s.invalid_cls);
|
this.addClass(n, s.invalid_cls);
|
||||||
n.setAttribute('aria-invalid', 'true');
|
n.setAttribute('aria-invalid', 'true');
|
||||||
this.markLabels(f, n, s.invalid_cls);
|
this.markLabels(f, n, s.invalid_cls);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
markLabels : function(f, n, ic) {
|
markLabels : function (f, n, ic) {
|
||||||
var nl, i;
|
var nl, i;
|
||||||
|
|
||||||
nl = this.tags(f, "label");
|
nl = this.tags(f, "label");
|
||||||
for (i=0; i<nl.length; i++) {
|
for (i = 0; i < nl.length; i++) {
|
||||||
if (nl[i].getAttribute("for") == n.id || nl[i].htmlFor == n.id)
|
if (nl[i].getAttribute("for") == n.id || nl[i].htmlFor == n.id) {
|
||||||
this.addClass(nl[i], ic);
|
this.addClass(nl[i], ic);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -18,7 +18,7 @@ $wp_db_version = 38590;
|
|||||||
*
|
*
|
||||||
* @global string $tinymce_version
|
* @global string $tinymce_version
|
||||||
*/
|
*/
|
||||||
$tinymce_version = '4506-20170408';
|
$tinymce_version = '4600-20170506';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the required PHP version
|
* Holds the required PHP version
|
||||||
|
Loading…
Reference in New Issue
Block a user