php-mpos/public/site_assets/mmcFE/js/jquery.select_skin.js
2013-05-06 14:11:38 +02:00

68 lines
2.9 KiB
JavaScript

/*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('<div class="cmf-skinned-select"></div>');
c = s.parent();
c.children().before('<div class="cmf-skinned-text">&nbsp;</div>').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));