/**
 * common_new.js
 */


/**
 * blockUI()
 */
function blockUI()
{
	$.blockUI({ message: '<div style="padding: 20px 30px;"><img src="/images/progress_bar.gif" /><div style="font-style: italic;">Processing, please wait...</div></div>' });
	// $.blockUI({ css: { backgroundColor: '#f00', color: '#fff'} });
}

function unblockUI()
{
	$.unblockUI();
}

/**
 * This function is used on text input event: onkeypress
 *	where param: validKeys is the only ones accepted.
 */
function theseKeysOnly(event, validKeys)
{
	var keyp = [event.keyCode||event.which];
	
	var i;
	var j;
	
	var editKeys	= Array(8, 9, 37, 39, 38, 40);
	
	for (i in editKeys)
	{
		if (editKeys[i] == keyp) {
			return true;
		}
	}
	
	for (j in validKeys)
	{
		if (validKeys[j] == keyp) {
			return true;
		}
	}

	return false;
}

/**
 * Toggles hiding and showing of sibling <p> of this
 */
function qaToggleShow(aLi)
{
	var paragraph	= $(aLi).parent().find("p");
	if (paragraph.is(":visible")) {
		paragraph.css("display", "none");
		$(aLi).parent().css("backgroundColor", "#F3F4F8");
	} else {
		paragraph.css("display", "block");
		$(aLi).parent().css("backgroundColor", "#FFF");
	}
	$(aLi).blur(); // remove focus.
	return false;
}

/**
 * Validates an email address.
 */
function validateEmail(str) {
	var at		= "@";
	var dot		= ".";
	var lat		= str.indexOf(at);
	var lstr	= str.length;
	var ldot	= str.indexOf(dot);
	
	if (str.indexOf(at)==-1){
	   return false;
	}

	if (str.indexOf(at)==-1 || str.indexOf(at)==0 || str.indexOf(at)==lstr){
	   return false;
	}

	if (str.indexOf(dot)==-1 || str.indexOf(dot)==0 || str.indexOf(dot)==lstr){
	    return false;
	}

	if (str.indexOf(at,(lat+1))!=-1){
	    return false;
	}

	if (str.substring(lat-1,lat)==dot || str.substring(lat+1,lat+2)==dot){
	    return false;
	}

	if (str.indexOf(dot,(lat+2))==-1){
	    return false;
	}
	
	if (str.indexOf(" ")!=-1){
	    return false;
	}

	return true;				
}

/**
 * Use this function to toggle the attribute: checked
 * Sample calls:
	$("input[@type='checkbox']").check();
	$("input[@type='checkbox']").check('on');
	$("input[@type='checkbox']").check('off');
	$("input[@type='checkbox']").check('toggle');
 */
$.fn.check = function(mode) {
	var mode = mode || 'on'; // if mode is undefined, use 'on' as default
	return this.each(function() {
		switch(mode) {
		case 'on':
			this.checked = true;
			break;
		case 'off':
			this.checked = false;
			break;
		case 'toggle':
			this.checked = !this.checked;
			break;
		}
	});
};

/**
 * Tooltip script 
 * powered by jQuery (http://www.jquery.com)
 * written by Alen Grakalic (http://cssglobe.com)
 * for more info visit http://cssglobe.com/post/1695/easiest-tooltip-and-image-preview-using-jquery
 */
this.tooltip = function(){	
	/* CONFIG */		
	xOffset = -15;
	yOffset = 14;		
	// these 2 variable determine popup's distance from the cursor
	// you might want to adjust to get the right result		
	/* END CONFIG */
	
	$("a.tooltip").hover(function(e){											  
		this.t = this.title;
		this.title = "";									  
		$("body").append("<p id='tooltip'>"+ this.t +"</p>");
		//~ $("#tooltip")
			//~ .css("top",(e.pageY - xOffset) + "px")
			//~ .css("left",(e.pageX + yOffset) + "px")
			//~ .fadeIn("fast");		
		$("#tooltip")
			.css("top","0px")
			.css("left","0px")
			.css("position", "absolute")
			.fadeIn("fast");		
	},
	function(){
		this.title = this.t;		
		$("#tooltip").remove();
	});	
	$("a.tooltip").mousemove(function(e){
		$("#tooltip")
			.css("top",(e.pageY - xOffset) + "px")
			.css("left",(e.pageX + yOffset) + "px");
	});
};

