uxrocket.clear
Version:
jQuery based clear input/textarea action handler
222 lines (170 loc) • 5.98 kB
JavaScript
/**
* UX Rocket
* jQuery based clear input/textarea action handler
* @author Bilal Cinarli
*/
;
(function($) {
var ux, // local shorthand
defaults = {
cssClass : 'icon-cross',
clearAlso: null,
// callbacks
onReady : false,
onClear : false,
onUpdate : false,
onRemove : false
},
events = {
keyup: 'keyup.uxClear',
focus: 'focus.uxClear',
input: 'input.uxClear',
click: 'click.uxClear'
},
ns = {
rocket : 'uxRocket',
data : 'uxClear',
ready : 'uxitd-clear-ready',
rocketWrap: 'uxitd-plugin-wrap',
wrap : 'uxitd-clear-wrap',
icon : 'uxitd-clear-icon'
};
// constructor method
var Clear = function(el, options, selector) {
var opts = $.extend({}, defaults, options, $(el).data(), {'selector': selector}),
$el = $(el);
opts.button = '<a class="' + ns.icon + ' hide ' + opts.cssClass + '"></a>';
opts.visible = false;
$el.data(ns.data, opts);
// set plugin layout for ease of usage
setLayout($el);
// call onReady function if any
callback(opts.onReady);
// bind the ui interactions
bindUIActions($el);
};
var setLayout = function($el) {
var columns = '',
_opts = $el.data(ns.data);
columns = ' ' + $el.context.className.replace(ns.ready, '');
if(_opts.selector.charAt(0) == '.') {
columns = columns.replace(' ' + _opts.selector.substr(1), '');
}
if($el.parent().is('.' + ns.rocketWrap)) {
$el.parent().addClass(ns.wrap + columns);
}
else {
$el.wrap('<span class="' + ns.rocketWrap + ' ' + ns.wrap + columns + '"></span>');
}
$el.after(_opts.button);
if($el.val() !== '') {
$el.next('.' + ns.icon).show();
_opts.visible = true;
$el.data(ns.data, _opts);
}
};
var bindUIActions = function($el) {
var $button = $el.next('.' + ns.icon),
_opts = $el.data(ns.data);
$el.on(events.keyup + ' ' + events.focus + ' ' + events.input, function() {
if(_opts.visible === false) {
$button.show();
_opts.visible = true;
}
if($(this).val() === '') {
$button.hide();
_opts.visible = false;
}
$el.data(ns.data, _opts);
});
$button.on(events.click, function() {
$el.val('').blur();
$button.hide();
_opts.visible = false;
if(_opts.clearAlso !== null) {
$(_opts.clearAlso).val('');
}
$el.data(ns.data, _opts);
callback(_opts.onClear);
});
};
// global callback
var callback = function(fn) {
// if callback string is function call it directly
if(typeof fn === 'function') {
fn.apply(this);
}
// if callback defined via data-attribute, call it via new Function
else {
if(fn !== false) {
var func = new Function('return ' + fn);
func();
}
}
};
// jquery binding
ux = $.fn.clear = $.uxclear = function(options) {
var selector = this.selector;
return this.each(function() {
var $el = $(this),
uxrocket = $el.data(ns.rocket) || {},
clear;
if($el.hasClass(ns.ready) || $el.hasClass(ns.rocketWrap)) {
return;
}
$el.addClass(ns.ready);
uxrocket[ns.data] = {'hasWrapper': true, 'wrapper': ns.wrap, 'ready': ns.ready, 'selector': selector, 'options': options};
$el.data(ns.rocket, uxrocket);
clear = new Clear(this, options, selector);
});
};
ux.update = function(el) {
var $el = el !== undefined ? $(el) : $("." + ns.ready);
$el.each(function() {
var _this = $(this),
_instance = _this.data(ns.data);
// remove previous instance data
_this.removeData(ns.data);
// add new options
_instance = $.extend({}, _instance, $(this).data());
// register new instance data
_this.data(ns.data, _instance);
_this.off(events.keyup + ' ' + events.focus + ' ' + events.input);
_this.next('.' + ns.icon).off(events.click);
bindUIActions(_this);
callback(_instance.onUpdate);
});
};
ux.remove = function(el) {
var $el = el !== undefined ? $(el) : $("." + ns.ready);
$el.each(function() {
var _this = $(this),
_instance = _this.data(ns.data),
_uxrocket = _this.data(ns.rocket);
// remove ready class
_this.removeClass(ns.ready);
// remove plugin events
_this.off(events.keyup + ' ' + events.focus + ' ' + events.input);
// remove icon and wrapper
_this.next('.' + ns.icon).remove();
if(_uxrocket[ns.data].hasWrapper) {
if(Object.keys && Object.keys(_uxrocket).length == 1) {
_this.unwrap();
}
else {
_this.parent().removeClass(ns.wrap);
}
}
// remove plugin data
_this.removeData(ns.data);
// remove uxRocket registry
delete _uxrocket[ns.data];
_this.data(ns.rocket, _uxrocket);
callback(_instance.onRemove);
});
};
// version
ux.version = "0.8.0";
// settings
ux.settings = defaults;
})(jQuery);