// Michel Deboom septembre 2004 menu largeur auto,flèches txt
  var delai,menu,dul,db,class_menu;
  pause=1000;
  D=document;
  wul1=0;
  ie=D.all?1:0;
  op=window.opera?1:0;
  dtd=D.compatMode=="CSS1Compat"?1:0;
  
// paramétrage :
//correction bug padding+border ie et opéra non dtd 
da=10 // des liens
dul=(ie&!dtd)?4:0; // des ul
danc=(ie&!dtd)?10:0;// hauteur du div "ancre_menu"

function initMenu(id_menu,class_menu){

	de=ie&!op&&dtd?D.documentElement:D.body; //exception IE6 dtd
	fx=ie&!op?de.clientWidth:innerWidth-20;  //l fenêtre
	menu=D.getElementById(id_menu);
	wul=[]; // tableau des largeurs de sous-menus
	as=menu.getElementsByTagName('a');
	sousMenu=menu.getElementsByTagName('ul');
	elem=document.getElementsByTagName('select');


	//ajoute un id aux sous-menus
	for(j=0;j<sousMenu.length;j++){
		sousMenu[j].id="ul"+j;
		wul[j]=0;
	}
	
	//construction du menu :
	for(i=0;i<as.length;i++){
	    lien=as[i];
		wa=lien.offsetWidth;
	    smenu=lien.parentNode.getElementsByTagName('ul')[0]?1:0;
	    
	    if(lien.parentNode.parentNode.id==id_menu){// 1er niveau horizontal 
			if(wa>wul1){wul1=wa+da;}			
	    }
	    else {//autres niveaux verticaux
			n=eval(lien.parentNode.parentNode.id.substr(2,2));
			if(wa>wul[n]){wul[n]=wa;}
	    }
		//ajoute les évènements.
		lien.onmouseover=lien.onfocus=function(){
			ul_parent=this.parentNode.parentNode;
			ul=this.parentNode.getElementsByTagName('ul')[0];
			ef(ul_parent); // cache tout après l'ul parent
			if(ul){
				ul.style.visibility="visible";// montre l'ul enfant
		        (class_menu=="vd")?ul.style.right="100%":
		        (class_menu=="mh"&&ul_parent.id!=id_menu)||(class_menu=="vg")?ul.style.left="100%":0;
		        this.className="suivi"; // marquage du suivi de lien 
		        voirSelect('hidden'); 
			}
		}
		lien.onmouseout=function(){
			delai=setTimeout('eftout()',pause);
		}
	}

	//fixe la largeur du 1er menu :
	if(wul1)menu.style.width=wul1+dul+"px";

	//largeur des sous-menu verticaux et de leurs liens :
	for(var x=0;x<wul.length;x++){
		ula=sousMenu[x].getElementsByTagName('a');
		dda=(ie&!dtd)?da:0;
		for(var i=0;i<ula.length;i++){
			//ula[i].style.width=wul[x]+dda+"px";
			if(wul[x]>0) ula[i].style.width=wul[x]+dda+"px";
			else ula[i].style.width="150px";
		}
		//sousMenu[x].style.width=wul[x]+da+dul+"px";
		if(wul[x]>0) sousMenu[x].style.width=wul[x]+da+dul+"px";
		else sousMenu[x].style.width=150+da+dul+"px";
	}
	
	lien.onblur = D.onclick = eftout // pour navigation clavier IE
	menu.className = class_menu; //activation retardée de la feuille de style
	
	ancremenu();
}

function ancremenu(){
	ancre=D.getElementById('ancre_menu');
	if(ancre){
		ancre.appendChild(menu);
		with(ancre.style){
			height=menu.offsetHeight+danc+'px';
			width=menu.offsetWidth+dul+'px';
		}
	}
}

function ef(ul) { //cache les uls qui suivent cet ul.
	clearTimeout(delai);
	var li=ul.getElementsByTagName('li');
	for(i=0;i<li.length;i++){
	    var ul=li[i].getElementsByTagName('ul')[0];
	    if(ul){
			ul.style.visibility="hidden";
			li[i].firstChild.className=""; //rétabli le marquage initial
		}
	}
}


function eftout(){
	ef(menu);
	voirSelect('visible');
	menu.style.visibility="hidden";
	menu.style.visibility="visible";// bug ie
}

// bug ie corrigé : cache les <select> quand le menu est visible
function voirSelect(v){
	if(ie&!op){
		for(i=0;i<elem.length;i++)elem[i].style.visibility=v;
	}
}