var _subMenuTimeout;
var _visibleMenu;
function LoadMenu()
{   
	/*Les spans qui ont un id dans la page sont des zones pour les menus*/
	var spans = document.getElementById("divMainMenu").getElementsByTagName("DIV");
	for( var nIdx=0; nIdx < spans.length; nIdx++ )
	{
		if( spans[nIdx].id != "" )
		{
			spans[nIdx].onmouseover = OnMainMenuItemMouseOver;
			spans[nIdx].onmouseout = OnMainMenuItemMouseOut;

            var submenu = document.getElementById(spans[nIdx].id + "Menu");
            if( submenu )
            {
                submenu.parentmenu = null;
                spans[nIdx].menu = submenu;
            }
		}
	}

    /*Assignation des événements des items des menu principaux*/
    var menu = document.getElementById("divSubMenus").childNodes;
    for( nIdx=0; nIdx<menu.length; nIdx++ )
    {
        if( menu[nIdx].tagName == "DIV" )
        {
            for( var nIdx2=0; nIdx2<menu[nIdx].childNodes.length; nIdx2++ )
            {
                var menuItem = menu[nIdx].childNodes[nIdx2];
    
                var submenu = document.getElementById(menuItem.id + "Menu");
                if( submenu != null )
                {
                    submenu.parentmenu = menu[nIdx];
                    menuItem.menu = submenu;
                }
                else
                {
                    menuItem.menu = null;
                }
    
                menuItem.onmouseover = OnSubMenuItemMouseOver;
                menuItem.onmouseout = OnSubMenuItemMouseOut;
                menuItem.onclick = OnSubMenuItemClick;
            }
        }
    }
}

function OnMainMenuItemMouseOver( evt )
{
	
	var div = GetEventObject( evt );
    while( div != null && div.tagName != "DIV" )
        div = div.parentNode;
    
    if( div != null )
    {
        div.className = "MainMenuItemSelected"
    
    	//Afficher le sous-menu correspondant s'il y a lieu
    	HideSubMenu();
    	//MM_swapImage(div.id,'', div.src.replace("off", "on") ,1);
    	div.style.color = "#FFFFFF";
        if( div.menu )
    	{
    	    div.menu.style.display = "block";
            div.menu.style.left = Number(getRealLeft( div ) - 2) + 'px';
            
            if(navigator.platform == "MacPPC")
            {
                div.menu.style.top = Number(getRealTop( div ) + div.offsetHeight + 7) + 'px';
            }
            else
            {
        	    div.menu.style.top = Number(getRealTop( div ) + div.offsetHeight + 5) + 'px';
        	}
        	
            _visibleMenu = div.menu;
    	
    	    /*
            div.menu.style.position = "absolute";
            if(navigator.platform == "MacPPC")
            {
                //Workaround pour Mac.
                //Il y a un bug en Mac, parce que le menu est dans un tableau, celui-ci
                //est traite comme relatif au lieu d'absolu, on doit donc faire la calcul
                //comme si le menu etait positionne de facon relative au tableau.            
                var tblMain = document.getElementById("tblMain");
                div.menu.style.left = ((getRealLeft( div )) - getRealLeft( tblMain ) + 5) + 'px';
                div.menu.style.top = (getRealTop( div ) - 11) + 'px';
            }
            else
            {
                div.menu.style.left = (getRealLeft( div ) - 2) + 'px';
    		    div.menu.style.top = Number(getRealTop( div ) + div.offsetHeight ) + 'px';   		
            }
            
            div.menu.style.display = "block";
            _visibleMenu = div.menu;
            */
    	}
    }
}

function OnMainMenuItemMouseOut( evt )
{
	var div = GetEventObject( evt );
    while( div != null && div.tagName != "DIV" )
        div = div.parentNode;
	
    if( div != null )
    {
        //if(div.menu == null)
            //MM_swapImgRestore();
        
        div.className = "MainMenuItem";
    }
    
    _subMenuTimeout = setTimeout( "HideSubMenu()", 2000 );
}

