/***************************************************************************************************
*	Lance les fonctions Javascript au chargement de la page
*	Param : void
*	Return : true
***************************************************************************************************/
function initApp() 
{
  
	load();
	masquerElements();
	return true;
}

/***************************************************************************************************
*	Ferme la iframe Greybox et ouvre la page dans la fenêtre principale
*
*	Param : string finalLocation
*	Return : void
***************************************************************************************************/
function fermerFenetreCarte(finalLocation)
{
	this.window.close();
	this.window.opener.location.href=finalLocation;
}

/***************************************************************************************************
*	Définition de la méthode getElementsByClassName sur l'objet document
*
*	Param : string clsName
*
*	Return : array retVal
***************************************************************************************************/
document.getElementsByClassName = function(clsName){
	var retVal = new Array();
	var elements = document.getElementsByTagName("*");
	for(var i = 0;i < elements.length;i++){
		if(elements[i].className.indexOf(" ") >= 0){
			var classes = elements[i].className.split(" ");
			for(var j = 0;j < classes.length;j++){
				if(classes[j] == clsName)
					retVal.push(elements[i]);
				}
			}
			else if(elements[i].className == clsName)
			retVal.push(elements[i]);
	}
	return retVal;
}

/***************************************************************************************************
*	Uncheck toutes les checkboxes ayant la même classe css
*
*	Param : string classLogement
*
*	Return : void
***************************************************************************************************/
function nettoyerCaracteristiquesLogement(classLogement) {

	var tabCaracteristiques = new Array();
	tabCaracteristiques = document.getElementsByClassName(classLogement);
	for(i=0; i<tabCaracteristiques.length; i++) {
		tabCaracteristiques[i].checked=false;
	}
}

/***************************************************************************************************
*	Prépare une nouvelle recherche
*
*	Param : string classLogement, str idForm
*
*	Return : void
***************************************************************************************************/
function nouvelleRecherche(idForm, classLogement) {

	nettoyerCaracteristiquesLogement(classLogement);
	document.getElementById(idForm).submit();
}

/***************************************************************************************************
*	Masque tous les éléments portant la même classe
*	Param : void
*	Return : void
***************************************************************************************************/
function masquerElements() {
  
  	open_ext_link();
	var tabElements = new Array();
	tabElements = document.getElementsByClassName('jsMasque');
	for(i=0; i<tabElements.length; i++) {
		tabElements[i].style.display='none';
	}
	
	//masque les elements de la fiche hebergement 
	masquerElementFicheHebegement();
	
	//masque les elements de la fiche activite 
	masquerElementFicheActivite();
	
	//masque les elements de la fiche evenement
	masquerElementFicheEvenement();
	
}

/***************************************************************************************************
*	Ouvre une popup pour une image agrandie
*
*	Param : 
*			- str URL : url de l'image
*			- int WIDTH : largeur de l'image
*			- int HEIGHT : hauteur de l'image
*
*	Return : void
***************************************************************************************************/
function PopUp2(URL,WIDTH,HEIGHT) {
	options="toolbar=no,location=no,directories=no,status=no,menubar=no,top=20,left=30, scrollbars=no,resizable=no,width=1,height=1"
	Box = window.open (URL,"Windows",options)
	Box.close()
	options="toolbar=no,location=no,directories=no,status=no,menubar=no,top=20,left=30, scrollbars=no,resizable=no,width="+WIDTH+",height="+HEIGHT
	Box = window.open (URL,"Windows",options)
	Box.focus();
}


// -- menu -->	
function open_ext_link()
{
 
	var liens = document.getElementsByTagName('a');
	for( var i = 0 ; i < liens.length ; i++)
	{
	
		if(liens[i].className == 'lien_ext')
		{
		  
			liens[i].onclick = function()
			{
				window.open(this.href);
				return false;
			}
		}
	}
}


function setActiveStyleSheet(title) {
	var i, a, main;
	for(i=0; (a = document.getElementsByTagName("link")[i]); i++) {
		if(a.getAttribute("rel").indexOf("style") != -1 && a.getAttribute("title")) {
			a.disabled = true;
			if(a.getAttribute("title") == title) a.disabled = false;
		}
	}
}

function getActiveStyleSheet() {
  var i, a;
  for(i=0; (a = document.getElementsByTagName("link")[i]); i++) {
    if(a.getAttribute("rel").indexOf("style") != -1 && a.getAttribute("title") && !a.disabled) return a.getAttribute("title");
  }
  return null;
}

