
  /*
   * Fügt den Listeneinträgen Eventhandler und CSS Klassen hinzu,
   * um die Menüpunkte am Anfang zu schließen.
   * Zu Beginn sind alle Knoten geöffnet
   * 
   * menu: Referenz auf die Liste.
   * data: String, der die Nummern aufgeklappter Menüpunkte enthält.
   */
  function treeMenu_init(menu, data) {
    var array = new Array(0);
    if(data != null && data != "") {
      array = data.match(/\d+/g);
    }
    var items = menu.getElementsByTagName("li");
    
		if (GetFileURI(window.location.href).length == 0) {
			window.Katalogseite = "index.htm"
		}
    
	  if (window.Katalogseite) 
	  {
	  	strHrefKatalogseite = window.Katalogseite;
	  }
	  else
	  {
	  	strHrefKatalogseite = window.location.href;
	  } 
	  strHrefKatalogseite = GetFileURI(strHrefKatalogseite);
    
    for(var i = 0; i < items.length; i++) {
      items[i].onclick = treeMenu_handleClick;
      
      // A-Tag
      if (GetFileURI(window.location.href).length > 0 && items[i].innerHTML.indexOf(strHrefKatalogseite) > -1 && items[i].innerHTML.toUpperCase().indexOf("<LI>") == -1)
      {
      	// items[i].style.fontSize = "20px";
      	items[i].firstChild.style.background = "#b9c9fe";
      	items[i].firstChild.style.color = "#000000";  // Farbe Text gewaehlte Kategorie
      }
      if(!treeMenu_contains(treeMenu_getClasses(items[i]), "treeMenu_opened")
          && items[i].getElementsByTagName("ul").length
            + items[i].getElementsByTagName("ol").length > 0) {
            
        var classes = treeMenu_getClasses(items[i]);
        // if(array.length > 0 && array[0] == i && items[i].innerHTML.indexOf(GetFileURI(window.location.href)) > -1) {
        if(items[i].innerHTML.indexOf(strHrefKatalogseite) > -1) {
        	if(array.length > 0 && array[0] == i) {
        		classes.push("treeMenu_opened");
        	}
          // classes.push("treeMenu_opened");
          // items[i].firstChild.style.background = "#FF0000";
          items[i].firstChild.style.fontWeight = "bold";
        }
        else {
          classes.push("treeMenu_closed");
        }
        items[i].className = classes.join(" ");
        if(array.length > 0 && array[0] == i) {
          array.shift();
        }
      }

			// if (array.length == 0 && GetFileURI(items[i].firstChild.href) == GetFileURI(window.location.href))
			if (GetFileURI(items[i].firstChild.href) == strHrefKatalogseite)
			{
				//  #b9c9fe
				items[i].firstChild.style.background = "#b9c9fe"; 
				items[i].firstChild.style.color = "#000000";  // Farbe Text gewaehlte Kategorie
			}

    }
  }
  
  function treeMenu_init_einzelseite(menu, data) {
    var array = new Array(0);
    if(data != null && data != "") {
      array = data.match(/\d+/g);
    }
    var items = menu.getElementsByTagName("li");
    for(var i = 0; i < items.length; i++) {
      items[i].onclick = treeMenu_handleClick;
      
      // A-Tag
      if (GetFileURI(window.location.href).length > 0 && items[i].innerHTML.indexOf(Katalogseite) > -1 && items[i].innerHTML.toUpperCase().indexOf("<LI>") == -1)
      {
      	// items[i].style.fontSize = "20px";
      	items[i].firstChild.style.background = "#b9c9fe";
      	items[i].firstChild.style.color = "#000000";  // Farbe Text gewaehlte Kategorie
      }
      if(!treeMenu_contains(treeMenu_getClasses(items[i]), "treeMenu_opened")
          && items[i].getElementsByTagName("ul").length
            + items[i].getElementsByTagName("ol").length > 0) {
        var classes = treeMenu_getClasses(items[i]);
        // if(array.length > 0 && array[0] == i && items[i].innerHTML.indexOf(Katalogseite) > -1) {
        if(items[i].innerHTML.indexOf(Katalogseite) > -1) {
        	if(array.length > 0 && array[0] == i) {
        		classes.push("treeMenu_opened");
        	}
          // classes.push("treeMenu_opened");
          // items[i].firstChild.style.background = "#FF0000";
          items[i].firstChild.style.fontWeight = "bold";
        }
        else {
          classes.push("treeMenu_closed");
        }
        items[i].className = classes.join(" ");
        if(array.length > 0 && array[0] == i) {
          array.shift();
        }
      }
      
			if (GetFileURI(items[i].firstChild.href) == GetFileURI(window.location.href))
			{
				items[i].firstChild.style.background = "#b9c9fe";
				items[i].firstChild.style.color = "#000000";  // Farbe Text gewaehlte Kategorie
			}
    }
  }

  /*
   * Ändert die Klasse eines angeclickten Listenelements, sodass
   * geöffnete Menüpunkte geschlossen und geschlossene geöffnet
   * werden.
   *
   * event: Das Event Objekt, dass der Browser übergibt.
   */
  function treeMenu_handleClick(event) {
  	
    if(event == null) { //Workaround für die fehlenden DOM Eigenschaften im IE
      event = window.event;
      event.currentTarget = event.srcElement;
      while(event.currentTarget.nodeName.toLowerCase() != "li") {
        event.currentTarget = event.currentTarget.parentNode;
      }
      event.cancelBubble = true;
    }
    else {
      event.stopPropagation();
    }
    var array = treeMenu_getClasses(event.currentTarget);

		// alert(liste_knoten_links(event.currentTarget));

    for(var i = 0; i < array.length; i++) {
      if(array[i] == "treeMenu_closed") {
        array[i] = "treeMenu_opened";
      }
      else if(array[i] == "treeMenu_opened") {
        array[i] = "treeMenu_closed"
      }
    }
    event.currentTarget.className = array.join(" ");
    
  }

  /*
   * Gibt alle Klassen zurück, die einem HTML-Element zugeordnet sind.
   *
   * element: Das HTML-Element
   * return: Die zugeordneten Klassen.
   */
  function treeMenu_getClasses(element) {
    if(element.className) {
      return element.className.match(/[^ \t\n\r]+/g);
    }
    else {
      return new Array(0);
    }
  }

  /*
   * Überprüft, ob ein Array ein bestimmtes Element enthält.
   *
   * array: Das Array
   * element: Das Element
   * return: true, wenn das Array das Element enthält.
   */
  function treeMenu_contains(array, element) {
    for(var i = 0; i < array.length; i++) {
      if(array[i] == element) {
        return true;
      }
    }
    return false;
  }

  /*
   * Gibt einen String zurück, indem die Nummern aller geöffneten
   * Menüpunkte stehen.
   *
   * menu: Referenz auf die Liste
   * return: Der String
   */
  function treeMenu_store(menu) {
    var result = new Array();;
    var items = menu.getElementsByTagName("li");
    for(var i = 0; i < items.length; i++) {
      if(treeMenu_contains(treeMenu_getClasses(items[i]), "treeMenu_opened")) {
        result.push(i);
      }
    }
    return result.join(" ");
  }
  
  
  function GetPathURL (url)
	{
		url_array = url.split("/");
		url_array.pop();
		return (url_array.join("/") + "/");
	}
	
	function GetFileURL (url)
	{
		url = unescape(url);
		return url.substring(url.lastIndexOf("/") + 1,unescape(location.href).length);
	}
	
	function GetFileURI (url)
	{
		url = unescape(url);
		url = url.substring(url.lastIndexOf("/") + 1,url.length);
		if (url.indexOf("?") > -1)
		{
			url = url.substring(0, url.indexOf("?"));
		}
		return url;
	}