// eof


// NOT SO COMMON
function showLang(){
	var l = document.getElementById("class_div");
	if(l.style.visibility == "hidden"){
		l.style.visibility = "visible";
	}else{
		l.style.visibility = "hidden";
	}
}
function changeLang(lang){
	var l = document.getElementById("langmain");
	l.innerHTML = lang;
	showLang();
}
function redirectToAnotherLanguage(site, lang, page)
{
	if (!site) site = 'de';
	if (!lang) lang = 'de';
	
	if (site == lang || (site == 'com' && lang == 'en') || (site == 'ch' && lang == 'de') || (site == 'at' && lang == 'de')) {
		lang	= '';
	}

	//document.location.href	= "http://www.maxiprint." + site + (lang == 'de' ? '' : '/' + lang) + (page == '/index.php' ? '' : page);
	document.location.href	= "http://" + httpHost + "." + site + (lang ? '/' + lang : '') + (page == '/index.php' ? '' : page);
}

function showLangOptions(selId, nCtry, langShort)
{
	$("#" + selId).removeOption(/./);
	
	if (nCtry == "de") {
		$("#" + selId).addOption({'de' : 'deutsch'}, true);
	} else if (nCtry == "fr") {
		$("#" + selId).addOption({'de' : 'deutsch'}, (langShort == 'de' ? true : false));
		$("#" + selId).addOption({'en' : 'english'}, (langShort == 'en' ? true : false));
		$("#" + selId).addOption({'es' : 'español'}, (langShort == 'es' ? true : false));
		$("#" + selId).addOption({'it' : 'italiano'}, (langShort == 'it' ? true : false));
		$("#" + selId).addOption({'fr' : 'français'}, (langShort == 'fr' ? true : false));
	} else if (nCtry == "com") {
		$("#" + selId).addOption({'de' : 'deutsch'}, (langShort == 'de' ? true : false));
		$("#" + selId).addOption({'en' : 'english'}, (langShort == 'en' ? true : false));
		$("#" + selId).addOption({'es' : 'español'}, (langShort == 'es' ? true : false));
		$("#" + selId).addOption({'it' : 'italiano'}, (langShort == 'it' ? true : false));
		$("#" + selId).addOption({'fr' : 'français'}, (langShort == 'fr' ? true : false));
	} else if (nCtry == "it") {
		$("#" + selId).addOption({'de' : 'deutsch'}, (langShort == 'de' ? true : false));
		$("#" + selId).addOption({'en' : 'english'}, (langShort == 'en' ? true : false));
		$("#" + selId).addOption({'es' : 'español'}, (langShort == 'es' ? true : false));
		$("#" + selId).addOption({'it' : 'italiano'}, (langShort == 'it' ? true : false));
		$("#" + selId).addOption({'fr' : 'français'}, (langShort == 'fr' ? true : false));
	} else if (nCtry == "uk") {
		$("#" + selId).addOption({'de' : 'deutsch'}, (langShort == 'de' ? true : false));
		$("#" + selId).addOption({'en' : 'english'}, (langShort == 'en' ? true : false));
		$("#" + selId).addOption({'es' : 'español'}, (langShort == 'es' ? true : false));
		$("#" + selId).addOption({'it' : 'italiano'}, (langShort == 'it' ? true : false));
		$("#" + selId).addOption({'fr' : 'français'}, (langShort == 'fr' ? true : false));
	} else if (nCtry == "at") {
		$("#" + selId).addOption({'de' : 'deutsch'}, true);
	} else if (nCtry == "ch") {
		$("#" + selId).addOption({'de' : 'deutsch'}, (langShort == 'de' ? true : false));
		$("#" + selId).addOption({'en' : 'english'}, (langShort == 'en' ? true : false));
		$("#" + selId).addOption({'es' : 'español'}, (langShort == 'es' ? true : false));
		$("#" + selId).addOption({'it' : 'italiano'}, (langShort == 'it' ? true : false));
		$("#" + selId).addOption({'fr' : 'français'}, (langShort == 'fr' ? true : false));
	} else if (nCtry == "es") {
		$("#" + selId).addOption({'de' : 'deutsch'}, (langShort == 'de' ? true : false));
		$("#" + selId).addOption({'en' : 'english'}, (langShort == 'en' ? true : false));
		$("#" + selId).addOption({'es' : 'español'}, (langShort == 'es' ? true : false));
		$("#" + selId).addOption({'it' : 'italiano'}, (langShort == 'it' ? true : false));
		$("#" + selId).addOption({'fr' : 'français'}, (langShort == 'fr' ? true : false));
	}
}

