2021-03-02 03:09:34 +00:00
|
|
|
/**
|
|
|
|
* Created by Stefan on 24.05.14.
|
2021-03-16 19:41:08 +00:00
|
|
|
*
|
2021-04-15 14:23:43 +00:00
|
|
|
* Edit: be careful to maintain version number near EOF
|
2021-03-02 03:09:34 +00:00
|
|
|
*/
|
|
|
|
|
2021-04-15 02:10:54 +00:00
|
|
|
(function () {
|
|
|
|
tinymce.create('tinymce.plugins.Footnotes', {
|
|
|
|
/**
|
|
|
|
* Initializes the plugin, this will be executed after the plugin has been created.
|
|
|
|
* This call is done before the editor instance has finished its initialization so use the onInit event
|
|
|
|
* of the editor instance to intercept that event.
|
|
|
|
*
|
|
|
|
* @param {tinymce.Editor} ed Editor instance that the plugin is initialized in.
|
|
|
|
* @param {string} url Absolute URL to where the plugin is located.
|
|
|
|
*/
|
|
|
|
init: function (ed, url) {
|
|
|
|
ed.addButton('footnotes', {
|
|
|
|
title: 'footnotes',
|
|
|
|
cmd: 'footnotes',
|
|
|
|
image: url + '/../img/fn-wysiwyg.png',
|
|
|
|
});
|
2021-03-02 03:09:34 +00:00
|
|
|
|
2021-04-15 02:10:54 +00:00
|
|
|
ed.addCommand('footnotes', function () {
|
|
|
|
jQuery.ajax({
|
|
|
|
type: 'POST',
|
|
|
|
url: './admin-ajax.php',
|
|
|
|
data: {
|
|
|
|
action: 'footnotes_getTags',
|
|
|
|
},
|
|
|
|
success: function (data, textStatus, XMLHttpRequest) {
|
|
|
|
var tags = JSON.parse(data);
|
|
|
|
var returnText = tags.start + ed.selection.getContent() + tags.end;
|
|
|
|
ed.execCommand('insertHTML', true, returnText);
|
|
|
|
},
|
|
|
|
error: function (MLHttpRequest, textStatus, errorThrown) {
|
|
|
|
console.log('Error: ' + errorThrown);
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
2021-03-02 03:09:34 +00:00
|
|
|
|
2021-04-15 02:10:54 +00:00
|
|
|
/**
|
|
|
|
* Creates control instances based on the incoming name. This method is normally not
|
|
|
|
* needed since the addButton method of the tinymce.Editor class is an easier way of adding buttons,
|
|
|
|
* but you sometimes need to create more complex controls like listboxes, split buttons etc then this
|
|
|
|
* method can be used to create those.
|
|
|
|
*
|
|
|
|
* @param {String} n Name of the control to create.
|
|
|
|
* @param {tinymce.ControlManager} cm Control manager to use in order to create new control.
|
|
|
|
* @return {tinymce.ui.Control} New control instance or null if no control was created.
|
|
|
|
*/
|
|
|
|
createControl: function (n, cm) {
|
|
|
|
return null;
|
|
|
|
},
|
2021-03-02 03:09:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns information about the plugin as a name/value array.
|
|
|
|
* The current keys are longname, author, authorurl, infourl and version.
|
|
|
|
*
|
|
|
|
* @return {Object} Name/value array containing information about the plugin.
|
2021-03-16 19:41:08 +00:00
|
|
|
*
|
2021-04-15 04:09:23 +00:00
|
|
|
* Edit: needs updating the version number manually
|
2021-03-02 03:09:34 +00:00
|
|
|
*/
|
|
|
|
getInfo : function() {
|
|
|
|
return {
|
|
|
|
longname : 'Inserts the Footnotes short code.',
|
|
|
|
author : 'Mark Cheret',
|
2021-03-15 19:37:41 +00:00
|
|
|
authorurl : 'https://cheret.org/footnotes/',
|
2021-03-02 03:09:34 +00:00
|
|
|
infourl : 'https://wordpress.org/plugins/footnotes/',
|
2021-04-14 23:10:29 +00:00
|
|
|
version : '2.7.0'
|
2021-03-02 03:09:34 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-04-15 02:10:54 +00:00
|
|
|
// Register plugin
|
|
|
|
tinymce.PluginManager.add('footnotes', tinymce.plugins.Footnotes);
|
2021-03-02 03:09:34 +00:00
|
|
|
})();
|