
/*
// thanks to www.boutell.com 
function playSound(soundname) {
 var sound = eval("document." + soundname);

 // make an effort to stop and rewind any playback
 // already in progress so that the sound starts over.
 // Otherwise this call has no effect when the sound
 // is already in progress. You can remove these lines
 // if you don't like this behavior.
 //try {
  sound.Stop();
  sound.Rewind();
 //} catch (e) {
  // A player that doesn't support
  // Stop and Rewind
 //}

// try {
  // For RealPlayer-enabled browsers.
  // Some versions of RealPlayer do not
  // offer a Play() function and will
  // fail to play sound if we try to
  // call Play().
 // sound.DoPlay();
 //} catch (e) {
  // If DoPlay doesn't work, call Play.
  // This works for all other audio
  // plug-ins.
  sound.Play();
 //}
}

function doClick (url)
{
  playSound ('menusound');
  window.location.replace (url);
  return false;
}
*/

// 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?
var menuId="menu";

/////No further editting needed

var ie4=document.all;
var ns6=document.getElementById&&!document.all;
var currentMenu = 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" style="visibility:hidden;position:absolute;" 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=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
    }
  }
//   alert (edgeoffset);
  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=what; // Daniel Crowe - just use string instead of an array
}

function dropdownmenu(obj, e, menucontents, /*menuwidth,*/ newClass){
  if (menucontents.length == 0) { hidemenu (); }

  // Daniel Crowe 10/4/6 - menucontents is now passed in url encoded form to ease problems with quote marks
  menucontents = decodeURIComponent (menucontents);
  
  // Daniel Crowe - adjust class of menu, so we set its appearance in css
  menuBar = document.getElementById (menuId);
  if (menuBar != null) menuBar.className = newClass;

  clearhidemenu()
  currentMenu = obj;

  if (menucontents.length == 0) { return; }

//  	  prevClassName = currentMenu.className;
//      currentMenu.className='selectedItem';

  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 (typeof dropmenuobj!="undefined"){
//        if (currentMenu!=null && (ie4||ns6))
//          currentMenu.className= prevClassName;
    dropmenuobj.style.visibility="hidden"
}

  // Daniel Crowe - return menu class to "off"
  menuBar = document.getElementById (menuId);
  if (menuBar != null) menuBar.className = "off";
}

function delayhidemenu(){
  if (ie4||ns6)
    delayhide=setTimeout("hidemenu()",disappeardelay)
}

function clearhidemenu(){
  if (typeof delayhide!="undefined")
  clearTimeout(delayhide)
}

if (hidemenu_onclick=="yes")
  document.onclick=hidemenu