(function ($) { $.fn.singleSelect = function () { return this.each(function (i, select) { var input = $('<input/>'), gravity = $(select).attr('data-tipsy-gravity'), inputTooltip = $(select).attr('data-inputtitle'); if (inputTooltip){ input.attr('title', inputTooltip); } if (typeof gravity === 'undefined') { gravity = 'n' } select = $(select); input.css('position', 'absolute'); input.css({ 'box-sizing': 'border-box', '-moz-box-sizing': 'border-box', 'margin': 0, 'width': (select.width() - 5) + 'px', 'height': (select.outerHeight() - 2) + 'px', 'border': 'none', 'box-shadow': 'none', 'margin-top': '1px', 'margin-left': '1px', 'z-index': 1000 }); input.hide(); $('body').append(input); select.on('change', function (event) { var value = $(this).val(), newAttr = $('option:selected', $(this)).attr('data-new'); if (!(typeof newAttr !== 'undefined' && newAttr !== false)) { input.hide(); select.data('previous', value); } else { event.stopImmediatePropagation(); // adjust offset, in case the user scrolled input.css(select.offset()); input.show(); if ($.fn.tipsy){ input.tipsy({gravity: gravity, trigger: 'manual'}); input.tipsy('show'); } select.css('background-color', 'white'); input.focus(); } }); $(select).data('previous', $(select).val()); input.on('change', function () { var value = $(this).val(); if (value) { select.children().attr('selected', null); var existingOption = select.children().filter(function (i, option) { return ($(option).val() == value); }); if (existingOption.length) { existingOption.attr('selected', 'selected'); } else { var option = $('<option/>'); option.attr('selected', 'selected').attr('value', value).text(value); select.children().last().before(option); } select.val(value); select.css('background-color', null); input.val(null); input.hide(); select.change(); } else { var previous = select.data('previous'); select.children().attr('selected', null); select.children().each(function (i, option) { if ($(option).val() == previous) { $(option).attr('selected', 'selected'); } }); select.removeClass('active'); input.hide(); } }); input.on('blur', function () { $(this).change(); if ($.fn.tipsy){ $(this).tipsy('hide'); } }); input.click(function(ev) { // prevent clicks to close any container ev.stopPropagation(); }); }); }; })(jQuery);