/*-- add/remove class --*/

	function addClass(obj, newclass) {
		if(obj.className.indexOf(newclass) == -1)
			obj.className += " " + newclass;
	}
	
	function removeClass(obj, newclass) {
		var classes = obj.className.split(' ');
		for(i=0; i<classes.length; i++) {
			if(classes[i].indexOf(newclass) > -1)
				classes[i] = "";
		}
		obj.className = classes.join(' ');
	}


/*-- alternativ x-menu --*/

	var navIDs = new Array('main_nav', 'service_nav');
	var navImagesNormal = new Array();
	var navImagesHover = new Array();
	function init_nav() {
		for(idcount=0; idcount<navIDs.length; idcount++) {
			var nav = document.getElementById(navIDs[idcount]);
			var lis = nav.getElementsByTagName('li');
			for(var i = 0; i < lis.length; i++) {
				if(lis[i].parentNode.id == navIDs[idcount]) {
					lis[i].number = (idcount*100) + i;
					lis[i].onmouseover = function() {
						addClass(this, 'hover');
						var img = this.getElementsByTagName('img');
						if(img[0] && navImagesHover[this.number])
							img[0].src = navImagesHover[this.number];
					}
					lis[i].onmouseout = function() {
						removeClass(this, 'hover');
						var img = this.getElementsByTagName('img');
						if(img[0] && navImagesNormal[this.number])
							img[0].src = navImagesNormal[this.number];
					}
					var img = lis[i].getElementsByTagName('img');
					if(img[0] && img[0].onmouseover) {
						navImagesNormal[lis[i].number] = img[0].src;
						img[0].onmouseover();
						navImagesHover[lis[i].number] = img[0].src;
						img[0].onmouseout();
						img[0].onmouseover = function() {};
						img[0].onmouseout = function() {};
					}
				}
			}
		}
	}


function ShowHide(layID) {
	var myLayer = document.getElementById(layID);
	if (myLayer.style.display=="none") {
		myLayer.style.display="";
		} else {
		myLayer.style.display="none";
	}
}

// Array für zusätzliche Funktionen die in der js_onload ausgeführt werden sollen
col_onload_functions = new Array();

// Cookie objekte
cookie_pairs = new Object();
cookie_expiration = new Date(2099,1,1,1,1,1,1);

// Objekt für die Stylesheet Regeln (hierauf greift dann die Schriftgrössenänderung zu)
css_rules = new Object();

// Objekt für die Stylesheet Regeln, die nicht behandelt werden sollen
// für jeden Behandlungsbereich (z.b. Schriftgrössen) sollte ein eigenes Objekt erstellt werden
css_rules_exceptions = new Object();
/*
da wir unter Umständen auch mal mehr machen, als nur die Schriftgrössen zu ändern, gibts für die Schriftgrössenausnahmen ein eigenes Objekt
*/
css_rules_exceptions.fontsizes = new Object();
/*
die einfachste variante ist die überprüfung ob das objekt existiert oder nicht
bsp:
css_rules_exceptions.fontsizes['#navigation'] = new Object();
css_rules_exceptions.fontsizes['#navigation td a:hover'] = new Object();
*/
css_rules_exceptions.fontsizes['#head_rfield a'] = new Object();
css_rules_exceptions.fontsizes['#web #form_search input'] = new Object();
css_rules_exceptions.fontsizes['#subnav'] = new Object();
css_rules_exceptions.fontsizes['#subnav a'] = new Object();
css_rules_exceptions.fontsizes['#web #form_search'] = new Object();
css_rules_exceptions.fontsizes['#contactinfo td'] = new Object();
css_rules_exceptions.fontsizes['#contactinfo td a'] = new Object();
css_rules_exceptions.fontsizes['#footer_container'] = new Object();

// Objekt für die Default Schriftgrössen
fontsizes_default = new Object();

// Allgemeine Variablen
window_loaded = false;
nav_hover_img = null;
nav_hover_img_event = null;
nav_hover_img_new = null;

// Ausführung von JS Code bevor die Seite geladen ist
js_init();

window.onload = js_onload;

// Initialisierung bevor Seite geladen ist
function js_init () {

	// die Schriftgrössen werden initialisiert
	js_fontsizes_init();
	
	if (js_browser_accepts_cookies()) {
		js_cookie_init();
		
		// Schriftgrössenänderung
		if (cookie_pairs.fontsizefactor!=0){
			js_fontsize_change(cookie_pairs.fontsizefactor);
		}
	}
	
}

