// 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['#fontsize td'] = new Object();
css_rules_exceptions.fontsizes['#fontsize td a'] = 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();

// 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_vals = document.cookie.split(";")[0];
	cookie_pairs_arr = cookie_vals.split(",");
	for (pair in cookie_pairs_arr){
		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(){

}

function js_onload(){
	window_loaded = true;
	
	js_nav_init();
	
	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){
		
	}
}

function js_nav_init(){
	var nav = document.getElementById('nav');
	var uls = nav.getElementsByTagName('UL');
	for(var i = 0; i < uls.length; i++){
		new xMenu1(uls[i], 'mouseover');
	}
}


function xMenu1(menu, openEvent) {
	var isOpen = false;
	if (menu){
		xAddEventListener(menu.parentNode, openEvent, onOpen, false);
	}

	function onOpen() {
		if (!isOpen) {
			js_nav_open(menu);
			xShow(menu);
			HideSelects(xPageX(menu), xPageY(menu), xWidth(menu), xHeight(menu));
			xAddEventListener(document, 'mousemove', onMousemove, false);
			isOpen = true;
		}
	}
	
	function onMousemove(ev) {
		var e = new xEvent(ev);
		contains = (xHasPoint(menu, e.pageX, e.pageY, 0,0,0,0) || xHasPoint(menu.parentNode, e.pageX, e.pageY, 0,0,0,0));
		if(!contains) {
			var submenus = menu.getElementsByTagName('UL');
			for(var i = 0; i < submenus.length; i++){
				if(xHasPoint(submenus[i], e.pageX, e.pageY, 0)) {
					contains = true;
					break;
				}
			}
		}
		if(!contains) {
			xRemoveEventListener(document, 'mousemove', onMousemove, false);
			js_nav_close(menu);
			xHide(menu);
			HideSelects(0, 0, 0, 0);
			isOpen = false;	
		}
	}
	
	function js_nav_open(menu){
		nav_hover_img_new = menu.parentNode.getElementsByTagName('A')[0].getElementsByTagName('IMG')[0];
		if (nav_hover_img && nav_hover_img != nav_hover_img_new){
			if (!nav_hover_img.onmouseout){
				nav_hover_img.onmouseout = nav_hover_img_event;
				nav_hover_img.onmouseout();
				nav_hover_img = null;
				nav_hover_img_event = null;
			}
		}
		if (nav_hover_img_new.onmouseout){
			nav_hover_img = nav_hover_img_new;
			nav_hover_img_event = nav_hover_img.onmouseout;
			nav_hover_img.onmouseout = null;
		}
	}
	
	function js_nav_close(menu){
		nav_out_img = menu.parentNode.getElementsByTagName('A')[0].getElementsByTagName('IMG')[0];
		if (nav_hover_img && nav_hover_img == nav_out_img){
			if (nav_hover_img_event){
				nav_hover_img.onmouseout = nav_hover_img_event;
				nav_hover_img.onmouseout();
				nav_hover_img = null;
				nav_hover_img_event = null;
			}
		}
	}
	
}


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 : 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";
		}
	}
}

// Leerzeichen hinten und vorne bei einem String Objekt wegschneiden
function js_trim(string) {
	return string.replace(/^\s*|\s*$/,'');
}


function js_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 MM_preloadImages() { //v3.0
  var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
    var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
    if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}

function MM_swapImgRestore() { //v3.0
  var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;
}

function MM_findObj(n, d) { //v4.01
  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
  if(!x && d.getElementById) x=d.getElementById(n); return x;
}

function MM_swapImage() { //v3.0
  var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)
   if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}
}  
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, '', 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,'','location=no,menubar=no,resizable=no,status=no,toolbar=no,dependent=yes,scrollbars=yes,width=' + window_width + ',height=' + window_height);
}
