-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjquery.dropdownpanel.js
119 lines (93 loc) · 3.54 KB
/
jquery.dropdownpanel.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/*
* JQuery Dropdown Panel plugin (v 0.3.0)
*
* Replaces an html select element with a
* simple, animated dropdown.
*
* https://github.com/metaflop/jquery-dropdownpanel
*
* © 2012 by Alexis Reigel
*
* Licensed under the GPL v3
*
*/
(function ($) {
$.fn.dropdownpanel = function(options) {
var defaults = {
panelToggleDuration: 500,
panelToggleEasing: 'easeInOutExpo',
wrapperCssClass: 'dropdown-value',
listCssClass: 'dropdown-list',
onClicked: function() {}
};
return $.each(this, function(index, select) {
select = $(select);
// settings
var settings = $.extend({}, defaults, options);
select.hide();
// current value -> display
var selectedOption = select.find('option:selected');
var wrapper = $('<div class="' + settings.wrapperCssClass + '">' + selectedOption.html() + '</div>');
var ul = '<ul class="' + settings.listCssClass + '">';
// list of all available options
$.each(select.find('option'), function(index, option) {
option = $(option);
ul += '<li data-value="' + option.val() + '">' +
'<a href="#">' + option.html() + '</a>' +
'</li>';
});
ul += '</ul>';
ul = $(ul);
var lis = ul.find('li');
// mark the currently selected option
$($.grep(lis, function(li) {
return $(li).find('a').html() == selectedOption.html();
})).addClass('active');
// listen for clicks on our custom dropdown
lis.click(function(e) {
e.preventDefault();
var selectEl = select;
var listItems = lis;
var li = $(this);
var displayEl = wrapper;
listItems.removeClass('active');
li.addClass('active');
// set select value
selectEl.val(li.data('value'));
// trigger the select's change event so third parties may
// still use handlers on the select element
selectEl.trigger('change', true);
// set display value
displayEl.html(li.find('a').text());
// hide
displayEl.click();
// callback
settings.onClicked();
});
// listen for changes on the original select
select.change(function(e, skip) {
if (skip) { return; }
var selectEl = select;
var listItems = lis;
var displayEl = wrapper;
var value = $(this).val();
var activeLi = $(lis.filter('[data-value="' + value + '"]'));
listItems.removeClass('active');
activeLi.addClass('active');
displayEl.html(activeLi.find('a').text());
});
select.after(ul);
select.after(wrapper);
// toggle panel
wrapper.click(function() {
var parent = $(this).parent();
parent.find('.' + settings.wrapperCssClass).toggleClass('active');
parent.find('.' + settings.listCssClass).animate(
{ height: 'toggle' },
settings.panelToggleDuration,
settings.panelToggleEasing
);
});
});
};
})(jQuery);