function js_browser_accepts_cookies () {
	return navigator.cookieEnabled;
}

// Cookie initialisieren
// sollten die Cookiewerte falsch sein, werden die js_variablen mit standardwerten befüllt
// am ende wird das cookie mit den js_variablen befüllt
function js_cookie_init () {
	// Wenn kein Cookie gesetzt ist, wird es mit Standardwerten befüllt.
	if (!document.cookie){
		document.cookie = "fontsizefactor=0; path=/; expires=" + cookie_expiration.toGMTString();
	}
	
	// die Cookiewerte werden in js_variablen umgesetzt
	cookie_pairs_arr = document.cookie.split(";");
	for (pair in cookie_pairs_arr){
		if(cookie_pairs_arr[pair].typeOf == 'string')
		{
			pair_arr = cookie_pairs_arr[pair].split("=");
			cookie_pairs[pair_arr[0]] = pair_arr[1];
		}
	}
	
	// die werte werden überprüft und gegebenfalls neu gesetzt
	if (cookie_pairs.fontsizefactor){
		parseInt(cookie_pairs.fontsizefactor);
		if (isNaN(cookie_pairs.fontsizefactor)){
			cookie_pairs.fontsizefactor = 0;
		}
	}
	else {
		cookie_pairs.fontsizefactor = 0;
	}
	
	// das cookie wird mit den js_variablen neu gespeichert (hat den sinn, falls die werte falsch waren, dass sie jetzt richtig gespeichert werden)
	document.cookie = "fontsizefactor=" + cookie_pairs.fontsizefactor + "; path=/; expires=" + cookie_expiration.toGMTString();
}


// Schriftgrösseninitialisierung
function js_fontsizes_init() {
	// Stylesheet laden
	obj_stylesheet = document.styleSheets[1];
	
	// Stylesheet Regeln laden (-> Array)
	if (obj_stylesheet.rules){
		arr_css_rules = obj_stylesheet.rules;
	}
	else {
		arr_css_rules = obj_stylesheet.cssRules;
	}
	
	// Loop über alle Regeln im Stylesheet
	for (i=0;i<arr_css_rules.length;i++){
		// Regelname temporär speichern
		rule_name = arr_css_rules[i].selectorText.toLowerCase();
		
		// wenn in der Regel eine Schriftgrösse vorhanden
		if (arr_css_rules[i].style.fontSize && arr_css_rules[i].style.fontSize.length > 0){
			
			size = parseInt(arr_css_rules[i].style.fontSize);
			if (size>1){
				// Die Regel wird mit dem Namen in das css_rules Objekt als Verweis auf die Regel im Stylesheet geladen, damit sie über den Regelnamen direkt angesprochen werden können
				css_rules[rule_name] = arr_css_rules[i];
				// Die Standardschriftgrössen werden gespeichert (zum zurücksetzen)				
				fontsizes_default[rule_name] = size;
			}
		}
	}
	
}


// beim Click auf Schriftgrösse grösser oder kleiner
function js_fontsize_change_click(factor){
	// die Schriftgrössen werden geändert
	js_fontsize_change(factor);
	
	// die neue Schriftgrösse wird im Cookie gespeichert
	js_fontsize_save(factor);
}



// Schriftgrössen werden geändert
function js_fontsize_change(factor) {
	// Schleife über alle relevanten Regeln
	for (rule in css_rules){
		// Wenn eine Schriftgrösse vorhanden ist (wurde zwar beim initialisieren überprüft, aber es können ja auch für andere Zwecke Regeln gespeichert werden, die keine Schriftgrösse haben )
		if (css_rules[rule].style.fontSize && css_rules[rule].style.fontSize.length > 0){
			size = parseInt(css_rules[rule].style.fontSize);
			if (size>1){
				// Standardausnahmen Routine, siehe oben
				doit = true;
				if (css_rules_exceptions.fontsizes[rule.toLowerCase()]){
				doit = false
				}
				// unter bestimmten Umständen reicht die Standardausnahmenroutine nicht aus
				/*
				Bsp:
				if (iam_startpage && andere_option && rule.toLowerCase()=='#container_fonthandler td'.toLowerCase()){
					doit = false;
				}
				*/
				
				// wenn alles ok wird jetzt Schriftgrösse geändert
				if (doit){
					size_new = size + parseInt(factor);
					css_rules[rule].style.fontSize = size_new + 'px';
				}
			}
		}
	}

	// wenn window bereits geladen ist jetzt der content neu gerendert
	if (window_loaded){
		js_content_rerender();
	}
	
	// da sich die grössenproportionen unter umständen geändert haben, wird die resizefunktion aufgerufen
	js_resize();
}