// mk Start ***
function liste_unterknoten (knoten) {
    var ausgabe;
    ausgabe = '<li>';
    switch (knoten.nodeType) {
        case 1 :
            ausgabe += '<strong>' + knoten.nodeName + '<\/strong>-Element';
            if (knoten.hasChildNodes()) {
                ausgabe += ', ' + knoten.childNodes.length + ' Unterknoten';
            }
            if (knoten.tagName == "A")
            {
            	ausgabe += '\n' + knoten.href;
            }
            break;
        case 3 :
            var knotenwert = knoten.nodeValue.replace(/</g, '&lt;').replace(/\n/g, '\\n');
            ausgabe += 'Textknoten: [<strong>' + knotenwert + '<\/strong>]';
            break;
        case 8 :
            var knotenwert = knoten.nodeValue.replace(/</g, '&lt;').replace(/\n/g, '\\n');
            ausgabe += 'Kommentarknoten: [' + knotenwert + ']';
            break;
        default :
            ausgabe += 'Knoten des Typs ' + knoten.nodeType +
                ', Wert: [' + knoten.nodeValue + ']';
    }
    if (knoten.hasChildNodes()) {
        ausgabe += '\n<ol>\n';
        for (var i = 0; i < knoten.childNodes.length; i++) {
            knotenneu = knoten.childNodes[i];
            ausgabe += liste_unterknoten(knotenneu); // Rekursion
        }
        ausgabe += '</ol>\n';
    }
    ausgabe += '</li>\n';
    return ausgabe;
}

function liste_knoten_links (knoten) {
    var ausgabe;
    ausgabe = '';
    switch (knoten.nodeType) {
        case 1 :
            if (knoten.tagName == "A")
            {
            	ausgabe += '<a href="' + knoten.href + '">' + knoten.getAttribute("innerHTML") + "</a>";
            }
            break;
        default :

    }
    if (knoten.hasChildNodes()) {
        for (var i = 0; i < knoten.childNodes.length; i++) {
            knotenneu = knoten.childNodes[i];
            ausgabe += liste_knoten_links(knotenneu); // Rekursion
        }
        
    }
    ausgabe += '\n';
    return ausgabe;
}

function get_href (knoten) {
    var ausgabe;
    ausgabe = '';
    switch (knoten.nodeType) {
        case 1 :
            if (knoten.tagName == "A")
            {
            	ausgabe += '<a href="' + knoten.href + '">' + knoten.getAttribute("innerHTML") + "</a>";
            }
            break;
        default :

    }

    ausgabe += '\n';
    return ausgabe;
}

  function get_link_path(menu) {
    var items = menu.getElementsByTagName("li");
    for(var i = 0; i < items.length; i++) {


        if(items[i].innerHTML.indexOf(GetFileURI(window.location.href)) > -1) {
          alert(get_href(items[i].firstChild));
        }


    }
  }
// mk End   ***


