-
Notifications
You must be signed in to change notification settings - Fork 1
/
kcToggle.js
67 lines (54 loc) · 1.53 KB
/
kcToggle.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/**
* kcToggle
* Description: Replace the default browser checkbox with a styled toggle
* Version: .1.2
* Author: Kevin Chappell
* Dependencies: jQuery Core v1.6+
*/
(function($) {
'use strict';
var Toggle = function(element, options) {
var defaults = {
theme: 'fresh',
text: {
off: 'Off',
on: 'On'
}
};
var utils = {
toggleChecked: function(elem) {
elem.attr('checked', !elem.attr('checked'));
}
};
var opts = $.extend(defaults, options),
elem = $(element);
if (elem.attr('checked') === 'checked') {
elem.wrap('<div class="kcToggle on" />');
} else {
elem.wrap('<div class="kcToggle off" />');
}
elem.parent('div.kcToggle').append('<div class="kcToggleInner"><div class="kcToggleOn">' + opts.text.on + '</div><div class="kcToggleHandle"></div><div class="kcToggleOff">' + opts.text.off + '</div></div>');
elem.parent('div.kcToggle').click(function() {
utils.toggleChecked(elem);
$(this).toggleClass('on');
$(this).toggleClass('off');
});
};
$.fn.kcToggle = function(options) {
var toggle = this;
return toggle.each(function() {
var element = $(this);
if (element.data('kcToggle')) {
return;
}
var kcToggle = new Toggle(this, options);
element.data('kcToggle', kcToggle);
});
};
$('input[kcToggle]').kcToggle({
text: {
off: 'No',
on: 'Yes'
}
});
})(jQuery);