function swapImage(imageToChangeID, imageSRC)
{
    //  Swap image
    var imageToSwap
    imageToSwap = document.getElementById(imageToChangeID);
    
    imageToSwap.src = imageSRC;
}

function swapInnerHTML(elementID, newText)
{
    //  Swap inner HTML
    var element
    element = document.getElementById(elementID);
    
    element.innerHTML = newText;
}

function swapHref(elementID,newHref)
{
    var element
    element = document.getElementById(elementID);
    element.href = newHref;
}

function swapTitle(elementID,newTitle)
{
    var element
    element = document.getElementById(elementID);
    element.title = newTitle;
}


function inputStyle(inputID)
{
    //  Change style
    var inputBox
    inputBox = document.getElementById(inputID);

    if (inputBox.className == "inputOver")
    {
        inputBox.className = "inputOut";
    }
    else
    {
        inputBox.className = "inputOver";
    }
}  


function changeStyle(elementID,cssClass)
{
    //  Change style
    var element
    element = document.getElementById(elementID);

    element.className = cssClass;
}  
 
function changeStyle2(topElementID,elementID,cssClass)
{
    //  Change style
    var topElement
    topElement = document.getElementById(topElementID);
    var element
    element = document.getElementById(elementID);
    
    for(var i=0;i<topElement.childNodes.length;i++)
    {
        var link
        link = topElement.childNodes[i];
        if (link.childNodes.length>0)
            link.childNodes[0].className = "";
    }

    element.className = cssClass;
}   

function show(elementID)
{
    var element
    element = document.getElementById(elementID);
    element.style.display = "block";
}

function hide(elementID)
{
    var element
    element = document.getElementById(elementID);
    element.style.display = "none";
}

function showHide(elementID)
{
    // Show or hide an element
    var element
    element = document.getElementById(elementID);
    
    if (element.style.display == "block")
    {
        element.style.display = "none";;
    }
    else
    {
        element.style.display = "block";;
    }
}

function showHide2(elementID)
{
    // Show or hide an element
    var element
    element = document.getElementById(elementID);
    
    if (element.style.display == "none")
    {
        element.style.display = "block";;
    }
    else
    {
        element.style.display = "none";;
    }
}

function confirmMsg(message)
{
    // Show a confirmation message
    
    if (confirm(message))
        return true;
    else
        return false;
}

function onClickMenu(elementID)
{
    var justChanged = true;
    var menu;
    menu = document.getElementById(elementID);
    
    if (menu.style.display == "block")
    {
        menu.style.display = "none";
    }
    else
    {
        menu.style.display = "block";
    }
    
    menu.offclick = function(e)
    {
      if (!justChanged)
      {
        // Hide dropdown                                                                       
        menu.style.display = "none";
        
        removeEventBase(document, 'click', this.offclick, menu.id);
      }
      else
      {                               
        justChanged = false;
      }
    }.bind(menu);

    addEventBase(document, 'click', menu.offclick, menu.id);
}

function addEventBase(obj, type, fn, name_hash)
{
	if (obj.addEventListener)
		obj.addEventListener( type, fn, false );
	else if (obj.attachEvent)
	{
                obj["e"+type+fn+name_hash] = fn;
		obj[type+fn+name_hash] = function() { obj["e"+type+fn+name_hash]( window.event ); }
		obj.attachEvent( "on"+type, obj[type+fn+name_hash] );
          
	}
}

function search(elementID)
{
    var element
    element = document.getElementById(elementID);
    
    if (element.value == "Search")
        element.value = "";
    else if (element.value == "")
        element.value = "Search";
}

