//Globales
var elementAllume="";
var intTimerVisibilite;
var bolAvecAnim = true;

/*
Si on veut des animations
*/
if (bolAvecAnim == true) {
	window.addEvent("domready",function() {
		initialiserParamsAnimation();
	});
};

/*
Initialise les paramètre pour les animations.
Utilise les sélecteur et fonctions de Mootools.
http://docs.mootools.net/Element/Element-Selectors.js
http://docs.mootools.net/Effects/Fx-Styles.js
http://docs.mootools.net/Effects/Fx-Transitions.js
*/
function initialiserParamsAnimation() {
	var elementsMenu = $$("ul#menuhaut li ul", "ul#menugauche li ul", "ul#menuutil li ul");
	elementsMenu.each(function(element) {
		//Styles initiaux ici. On utilise Fx.Style pour l'opacité car ça marche pour IE aussi. Pour le reste,
		//vous pouvez utiliser, par exemple, element.style.visibility="visible"; etc...
		element.stylesInitiaux = new Fx.Style(element, "opacity");
		element.stylesInitiaux.set(0);
		element.style.top = "55%";
		//Settings de l'effet ici.
		element.effet = new Fx.Styles(element, {duration:100,wait:false,Transition:"Cubic.easeOut"});
	});
	
	/* SUPPLÉMENTAIRE POUR MGM */
	var elementsImgRollover = $$("ul#menuhaut li img.rollover");
	elementsImgRollover.each(function(element) {
		var effetImg = new Fx.Style(element, "opacity", {duration:200,wait:false,Transition:"Cubic.easeOut"});
		effetImg.addEvent("onComplete", function(element) {
			element.style.visibility = "visible";
		});
		element.addEvent("mouseenter", function() {
			effetImg.start(0,1);
		});
		
		element.addEvent("mouseleave", function() {
			effetImg.start(0,0);
		});
	});
};

/*
Timer de disparition du menu
*/
function lancerTimerVisibilite() {
	intTimerVisibilite=setTimeout("fermerElementVisible()",1000);
};

/*
Arrête le timer quand on passe rapidement d'un menu à l'autre.
*/
function interrompreTimerVisibilite() {
	clearTimeout(intTimerVisibilite);
};

/*
Fait apparaitre le sous-menu au survol d'un élément de menu
*/
function montrerSousMenu(intIdRecu) {
	interrompreTimerVisibilite();
	//Si on nous ne nous envoie pas le même ID et qu'il y a déjà un élément de menu ouvert, fermer ce menu.
	if (elementAllume != "" && elementAllume.id != intIdRecu) {
		fermerElementVisible();
	};
	//Si l'élément demandé existe et qu'il n'est pas déjà allumé, faire apparaître
	if (document.getElementById(intIdRecu) && (document.getElementById(intIdRecu) != elementAllume)) {
		elementAllume=document.getElementById(intIdRecu);
		elementAllume.parentNode.className="allume";
		//Mettre le zIndex du LI de menu plus haut que les autres
		elementAllume.parentNode.style.zIndex = retournerZIndex(elementAllume.parentNode) + 1;
		elementAllume.style.visibility="visible";
		//Si on veut de l'animation. Placez les valeurs de CSS pour la fin de la transition ici.
		if (bolAvecAnim == true) {
			elementAllume.effet.removeEvent("onComplete");
			elementAllume.effet.addEvent("onComplete",function(element) {
				element.style.visibility="visible";
			});
			elementAllume.effet.start({
				"opacity" : 1,
				"top" : "55%"
			});
		};
	};
};

/*
Fait disparaitre le sous-menu
*/
function fermerElementVisible() {
	//Si on a un élément allumé
	if(elementAllume) {
		//Si on veut de l'animation. Placez les valeurs de CSS pour le début de la transition ici.
		if (bolAvecAnim == true) {
			elementAllume.effet.removeEvent("onComplete");
			elementAllume.effet.addEvent("onComplete",function(element) {
				element.style.visibility="hidden";
			});
			elementAllume.effet.start({
				"opacity" : 0,
				"top" : "55%"
			});	
		}
		else {
			elementAllume.style.visibility="hidden";
		};
		//Remettre l'élément au bon zIndex
		elementAllume.parentNode.style.zIndex = elementAllume.parentNode.style.zIndex - 1;
		elementAllume.parentNode.className="";
		elementAllume="";
	};
};

/*
Retourne le z-index d'un element
Source : http://www.quirksmode.org/dom/getstyles.html
*/
function retournerZIndex(element) {
	if (element.currentStyle) {
		var intZIndex = parseInt(element.currentStyle["zIndex"]);
	}
	else if (window.getComputedStyle) {
		var intZIndex = parseInt(document.defaultView.getComputedStyle(element,null).getPropertyValue("z-index"));
	};
	return intZIndex;
};
