integarting admin dashboard
This commit is contained in:
7
public/Dashboard/vendors/tinymce/plugins/toc/index.js
vendored
Normal file
7
public/Dashboard/vendors/tinymce/plugins/toc/index.js
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
// Exports the "toc" plugin for usage with module loaders
|
||||
// Usage:
|
||||
// CommonJS:
|
||||
// require('tinymce/plugins/toc')
|
||||
// ES2015:
|
||||
// import 'tinymce/plugins/toc'
|
||||
require('./plugin.js');
|
236
public/Dashboard/vendors/tinymce/plugins/toc/plugin.js
vendored
Normal file
236
public/Dashboard/vendors/tinymce/plugins/toc/plugin.js
vendored
Normal file
@ -0,0 +1,236 @@
|
||||
/**
|
||||
* 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.7.0 (2021-02-10)
|
||||
*/
|
||||
(function () {
|
||||
'use strict';
|
||||
|
||||
var global = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
||||
|
||||
var global$1 = tinymce.util.Tools.resolve('tinymce.dom.DOMUtils');
|
||||
|
||||
var global$2 = tinymce.util.Tools.resolve('tinymce.util.I18n');
|
||||
|
||||
var global$3 = tinymce.util.Tools.resolve('tinymce.util.Tools');
|
||||
|
||||
var getTocClass = function (editor) {
|
||||
return editor.getParam('toc_class', 'mce-toc');
|
||||
};
|
||||
var getTocHeader = function (editor) {
|
||||
var tagName = editor.getParam('toc_header', 'h2');
|
||||
return /^h[1-6]$/.test(tagName) ? tagName : 'h2';
|
||||
};
|
||||
var getTocDepth = function (editor) {
|
||||
var depth = parseInt(editor.getParam('toc_depth', '3'), 10);
|
||||
return depth >= 1 && depth <= 9 ? depth : 3;
|
||||
};
|
||||
|
||||
var create = function (prefix) {
|
||||
var counter = 0;
|
||||
return function () {
|
||||
var guid = new Date().getTime().toString(32);
|
||||
return prefix + guid + (counter++).toString(32);
|
||||
};
|
||||
};
|
||||
|
||||
var tocId = create('mcetoc_');
|
||||
var generateSelector = function (depth) {
|
||||
var i;
|
||||
var selector = [];
|
||||
for (i = 1; i <= depth; i++) {
|
||||
selector.push('h' + i);
|
||||
}
|
||||
return selector.join(',');
|
||||
};
|
||||
var hasHeaders = function (editor) {
|
||||
return readHeaders(editor).length > 0;
|
||||
};
|
||||
var readHeaders = function (editor) {
|
||||
var tocClass = getTocClass(editor);
|
||||
var headerTag = getTocHeader(editor);
|
||||
var selector = generateSelector(getTocDepth(editor));
|
||||
var headers = editor.$(selector);
|
||||
if (headers.length && /^h[1-9]$/i.test(headerTag)) {
|
||||
headers = headers.filter(function (i, el) {
|
||||
return !editor.dom.hasClass(el.parentNode, tocClass);
|
||||
});
|
||||
}
|
||||
return global$3.map(headers, function (h) {
|
||||
var id = h.id;
|
||||
return {
|
||||
id: id ? id : tocId(),
|
||||
level: parseInt(h.nodeName.replace(/^H/i, ''), 10),
|
||||
title: editor.$.text(h),
|
||||
element: h
|
||||
};
|
||||
});
|
||||
};
|
||||
var getMinLevel = function (headers) {
|
||||
var i, minLevel = 9;
|
||||
for (i = 0; i < headers.length; i++) {
|
||||
if (headers[i].level < minLevel) {
|
||||
minLevel = headers[i].level;
|
||||
}
|
||||
if (minLevel === 1) {
|
||||
return minLevel;
|
||||
}
|
||||
}
|
||||
return minLevel;
|
||||
};
|
||||
var generateTitle = function (tag, title) {
|
||||
var openTag = '<' + tag + ' contenteditable="true">';
|
||||
var closeTag = '</' + tag + '>';
|
||||
return openTag + global$1.DOM.encode(title) + closeTag;
|
||||
};
|
||||
var generateTocHtml = function (editor) {
|
||||
var html = generateTocContentHtml(editor);
|
||||
return '<div class="' + editor.dom.encode(getTocClass(editor)) + '" contenteditable="false">' + html + '</div>';
|
||||
};
|
||||
var generateTocContentHtml = function (editor) {
|
||||
var html = '';
|
||||
var headers = readHeaders(editor);
|
||||
var prevLevel = getMinLevel(headers) - 1;
|
||||
var i, ii, h, nextLevel;
|
||||
if (!headers.length) {
|
||||
return '';
|
||||
}
|
||||
html += generateTitle(getTocHeader(editor), global$2.translate('Table of Contents'));
|
||||
for (i = 0; i < headers.length; i++) {
|
||||
h = headers[i];
|
||||
h.element.id = h.id;
|
||||
nextLevel = headers[i + 1] && headers[i + 1].level;
|
||||
if (prevLevel === h.level) {
|
||||
html += '<li>';
|
||||
} else {
|
||||
for (ii = prevLevel; ii < h.level; ii++) {
|
||||
html += '<ul><li>';
|
||||
}
|
||||
}
|
||||
html += '<a href="#' + h.id + '">' + h.title + '</a>';
|
||||
if (nextLevel === h.level || !nextLevel) {
|
||||
html += '</li>';
|
||||
if (!nextLevel) {
|
||||
html += '</ul>';
|
||||
}
|
||||
} else {
|
||||
for (ii = h.level; ii > nextLevel; ii--) {
|
||||
html += '</li></ul><li>';
|
||||
}
|
||||
}
|
||||
prevLevel = h.level;
|
||||
}
|
||||
return html;
|
||||
};
|
||||
var isEmptyOrOffscren = function (editor, nodes) {
|
||||
return !nodes.length || editor.dom.getParents(nodes[0], '.mce-offscreen-selection').length > 0;
|
||||
};
|
||||
var insertToc = function (editor) {
|
||||
var tocClass = getTocClass(editor);
|
||||
var $tocElm = editor.$('.' + tocClass);
|
||||
if (isEmptyOrOffscren(editor, $tocElm)) {
|
||||
editor.insertContent(generateTocHtml(editor));
|
||||
} else {
|
||||
updateToc(editor);
|
||||
}
|
||||
};
|
||||
var updateToc = function (editor) {
|
||||
var tocClass = getTocClass(editor);
|
||||
var $tocElm = editor.$('.' + tocClass);
|
||||
if ($tocElm.length) {
|
||||
editor.undoManager.transact(function () {
|
||||
$tocElm.html(generateTocContentHtml(editor));
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
var register = function (editor) {
|
||||
editor.addCommand('mceInsertToc', function () {
|
||||
insertToc(editor);
|
||||
});
|
||||
editor.addCommand('mceUpdateToc', function () {
|
||||
updateToc(editor);
|
||||
});
|
||||
};
|
||||
|
||||
var setup = function (editor) {
|
||||
var $ = editor.$, tocClass = getTocClass(editor);
|
||||
editor.on('PreProcess', function (e) {
|
||||
var $tocElm = $('.' + tocClass, e.node);
|
||||
if ($tocElm.length) {
|
||||
$tocElm.removeAttr('contentEditable');
|
||||
$tocElm.find('[contenteditable]').removeAttr('contentEditable');
|
||||
}
|
||||
});
|
||||
editor.on('SetContent', function () {
|
||||
var $tocElm = $('.' + tocClass);
|
||||
if ($tocElm.length) {
|
||||
$tocElm.attr('contentEditable', false);
|
||||
$tocElm.children(':first-child').attr('contentEditable', true);
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
var toggleState = function (editor) {
|
||||
return function (api) {
|
||||
var toggleDisabledState = function () {
|
||||
return api.setDisabled(editor.mode.isReadOnly() || !hasHeaders(editor));
|
||||
};
|
||||
toggleDisabledState();
|
||||
editor.on('LoadContent SetContent change', toggleDisabledState);
|
||||
return function () {
|
||||
return editor.on('LoadContent SetContent change', toggleDisabledState);
|
||||
};
|
||||
};
|
||||
};
|
||||
var isToc = function (editor) {
|
||||
return function (elm) {
|
||||
return elm && editor.dom.is(elm, '.' + getTocClass(editor)) && editor.getBody().contains(elm);
|
||||
};
|
||||
};
|
||||
var register$1 = function (editor) {
|
||||
editor.ui.registry.addButton('toc', {
|
||||
icon: 'toc',
|
||||
tooltip: 'Table of contents',
|
||||
onAction: function () {
|
||||
return editor.execCommand('mceInsertToc');
|
||||
},
|
||||
onSetup: toggleState(editor)
|
||||
});
|
||||
editor.ui.registry.addButton('tocupdate', {
|
||||
icon: 'reload',
|
||||
tooltip: 'Update',
|
||||
onAction: function () {
|
||||
return editor.execCommand('mceUpdateToc');
|
||||
}
|
||||
});
|
||||
editor.ui.registry.addMenuItem('toc', {
|
||||
icon: 'toc',
|
||||
text: 'Table of contents',
|
||||
onAction: function () {
|
||||
return editor.execCommand('mceInsertToc');
|
||||
},
|
||||
onSetup: toggleState(editor)
|
||||
});
|
||||
editor.ui.registry.addContextToolbar('toc', {
|
||||
items: 'tocupdate',
|
||||
predicate: isToc(editor),
|
||||
scope: 'node',
|
||||
position: 'node'
|
||||
});
|
||||
};
|
||||
|
||||
function Plugin () {
|
||||
global.add('toc', function (editor) {
|
||||
register(editor);
|
||||
register$1(editor);
|
||||
setup(editor);
|
||||
});
|
||||
}
|
||||
|
||||
Plugin();
|
||||
|
||||
}());
|
9
public/Dashboard/vendors/tinymce/plugins/toc/plugin.min.js
vendored
Normal file
9
public/Dashboard/vendors/tinymce/plugins/toc/plugin.min.js
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
/**
|
||||
* 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.7.0 (2021-02-10)
|
||||
*/
|
||||
!function(){"use strict";var e,n,t=tinymce.util.Tools.resolve("tinymce.PluginManager"),s=tinymce.util.Tools.resolve("tinymce.dom.DOMUtils"),f=tinymce.util.Tools.resolve("tinymce.util.I18n"),c=tinymce.util.Tools.resolve("tinymce.util.Tools"),l=function(t){return t.getParam("toc_class","mce-toc")},m=function(t){var e=t.getParam("toc_header","h2");return/^h[1-6]$/.test(e)?e:"h2"},a=(e="mcetoc_",n=0,function(){var t=(new Date).getTime().toString(32);return e+t+(n++).toString(32)}),v=function(n){var t,o=l(n),e=m(n),r=function(t){for(var e=[],n=1;n<=t;n++)e.push("h"+n);return e.join(",")}(1<=(t=parseInt(n.getParam("toc_depth","3"),10))&&t<=9?t:3),i=n.$(r);return i.length&&/^h[1-9]$/i.test(e)&&(i=i.filter(function(t,e){return!n.dom.hasClass(e.parentNode,o)})),c.map(i,function(t){var e=t.id;return{id:e||a(),level:parseInt(t.nodeName.replace(/^H/i,""),10),title:n.$.text(t),element:t}})},u=function(t){var e,n,o,r,i,c,l,a="",u=v(t),d=function(t){for(var e=9,n=0;n<t.length;n++)if(t[n].level<e&&(e=t[n].level),1===e)return e;return e}(u)-1;if(!u.length)return"";for(a+=(i=m(t),c=f.translate("Table of Contents"),l="</"+i+">","<"+i+' contenteditable="true">'+s.DOM.encode(c)+l),e=0;e<u.length;e++){if((o=u[e]).element.id=o.id,r=u[e+1]&&u[e+1].level,d===o.level)a+="<li>";else for(n=d;n<o.level;n++)a+="<ul><li>";if(a+='<a href="#'+o.id+'">'+o.title+"</a>",r!==o.level&&r)for(n=o.level;r<n;n--)a+="</li></ul><li>";else a+="</li>",r||(a+="</ul>");d=o.level}return a},i=function(t){var e,n,o,r,i=l(t),c=t.$("."+i);o=t,!(r=c).length||0<o.dom.getParents(r[0],".mce-offscreen-selection").length?t.insertContent((n=u(e=t),'<div class="'+e.dom.encode(l(e))+'" contenteditable="false">'+n+"</div>")):d(t)},d=function(t){var e=l(t),n=t.$("."+e);n.length&&t.undoManager.transact(function(){n.html(u(t))})},o=function(n){return function(t){var e=function(){return t.setDisabled(n.mode.isReadOnly()||!(0<v(n).length))};return e(),n.on("LoadContent SetContent change",e),function(){return n.on("LoadContent SetContent change",e)}}},g=function(t){var e;t.ui.registry.addButton("toc",{icon:"toc",tooltip:"Table of contents",onAction:function(){return t.execCommand("mceInsertToc")},onSetup:o(t)}),t.ui.registry.addButton("tocupdate",{icon:"reload",tooltip:"Update",onAction:function(){return t.execCommand("mceUpdateToc")}}),t.ui.registry.addMenuItem("toc",{icon:"toc",text:"Table of contents",onAction:function(){return t.execCommand("mceInsertToc")},onSetup:o(t)}),t.ui.registry.addContextToolbar("toc",{items:"tocupdate",predicate:(e=t,function(t){return t&&e.dom.is(t,"."+l(e))&&e.getBody().contains(t)}),scope:"node",position:"node"})};t.add("toc",function(t){var e,n,o,r;(e=t).addCommand("mceInsertToc",function(){i(e)}),e.addCommand("mceUpdateToc",function(){d(e)}),g(t),o=(n=t).$,r=l(n),n.on("PreProcess",function(t){var e=o("."+r,t.node);e.length&&(e.removeAttr("contentEditable"),e.find("[contenteditable]").removeAttr("contentEditable"))}),n.on("SetContent",function(){var t=o("."+r);t.length&&(t.attr("contentEditable",!1),t.children(":first-child").attr("contentEditable",!0))})})}();
|
Reference in New Issue
Block a user