function getPreferredStyleSheet() {
  var i, a;
  for(i=0; (a = document.getElementsByTagName("link")[i]); i++) {
    if(a.getAttribute("rel").indexOf("style") != -1
       && a.getAttribute("rel").indexOf("alt") == -1
       && a.getAttribute("title")
       ) return a.getAttribute("title");
  }
  return null;
}

function createCookie(name,value,days) {
  if (days) {
    var date = new Date();
    date.setTime(date.getTime()+(days*24*60*60*1000));
    var expires = "; expires="+date.toGMTString();
  }
  else expires = "";
  document.cookie = name+"="+value+expires+"; path=/";
}

function readCookie(name) {
  var nameEQ = name + "=";
  var ca = document.cookie.split(';');
  for(var i=0;i < ca.length;i++) {
    var c = ca[i];
    while (c.charAt(0)==' ') c = c.substring(1,c.length);
    if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
  }
  return null;
}

//masque les differentes div de la fiche hebergement
function masquerElementFicheHebegement()
{
    if(document.getElementById('hebergement'))
    {
        //si div hebergementDescription
        if (document.getElementById("hebergementDescription"))
        {
          afficherCritere("hebergementDescription");
        }
        
        //div hebergementClassement
        if (document.getElementById("hebergementClassement"))
        {
          afficherCritere("hebergementClassement");
        }
        
        //div hebergementTarifs
        if (document.getElementById("hebergementTarifs"))
        {
          afficherCritere("hebergementTarifs");
        }
        
        //div hebergementReservations
        if (document.getElementById("hebergementReservations"))
        {
          afficherCritere("hebergementReservations");
        }
        
        //div hebergementPrestations
        if (document.getElementById("hebergementPrestations"))
        {
          afficherCritere("hebergementPrestations");
        }
        
        //div hebergementAutresPrestations
        if (document.getElementById("hebergementAutresPrestations"))
        {
          afficherCritere("hebergementAutresPrestations");
        }
        
    }
}

//Affiche masque les differentes div dans une fiche sitra type activite
function masquerElementFicheActivite()
{
   if(document.getElementById('Activite'))
   {
        //si div ActivitesDescription
        if (document.getElementById("ActivitesDescription"))
        {
          afficherCritere("ActivitesDescription");
        }
        
        //si div ActivitesClassement
        if (document.getElementById("ActivitesClassement"))
        {
          afficherCritere("ActivitesClassement");
        }
        
        //si div ActivitesTarifs
        if (document.getElementById("ActivitesTarifs"))
        {
          afficherCritere("ActivitesTarifs");
        }
        
        //si div ActivitesReservations
        if (document.getElementById("ActivitesReservations"))
        {
          afficherCritere("ActivitesReservations");
        }
        
        //si div ActivitesPrestations
        if (document.getElementById("ActivitesPrestations"))
        {
          afficherCritere("ActivitesPrestations");
        }
        
        //si div ActivitesAutresPrestations
        if (document.getElementById("ActivitesAutresPrestations"))
        {
          afficherCritere("ActivitesAutresPrestations");
        }
   
   }

}


//affiche/masque les differentes div de la fiche evenement
function masquerElementFicheEvenement()
{
   if(document.getElementById('Evenement'))
   {
        //si div EvenementDescription
        if (document.getElementById("EvenementDescription"))
        {
          afficherCritere("EvenementDescription");
        }
        
        //si div EvenementClassement
        if (document.getElementById("EvenementClassement"))
        {
          afficherCritere("EvenementClassement");
        }
        
        //si div EvenementTarifs
        if (document.getElementById("EvenementTarifs"))
        {
          afficherCritere("EvenementTarifs");
        }
        
        //si div EvenementReservations
        if (document.getElementById("EvenementReservations"))
        {
          afficherCritere("EvenementReservations");
        }
        
        //si div EvenementPrestations
        if (document.getElementById("EvenementPrestations"))
        {
          afficherCritere("EvenementPrestations");
        }
        
        //si div EvenementAutresPrestations
        if (document.getElementById("EvenementAutresPrestations"))
        {
          afficherCritere("EvenementAutresPrestations");
        }
   }


}


