(function( $ ) {
		$.widget( "ui.combobox", {
			_create: function() {
				var self = this,
					select = this.element.hide(),
					selected = select.children( ":selected" ),
					value = selected.val() ? selected.text() : "";
				var input = this.input = $( "<input>" )
					.insertAfter( select )
					.val( value )
					.autocomplete({
						delay: 0,
						minLength: 0,
						source: function( request, response ) {
							var matcher = new RegExp("^" + $.ui.autocomplete.escapeRegex(request.term), "i" );
							response( select.children( "option" ).map(function() {
								var text = $( this ).text();
								var lastSpace = text.lastIndexOf(' ');
								var currency = text.substring(lastSpace + 1);
								text = text.substring(0, lastSpace);
								if ( this.value && ( !request.term || matcher.test(text) ) )
									return {
										label: text.replace(
											new RegExp(
												"(?![^&;]+;)(?!<[^<>]*)(" +
												$.ui.autocomplete.escapeRegex(request.term) +
												")(?![^<>]*>)(?![^&;]+;)", "gi"
											), "<strong>$1</strong>" ) + " " + currency,
										value: text + " " + currency,
										option: this
									};
							}) );
						},
						select: function( event, ui ) {
							ui.item.option.selected = true;
							$("#valuta_select_sell").change();
							self.input.css("background-image", "url(" + ui.item.option.attributes["data"].value + ")");
							self._trigger( "selected", event, {
								item: ui.item.option
							});
						},
						change: function( event, ui ) {
							if ( !ui.item ) {
								var matcher = new RegExp( "^" + $.ui.autocomplete.escapeRegex( $(this).val() ) + "$", "i" ),
									valid = false;
								select.children( "option" ).each(function() {
									if ( $( this ).text().match( matcher ) ) {
										this.selected = valid = true;
										return false;
									}
								});
								if ( !valid ) {
									// remove invalid value, as it didn't match anything
									$( this ).val( "" );
									select.val( "" );
									select.children("option:selected").removeAttr("selected");
									input.css("background-image", "none");
									input.data( "autocomplete" ).term = "";
									return false;
								}
							}
						}
					});

				input.data( "autocomplete" )._renderItem = function( ul, item ) {
					var selected = '';
					
					if(item.option.selected)
					{
						selected = " class=\"selected\"";
					}
				
					return $( "<li></li>" )
						.data( "item.autocomplete", item )
						.append( "<a style=\"background-image: url(" + item.option.attributes["data"].value + ");\"" + selected + ">" + item.label + "</a>" )
						.appendTo( ul );
				};

				this.button = $( "<button type='button'>&nbsp;</button>" )
					.attr( "tabIndex", -1 )
					.attr( "title", "Visa alla valutor" )
					.insertAfter( input )
					.button({
						icons: {
							primary: "ui-icon-triangle-1-s"
						},
						text: false
					})
					.removeClass( "ui-corner-all" )
					.addClass( "ui-corner-right ui-button-icon" )
					.click(function() {
						// close if already visible
						if ( input.autocomplete( "widget" ).is( ":visible" ) ) {
							input.autocomplete( "close" );
							return;
						}

						// work around a bug (likely same cause as #5265)
						$( this ).blur();

						// pass empty string as value to search for, displaying all results
						input.autocomplete( "search", "" );
						input.focus();
					});					
			},

			destroy: function() {
				this.input.remove();
				this.button.remove();
				this.element.show();
				$.Widget.prototype.destroy.call( this );
			}
		});
	})( jQuery );

	$(function() {
		$( "#valuta_select_sell" ).combobox();
		$( "#toggle" ).click(function() {
			$( "#valuta_select_sell" ).toggle();		
				
		});
				
		$("#select-box input").css("background-image", "url(" + $("#valuta_select_sell option:selected").attr("data") + ")");
		$("#select-box input").click(function()
		{						
			$(this).css("background-image", "none");
			$(this).val("");
			$("#valuta_select_sell option:selected").removeAttr("selected");
			$( "#select-box button").click();	
		});
			
	});
