var MAINWIDTH	= 975;
var MAINPADDING	= 45
var DDSPEED	= 2; // animation speed, the greater the slower
var IMMEDOUT	= false; // true would apply delay on hiding of menu
var IMMEDDISP	= false; // false would apply delay on display
var OPAQUE	= true;
var HSTICKY	= 0;
var DDTIMER	= 5;
var maxHeight	= 377;
var hoverClsAdded;

// main function to handle the mouse events //
function ddMenu(id,d){
  window.hoverClsAdded	= false;
  //~ $('#flash_menu').html('&nbsp;');
  //if (holdFlash) {eval(clearFlash);}
  var h = document.getElementById(id + '-ddheader');
  var c = document.getElementById(id + '-ddcontent');

  clearInterval(c.timer);
  if(d == 1){
    clearTimeout(h.timer);
      c.style.display = 'block';
    if(c.maxh && c.maxh <= c.offsetHeight){return}
    else if(!c.maxh){
      c.style.height = 'auto';
      c.maxh = (c.offsetHeight > maxHeight ? c.offsetHeight : maxHeight);
      c.style.height = '0px';
    }
    if (IS_CLIENT_BROWSER_IE6) $('#divKonfigurator').hide();
    c.timer = setInterval(function(){ddSlide(c,1)},DDTIMER);
  }else{
      h.timer = setTimeout(function(){ddCollapse(c)},50);
  }

}

// collapse the menu //
function ddCollapse(c){
	if (window.IMMEDOUT) {
		c.style.display = 'none';
		c.style.height = '0px';
		c.offsetHeight = 0;
		c.style.opacity = 0;
		c.style.filter = 'alpha(opacity=0)';
		if (IS_CLIENT_BROWSER_IE6) $('#divKonfigurator').show();
		$('#mnuLnk1').removeClass('hoverMnuLnk1');
	} else {
		c.timer = setInterval(function(){ddSlide(c,-1)},DDTIMER);
	}
	//if (holdFlash) {eval(window.restoreFlash);}
}

// cancel the collapse if a user rolls over the dropdown //
function cancelHide(id){
  var h = document.getElementById(id + '-ddheader');
  var c = document.getElementById(id + '-ddcontent');
  clearTimeout(h.timer);
  clearInterval(c.timer);
  if(c.offsetHeight < c.maxh){
    c.timer = setInterval(function(){ddSlide(c,1)},DDTIMER);
  }
  $('#mnuLnk1').addClass('hoverMnuLnk1');
}

// incrementally expand/contract the dropdown and change the opacity //
function ddSlide(c,d){
  if (window.IMMEDDISP) {
    var currh = window.HSTICKY;
  } else {
    var currh = c.offsetHeight;
  }
  var dist;
  if(d == 1){
    if (c.offsetWidth > 0) $(c).css('margin-left', ((window.MAINWIDTH - c.offsetWidth - window.MAINPADDING) + 2));
    dist = (Math.round((c.maxh - currh) / DDSPEED));
  }else{
    dist = (Math.round(currh / DDSPEED));
  }
  if(dist <= 1 && d == 1){
    dist = 1;
  }
  if (d == 1 && window.IMMEDDISP) {
    c.style.height = c.maxh + 'px';
    window.HSTICKY = currh + (dist * d);
  } else {
    c.style.height = currh + (dist * d) + 'px';
  }
  if (OPAQUE) {
	c.style.opacity = 1;
	c.style.filter = 'alpha(opacity=100)';
  } else {
	c.style.opacity = currh / c.maxh;
	c.style.filter = 'alpha(opacity=' + (currh * 100 / c.maxh) + ')';
  }
  if(currh < 2 && d != 1){
    // Menu is completely hidden
    clearInterval(c.timer);
    window.HSTICKY	= 0;
    if (d == -1 && IS_CLIENT_BROWSER_IE6) $('#divKonfigurator').show();
    $('#mnuLnk1').removeClass('hoverMnuLnk1');
  }
  if(currh > (c.maxh - 2) && d == 1){
    // Menu is completely shown
    clearInterval(c.timer);
  }
}

/**
 * Inline code moved here.
 */
//findPos function is from http://www.quirksmode.org/js/findpos.html;
//where its workings are explained in more detail.
function findPos(obj) {
	var curleft = curtop = 0;
	if (obj.offsetParent) {
		curleft = obj.offsetLeft
		curtop = obj.offsetTop
		while (obj = obj.offsetParent) {
			curleft += obj.offsetLeft
			curtop += obj.offsetTop
		}
	}
	if (navigator.appName == 'Microsoft Internet Explorer') {
		if (IS_CLIENT_BROWSER_IE8 == false) {
			curtop  -= 5;
			curleft -= 10;
		}
	} else if (navigator.appName == 'Opera') {
		curtop  += 11;
	}
	return [curleft,curtop];
}

function display_menu(parent,named, nDown)
{
	//get the named menu
	var menu_element = document.getElementById(named);
	//override the 'display:none;' style attribute
	menu_element.style.display = "";
	//get the placement of the element that invoked the menu...
	var placement = findPos(parent);
	//...and put the menu there
	
	if (named == 'newsletterPopup') {
		// 295 is width of form body
		// 92 is width of tab head
		placement[0]	= placement[0] - 295 + 92;
	}
	
	menu_element.style.left = placement[0] + "px";
	if (nDown) {
		menu_element.style.top = (placement[1] + nDown) + "px";
	} else {
		menu_element.style.top = placement[1] + "px";
	}
	
	if (named == 'loginPopup') {
		$('#loginEmail').focus();
	}
}

function slideDown_menu(parent,named, nDown)
{
	var menu_element = document.getElementById(named);
	var placement = findPos(parent);
	menu_element.style.left = placement[0] + "px";
	if (nDown) {
		menu_element.style.top = (placement[1] + nDown) + "px";
	} else {
		menu_element.style.top = placement[1] + "px";
	}
	
	$('#' + named).slideDown();
}

//Hide menu
function hide_menu(named)
{
	var menu_element = document.getElementById(named);
	menu_element.style.display = "none";
}

function hide_other_menu()
{
	document.getElementById('mnu1').style.display			= "none";
	document.getElementById('menu1').style.display			= "none";
	
	document.getElementById('mnuLoginPopup').style.display		= "none";
	document.getElementById('loginPopup').style.display		= "none";
	
	document.getElementById('mnuNewsletterPopup').style.display	= "none";
	document.getElementById('newsletterPopup').style.display	= "none";
}

// eof