// Schriftgrössen auf Standard zurücksetzen
function js_fontsize_reset() {
	// die gespeicherten Standardschriftgrössen werden auf die Stylesheet Regeln angewandt.
	for (rule in fontsizes_default){
		css_rules[rule].style.fontSize = fontsizes_default[rule] + 'px';
	}
	
	if (js_browser_accepts_cookies()) {
		// der fontsizefactor wird auf 0 gesetzt und im cookie gespeichert
		cookie_pairs.fontsizefactor = 0;
		document.cookie = "fontsizefactor=" + cookie_pairs.fontsizefactor + "; path=/; expires=" + cookie_expiration.toGMTString();
	}
	
	// wenn window bereits geladen ist jetzt der content neu gerendert
	if (window_loaded){
		js_content_rerender();
	}
	
	// da sich die grössenproportionen unter umständen geändert haben, wird die resizefunktion aufgerufen
	js_resize();
}


// der Schriftgrössenfactor wird im Cookie gespeichert
function js_fontsize_save(factor){
	// wenn Cookies erlaubt sind
	if (js_browser_accepts_cookies()) {
		if (!cookie_pairs.fontsizefactor) {
			cookie_pairs.fontsizefactor = factor;
		}
		cookie_pairs.fontsizefactor = parseInt(cookie_pairs.fontsizefactor) + parseInt(factor);
		document.cookie = "fontsizefactor=" + cookie_pairs.fontsizefactor + "; path=/; expires=" + cookie_expiration.toGMTString();
	}
}


// der content wird neu gerendert (muss nur angepasst werden, wenn in einzelnen browsern der content nach der schriftgrössenänderung nicht aussieht wie er sollte)
function js_content_rerender(){
document.body.innerHTML = document.body.innerHTML;
}

function js_onload(){
	window_loaded = true;

	for (i=0;i<col_onload_functions.length;i++){
		eval(col_onload_functions[i]);
	}
	
	// Resizefunktion aufrufen
	window.onresize = js_resize;
	js_resize();
}

function js_resize(){
	if (window_loaded){
		var sitepic = document.getElementById('sitepic')
		var content_bg = document.getElementById('content_bg')
		var subnav_bg = document.getElementById('subnav_bg')

		if(sitepic && subnav_bg && content_bg)
		{
			if (document.body.offsetHeight < 585)
			{
				subnav_bg.style.bottom='230px'
				content_bg.style.height='113px'
				sitepic.style.height='127px'
			} else {
				subnav_bg.style.bottom='320px'
				content_bg.style.height='203px'
				sitepic.style.height='217px'
			}
		}
	}
}


function swapImage(element, newimage, direction) {
    var oldsrc = element.src
	element.src = newimage
	if (direction){
		element.onmouseout = null
		element.onmouseover = function (event) { swapImage(this, oldsrc); }
	}
	else{
		element.onmouseover = null;
		element.onmouseout = function (event) { swapImage(this, oldsrc, 1); }
	}
}


function GetDate() {
	obj = document.getElementById("date");
	if (!obj)
		return;
	var jetzt = new Date();
	var Tag = jetzt.getDate();
	if (Tag < 10)
		Tag = "0" + String(Tag);
	var months = new Array("Jänner", "Februar", "März", "April", "Mai", "Juni", "Juli", "August", "September", "Oktober", "November", "Dezember");
	var Wochentag = new Array("Sonntag", "Montag", "Dienstag", "Mittwoch", "Donnerstag", "Freitag", "Samstag");
	var Jahr = jetzt.getYear();
	if (Jahr < 999)
		Jahr += 1900;
	obj.innerHTML = Wochentag[jetzt.getDay()] + ", <span>" + Tag + ". " + months[jetzt.getMonth()] + " " + Jahr + "</span>";
}

