
// Daniel Crowe - ie5.0 doesn't provide decodeURIComponent, so here's the replacement
function myDecodeUriComponent (msg)
{
	regex = /(.*)%(..)(.*)/;
	
	while (r = regex.exec (msg))
	{
		ch = String.fromCharCode (parseInt (r[2], 16));
		msg = r [1] + ch + r [3];
	}
	
	return msg;
}

if (typeof (decodeURIComponent) == "undefined")
	decodeURIComponent = myDecodeUriComponent;

/***********************************************
* AnyLink Drop Down Menu- © Dynamic Drive (www.dynamicdrive.com)
* This notice MUST stay intact for legal use
* Visit http://www.dynamicdrive.com/ for full source code
***********************************************/

var menuwidth='141px';//'165px'; //default menu width
var disappeardelay=250;  //menu disappear speed onMouseout (in miliseconds)
var hidemenu_onclick="yes"; //hide menu when user clicks within menu?
var clearParent=0; // should the menu be horizontally contained within the link's parent box?

/////No further editting needed

var ie4=document.all;
var ns6=document.getElementById&&!document.all;
var macie = document.all && !window.print;

var currentMenu = null;
var prevClassName = null;

if (ie4||ns6)
  //document.write('<div id="dropmenudiv" style="visibility:hidden;position:absolute;width:'+menuwidth+';" onMouseover="clearhidemenu()" onMouseout="dynamichide(event)"></div>')
  document.write('<div id="dropmenudiv" onMouseover="clearhidemenu()" onMouseout="dynamichide(event)"></div>')
    
function getposOffset(what, offsettype){
  var totaloffset=(offsettype=="left")? what.offsetLeft : what.offsetTop;
  var parentEl=what.offsetParent;
  while (parentEl!=null){
    totaloffset=(offsettype=="left")? totaloffset+parentEl.offsetLeft : totaloffset+parentEl.offsetTop;
    parentEl=parentEl.offsetParent;
  }
  return totaloffset;
}

function showhide(obj, e, visible, hidden, menuwidth){
  
  if (ie4||ns6) {
    dropmenuobj.style.left=-500;
    dropmenuobj.style.top=-500;
  }

  if (menuwidth!=""){
    dropmenuobj.widthobj=dropmenuobj.style;
    //dropmenuobj.widthobj.width=menuwidth
  }

  if (e.type=="click" && obj.visibility==hidden || e.type=="mouseover")
    obj.visibility=visible;
  else if (e.type=="click")
    obj.visibility=hidden;
}

function iecompattest(){
  return (document.compatMode && document.compatMode!="BackCompat")? document.documentElement : document.body
}

function clearbrowseredge(obj, whichedge){
  var edgeoffset=0
  if (whichedge=="rightedge")
{
    var windowedge=ie4 && !window.opera? iecompattest().scrollLeft+iecompattest().clientWidth-15 : window.pageXOffset+window.innerWidth-15
    dropmenuobj.contentmeasure=dropmenuobj.offsetWidth
    if (windowedge-dropmenuobj.x < dropmenuobj.contentmeasure)
      edgeoffset=dropmenuobj.contentmeasure-obj.offsetWidth;
  }
  else
{
    var topedge=ie4 && !window.opera? iecompattest().scrollTop : window.pageYOffset
    var windowedge=ie4 && !window.opera? iecompattest().scrollTop+iecompattest().clientHeight-15 : window.pageYOffset+window.innerHeight-18
    dropmenuobj.contentmeasure=dropmenuobj.offsetHeight
    if (windowedge-dropmenuobj.y < dropmenuobj.contentmeasure)
{ //move up?
      edgeoffset=dropmenuobj.contentmeasure+obj.offsetHeight
if ((dropmenuobj.y-topedge)<dropmenuobj.contentmeasure) //up no good either?
  edgeoffset=dropmenuobj.y+obj.offsetHeight
    }
  }

  return edgeoffset;
}

// Daniel Crowe - make right hand menu adjust left, so it doesn't stick out
function clearParentEdge(obj)
{
  var edgeoffset = 0;

  if (clearParent)
  {
    var contentmeasure = dropmenuobj.offsetWidth;
    
    if (obj.offsetLeft + contentmeasure > obj.parentNode.offsetLeft + obj.parentNode.offsetWidth)
      edgeoffset = obj.offsetLeft + contentmeasure - obj.parentNode.offsetWidth - obj.parentNode.offsetLeft;
  }
  
  return edgeoffset;
}

function populatemenu(what){
  if (ie4||ns6)
    // dropmenuobj.innerHTML=what.join("")
    dropmenuobj.innerHTML=decodeURIComponent (what); // Daniel Crowe - use urlencoded string instead of an array
}

function dropdownmenu(obj, e, menucontents, /*menuwidth,*/ newClass){
  if (macie) return; // Daniel Crowe 060608 menu doesn't work in macIE
  if (menucontents.length == 0 || obj != currentMenu) { hidemenu (); }
    
  clearhidemenu();

  // Daniel Crowe - adjust class of button, so we set its appearance in css
  if (obj != currentMenu || obj == null) {
    currentMenu = obj;
    prevClassName = currentMenu.className;
    currentMenu.className = newClass;
  }

  if (menucontents.length == 0) { return; }

  menuwidth = menuwidth== null? obj.offsetWidth : menuwidth;
  dropmenuobj=document.getElementById? document.getElementById("dropmenudiv") : dropmenudiv
  populatemenu(menucontents)
  
  if (ie4||ns6){
    showhide(dropmenuobj.style, e, "visible", "hidden", menuwidth);
    
    dropmenuobj.x=getposOffset(obj, "left");
    dropmenuobj.y=getposOffset(obj, "top");

    var redgeAdjust = clearbrowseredge(obj, "rightedge");
    if (redgeAdjust == 0) redgeAdjust = clearParentEdge(obj);
    dropmenuobj.style.left=dropmenuobj.x-redgeAdjust+"px";
		dropmenuobj.style.top=dropmenuobj.y-clearbrowseredge(obj, "bottomedge")+obj.offsetHeight+"px"
  }
  
  return clickreturnvalue()
}

function clickreturnvalue(){
  if (ie4||ns6) return false
  else return true
}

function contains_ns6(a, b) {
  while (b.parentNode)
    if ((b = b.parentNode) == a)
      return true;
  return false;
}

function dynamichide(e){
  if (ie4&&!dropmenuobj.contains(e.toElement))
    delayhidemenu()
  else if (ns6&&e.currentTarget!= e.relatedTarget&& !contains_ns6(e.currentTarget, e.relatedTarget))
    delayhidemenu()
}

function hidemenu(e){
  if (currentMenu!=null && (ie4||ns6)) {
    currentMenu.className = prevClassName;
    currentMenu = null;
  }
  
  if (typeof dropmenuobj!="undefined"){
    dropmenuobj.style.visibility="hidden";
  }
}

function delayhidemenu(){
  if (macie) return; // Daniel Crowe 060608 menu doesn't work in macIE

  if (ie4||ns6)
    delayhide=setTimeout("hidemenu()",disappeardelay);
}

function clearhidemenu(){
  if (typeof delayhide!="undefined")
  clearTimeout(delayhide);
}

if (hidemenu_onclick=="yes")
  document.onclick=hidemenu;