mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
8f23fa99a5
The 'admin' module will be split off from 'framework', where 'framework' only provides (mostly) frontend-agnostic PHP classes. For example, HTMLEditorField.php has a TinyMCEConfig.php driver, but doesn't come with its own JS includes.
89 lines
2.3 KiB
JavaScript
89 lines
2.3 KiB
JavaScript
/**
|
|
* plugin.js
|
|
*
|
|
* Released under LGPL License.
|
|
* Copyright (c) 1999-2015 Ephox Corp. All rights reserved
|
|
*
|
|
* License: http://www.tinymce.com/license
|
|
* Contributing: http://www.tinymce.com/contributing
|
|
*/
|
|
|
|
/*global tinymce:true */
|
|
|
|
tinymce.PluginManager.add('pagebreak', function(editor) {
|
|
var pageBreakClass = 'mce-pagebreak', separatorHtml = editor.getParam('pagebreak_separator', '<!-- pagebreak -->');
|
|
|
|
var pageBreakSeparatorRegExp = new RegExp(separatorHtml.replace(/[\?\.\*\[\]\(\)\{\}\+\^\$\:]/g, function(a) {
|
|
return '\\' + a;
|
|
}), 'gi');
|
|
|
|
var pageBreakPlaceHolderHtml = '<img src="' + tinymce.Env.transparentSrc + '" class="' +
|
|
pageBreakClass + '" data-mce-resize="false" data-mce-placeholder />';
|
|
|
|
// Register commands
|
|
editor.addCommand('mcePageBreak', function() {
|
|
if (editor.settings.pagebreak_split_block) {
|
|
editor.insertContent('<p>' + pageBreakPlaceHolderHtml + '</p>');
|
|
} else {
|
|
editor.insertContent(pageBreakPlaceHolderHtml);
|
|
}
|
|
});
|
|
|
|
// Register buttons
|
|
editor.addButton('pagebreak', {
|
|
title: 'Page break',
|
|
cmd: 'mcePageBreak'
|
|
});
|
|
|
|
editor.addMenuItem('pagebreak', {
|
|
text: 'Page break',
|
|
icon: 'pagebreak',
|
|
cmd: 'mcePageBreak',
|
|
context: 'insert'
|
|
});
|
|
|
|
editor.on('ResolveName', function(e) {
|
|
if (e.target.nodeName == 'IMG' && editor.dom.hasClass(e.target, pageBreakClass)) {
|
|
e.name = 'pagebreak';
|
|
}
|
|
});
|
|
|
|
editor.on('click', function(e) {
|
|
e = e.target;
|
|
|
|
if (e.nodeName === 'IMG' && editor.dom.hasClass(e, pageBreakClass)) {
|
|
editor.selection.select(e);
|
|
}
|
|
});
|
|
|
|
editor.on('BeforeSetContent', function(e) {
|
|
e.content = e.content.replace(pageBreakSeparatorRegExp, pageBreakPlaceHolderHtml);
|
|
});
|
|
|
|
editor.on('PreInit', function() {
|
|
editor.serializer.addNodeFilter('img', function(nodes) {
|
|
var i = nodes.length, node, className;
|
|
|
|
while (i--) {
|
|
node = nodes[i];
|
|
className = node.attr('class');
|
|
if (className && className.indexOf('mce-pagebreak') !== -1) {
|
|
// Replace parent block node if pagebreak_split_block is enabled
|
|
var parentNode = node.parent;
|
|
if (editor.schema.getBlockElements()[parentNode.name] && editor.settings.pagebreak_split_block) {
|
|
parentNode.type = 3;
|
|
parentNode.value = separatorHtml;
|
|
parentNode.raw = true;
|
|
node.remove();
|
|
continue;
|
|
}
|
|
|
|
node.type = 3;
|
|
node.value = separatorHtml;
|
|
node.raw = true;
|
|
}
|
|
}
|
|
});
|
|
});
|
|
});
|