function HideSubMenu()
{
    clearTimeout(_subMenuTimeout );
    while( _visibleMenu != null )
    {
        _visibleMenu.style.display = "none";
        
        var menu = document.getElementById(_visibleMenu.id.replace("Menu",""));
        if( menu != null)
            menu.style.color = "#E3A842";
        
        _visibleMenu = _visibleMenu.parentmenu;
        
        
    }
    
    //MM_swapImgRestore();
    //div.style.color = "#E3A844";
}

function OnSubMenuItemMouseOver( evt )
{
	var div = GetEventObject( evt );
	while( div != null && div.tagName != "DIV" )
		div = div.parentNode;

	if( div != null )
	{
        //si le menu de l'item est différent du menu affiché
        //on cache le menu affiché.
        if( _visibleMenu != null && div.parentNode != _visibleMenu )
        {
            _visibleMenu.style.display = "none";
            _visibleMenu = div.parentNode;
        }
        
        clearTimeout(_subMenuTimeout );
        div.className = "subMenuSelectedItem";

        //Si l'item a un sous menu, on l'affiche
        if( div.menu != null )
        {
            div.menu.style.display = "block";
            
            if(navigator.platform == "MacPPC")
            {
                div.menu.style.left = Number(getRealLeft( div ) + div.offsetWidth - 4) + 'px';
                div.menu.style.top = Number(getRealTop( div ) - 3) + 'px'
            }
            else
            {
                div.menu.style.left = Number(getRealLeft( div ) + div.offsetWidth) + 'px'
                div.menu.style.top = Number(getRealTop( div )) + 'px'
            }
                
            _visibleMenu = div.menu;
            
            /*
            div.menu.style.position = "absolute";
            if(navigator.platform == "MacPPC")
            {
                //Workaround pour Mac.
                //Il y a un bug en Mac, parce que le menu est dans un tableau, celui-ci
                //est traite comme relatif au lieu d'absolu, on doit donc faire la calcul
                //comme si le menu etait positionne de facon relative au tableau.            
                var tblMain = document.getElementById("tblMain");
                div.menu.style.left = ((getRealLeft( div ) + div.offsetWidth) - getRealLeft( tblMain ) - 1) + 'px';
                div.menu.style.top = (getRealTop( div ) - 43) + 'px';
            }
            else
            {
                div.menu.style.left = (getRealLeft( div ) + div.offsetWidth) + 'px'
                div.menu.style.top = getRealTop( div ) + 'px' 		
            }
            
            div.menu.style.display = "block";
            _visibleMenu = div.menu;
            */
        }
	}
}

function OnSubMenuItemMouseOut( evt )
{
    clearTimeout(_subMenuTimeout );
	var div = GetEventObject( evt );
	if( div != null && div.tagName == "A" )
		div = div.parentNode;

	if( div != null )
	{
		div.className = "subMenuItem";
		_subMenuTimeout = setTimeout( "HideSubMenu()", 2000 );
	}
}

function OnSubMenuItemClick ( evt )
{
    var objClicked = GetEventObject( evt );
	while( objClicked != null && objClicked.tagName != "DIV" && objClicked.tagName != "A" )
		objClicked = objClicked.parentNode;
            
    if( objClicked != null && objClicked.tagName != "A" )
    {
        var lnk = objClicked.getElementsByTagName("A");
        if( lnk != null && lnk.length > 0 );
            window.location.href = lnk[0].href;
    }
}

// To swap the image in the nav according to the actual section where in.

function changeImages()
{	
	var el = getElementsByClass('selected');
	for (var i=0; i < el.length; i++)
	{
		var image = el[i].firstChild;
		var source = image.getAttribute("src").split(".gif");
		var newSource = source[0] + "-down.gif";
		image.setAttribute("src", newSource);
	}
}

function MM_swapImgRestore() 
{ //v3.0
  var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;
}

function MM_findObj(n, d) 
{ //v4.01
  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
  if(!x && d.getElementById) x=d.getElementById(n); return x;
}

function MM_swapImage() 
{ //v3.0
  var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)
   if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}
}