// JavaScript Document

// holds an instance of XMLHttpRequest
var xmlHttp = createXmlHttpRequestObject();
// holds the remote server address 
var serverAddress_mail = "_mmServerScripts/sendQut.php";
var serverAddress_qte = "_mmServerScripts/changeQut.php";
// when set to true, display detailed error messages
var showErrors = false;
// initialize the validation requests cache 
//var cache = new Array();

// creates an XMLHttpRequest instance
function createXmlHttpRequestObject() 
{
  // will store the reference to the XMLHttpRequest object
  var xmlHttp;
  // this should work for all browsers except IE6 and older
  try
  {
    // try to create XMLHttpRequest object
    xmlHttp = new XMLHttpRequest();
  }
  catch(e)
  {
    // assume IE6 or older
    var XmlHttpVersions = new Array("MSXML2.XMLHTTP.6.0",
                                    "MSXML2.XMLHTTP.5.0",
                                    "MSXML2.XMLHTTP.4.0",
                                    "MSXML2.XMLHTTP.3.0",
                                    "MSXML2.XMLHTTP",
                                    "Microsoft.XMLHTTP");
    // try every id until one works
    for (var i=0; i<XmlHttpVersions.length && !xmlHttp; i++) 
    {
      try 
      { 
        // try to create XMLHttpRequest object
        xmlHttp = new ActiveXObject(XmlHttpVersions[i]);
      } 
      catch (e) {} // ignore potential error
    }
  }
  // return the created object or display an error message
  if (!xmlHttp)
    displayError("Error creating the XMLHttpRequest object.");
  else 
    return xmlHttp;
}

// function that displays an error message
function displayError($message)
{
  // ignore errors if showErrors is false
  if (showErrors)
  {
    // turn error displaying Off
    //showErrors = false;
 
    alert("Erreur: \n" + $message);
    exit();
  }
}

function suppressQut(reference, typeProd)
{
  // only continue if xmlHttp isn't void
  if (xmlHttp)
  {
	  /// Cursor d'attente
	  var box = document.getElementById("wait_"+reference);
	  box.innerHTML = '<img src="images/ajax-loader_10x10.gif" width="10" height="10" />';
	  
	  cache = 'reference=' + reference + '&quantite=0&typeProd=' + typeProd;
	  //alert(cache);
    // try to connect to the server
    try
    {
		// continue only if the XMLHttpRequest object isn't busy
		// and the cacheOptions is not empty
		if (xmlHttp.readyState == 4 || xmlHttp.readyState == 0)
		{
			// make a server request to validate the extracted data
			xmlHttp.open("POST", serverAddress_qte, true);
			xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
			xmlHttp.onreadystatechange = handleRequestStateChange;
			xmlHttp.send(cache);
		}
    }
		catch (e)
    {
		// display an error when failing to connect to the server
		displayError(e.toString());
	}
  }
}

function changeQut(reference, typeProd)
{
  // only continue if xmlHttp isn't void
  if (xmlHttp)
  {
	  /// Cursor d'attente
	  var box = document.getElementById("wait_"+reference);
	  box.innerHTML = '<img src="images/ajax-loader_10x10.gif" width="10" height="10" />';
	  var value = document.getElementById("value_"+reference).value;
	  
	  cache = 'reference=' + reference + '&quantite=' + value + '&typeProd=' + typeProd;;
	  //alert(cache);
    // try to connect to the server
    try
    {
		// continue only if the XMLHttpRequest object isn't busy
		// and the cacheOptions is not empty
		if (xmlHttp.readyState == 4 || xmlHttp.readyState == 0)
		{
			// make a server request to validate the extracted data
			xmlHttp.open("POST", serverAddress_qte, true);
			xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
			xmlHttp.onreadystatechange = handleRequestStateChange;
			xmlHttp.send(cache);
		}
    }
		catch (e)
    {
		// display an error when failing to connect to the server
		displayError(e.toString());
	}
  }
}

