Features can be added to Selectize without modifying the main library. This is great because it protects against code bloat, allows for lean builds, and allows for addons to be sanely isolated. The plugin system isn't meant to be sexy; it's lean, makes very few assumptions, and gives the developer complete control.
A few notes:
- All plugins live in their own folders in "src/plugins".
- Plugin names should be in follow the format:
/[a-z_]+$
- JS source should live in a "plugin.js" file (required).
- CSS should live in a "plugin.css" file (optional). It will be bundled at build time.
- Plugins are initialized right before the control is setup.
This means that if you want to listen for events on any of the control's
elements, you should override the
setup()
method (see "DOM Events").
Selectize.registerPlugin('plugin_name', function(options) {
// options: plugin-specific options
// this: selectize instance
});
Selectize.registerPlugin('plugin_name', ['another_plugin'], function(options) {
// "another_plugin" will be loaded at this point
});
Methods should be extended by wrapping them:
var self = this;
this.someMethod = function() {
var original = self.someMethod;
return function() {
// do your logic
return original.apply(this, arguments);
};
});
Important: If the method you're overriding returns a value, make sure the overridden function returns a value as well.
Because all elements for the control are created within the setup()
method (which is
invoked after the plugin initialized) events should be added by overriding the setup method,
like so:
Selectize.registerPlugin('plugin_name', function(options) {
var self = this;
// override the setup method to add an extra "click" handler
this.setup = (function() {
var original = self.setup;
return function() {
original.apply(this, arguments);
this.$control.on('click', 'div', function(e) {
alert('A div was clicked!');
});
};
})();
});
$('select').selectize({
plugins: ['plugin_a', 'plugin_b']
});
$('select').selectize({
plugins: {
'plugin_a': { /* ... */ },
'plugin_b': { /* ... */ }
}
});