function correctPNG() // correctly handle PNG transparency in Win IE 5.5 & 6.
{
   var arVersion = navigator.appVersion.split("MSIE")
   var version = parseFloat(arVersion[1])
   if ((version >= 5.5) && (document.body.filters)) 
   {
      for(var i=0; i<document.images.length; i++)
      {
         var img = document.images[i]
         var imgName = img.src.toUpperCase()
         if (imgName.substring(imgName.length-3, imgName.length) == "PNG" && imgName.indexOf("GOOGLE") < 0)
         {
            var imgID = (img.id) ? "id='" + img.id + "' " : ""
            var imgClass = (img.className) ? "class='" + img.className + "' " : ""
            var imgTitle = (img.title) ? "title='" + img.title + "' " : "title='" + img.alt + "' "
            var imgStyle = "display:inline-block;" + img.style.cssText 
            if (img.align == "left") imgStyle = "float:left;" + imgStyle
            if (img.align == "right") imgStyle = "float:right;" + imgStyle
            if (img.parentElement.href) imgStyle = "cursor:hand;" + imgStyle
            var strNewHTML = "<span " + imgID + imgClass + imgTitle
            + " style=\"" + "width:" + img.width + "px; height:" + img.height + "px;" + imgStyle + ";"
            + "filter:progid:DXImageTransform.Microsoft.AlphaImageLoader"
            + "(src=\'" + img.src + "\', sizingMethod='scale');\"></span>" 
            img.outerHTML = strNewHTML
            i = i-1
         }
      }
   }    
   //alphaBackgrounds();
}
function alphaBackgrounds(){
    if (navigator.platform == "Win32" && navigator.appName == "Microsoft Internet Explorer" && window.attachEvent)
    {
        var rslt = navigator.appVersion.match(/MSIE (\d+\.\d+)/, '');
        var itsAllGood = (rslt != null && Number(rslt[1]) >= 5.5);
        for (i=0; i<document.all.length; i++){
            var bg = document.all[i].currentStyle.backgroundImage;
            if (itsAllGood && bg && bg.toUpperCase().indexOf("TRANSPARENTGRAD") < 0){
                if (bg.match(/\.png/i) != null){
                    var mypng = bg.substring(5,bg.length-2);
                    document.all[i].style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+mypng+"', sizingMethod='scale')";
                    document.all[i].style.backgroundImage = "url('/templates/enjoyability/images/layout/spacer.gif')";
                }
            }
        }
    }
}
if (window.addEventListener) //DOM method for binding an event
    window.addEventListener("load", correctPNG, false);
//else if (window.attachEvent) //IE exclusive method for binding an event
    //window.attachEvent("onload", correctPNG)
else if (window.attachEvent) //support older modern browsers
{
    //window.onload=correctPNG;
    window.attachEvent("onload", correctPNG);
    //window.attachEvent("onload", alphaBackgrounds);
}

function positionBox(boxID,e)
{
    var box;
    box = document.getElementById(boxID);
        
    var obj2 = document.getElementById("box");
    // Find the content offsetTop and offsetLeft relative to the BODY tag.
    var objLeft   = obj2.offsetLeft;
    var objTop    = obj2.offsetTop;
    var objParent = obj2.offsetParent;
    while(objParent.tagName.toUpperCase() != 'BODY') {
        objLeft  += objParent.offsetLeft;
        objTop -= objParent.offsetTop;
        objParent = objParent.offsetParent;
    }    
    
    var leftX;
    var topY;
    leftX = e.clientX - objLeft + 40;
    topY = e.clientY - objTop;
    
    if (leftX > 350)
    {
        var img;
        img = document.getElementById("preview");
        leftX = leftX - 100 - img.width;
        box.style.left = leftX +"px";
    }
    else
        box.style.left = leftX +"px";
    
    box.style.position = "absolute";
    box.style.top = topY +"px";
}



function countCharacters(elementID,charactersAllowed,e)
{
    var element;
    var keyCode;
    
    element = document.getElementById(elementID);
    
    // Look for a label that can be written to so we can show how many characters have been typed
    var lblResult;
    lblResult = document.getElementById(elementID+"_Result");
    if (lblResult != null)
    {
        var count = element.value.length;
        if (element.value == "")
            count = 0;
        lblResult.innerHTML = "("+ count +"/"+ charactersAllowed +")";
    }

    if (window.event)
        keyCode = window.event.keyCode;
    else
        keyCode = e.which; 

    if (count > charactersAllowed)
    {
        element.className = "inputError";
        return false;
    }
    
    element.className = "inputOver";

    return true;
}