/*jquery.select_skin.js */ /* * jQuery select element skinning * version: 1.0.4 (03/03/2009) * @requires: jQuery v1.2 or later * adapted from Derek Harvey code * http://www.lotsofcode.com/javascript-and-ajax/jquery-select-box-skin.htm * Licensed under the GPL license: * http://www.gnu.org/licenses/gpl.html * * Copyright 2009 Colin Verot */ (function ($) { $.fn.select_skin = function (w) { return $(this).each(function (i) { s = $(this); if (!s.attr('multiple')) { // create the container s.wrap('
'); c = s.parent(); c.children().before('
 
').each(function () { if (this.selectedIndex >= 0) $(this).prev().text(this.options[this.selectedIndex].innerHTML) }); c.width(s.outerWidth() - 2); c.height(s.outerHeight() - 2); // skin the container c.css('background-color', s.css('background-color')); c.css('color', s.css('color')); c.css('font-size', s.css('font-size')); c.css('font-family', s.css('font-family')); c.css('font-style', s.css('font-style')); c.css('position', 'relative'); // hide the original select s.css({ 'opacity': 0, 'position': 'relative', 'z-index': 100 }); // get and skin the text label var t = c.children().prev(); t.height(c.outerHeight() - s.css('padding-top').replace(/px,*\)*/g, "") - s.css('padding-bottom').replace(/px,*\)*/g, "") - t.css('padding-top').replace(/px,*\)*/g, "") - t.css('padding-bottom').replace(/px,*\)*/g, "") - 2); t.width(c.innerWidth() - s.css('padding-right').replace(/px,*\)*/g, "") - s.css('padding-left').replace(/px,*\)*/g, "") - t.css('padding-right').replace(/px,*\)*/g, "") - t.css('padding-left').replace(/px,*\)*/g, "") - c.innerHeight()); t.css({ 'opacity': 100, 'overflow': 'hidden', 'position': 'absolute', 'text-indent': '0px', 'z-index': 1, 'top': 0, 'left': 0 }); // add events c.children().click(function () { t.text((this.options.length > 0 && this.selectedIndex >= 0 ? this.options[this.selectedIndex].innerHTML : '')); }); c.children().change(function () { t.text((this.options.length > 0 && this.selectedIndex >= 0 ? this.options[this.selectedIndex].innerHTML : '')); }); } }); } }(jQuery));