function sendQut(nom,prenom,adresse,code_postal,ville,telephone,email,commentaires,date_livraison)
{
  // only continue if xmlHttp isn't void
  if (xmlHttp)
  {
	  
	  if (nom.length < 1) {
			var mes=document.createElement('span');
			mes.innerHTML = "Le nom doit &ecirc;tre renseign&eacute;";
			alert(mes.innerHTML);
			return (false);
	  }
	  if (prenom.length < 1) {
			var mes=document.createElement('span');
			mes.innerHTML = "Le pr&eacute;nom doit &ecirc;tre renseign&eacute;";
			alert(mes.innerHTML);
			return (false);
	  }
	  if (telephone.length < 10 && email.length < 8) {
		  	var mes=document.createElement('span');
			mes.innerHTML = "Le t&eacute;l&eacute;phone ou l'email doit &ecirc;tre renseign&eacute;";
			alert(mes.innerHTML);
			return (false);
	  } 
	  /// Cursor d'attente
	  var box = document.getElementById("ent_cols_contact");
	  box.innerHTML = "<img src=\"images/ajax-loader.gif\" width=\"20\" height=\"20\" /> Envoi du message en cours...";
	  
	  cache = 'nom='+nom+"&prenom="+prenom+"&adresse="+adresse+"&code_postal="+code_postal+"&ville="+ville+"&telephone="+telephone+"&email="+email+"&commentaires="+commentaires+"&date_livraison="+date_livraison;
    // try to connect to the server
    try
    {
		// continue only if the XMLHttpRequest object isn't busy
		// and the cacheOptions is not empty
		if (xmlHttp.readyState == 4 || xmlHttp.readyState == 0)
		{
			// make a server request to validate the extracted data
			xmlHttp.open("POST", serverAddress_mail, true);
			xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
			xmlHttp.onreadystatechange = handleRequestStateChange;
			xmlHttp.send(cache);
		}
    }
		catch (e)
    {
		// display an error when failing to connect to the server
		displayError(e.toString());
	}
	
  }
}


// function that handles the HTTP response
function handleRequestStateChange() 
{
  // when readyState is 4, we read the server response
  if (xmlHttp.readyState == 4) 
  {
    // continue only if HTTP status is "OK"
    if (xmlHttp.status == 200) 
    {
      try
      {
        // read the response from the server
        readResponse();
	  }
      catch(e)
      {
        // display error message
        displayError(e.toString());
      }
    }
    else
    {
      // display error message
      displayError(xmlHttp.statusText);
    }
  }
}

// read server's response 
function readResponse()
{
	// retrieve the server's response 
	var response = xmlHttp.responseText;
	//alert(response);
	// server error?
	if (response.indexOf("ERRNO") >= 0 || response.indexOf("error:") >= 0 || response.length == 0)
	throw(response.length == 0 ? "Server error." : response);
	// get response in XML format (assume the response is valid XML)
	responseXml = xmlHttp.responseXML;

	////// RECUPERATION DES RETOUR DU SERVEUR
	// get the document element
	xmlDoc = responseXml.documentElement;
	var result = xmlDoc.getElementsByTagName("result")[0].firstChild.data;
	
	
  
  ////// PRISE EN CHARGE REPONSES DES OPTIONS
  if (result == "mail")
  {
	  message = document.getElementById('ent_cols_contact');
	  message.innerHTML = "<h2>Votre demande a &eacute;t&eacute; envoy&eacute;e avec succ&egrave;s. L'&eacute;quipe Lucera vous fera parvenir un devis par email dans les meilleurs d&eacute;lais.</h2><h2>Toute l'&eacute;quipe LUCERA vous remercie de votre confiance.</h2>";
  }
  else if (result == "qte")
  {
	 var reference = xmlDoc.getElementsByTagName("reference")[0].firstChild.data;
	 var quantite = xmlDoc.getElementsByTagName("quantite")[0].firstChild.data;
	 message = document.getElementById('wait_'+reference);
	 message.innerHTML = "<h3>Quantit&eacute; : "+quantite+"</h3>";	  
  }
  else if (result == "removeEmptyDeco")
  {
	  var reference = xmlDoc.getElementsByTagName("reference")[0].firstChild.data;
	  var parent = document.getElementById("ent_cols");
	  var box = document.getElementById("box_"+reference);
	  parent.removeChild(box);
  }
  else if (result == "removeEmptyDecoFinish")
  {
	  var reference = xmlDoc.getElementsByTagName("reference")[0].firstChild.data;
	  var parent = document.getElementById("ent_cols");
	  var box = document.getElementById("box_"+reference);
	  parent.removeChild(box);
	  
	  var mess = document.getElementById("content_deco");
	  mess.innerHTML = "<h2>Aucun article n'a &eacute;t&eacute; ajout&eacute;.</h2>";
  }
  else if (result == "removeEmptyTech")
  {
	  var reference = xmlDoc.getElementsByTagName("reference")[0].firstChild.data;
	  var parent = document.getElementById("ent_cols_tech");
	  var box = document.getElementById("box_"+reference);
	  parent.removeChild(box);
  }
  else if (result == "removeEmptyTechFinish")
  {
	  var reference = xmlDoc.getElementsByTagName("reference")[0].firstChild.data;
	  var parent = document.getElementById("ent_cols_tech");
	  var box = document.getElementById("box_"+reference);
	  parent.removeChild(box);
	  
	  var mess = document.getElementById("content_tech");
	  mess.innerHTML = "<h2>Aucun article n'a &eacute;t&eacute; ajout&eacute;.</h2>";
  }
  else
  {
	  message = document.getElementById("content");
	  message.innerHTML = "Une erreur est survenue ! Merci de rafra&icirc;chir la page pour essayer à nouveau.";
  }
 
}
