/**
|
* Copyright (c) Tiny Technologies, Inc. All rights reserved.
|
* Licensed under the LGPL or a commercial license.
|
* For LGPL see License.txt in the project root for license information.
|
* For commercial licenses see https://www.tiny.cloud/
|
*
|
* Version: 5.2.0 (2020-02-13)
|
*/
|
(function (domGlobals) {
|
'use strict';
|
|
var global = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
|
var global$1 = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
|
var setDir = function (editor, dir) {
|
var dom = editor.dom;
|
var curDir;
|
var blocks = editor.selection.getSelectedBlocks();
|
if (blocks.length) {
|
curDir = dom.getAttrib(blocks[0], 'dir');
|
global$1.each(blocks, function (block) {
|
if (!dom.getParent(block.parentNode, '*[dir="' + dir + '"]', dom.getRoot())) {
|
dom.setAttrib(block, 'dir', curDir !== dir ? dir : null);
|
}
|
});
|
editor.nodeChanged();
|
}
|
};
|
var Direction = { setDir: setDir };
|
|
var register = function (editor) {
|
editor.addCommand('mceDirectionLTR', function () {
|
Direction.setDir(editor, 'ltr');
|
});
|
editor.addCommand('mceDirectionRTL', function () {
|
Direction.setDir(editor, 'rtl');
|
});
|
};
|
var Commands = { register: register };
|
|
var noop = function () {
|
};
|
var constant = function (value) {
|
return function () {
|
return value;
|
};
|
};
|
var never = constant(false);
|
var always = constant(true);
|
|
var none = function () {
|
return NONE;
|
};
|
var NONE = function () {
|
var eq = function (o) {
|
return o.isNone();
|
};
|
var call = function (thunk) {
|
return thunk();
|
};
|
var id = function (n) {
|
return n;
|
};
|
var me = {
|
fold: function (n, s) {
|
return n();
|
},
|
is: never,
|
isSome: never,
|
isNone: always,
|
getOr: id,
|
getOrThunk: call,
|
getOrDie: function (msg) {
|
throw new Error(msg || 'error: getOrDie called on none.');
|
},
|
getOrNull: constant(null),
|
getOrUndefined: constant(undefined),
|
or: id,
|
orThunk: call,
|
map: none,
|
each: noop,
|
bind: none,
|
exists: never,
|
forall: always,
|
filter: none,
|
equals: eq,
|
equals_: eq,
|
toArray: function () {
|
return [];
|
},
|
toString: constant('none()')
|
};
|
if (Object.freeze) {
|
Object.freeze(me);
|
}
|
return me;
|
}();
|
var some = function (a) {
|
var constant_a = constant(a);
|
var self = function () {
|
return me;
|
};
|
var bind = function (f) {
|
return f(a);
|
};
|
var me = {
|
fold: function (n, s) {
|
return s(a);
|
},
|
is: function (v) {
|
return a === v;
|
},
|
isSome: always,
|
isNone: never,
|
getOr: constant_a,
|
getOrThunk: constant_a,
|
getOrDie: constant_a,
|
getOrNull: constant_a,
|
getOrUndefined: constant_a,
|
or: self,
|
orThunk: self,
|
map: function (f) {
|
return some(f(a));
|
},
|
each: function (f) {
|
f(a);
|
},
|
bind: bind,
|
exists: bind,
|
forall: bind,
|
filter: function (f) {
|
return f(a) ? me : NONE;
|
},
|
toArray: function () {
|
return [a];
|
},
|
toString: function () {
|
return 'some(' + a + ')';
|
},
|
equals: function (o) {
|
return o.is(a);
|
},
|
equals_: function (o, elementEq) {
|
return o.fold(never, function (b) {
|
return elementEq(a, b);
|
});
|
}
|
};
|
return me;
|
};
|
var from = function (value) {
|
return value === null || value === undefined ? NONE : some(value);
|
};
|
var Option = {
|
some: some,
|
none: none,
|
from: from
|
};
|
|
var fromHtml = function (html, scope) {
|
var doc = scope || domGlobals.document;
|
var div = doc.createElement('div');
|
div.innerHTML = html;
|
if (!div.hasChildNodes() || div.childNodes.length > 1) {
|
domGlobals.console.error('HTML does not have a single root node', html);
|
throw new Error('HTML must have a single root node');
|
}
|
return fromDom(div.childNodes[0]);
|
};
|
var fromTag = function (tag, scope) {
|
var doc = scope || domGlobals.document;
|
var node = doc.createElement(tag);
|
return fromDom(node);
|
};
|
var fromText = function (text, scope) {
|
var doc = scope || domGlobals.document;
|
var node = doc.createTextNode(text);
|
return fromDom(node);
|
};
|
var fromDom = function (node) {
|
if (node === null || node === undefined) {
|
throw new Error('Node cannot be null or undefined');
|
}
|
return { dom: constant(node) };
|
};
|
var fromPoint = function (docElm, x, y) {
|
var doc = docElm.dom();
|
return Option.from(doc.elementFromPoint(x, y)).map(fromDom);
|
};
|
var Element = {
|
fromHtml: fromHtml,
|
fromTag: fromTag,
|
fromText: fromText,
|
fromDom: fromDom,
|
fromPoint: fromPoint
|
};
|
|
var typeOf = function (x) {
|
if (x === null) {
|
return 'null';
|
}
|
var t = typeof x;
|
if (t === 'object' && (Array.prototype.isPrototypeOf(x) || x.constructor && x.constructor.name === 'Array')) {
|
return 'array';
|
}
|
if (t === 'object' && (String.prototype.isPrototypeOf(x) || x.constructor && x.constructor.name === 'String')) {
|
return 'string';
|
}
|
return t;
|
};
|
var isType = function (type) {
|
return function (value) {
|
return typeOf(value) === type;
|
};
|
};
|
var isFunction = isType('function');
|
|
var nativeSlice = Array.prototype.slice;
|
var from$1 = isFunction(Array.from) ? Array.from : function (x) {
|
return nativeSlice.call(x);
|
};
|
|
var isSupported = function (dom) {
|
return dom.style !== undefined && isFunction(dom.style.getPropertyValue);
|
};
|
|
var ATTRIBUTE = domGlobals.Node.ATTRIBUTE_NODE;
|
var CDATA_SECTION = domGlobals.Node.CDATA_SECTION_NODE;
|
var COMMENT = domGlobals.Node.COMMENT_NODE;
|
var DOCUMENT = domGlobals.Node.DOCUMENT_NODE;
|
var DOCUMENT_TYPE = domGlobals.Node.DOCUMENT_TYPE_NODE;
|
var DOCUMENT_FRAGMENT = domGlobals.Node.DOCUMENT_FRAGMENT_NODE;
|
var ELEMENT = domGlobals.Node.ELEMENT_NODE;
|
var TEXT = domGlobals.Node.TEXT_NODE;
|
var PROCESSING_INSTRUCTION = domGlobals.Node.PROCESSING_INSTRUCTION_NODE;
|
var ENTITY_REFERENCE = domGlobals.Node.ENTITY_REFERENCE_NODE;
|
var ENTITY = domGlobals.Node.ENTITY_NODE;
|
var NOTATION = domGlobals.Node.NOTATION_NODE;
|
|
var Global = typeof domGlobals.window !== 'undefined' ? domGlobals.window : Function('return this;')();
|
|
var type = function (element) {
|
return element.dom().nodeType;
|
};
|
var isType$1 = function (t) {
|
return function (element) {
|
return type(element) === t;
|
};
|
};
|
var isText = isType$1(TEXT);
|
|
var inBody = function (element) {
|
var dom = isText(element) ? element.dom().parentNode : element.dom();
|
return dom !== undefined && dom !== null && dom.ownerDocument.body.contains(dom);
|
};
|
|
var get = function (element, property) {
|
var dom = element.dom();
|
var styles = domGlobals.window.getComputedStyle(dom);
|
var r = styles.getPropertyValue(property);
|
var v = r === '' && !inBody(element) ? getUnsafeProperty(dom, property) : r;
|
return v === null ? undefined : v;
|
};
|
var getUnsafeProperty = function (dom, property) {
|
return isSupported(dom) ? dom.style.getPropertyValue(property) : '';
|
};
|
|
var getDirection = function (element) {
|
return get(element, 'direction') === 'rtl' ? 'rtl' : 'ltr';
|
};
|
|
var getNodeChangeHandler = function (editor, dir) {
|
return function (api) {
|
var nodeChangeHandler = function (e) {
|
var element = Element.fromDom(e.element);
|
api.setActive(getDirection(element) === dir);
|
};
|
editor.on('NodeChange', nodeChangeHandler);
|
return function () {
|
return editor.off('NodeChange', nodeChangeHandler);
|
};
|
};
|
};
|
var register$1 = function (editor) {
|
editor.ui.registry.addToggleButton('ltr', {
|
tooltip: 'Left to right',
|
icon: 'ltr',
|
onAction: function () {
|
return editor.execCommand('mceDirectionLTR');
|
},
|
onSetup: getNodeChangeHandler(editor, 'ltr')
|
});
|
editor.ui.registry.addToggleButton('rtl', {
|
tooltip: 'Right to left',
|
icon: 'rtl',
|
onAction: function () {
|
return editor.execCommand('mceDirectionRTL');
|
},
|
onSetup: getNodeChangeHandler(editor, 'rtl')
|
});
|
};
|
var Buttons = { register: register$1 };
|
|
function Plugin () {
|
global.add('directionality', function (editor) {
|
Commands.register(editor);
|
Buttons.register(editor);
|
});
|
}
|
|
Plugin();
|
|
}(window));
|