1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-07-20 21:59:42 +02:00
documize/gui/public/tinymce/plugins/contextmenu/plugin.js

168 lines
4.6 KiB
JavaScript
Raw Normal View History

2017-12-09 12:42:35 +00:00
(function () {
2018-01-19 11:36:38 +00:00
var contextmenu = (function () {
'use strict';
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var Cell = function (initial) {
var value = initial;
var get = function () {
return value;
2017-12-09 12:42:35 +00:00
};
2018-01-19 11:36:38 +00:00
var set = function (v) {
value = v;
2017-12-09 12:42:35 +00:00
};
2018-01-19 11:36:38 +00:00
var clone = function () {
return Cell(get());
2017-12-09 12:42:35 +00:00
};
return {
2018-01-19 11:36:38 +00:00
get: get,
set: set,
clone: clone
2017-12-09 12:42:35 +00:00
};
2018-01-19 11:36:38 +00:00
};
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var PluginManager = tinymce.util.Tools.resolve('tinymce.PluginManager');
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var get = function (visibleState) {
var isContextMenuVisible = function () {
return visibleState.get();
2017-12-09 12:42:35 +00:00
};
2018-01-19 11:36:38 +00:00
return { isContextMenuVisible: isContextMenuVisible };
};
2018-01-25 16:14:37 +00:00
var $_ev2v509qjcun3xno = { get: get };
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var shouldNeverUseNative = function (editor) {
return editor.settings.contextmenu_never_use_native;
};
var getContextMenu = function (editor) {
return editor.getParam('contextmenu', 'link openlink image inserttable | cell row column deletetable');
};
2018-01-25 16:14:37 +00:00
var $_6qfjaw9sjcun3xns = {
2018-01-19 11:36:38 +00:00
shouldNeverUseNative: shouldNeverUseNative,
getContextMenu: getContextMenu
};
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var Env = tinymce.util.Tools.resolve('tinymce.Env');
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var DOMUtils = tinymce.util.Tools.resolve('tinymce.dom.DOMUtils');
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var nu = function (x, y) {
2017-12-09 12:42:35 +00:00
return {
2018-01-19 11:36:38 +00:00
x: x,
y: y
2017-12-09 12:42:35 +00:00
};
2018-01-19 11:36:38 +00:00
};
var transpose = function (pos, dx, dy) {
return nu(pos.x + dx, pos.y + dy);
};
var fromPageXY = function (e) {
return nu(e.pageX, e.pageY);
};
var fromClientXY = function (e) {
return nu(e.clientX, e.clientY);
};
var transposeUiContainer = function (element, pos) {
if (element && DOMUtils.DOM.getStyle(element, 'position', true) !== 'static') {
var containerPos = DOMUtils.DOM.getPos(element);
var dx = containerPos.x - element.scrollLeft;
var dy = containerPos.y - element.scrollTop;
return transpose(pos, -dx, -dy);
} else {
return transpose(pos, 0, 0);
}
};
var transposeContentAreaContainer = function (element, pos) {
var containerPos = DOMUtils.DOM.getPos(element);
return transpose(pos, containerPos.x, containerPos.y);
};
var getUiContainer = function (editor) {
return Env.container;
};
var getPos = function (editor, e) {
if (editor.inline) {
return transposeUiContainer(getUiContainer(editor), fromPageXY(e));
} else {
var iframePos = transposeContentAreaContainer(editor.getContentAreaContainer(), fromClientXY(e));
return transposeUiContainer(getUiContainer(editor), iframePos);
}
};
2018-01-25 16:14:37 +00:00
var $_5cnrbd9tjcun3xnu = { getPos: getPos };
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var Factory = tinymce.util.Tools.resolve('tinymce.ui.Factory');
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var Tools = tinymce.util.Tools.resolve('tinymce.util.Tools');
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var renderMenu = function (editor, visibleState) {
var menu, contextmenu;
var items = [];
2018-01-25 16:14:37 +00:00
contextmenu = $_6qfjaw9sjcun3xns.getContextMenu(editor);
2018-01-19 11:36:38 +00:00
Tools.each(contextmenu.split(/[ ,]/), function (name) {
var item = editor.menuItems[name];
if (name === '|') {
item = { text: name };
2017-12-09 12:42:35 +00:00
}
2018-01-19 11:36:38 +00:00
if (item) {
item.shortcut = '';
items.push(item);
2017-12-09 12:42:35 +00:00
}
2018-01-19 11:36:38 +00:00
});
for (var i = 0; i < items.length; i++) {
if (items[i].text === '|') {
if (i === 0 || i === items.length - 1) {
items.splice(i, 1);
2017-12-09 12:42:35 +00:00
}
2018-01-19 11:36:38 +00:00
}
}
menu = Factory.create('menu', {
items: items,
context: 'contextmenu',
classes: 'contextmenu'
}).renderTo();
menu.on('hide', function (e) {
if (e.control === this) {
visibleState.set(false);
}
});
editor.on('remove', function () {
menu.remove();
menu = null;
});
return menu;
};
var show = function (editor, pos, visibleState, menu) {
if (menu.get() === null) {
menu.set(renderMenu(editor, visibleState));
} else {
menu.get().show();
}
menu.get().moveTo(pos.x, pos.y);
visibleState.set(true);
};
2018-01-25 16:14:37 +00:00
var $_1v3p6d9wjcun3xnz = { show: show };
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
var isNativeOverrideKeyEvent = function (editor, e) {
2018-01-25 16:14:37 +00:00
return e.ctrlKey && !$_6qfjaw9sjcun3xns.shouldNeverUseNative(editor);
2018-01-19 11:36:38 +00:00
};
var setup = function (editor, visibleState, menu) {
editor.on('contextmenu', function (e) {
if (isNativeOverrideKeyEvent(editor, e)) {
return;
}
e.preventDefault();
2018-01-25 16:14:37 +00:00
$_1v3p6d9wjcun3xnz.show(editor, $_5cnrbd9tjcun3xnu.getPos(editor, e), visibleState, menu);
2017-12-09 12:42:35 +00:00
});
2018-01-19 11:36:38 +00:00
};
2018-01-25 16:14:37 +00:00
var $_6m3a7i9rjcun3xnq = { setup: setup };
2018-01-19 11:36:38 +00:00
PluginManager.add('contextmenu', function (editor) {
var menu = Cell(null), visibleState = Cell(false);
2018-01-25 16:14:37 +00:00
$_6m3a7i9rjcun3xnq.setup(editor, visibleState, menu);
return $_ev2v509qjcun3xno.get(visibleState);
2018-01-19 11:36:38 +00:00
});
var Plugin = function () {
};
return Plugin;
2017-12-09 12:42:35 +00:00
2018-01-19 11:36:38 +00:00
}());
})()