function getAdr(prefix, postfix, text) {
        document.write('<a href="mailto:' + prefix + '@' + postfix + '">' + (text ? text.replace(/&quot;/g, '"').replace(/%EMAIL%/, prefix + '@' + postfix) : prefix + '@' + postfix) + '</a>');
}

var sel;
function HideSelects(x,y,w,h) {
	if(xIE4Up && !xMac) {
		var selx, sely, selw, selh, i
		if(!sel)
			sel = document.getElementsByTagName("SELECT");
		for(i = 0; i < sel.length; i++) {
			selx = xPageX(sel[i]);
			sely = xPageY(sel[i]);
			selw = sel[i].offsetWidth;
			selh = sel[i].offsetHeight;
			sel[i].style.visibility = (selx + selw > x && selx < x + w && sely + selh > y && sely < y + h) ? "hidden" : "visible";
		}
	}
}

// deletes leading and trailing spaces in a string - adds the function directly to the String Object, so that all strings inherit this method
String.prototype.trim = function() {
    return this.replace(/(^\s*)|(\s*$)/g, '');
}

function checkEmail(val) {
	if (val) {
		var usr = "([a-zA-Z0-9][a-zA-Z0-9_.-]*|\"([^\\\\\x80-\xff\015\012\"]|\\\\[^\x80-\xff])+\")";
		var domain = "([a-zA-Z0-9][a-zA-Z0-9._-]*\\.)*[a-zA-Z0-9][a-zA-Z0-9._-]*\\.[a-zA-Z]{2,5}";
		var regex = "^"+usr+"\@"+domain+"$";
		var myrxp = new RegExp(regex);
		var check = (myrxp.test(val));
		if (check!=true) {
			return false;
		}
		else {
			return true;
		}
	}
}

/*printjob*/
function printjob() {
	if (document.all && (navigator.appVersion.indexOf("Mac") != -1)) {
		self.focus();
		alert("Drucken-Funktion unter Macintosh nicht moeglich! \nBitte verwenden Sie Datei/Drucken");
	} else {
		if (document.all && navigator.appVersion.substring(22,23)==4) {
			self.focus();
			var OLECMDID_PRINT = 6;
			var OLECMDEXECOPT_DONTPROMPTUSER = 2;
			var OLECMDEXECOPT_PROMPTUSER = 1;
			var WebBrowser = '<object id="WebBrowser1" width="0" height="0" classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2"></object>';
			document.body.insertAdjacentHTML('beforeEnd',WebBrowser);
			WebBrowser1.ExecWB(OLECMDID_PRINT,OLECMDEXECOPT_DONTPROMPTUSER);
			WebBrowser1.outerHTML = '';
		} else{
			self.focus();
			window.print();
		}
	}
}


function js_search_submit() {
	search_ok = false;
	obj = document.getElementById('form_search_words');
	obj.value = 'nicht aktiv'
	return false;
	if (obj){
		if (js_trim(obj.value).length>0) {
			search_ok = true;
		}
	}
	if (search_ok){
		return true;
	}
	else {
		obj.focus();
		return false;
	}
}


function popup(url,typ,para1,width,height)
{
	attrib = "";
	Y = (screen.height - width) / 2;
	X = (screen.width - height) / 2;
	X = Math.round(X);
	Y = Math.round(Y);
	if (para1 == 'CENTER') {attrib += 'height=' + height + ',width=' + width + ',top=' + Y + ',left=' + X;}
	if (typ == 'TYP1') {attrib += ",scrollbars=no";}
	if (typ == 'TYP2') {attrib += ",scrollbars=yes";}
	if (typ == 'TYP3') {attrib += ",scrollbars=yes,menubar=yes";}
	x = Math.random();
	fenster = window.open(url, 'win', attrib);
	return false;
}

function js_popup_image(image, image_width, image_height) {
	window_width = image_width + 'px';
	window_height = image_height + 'px';
	window.open(image,'_blank','location=no,menubar=no,resizable=no,status=no,toolbar=no,dependent=yes,scrollbars=yes,width=' + window_width + ',height=' + window_height);
}

