var currentPage = 1 ; //La page courante

/** #########################################
* Permet d'avoir le nombre reel total de page a partir du nombre de produit reel dans la famille
*/
function getTotalPages(_nbProduitFamille){
    var nbPage = 1 ;
    if(_nbProduitFamille/nbProduitParPage == Math.floor(_nbProduitFamille/nbProduitParPage)){
        nbPage = Math.floor(_nbProduitFamille/nbProduitParPage) ;
    }
    else{
        nbPage = Math.floor(_nbProduitFamille/nbProduitParPage) + 1 ;
    }
    return nbPage
}


/** #########################################
* Permet d'ecrire dans l'html le bloc pagination
* @params :
*    _isModeDegrade : Sommes nous dans le cas ou erep est ko
*/
function writePagination(_isModeDegrade){
    var isModeDegrade = false ;
    if(typeof _isModeDegrade != undefined){
        isModeDegrade = _isModeDegrade ;
    }
    
    if(!isModeDegrade){
        nbProduitFamille = enableModelList.length() ;
    }
    else{
        nbProduitFamille = modelList.length() ;
    }

    var nbPages = getTotalPages(nbProduitFamille) ;

    var paginationBloc = "" ;
    for(var i=1 ; i<=nbPages ; i++){
        //[TAG]Ajout du taggage Google analytics pour le texte
        var func = setLinkTag(tagFamille+"pagination", "showPage("+i+", "+nbPages+");") ;
        
        paginationBloc = paginationBloc + '<a href="#" onclick="'+func+'" id="numpage'+i+'">' ;
        paginationBloc = paginationBloc + i ;
        paginationBloc = paginationBloc + '</a>' ;
        if(i < nbPages){
            paginationBloc = paginationBloc + " - " ;
        }        
    }
    
    var paginationObj = getElement("listepage", true, "") ;

    if(paginationObj){
        paginationObj.innerHTML = paginationBloc ;
    }

    if(getElement("pagination", true, "")){
        getElement("pagination", true, "").style.visibility = "visible" ;
    }
}



/** #########################################
* Permet de positionner le bloc concu pour en fonction de la position de la fenêtre
*/
function hideAll(){    
    var pagesDIV = getElement('produits', true, "")
    if(pagesDIV){
        var page = pagesDIV.getElementsByTagName('div');
        if(page){
            for(i=0;i  < page.length; i++){
                if(page[i] && page[i].id && page[i].id.indexOf("vignetteproduit-") > -1){
                    page[i].style.display = 'none';
                }
            }
        }
    }
    
    var paginationDIV = getElement('pagination', true, "") ;
    if(paginationDIV){    
        var numPages = paginationDIV.getElementsByTagName('a');
        if(numPages){
            for(i=0;i  < numPages.length; i++){
                if(numPages[i].id.indexOf("numpage") > -1){
                    numPages[i].className = "" ;
                }
            }
        }
    }
}


/** #########################################
* Permet de recuperer la page courante
*/
function getCurrentPage(){
    var currentPageSaved = getCookie("pagination") ;
    var numPage = 1 ;
    
    if(currentPageSaved && currentPageSaved != "" && currentPageSaved != "null"){
        if(currentPageSaved.indexOf("allproducts_") > -1){
             numPage = 1 ;
        }
        else{
            var lastPageUrl = currentPageSaved.split("_")[2] ;
            if(lastPageUrl == document.location.href){
                numPage = currentPageSaved.split("_")[0] ;
            }
        }
    }
    return numPage ;
}


/** #########################################
* Permet de gérer le bloc pagination : visibilite des fleches et mis à jour du numero de page
*/
function setPagination(_numPage, _totalPages){
    currentPage = _numPage;
        
    var next = getElement('next-page', true, "");
    var previous = getElement('previous-page', true, "");
    
    var lienPageCourante = getElement("numpage"+_numPage, true, "") ;

    //update the page number                    
    if(lienPageCourante){
        lienPageCourante.className = "active" ;
    }
    
    //Dans le cas d'une seule page, on cache les liens precedent et suivant
    if(totalPages == 1){
        if(previous){
            previous.style.visibility = 'hidden';
        }
        if(next){
            next.style.visibility = 'hidden';
        }
    }
    else{    
        //update the previous and next page links
        if(_numPage == 1){
            if(previous){
                previous.style.visibility = 'hidden';
            }
        }
        else{
            if(previous){
                previous.style.visibility = 'visible';
            } 
        }
        
        if(_numPage == _totalPages){
            if(next){
                next.style.display = 'none';
            }
        }
        else{
           if(next){
                next.style.display = 'block';
            } 
        }
    }
}


/** #########################################
* Permet d'afficher tous les produits
*/
var isAllPages = false ;