//
window.onload = function(e) {

	  var cookie = readCookie("style");
	  var title = cookie ? cookie : getPreferredStyleSheet();
	  setActiveStyleSheet(title);
	  //open_ext_link();
}
window.onunload = function(e) {
  var title = getActiveStyleSheet();
  createCookie("style", title, 365);
}

function descendreElement(idElement) {

	if(document.getElementById(idElement)) {
		Effect.Appear(idElement,{duration:2.0});
	}
}


function afficheImageSitra(fileName)
{
    var obj = window.document;
    var image = obj.getElementById('imgPrincipal');
    image.src = fileName;
}


//Affichage/masquage des differentes div dans une fiche sitra
function afficherCritere(obj,link){
       var affCrit = document.getElementById(obj);
       var position_ini = 0;
       if (affCrit.style.display == "none"){
       		affCrit.style.display = "block";
       		if (link!=undefined)
       		{
       		     link.style.background='url(./images/puce_moins.gif) 0px 2px no-repeat';
       		}
       	}else{
       	  if (link!=undefined)
       	  {
       	      link.style.background='url(./images/puce_plus.gif) 0px 2px no-repeat';
       	  }
       		affCrit.style.display = "none";
       		affCrit.Offset = window.pageYOffset;
       	}

}



function afficherCriterePrecision(obj,value)
{
    if(value==7)
    {
      afficherCritere(obj);  
    }
    else
    {
        var affCrit = document.getElementById(obj);
        affCrit.style.display = "none";
    }
    
}
/*GESTION DU ZOOM */

//gestion de l'agrandissemente de la police de caracteres (outil) 
var tailleTexte = 11;
//taille initial du text
var tailleInit = 11;
//taille maximum autorise 
var tailleMax = 17;
//nom de la div ou ce trouve les texte a agrandir
var divPrincipal = 'centre';

/*@
    Fonction : changeTaille 
    Description : change la taille de la police d'un page
    Variable : pas (int) -> Valeur indiquant de combien de pixel la taille doit etre diminue ou
                        augmenter (souvent -1 ->diminution ou 1 -> augmentation) 
    
@*/
function changeTaille(pas)
{
  
  //determine si on veut changer de la taille de la poilce ou non (en rapport au taille max et initial defini)     
  var changeSize = true;
  
  tailleTexte = tailleTexte + pas;
    
  //on va verifier si la taille du texte n'est pas inferieur a la taille minimum
  if (tailleTexte < tailleInit)
  {
        //si la taille minumm a ete atteinte, on remet notre tailleTexte a la taille minumum, et
        //on considereque ce n'est pas la peine de changer la taille des element
        tailleTexte = tailleInit;
        changeSize = false;
   
  }        
  else
  {
        //cette fois ci on verifier que la taille maximum n'a ete atteinte
        if (tailleTexte > tailleMax)
        {
            tailleTexte = tailleMax;
            changeSize = false;
        }
  }
  
  //si changesize est true, c partie on change la taille de la police !!
  if (changeSize)
  {
      var text = document.getElementById(divPrincipal);
      
      //ici on va changer la taille de tout les p de la page
      //ICI ON MET TOUT LES TAGS QUI N'AUGMENTE PAS CA TAILLE AVEC LA SIMPLE INSTRUCTION 
      // text.style.fontSize = tailleTexte + 'px';
      
      updateTaille(text,'p',tailleTexte)
      updateTaille(text,'h6',tailleTexte)
      
      //on rajoute quand meme cette ligne pour augmenter d'autre element
      text.style.fontSize = tailleTexte + 'px';

  }
 
}

/*@
    Fonction  : updateTaille 
    Description : Change la taille des bloc d'une page(fonction appele dans changeTaille)
    Variables : - > divParent(object) : div de notre page pour laquel on veux changer la taille du texte
                - > tag (text) -> : tag html de l'element qui fera l'objet d'un changement de taille 
                              (ex : p, si l'on veut changer la taille de tout les p)
                - > tailleText : taille du texte
    
@*/
function updateTaille(divParent,tag,tailleTexte)
{

        //determine si on veut changer de la taille de la poilce ou non (en rapport au taille max et initial defini)  
        var changeSize = true;
        
        //on va augmenter la taille de tout ce qui ce trouve dans p
        var textPart = divParent.getElementsByTagName(tag);
        for (var i = 0; i < textPart.length; i++) 
        {
            textPart[i].style.fontSize = tailleTexte + 'px';
        }  
}