/**
 * Dummy function, actual is on http://print24.de/
 */
function countBookmarkClick(nBookmark)
{
	return;
}

/**
 * Validate Pop-up Login
 */
function validatePopupLogin()
{
	var nErr	= 0;
	if ($('#loginEmail').val() == '') {
		nErr	= 1;
	}
	if ($('#loginPassword').val() == '') {
		nErr	+= 10;
	}
	if (nErr == 0) {
		return true;
	}
	if (nErr == 1) {
		alert('Please enter your email address.');
		$('#loginEmail').focus();
	} else if (nErr == 10) {
		alert('Please enter your password.');
		$('#loginPassword').focus();
	} else if (nErr == 11) {
		alert('Please enter your email and password.');
		$('#loginEmail').focus();
	}
	return false;
}

function get_html_translation_table(table, quote_style) {
    // http://kevin.vanzonneveld.net
    // +   original by: Philip Peterson
    // +    revised by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
    // +   bugfixed by: noname
    // +   bugfixed by: Alex
    // +   bugfixed by: Marco
    // +   bugfixed by: madipta
    // +   improved by: KELAN
    // +   improved by: Brett Zamir (http://brettz9.blogspot.com)
    // %          note: It has been decided that we're not going to add global
    // %          note: dependencies to php.js. Meaning the constants are not
    // %          note: real constants, but strings instead. integers are also supported if someone
    // %          note: chooses to create the constants themselves.
    // *     example 1: get_html_translation_table('HTML_SPECIALCHARS');
    // *     returns 1: {'"': '&quot;', '&': '&amp;', '<': '&lt;', '>': '&gt;'}
    
    var entities = {}, histogram = {}, decimal = 0, symbol = '';
    var constMappingTable = {}, constMappingQuoteStyle = {};
    var useTable = {}, useQuoteStyle = {};
    
    // Translate arguments
    constMappingTable[0]      = 'HTML_SPECIALCHARS';
    constMappingTable[1]      = 'HTML_ENTITIES';
    constMappingQuoteStyle[0] = 'ENT_NOQUOTES';
    constMappingQuoteStyle[2] = 'ENT_COMPAT';
    constMappingQuoteStyle[3] = 'ENT_QUOTES';
 
    useTable     = !isNaN(table) ? constMappingTable[table] : table ? table.toUpperCase() : 'HTML_SPECIALCHARS';
    useQuoteStyle = !isNaN(quote_style) ? constMappingQuoteStyle[quote_style] : quote_style ? quote_style.toUpperCase() : 'ENT_COMPAT';
 
    if (useTable !== 'HTML_SPECIALCHARS' && useTable !== 'HTML_ENTITIES') {
        throw Error("Table: "+useTable+' not supported');
        // return false;
    }
 
    // ascii decimals for better compatibility
    entities['38'] = '&amp;';
    if (useQuoteStyle !== 'ENT_NOQUOTES') {
        entities['34'] = '&quot;';
    }
    if (useQuoteStyle === 'ENT_QUOTES') {
        entities['39'] = '&#039;';
    }
    entities['60'] = '&lt;';
    entities['62'] = '&gt;';
 
    if (useTable === 'HTML_ENTITIES') {
      entities['160'] = '&nbsp;';
      entities['161'] = '&iexcl;';
      entities['162'] = '&cent;';
      entities['163'] = '&pound;';
      entities['164'] = '&curren;';
      entities['165'] = '&yen;';
      entities['166'] = '&brvbar;';
      entities['167'] = '&sect;';
      entities['168'] = '&uml;';
      entities['169'] = '&copy;';
      entities['170'] = '&ordf;';
      entities['171'] = '&laquo;';
      entities['172'] = '&not;';
      entities['173'] = '&shy;';
      entities['174'] = '&reg;';
      entities['175'] = '&macr;';
      entities['176'] = '&deg;';
      entities['177'] = '&plusmn;';
      entities['178'] = '&sup2;';
      entities['179'] = '&sup3;';
      entities['180'] = '&acute;';
      entities['181'] = '&micro;';
      entities['182'] = '&para;';
      entities['183'] = '&middot;';
      entities['184'] = '&cedil;';
      entities['185'] = '&sup1;';
      entities['186'] = '&ordm;';
      entities['187'] = '&raquo;';
      entities['188'] = '&frac14;';
      entities['189'] = '&frac12;';
      entities['190'] = '&frac34;';
      entities['191'] = '&iquest;';
      entities['192'] = '&Agrave;';
      entities['193'] = '&Aacute;';
      entities['194'] = '&Acirc;';
      entities['195'] = '&Atilde;';
      entities['196'] = '&Auml;';
      entities['197'] = '&Aring;';
      entities['198'] = '&AElig;';
      entities['199'] = '&Ccedil;';
      entities['200'] = '&Egrave;';
      entities['201'] = '&Eacute;';
      entities['202'] = '&Ecirc;';
      entities['203'] = '&Euml;';
      entities['204'] = '&Igrave;';
      entities['205'] = '&Iacute;';
      entities['206'] = '&Icirc;';
      entities['207'] = '&Iuml;';
      entities['208'] = '&ETH;';
      entities['209'] = '&Ntilde;';
      entities['210'] = '&Ograve;';
      entities['211'] = '&Oacute;';
      entities['212'] = '&Ocirc;';
      entities['213'] = '&Otilde;';
      entities['214'] = '&Ouml;';
      entities['215'] = '&times;';
      entities['216'] = '&Oslash;';
      entities['217'] = '&Ugrave;';
      entities['218'] = '&Uacute;';
      entities['219'] = '&Ucirc;';
      entities['220'] = '&Uuml;';
      entities['221'] = '&Yacute;';
      entities['222'] = '&THORN;';
      entities['223'] = '&szlig;';
      entities['224'] = '&agrave;';
      entities['225'] = '&aacute;';
      entities['226'] = '&acirc;';
      entities['227'] = '&atilde;';
      entities['228'] = '&auml;';
      entities['229'] = '&aring;';
      entities['230'] = '&aelig;';
      entities['231'] = '&ccedil;';
      entities['232'] = '&egrave;';
      entities['233'] = '&eacute;';
      entities['234'] = '&ecirc;';
      entities['235'] = '&euml;';
      entities['236'] = '&igrave;';
      entities['237'] = '&iacute;';
      entities['238'] = '&icirc;';
      entities['239'] = '&iuml;';
      entities['240'] = '&eth;';
      entities['241'] = '&ntilde;';
      entities['242'] = '&ograve;';
      entities['243'] = '&oacute;';
      entities['244'] = '&ocirc;';
      entities['245'] = '&otilde;';
      entities['246'] = '&ouml;';
      entities['247'] = '&divide;';
      entities['248'] = '&oslash;';
      entities['249'] = '&ugrave;';
      entities['250'] = '&uacute;';
      entities['251'] = '&ucirc;';
      entities['252'] = '&uuml;';
      entities['253'] = '&yacute;';
      entities['254'] = '&thorn;';
      entities['255'] = '&yuml;';
    }
    
    // ascii decimals to real symbols
    for (decimal in entities) {
        symbol = String.fromCharCode(decimal);
        histogram[symbol] = entities[decimal];
    }
    
    return histogram;
}

function html_entity_decode( string, quote_style ) {
    // http://kevin.vanzonneveld.net
    // +   original by: john (http://www.jd-tech.net)
    // +      input by: ger
    // +   improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
    // +    revised by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
    // +   bugfixed by: Onno Marsman
    // +   improved by: marc andreu
    // +    revised by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
    // -    depends on: get_html_translation_table
    // *     example 1: html_entity_decode('Kevin &amp; van Zonneveld');
    // *     returns 1: 'Kevin & van Zonneveld'
    // *     example 2: html_entity_decode('&amp;lt;');
    // *     returns 2: '&lt;'
 
    var histogram = {}, symbol = '', tmp_str = '', entity = '';
    tmp_str = string.toString();
    
    if (false === (histogram = this.get_html_translation_table('HTML_ENTITIES', quote_style))) {
        return false;
    }
 
    // &amp; must be the last character when decoding!
    delete(histogram['&']);
    histogram['&'] = '&amp;';
 
    for (symbol in histogram) {
        entity = histogram[symbol];
        tmp_str = tmp_str.split(entity).join(symbol);
    }
    
    return tmp_str;
}

// eof