function showAll(){
    if(!isAllPages){
        var pagesDIV = window.document.getElementById('produits');
        var showall = document.getElementById('all-pages');
        
        //On affiche tous les produits
        displayAllProducts(false, true) ;
        
        setPagination(1, 99) ;
    
        //On va modifier le texte
        var allPages = getElement("all_pages", true, "") ;
        if(allPages){
            allPages.innerHTML = libRetourPagination ;
            isAllPages = true ;
            
            //on va cacher le bloc liste pages
            var listePages = getElement("listepage", true, "") ;
            if(listePages){
                listePages.style.visibility = "hidden" ;
            }
        }
        var currentLocationHref = (document.location.href).split("#")[0] ;
        setCookie(_language, "pagination", "allproducts_"+currentLocationHref) ;
    }
    else{
        //On va modifier le texte
        var allPages = getElement("all_pages", true, "") ;
        if(allPages){
            allPages.innerHTML = toutAfficherLabel ;
            isAllPages = false ;
        }
        
        //on va afficher le bloc liste pages
        var listePages = getElement("listepage", true, "") ;
        if(listePages){
            listePages.style.visibility = "visible" ;
            displayBloc(listePages) ;
        }
    
        showPage(1, 99) ;
    }
}


/** #########################################
* Permet d'afficher les produits d'une page
*/
function show(_numPage){
    //Nombre de produit a afficher par page : nbProduitParPage (declare dans l'html)
    
    //Si le nombre de produit de la famille est inférieur au nombre de produit a afficher par page, on va cacher les blocs suivants :
    //    allpages
    //    listepages
    if(nbProduitFamille <= nbProduitParPage){ //declarer dans l'html
        var toutAfficherObj = getElement("allpages", true, "") ;
        var listePageObj = getElement("listepage", true, "") ;        
        if(toutAfficherObj){
            hideBloc(toutAfficherObj) ;
        }        
        if(listePageObj){
            hideBloc(listePageObj) ;
        }
    }

    var nbPages = getTotalPages(nbProduitFamille) ;
    
    //Page courante pour le retour arriere : ce numero de page est stocke dans un cookie "pagination"
    var currentPageSaved = getCookie("pagination") ;
    var currentLocationHref = (document.location.href).split("#")[0] ;
    
    //Selon la valeur de cette page sauvegardee
    if(currentPageSaved && currentPageSaved != "" && currentPageSaved != "null"){
        //Si la page sauvegardee est "tout afficher"
        if(currentPageSaved.indexOf("allproducts_") > -1){
             var lastPageUrl = currentPageSaved.split("_")[1] ;
             
             //Si l'internaute reaccede a la page alors on va remettre l'etat de cette page (tout afficher) au moment ou il l'a quitte
             if(lastPageUrl == currentLocationHref){
                showAll() ;
                return false ;
            }
            else{ //Sinon, l'internaute accede a une autre page, on remet alors a jour le cookie pagination avec la nouvelle page et le numero de page courante
                setCookie(_language, "pagination", currentPage+"_"+nbPages+"_"+currentLocationHref) ;
            }
        }
        else{ //Sinon si la page sauvegarde est un numero de page 
            var lastPageUrl = currentPageSaved.split("_")[2] ;
            
            //Si l'internaute reaccede a la page alors on va remettre l'etat de cette page (numero de page) au moment ou il l'a quitte
            if(lastPageUrl == currentLocationHref){
                _numPage = currentPageSaved.split("_")[0] ;
                nbPages = currentPageSaved.split("_")[1] ;
            }
            else{ //Sinon, l'internaute accede a une autre page, on remet alors a jour le cookie pagination avec la nouvelle page et le numero de page courante
                setCookie(_language, "pagination", currentPage+"_"+nbPages+"_"+currentLocationHref) ;
            }
        }
    }
    else{ //Sinon l'internaute accede pour lapremiere fois 
        setCookie(_language, "pagination", currentPage+"_"+nbPages+"_"+currentLocationHref) ;
    }
    
    //on sette la page courante avec la variable _numPage
    currentPage = _numPage ;
    
    hideAll();

    setPagination(_numPage, nbPages) ;
     
    //display the selected page
    displayProductsPage(_numPage, nbPages, nbProduitFamille, nbProduitParPage) ;
    
    //update the show all link
    showall = window.document.getElementById('all-pages');
    if(showall){
        showall.style.visibility = 'visible';
    }
    
    //affichage ou non du bouton comparer
    var lienGdbc = getElement("comparaison") ;
    
    if(nbProduitFamille == 1){
        if(lienGdbc){        
            hideBloc(lienGdbc) ;
        }
    }
    else{
        if(lienGdbc){        
            displayBloc(lienGdbc) ;
        }
    }
}


