-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbroSelect.1.1.js
61 lines (45 loc) · 2.14 KB
/
broSelect.1.1.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
(function($){
$.fn.extend({
broSelect: function() {
return this.each(function() {
var t = $(this),
opt = $(this).children(),
arg = [];
for(i=0;opt.length>i;i++) {
arg.push({
'value': opt.eq(i).val(),
'name': opt.eq(i).text()
});
}
t.css({display:'none'}).wrap('<div class="selectWrap" />');
var selectWrap = t.parent();
selectWrap.append('<div class="selectTab"><span class="val"></span><div class="arrows"><span class="up">▲</span><span class="down">▼</span></div></div><div class="selectOptions" />');
var selectTab = $('.selectTab',selectWrap),
selectOptions = $('.selectOptions',selectWrap),
selected = 0;
opt.each(function() {
if($(this).attr('selected')) {
selected = $(this).index();
}
});
$('.val',selectTab).text(arg[selected]['name']).attr('alt',arg[selected]['value']);
for(i=0;arg.length>i;i++) {
selectOptions.append('<div alt="'+arg[i]['value']+'">'+arg[i]['name']+'</div>');
}
function tog() {
selectOptions.slideToggle();
selectTab.toggleClass('active');
}
selectTab.click(function() {
tog();
});
selectOptions.children().click(function() {
var i = $(this).index();
$('.val',selectTab).text(arg[i]['name']).attr('alt',arg[i]['value']);
t.val($('.val',selectTab).attr('alt'));
tog();
});
});
}
});
})(jQuery);