// JavaScript Document

// ================ survols du menu =================================================
// ==================================================================================
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_preloadImages() { //v3.0
  var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
    var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
    if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}

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];}
   
   
}


// =========================== affichage Ajax des doubles ========================
// ===============================================================================

// Creation d'une instance de l'objet XMLHTTPRequest (qui va permettre la requete)
   if(document.all && !window.opera)
   	{
  		//si Internet Explorer ou Opera
   		var XhrObj = new ActiveXObject("Microsoft.XMLHTTP") ;
   	}
   else
  	{
   		//si Mozilla
  		var XhrObj = new XMLHttpRequest();
   	}
	
// Fonction de gestion du calque de loading pendant le chargement de la requete
function gestionstatechange() {
 	var elt = document.getElementById('loading');
	switch (XhrObj.readyState) {
 		case 1:
			// 1 (loading)	début du transfert des données : loading visible
 			elt.style.display="block";
 			break;
 		case 2:
 			// 2 (loaded)	données transférées : loading visible
 			elt.style.display="block";
 			break;
 		case 3:
 			// 3 (interactive)	les données reçues sont accssibles en partie : loading visible
 			elt.style.display="block";
 			break;
		case 4:

 			//si la page cible est OK (code HTTP 200) et 4 (complete :les données sont complètement accessibles), loading caché
 			// NB : Firefox declanche avec "status" tant que le code de chargement n'est pas à  4
 			if (XhrObj.status == 200) 
 				{
 					//définition de l'endroit d'affichage:
 					var content = document.getElementById("prod-double");
 					//on affecte à  l'endroit d'affichage la valeur du fichier distant recupéré avec  la propriété .responseText
 					content.innerHTML = XhrObj.responseText ;
 					// s'il y avait un Javascript à  interpreter dans le fichier distant, on ecrirait : eval(XhrObj.responseText);
 				}
 			elt.style.display="none";
 			break;
 		default:
 			// 0 (uninitialized)	non initialisé
 			alert('Le serveur est bloqué. Veuillez recommencer.');
 			break;
 	}
 }

// 3eme étape : on peut maintenant déclarer la fonction de lancememnt de la requete distante
// Fonction d'envoi des données sur le fichier PHP distant
  function envoi(donnees, page) {
  	// On spécifie la page cible et les modalité d"envoi (true spécifie le mode asynchrone)
  	var sURL = "double.php";
  	// on peut aussi utiliser GET ou HEAED
  	XhrObj.open("POST",sURL,true);
  	// declanche la fonction qui affiche le loading en fonction de l'etat de la requetet
  	XhrObj.onreadystatechange = gestionstatechange;
  	// et on execute la requete elle-meme  ( send ) : header puisque c'est une methode POST, puis données
  	XhrObj.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
  	XhrObj.send(donnees);
  }