/** #########################################
* Permet d'afficher les produits de la page selectionnee
*/
function displayProductsPage(_numPage, _totalPages, _nbProduitFamille, _nbProduitParPage){
    var listeProduitAAfficher = new ArrayList() ;

    //On va determine si on est en mode degrade ou non, cad est ce que erep est ok ou ko
    var isModeDegrade = false ;
    if(typeof enableModelList != "undefined" && enableModelList.length() > 0){
        isModeDegrade = false ;
    }
    else{
        isModeDegrade = true ;
    }
    
    //On va definir quelle liste d'origine prendre en compte
    var tempList = new ArrayList() ;    
    if(typeof sortedList != "undefined" && sortedList.length() > 0){
        tempList = sortedList ;
    }
    else if(isModeDegrade){
        tempList = modelList ;
    }
    else{
        tempList = enableModelList ;
    }
    
    //Si le nombre de produit de la famille est inferieur ou egal au nombre de produit a afficher par page, on copie la liste modelList dans listeProduitAAfficher
    if(_nbProduitFamille <= _nbProduitParPage){
        listeProduitAAfficher = tempList ;
    }
    else{
        var indexProduitInit = (parseInt(_numPage)*_nbProduitParPage) - _nbProduitParPage ;

        //On va parcourir la liste des modeles pour aficher les bons blocs produit
        for(var i=indexProduitInit ; i<indexProduitInit+_nbProduitParPage ; i++){
            var idModel = tempList.get(i) ;
            
            listeProduitAAfficher.add(idModel) ;
        }    
    }
    
    //On va afficher les produits
    for(var i=0 ; i<listeProduitAAfficher.length() ; i++){
        var currentModel = listeProduitAAfficher.get(i) ;
        var blocModel = "vignetteproduit-"+currentModel ;
    
        displayBloc(getElement(blocModel, true, "")) ;
    }
}


/* **************************************
* Fonction permettant d'afficher tous les produits
*/
function displayAllProducts(isDisplayPaginationBloc, isDisplayAllBloc){
    //on affiche ou on cache le bloc de pagination
    if(isDisplayPaginationBloc){
        displayBloc(getElement("listepage", true, "")) ;
    }
    else{
        hideBloc(getElement("listepage", true, "")) ;
    }
    
    //on affiche ou on cache le bloc de pagination
    if(isDisplayAllBloc){
        displayBloc(getElement("allpages", true, "")) ;
    }
    else{
        hideBloc(getElement("allpages", true, "")) ;
    }
    
    
    //on affiche tous les produits
    var produitsObj = getElement("produits", true, "") ;
    var produitsElts = produitsObj.getElementsByTagName("DIV") ;

    //Mode degrade ou non
    var isModeDegrade = false ;
    if(typeof enableModelList != "undefined" && enableModelList.length() > 0){
        isModeDegrade = false ;
    }
    else{
        isModeDegrade = true ;
    }
    
    for(var i=0 ; i<produitsElts.length ; i++){
        if(produitsElts[i] && produitsElts[i].id && produitsElts[i].id.indexOf("vignetteproduit-") > -1){
            var idModel = produitsElts[i].id.split("-")[1] ;
            
            if(isModeDegrade){
                displayBloc(produitsElts[i]) ;
            }
            else{
                if(enableModelList.contains(idModel) > -1){
                    displayBloc(produitsElts[i]) ;
                }
            }
        }
    }
}


/* **************************************
* Fonction permettant d'afficher tous les produits
*/
function hideAllProducts(){
    //on cache le bloc de pagination
    hideBloc(getElement("pagination", true, "")) ;    
    
    //on affiche tous les produits
    var produitsObj = getElement("produits", true, "") ;
    var produitsElts = produitsObj.getElementsByTagName("LI") ;
    
    for(var i=0 ; i<produitsElts.length ; i++){
        if(produitsElts[i] && produitsElts[i].id && produitsElts[i].id.indexOf("vignetteproduit-") > -1){
            hideBloc(produitsElts[i]) ;
        }
    }
}


/** #########################################
* Permet d'afficher les produits de la page d'apres
*/
function showAfter(totalPages){
    currentPage++ ;
    var currentLocationHref = (document.location.href).split("#")[0] ;
    setCookie(_language, "pagination", currentPage+"_"+totalPages+"_"+currentLocationHref) ;
    show(currentPage); 
}


/** #########################################
* Permet d'afficher les produits de la page precedente
*/
function showBefore(totalPages){
    currentPage-- ;
    var currentLocationHref = (document.location.href).split("#")[0] ;
    setCookie(_language, "pagination", currentPage+"_"+totalPages+"_"+currentLocationHref) ;
    show(currentPage);
}


/** #########################################
* Permet d'afficher les produit de la page selectionne
*/
function showPage(thePage, totalPages){
    var currentLocationHref = (document.location.href).split("#")[0] ;
    setCookie(_language, "pagination", thePage+"_"+totalPages+"_"+currentLocationHref) ;
    show(thePage);
}
