-
Notifications
You must be signed in to change notification settings - Fork 0
Extending Mercury
This page explains the different ways that you can customize Mercury for your specific needs. One of the easiest ways is to add your own toolbar buttons, which you can do directly from the configuration.
Let's say you want to provide some basic markup, like a title, paragraph tag, and a styled link. You can add a new button to the configuration:
titleAndContent: ['Simple Markup', 'Inserts a title, paragraph tag, and a button']
Now, define a behavior for it in the behaviors section of the configuration:
titleAndContent: function(selection) {
var url = prompt('Enter the link for the button');
selection.replace('<h2>Title</h2><p>content</p><a href="' + url + '" class="button">button</a><hr/>');
}
That's it. Now you have a button that will insert a predefined set of markup, along with a user provided url.
To change existing functionality you can follow a very similar pattern. Let's say you want to insert an image instead of an HR tag when a user clicks the Insert HR button. Because behaviors are used before the default actions defined in Mercury.Regions.Editable.actions you can override existing behavior, which you can check for all the default actions.
Define a behavior in the configuration:
horizontalRule: function(selection) {
selection.replace('<img src="/rule.gif" class="horizontal-rule">');
}
Now when a user inserts a horizontal rule, they'll actually get the image tag.
If you want to change the functionality of Mercury, you'll have to dive into the source a bit more. But let's say you wanted to change how the PageEditor saves content (to make it use PUT instead of POST). You can configure a lot of this in the configuration, but if that falls short for your needs, you have a few options. If you want to work in coffeescript you're welcome to define a new file /assets/mercury/custom_page_editor.js.coffee
and put something like the following:
class CustomPageEditor extends PageEditor
constructor: ->
super
save: ->
data = @serialize()
Mercury.log('saving', data)
data = jQuery.toJSON(data) unless @options.saveStyle == 'form'
jQuery.ajax '/contents', {
type: 'POST'
data: {_method: 'PUT', content: data}
success: =>
Mercury.changes = false
error: =>
alert("Mercury was unable to save.")
}
Instead of instantiating Mercury.PageEditor, you can instantiate Mercury.CustomPageEditor and saving will be an update action instead of a create action.
Alternatively, and perhaps more simply, in javascript just put the following after Mercury.PageEditor has been defined:
Mercury.PageEditor.prototype.save = function() {
var data = this.serialize();
Mercury.log('saving', data);
var data = jQuery.toJSON(data);
jQuery.ajax('/contents', {
type: 'POST',
data: {_method: 'PUT', content: data},
success: function() { Mercury.changes = false },
error: function() { alert("Mercury was unable to save.") }
});
};