function judf_link_gifchange(obj,over){
	
	if (obj){
		obj_img = obj.getElementsByTagName('IMG')[0];
		file = obj_img.src;
		tmp_img= new Image();
		if (over){
			tmp_img.src = file.replace(/2*\.gif/,'2.gif');
		}else{
			tmp_img.src = file.replace(/2*\.gif/,'.gif');
		}
		obj_img.src = tmp_img.src;
	}
}
// Leerzeichen hinten und vorne bei einem String Objekt wegschneiden
function trim(string) {
	return string.replace(/^\s*|\s*$/,'');
}

function checkEmail(val) {
	if (val) {
		var usr = "([a-zA-Z0-9][a-zA-Z0-9_.-]*|\"([^\\\\\x80-\xff\015\012\"]|\\\\[^\x80-\xff])+\")";
		var domain = "([a-zA-Z0-9][a-zA-Z0-9._-]*\\.)*[a-zA-Z0-9][a-zA-Z0-9._-]*\\.[a-zA-Z]{2,5}";
		var regex = "^"+usr+"\@"+domain+"$";
		var myrxp = new RegExp(regex);
		var check = (myrxp.test(val));
		if (check!=true) {
			return false;
		}
		else {
			return true;
		}
	}
}

/*
validates formfields if they have a value or not
to check for other options do the following
specialfields = new Object();
specialfields.fieldname = new Object();
specialfields.fieldname.check1 = 'function_to_call,error_message';
specialfields.fieldname.check2 = 'second_function_to_call,second_error_message';
specialfields.another_fieldname = new Object();
specialfields.another_fieldname.check1 = 'function_to_call,error_message';
*/
function validateForm(form,specialfields) {
	var errors = new Array();
	var fields = form.getElementsByTagName('label');
	for (i = 0; i < fields.length; i++) {
		var span = fields[i].getElementsByTagName('span')[0];
		if (span) {
			var label = span.firstChild.data;
			label = label.trim();
			// if there is a '*' in the label - this indicates the inputfield has to be filled
			if (label.charAt(label.length - 1) == '*'){
                                label = label.substring(0, label.length - 1).trim();
				// get the inputfield
				var obj_input = fields[i].getElementsByTagName('input');
				if (!obj_input[0])
					obj_input = fields[i].getElementsByTagName('select');
				if (!obj_input[0])
					obj_input = fields[i].getElementsByTagName('textarea');

				// if there is an inputfield
				if (obj_input && obj_input[0]) {
					input = obj_input[0];
					error = false;
					
					// check if the inputfield has a value
					if (!input.value || input.value.trim().length==0) {
						error = true;
						errors.push(label + ' nicht eingegeben');
					}
					
					// check the inputfield for special things (email, ...)
					if (!error && specialfields[input.name]){
						specialfield = specialfields[input.name];
						for (check in specialfield){
							check_function = specialfield[check].split(',')[0];
							check_message = specialfield[check].split(',')[1];
							if (!eval(check_function)(input.value)){
								error = true;
								errors.push(label + ' ' + check_message);
							}
						}
					}
		            
					// on error give the label the className 'error' otherwise delete the className 'error' (if exists)
					if (error){
						className = fields[i].className;
						if (className.length>0){
							className = className + ' ';
						}
						fields[i].className = className + 'error';
					} else {
		            	className = fields[i].className;
		                if (className.indexOf('error')>-1){
							className = className.replace(' error', '');
							className = className.replace('error', '');
							fields[i].className = className;
						}
		            }
				}
			}
		}
	}
    return errors;
}

function showFormErrors (errors) {
	error_message = '';
	for (i=0;i<errors.length;i++){
		error_message += errors[i] + '\n';
	}
	alert(error_message);
}
	
function gallery_open(galleryurl) {
    standardWidth = 500;
    standardHeight = 400;
    optionstring = 'width=' + standardWidth + ',height=' + standardHeight + ',resizable=yes';
    window.open(galleryurl,'gallery',optionstring);
}


/*
             \|/
            .-*-
           / /|\
          _L_
        ,"   ".
    (\ /  O O  \ /)
     \|    _    |/
       \  (_)  /
       _/.___,\_
     (_/ doom  \_)
         ready, the end is near
*/

	var doomreadywaiter = window.setInterval(function() {
		if (document.body && document.getElementById('content')) {
			window.clearInterval(doomreadywaiter);
			doomready();
		}
	}, 1000);
	function doomready() {
		init_nav();
	} 
