/**
 * Search suggest call script for FACT-Finder
 * largely based on ffsuggest.jquery.json.js (15.03.2011)
 *
 * @package 	mb3p
 * @subpackage	dmc_m3_integratedsearch_core
 * @access 		public
 * @author		Dieter Rothacker <dieter.rothacker@dmc.de>
 * @version		$Id: ffsuggest.jquery.json.mb3p.js 31630 2011-07-20 14:16:56Z mielkfab $
*/
function FFSuggest() {

	var pDebug					= false;
	var pInstanceName			= '';
	var pSearchURL				= '';
	var pQueryParamName			= '';
	var pFormname 				= '';
	var pLayerName				= '';
	var pQueryInput;
	var pSuggest				= new Array();
	var pLastQuery;
	var submitted				= false;
	var pShowImages				= false;
	var	pSearchDelay			= 400; // timer for request-delay between keypresses in milliseconds
	var	pSearchChars			= 2; // searchword must be at least this length before suggest is triggered
	var pTimer					= false;
	var	pSearchTriggered		= false;

	var pSuggestImageClass 		= 'suggestImage';
	var pSuggestQueryClass 		= 'suggestTextQuery';
	var pSuggestTypeClass 		= 'suggestTextType';
	var pSuggestAmountClass     = 'suggestTextAmount';
	var pSuggestQueryTypedClass = 'suggestTextQueryTyped';
	var pSuggestFooterClass     = 'suggestFooter';
	var pSuggestHeaderClass     = 'suggestHeader';
	var pSuggestRowClass	    = 'suggestRow';
	var pSuggestHighlightClass  = 'suggestHighlight';
	
	var ptranslation;
	
	this.init = function(searchURL, formname, queryParamName, divLayername, instanceName, debugMode, showImages, suggestdelay, suggestchars, translation) {
		pSearchURL			= searchURL;
		pFormname			= formname;
		pQueryParamName		= queryParamName;
		pLayerName			= divLayername;
		pInstanceName		= instanceName;
 		pDebug				= debugMode;
 		pShowImages			= showImages;
		if (pSearchURL == '') {		
			if (pDebug) alert('no searchurl defined');
			return null;
		} else if (pInstanceName == '') {
			if (pDebug) alert('no instancename defined');
			return null;
		} else if (pFormname == '') {
			if (pDebug) alert('no formname defined');
			return null;
		} else if (pQueryParamName == '') {
			if (pDebug) alert('no queryparamname defined');
			return null;
		} else if (pLayerName == '') {
			if (pDebug) alert('need a layer for output');
		}
		if (suggestdelay != '') {
			pSearchDelay = suggestdelay;
		}
		if (suggestchars != '') {
			pSearchChars = suggestchars;
		}
		pQueryInput = document[pFormname][pQueryParamName];
		defaultInput();
		pQueryInput.onkeyup	= handleKeyPress;
		pQueryInput.onfocus	= function() { showLayer(); clearInput(); };
		pQueryInput.onblur	= function() { hideLayer(); defaultInput(); };
		document[pFormname].onsubmit = handleSubmit;
		
		ptranslation = translation;
	}
	
	function clearInput() {
		if ( pQueryInput.value == translation['noinput'] ) {
			pQueryInput.value = '';
		} // end: if
	}
	function defaultInput() {
		if ( pQueryInput.value == '' || pQueryInput.value == '*' ) {
			pQueryInput.value = translation['noinput'];
		} // end: if
	}

	function handleSubmit() {
		if (pQueryInput.value == '' || pQueryInput.value == translation['noinput']) {
			defaultInput();
			return false;
		}
		var id = $('div.'+pSuggestHighlightClass).attr("id");
		if (id != undefined) {
			var id = $('div.'+pSuggestHighlightClass).attr("id");
			var query;
			for (var i=0; i<pSuggest.length; i++) {
				if (pSuggest[i].search(id)==0) {
					query = pSuggest[i].substring(id.length);
					break;
				}
			}
			addInputToForm('userInput', document[pFormname][pQueryParamName].value);
			document[pFormname][pQueryParamName].value = query;
			addInputToForm('queryFromSuggest', 'true');
		}
		$.cookie('searchbacklink', null, { path: '/' });
	}
	
	this.handleClick = function() {
		document[pFormname].onsubmit();
		document[pFormname].submit();
	}

	this.handleMouseOver = function(id) {
		unmarkAll();
		$('#'+pLayerName+' div[id="'+id+'"]').removeClass(pSuggestRowClass).addClass(pSuggestHighlightClass);
	}
	
	this.handleMouseOut = function(id) {
		$('#'+pLayerName+' div[id="'+id+'"]').removeClass(pSuggestHighlightClass).addClass(pSuggestRowClass);
	}
	
	function handleKeyPress(evt) {
		evt = (evt) ? evt : ((event) ? event : null);
		var keyCode = evt.keyCode;
		if (keyCode == 38) {
			moveUp();
		} else if (keyCode == 27) {
			hideLayer();
		} else if (keyCode == 40) {
			moveDown();
		} else {
			if (pTimer) {
				clearTimeout(pTimer);
				pSearchTriggered = false;
			}
			if (pQueryInput.value == '') {
				hideLayer();
				if (pLayer != null){ pLayer.innerHTML = ''; }
				pLastQuery = '';
				return null;
			}
			// start delay timer
			if (!pSearchTriggered && pLastQuery != pQueryInput.value && pQueryInput.value.length >= pSearchChars){
				pSearchTriggered = true;
				pTimer = setTimeout(getSuggestions, pSearchDelay);
			}
			pLastQuery = pQueryInput.value;
		}
	}
	
	
	function moveUp(){
		if($('div.'+pSuggestHighlightClass).length == 0){
		 	$('div.'+pSuggestRowClass+':last').removeClass(pSuggestRowClass).addClass(pSuggestHighlightClass);
	 	}else{
		 	if($('div.'+pSuggestHighlightClass).prev('div.'+pSuggestRowClass).length == 0){
			 	$('div.'+pSuggestHighlightClass).removeClass(pSuggestHighlightClass).addClass(pSuggestRowClass);
			 	$('div.'+pSuggestRowClass+':last').removeClass(pSuggestRowClass).addClass(pSuggestHighlightClass);
			 }
			 else{
			 	$('div.'+pSuggestHighlightClass)
			 	.removeClass(pSuggestHighlightClass).addClass(pSuggestRowClass)
		 		.prev('div.'+pSuggestRowClass).removeClass(pSuggestRowClass).addClass(pSuggestHighlightClass); 
		 	}	
	 	}
	}

	function moveDown(){
		if($('div.'+pSuggestHighlightClass).length == 0){
		 	$('div.'+pSuggestRowClass+':first')
		 	.removeClass(pSuggestRowClass)
		 	.addClass(pSuggestHighlightClass);
	 	}
	 	else{
		 	if($('div.'+pSuggestHighlightClass).next('div.'+pSuggestRowClass).length == 0){
			 	$('div.'+pSuggestHighlightClass).addClass(pSuggestRowClass).removeClass(pSuggestHighlightClass);
			 	$('div.'+pSuggestRowClass+':first').removeClass(pSuggestRowClass).addClass(pSuggestHighlightClass);
		 	}
		 	else{
			 	$('div.'+pSuggestHighlightClass).addClass(pSuggestRowClass).removeClass(pSuggestHighlightClass)
		 		.next('div.'+pSuggestRowClass).removeClass(pSuggestRowClass).addClass(pSuggestHighlightClass); 
		 	}
	 	}
	}
	
	function getSuggestions(){
		var query = $('input[name='+pQueryParamName+']').attr('value');
		//check if the same query was asked before
/*		if(pLastQuery == query){
			return;
		}
		else {
			pLastQuery = query;
		}*/
			//var requestURL = pSearchURL +'?'+ pQueryParamName +'='+ encodeURIComponent(query) +'&'+ pChannelParamName +'='+ pChannel+'&format=json';
		var requestURL = pSearchURL + '&query=' + encodeURIComponent(query);
		$.ajax({
			type: "GET",
			url: requestURL,
			contentType: "application/x-www-form-urlencoded; charset=UTF-8",
			success:
				function (json, textStatus) {
					var jsonObj = eval(json);
					if (jsonObj.length > 0) {
						//create output text
						var outputText = '<div class="' + pLayerName + '" onMouseDown="' + pInstanceName + '.handleClick();">';
							outputText += '<div class="'+pSuggestHeaderClass+'" >' + ptranslation['header'] + '</div><div class="suggestRowContainer">';
					
						pSuggest = new Array();
						for (var i=0; i<jsonObj.length; i++) {
							var suggestQuery = jsonObj[i].query;
							var suggestCount = jsonObj[i].hitCount;
							/*if (suggestCount==0) {
								suggestCount = '';
							}else if (suggestCount==1) {
								suggestCount = 'Ein Produkt';
							}else {
								suggestCount = suggestCount + ' Produkte';
							}*/
							var suggestType = ptranslation[jsonObj[i].type];
							if (!suggestType) {
								suggestType = "";
							}
							var suggestImageUrl = jsonObj[i].imageURL;
							var id = i;			
							outputText += '<div id="' + id + '" class="'+pSuggestRowClass+'" onMouseOver="' + pInstanceName + '.handleMouseOver(' + id + ');" onMouseOut="' + pInstanceName + '.handleMouseOut(' + id + ');">'
								+(pShowImages ? '<td nowrap="nowrap" class="'+ pSuggestImageClass +'"><img src="' + suggestImageUrl + '" alt=""/></td>' : '')
								+'<span class="'+ pSuggestQueryClass +'">' + suggestQuery.replace(new RegExp("("+query+")","ig"),'<span class="'+pSuggestQueryTypedClass+'">$1</span>') + '</span>'
								+'<span class="'+ pSuggestAmountClass +'">(' + suggestCount + ')</span>'
								+'</div>';
							pSuggest[i] = id + suggestQuery;
						}
						outputText += '</div><div class="'+pSuggestFooterClass+'" colspan="'+(3+pShowImages)+'">&nbsp;</div></div>';
						
						//show layer
						$('div#'+pLayerName).html(outputText).show();
					}
					else {
						//hide layer
						$('div#'+pLayerName).hide();
					}				
				},
			error:
				function (e, xhr, settings, exception) {
					if (pDebug) {
						alert('Error:\nHTTP result code: ' + e.status+'\nrequested URL: '+requestURL);
					}
				}
		});
		pSearchTriggered = false;
	}
		
	function hideLayer() {
		unmarkAll();
		$('div#'+pLayerName).hide();
		fireSuggestLayerHidden();
	}
	
	this.hideLayerOutsideCall = function() {
		hideLayer();
	}

	function showLayer() {
		$('div#'+pLayerName).show();
	}

	// calls the callback for "outside" listeners if the callback is implemented
	function fireSuggestCompleted(suggestLayerIsVisible) {
		if (typeof(onSuggestCompleted) == 'function') {
			onSuggestCompleted(suggestLayerIsVisible);
		}
	}

	// calls the callback for "outside" listeners if the callback is implemented
	function fireSuggestLayerHidden() {
		if (typeof(onSuggestLayerHidden) == 'function') {
			onSuggestLayerHidden();
		}
	}

	function unmarkAll() {
		$('tr.'+pSuggestHighlightClass).each(function(i) {
			$(this).removeClass(pSuggestHighlightClass).addClass(pSuggestRowClass);			
		});
	}
	
	function addInputToForm(name, value) {
		var element = document.createElement('input');
		element.name = name;
		element.type = 'hidden';
		element.value = value;
		document[pFormname].appendChild(element);
	}
}
