X-Git-Url: http://git.euphorik.ch/?a=blobdiff_plain;f=js%2Fyopyop.js;h=da49920f9d588bddc7959781c152873316bbfb1b;hb=84fd971104c7cc367ecca4b7ae7073fb7a7e5a7a;hp=9fa85a4a7df41136bbf9de870f11c958ff088713;hpb=202a3b4495bc486dc0f5bb6a34da66d5e34832bf;p=pompage.git diff --git a/js/yopyop.js b/js/yopyop.js index 9fa85a4..da49920 100644 --- a/js/yopyop.js +++ b/js/yopyop.js @@ -36,21 +36,6 @@ function rtrim(s) return s.substring(0, r+1); } -/** - * Affiche les fichiers d'un film. - */ -function afficherFichiers(id) -{ - var listeFichiers = document.getElementById("listeFichiers"+id) - listeFichiers.style.display = "block" -} - -function cacherFichiers(id) -{ - var listeFichiers = document.getElementById("listeFichiers"+id) - listeFichiers.style.display = "none" -} - /** * Callback appelé lorsque un film est cliqué * Affiche ou cache les informations de détail pour ce film. @@ -71,28 +56,44 @@ var derniereRecherche = new Date(); derniereRecherche.setMinutes(derniereRecherche.getMinutes() - 1); var motifDerniereRecherche = "" +var nbPending = 0 + +/** + * Permet de mettr en queue les requêtes. + */ +function doRecherchePending() +{ + nbPending -= 1; + if (nbPending == 0) // si c'est la dernière requête en attente on l'effectue + doRecherche(); +} + /** * Effectue une recherche, n'affiche que les films qui contiennent le motif recherché * Recherche dans le titre, le realisateur, les acteurs, les genres et les pays en fonction des checkbox respectives. */ -function doRecherche() +function doRecherche(f) { // le motif à chercher var motif = document.getElementById("recherche").value - if (motif == motifDerniereRecherche) return; + motif = trim(motif) + if (f == null && motif == motifDerniereRecherche) return; + // empèche de faire deux recherches successive en moins de 800ms var now = new Date(); if (now.getTime() < derniereRecherche.getTime() + 800) { // si une recherche à était demandé mais n'a pu aboutir alors on la refait dans certain temps - setTimeout("doRecherche()", 810 - (now.getTime() - derniereRecherche.getTime())); + setTimeout("doRecherchePending()", 810 - (now.getTime() - derniereRecherche.getTime())); + nbPending += 1 return; } + motifDerniereRecherche = motif; derniereRecherche = now; - - dump ("recherche : " + motif + "\r\n"); + + //dump ("recherche : " + motif + "\r\n"); debut = new Date().getTime() var afficherTout = false; @@ -105,32 +106,26 @@ function doRecherche() afficherTout = true; var nbFilm = 0; // pour compter le nombre de film total - var nbFilmAffiche = 0; // pour compter le nombre de film affiché - - var rechercheRegExp = new RegExp(motif, "i") + var nbFilmAffiche = 0; // pour compter le nombre de film affiché + var rechercheRegExp = new RegExp(motif, "i") + var liste = document.getElementById("liste") var lignes = liste.childNodes for(var i = 0; i < lignes.length; i += 2) { nbFilm++; - // extraction des informations du film courant - var titre = lignes[i].firstChild.innerHTML var tableDetails = lignes[i+1].firstChild.firstChild.childNodes - var genres = tableDetails[0].firstChild.nextSibling.textContent - var realisateurs = tableDetails[1].firstChild.nextSibling.textContent - var acteurs = tableDetails[2].firstChild.nextSibling.textContent - var pays = tableDetails[3].firstChild.nextSibling.textContent // si le film satisfait la recherche alors on l'affiche sinon ou le cache if ( afficherTout || - document.getElementById("checkRechercheTitre").checked && rechercheRegExp.exec(titre) != null - || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.exec(genres) != null - || document.getElementById("checkRechercheRealisateurs").checked && rechercheRegExp.exec(realisateurs) != null - || document.getElementById("checkRechercheActeurs").checked && rechercheRegExp.exec(acteurs) != null - || document.getElementById("checkRecherchePays").checked && rechercheRegExp.exec(pays) != null) + document.getElementById("checkRechercheTitre").checked && rechercheRegExp.test(lignes[i].childNodes[2].textContent) + || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.test(tableDetails[0].firstChild.nextSibling.nextSibling.textContent) + || document.getElementById("checkRechercheRealisateurs").checked && rechercheRegExp.test(tableDetails[1].firstChild.nextSibling.textContent) + || document.getElementById("checkRechercheActeurs").checked && rechercheRegExp.test(tableDetails[2].firstChild.nextSibling.textContent) + || document.getElementById("checkRecherchePays").checked && rechercheRegExp.test(tableDetails[3].firstChild.nextSibling.textContent)) { lignes[i].style.display = "table-row" lignes[i+1].style.display = "table-row" @@ -147,7 +142,7 @@ function doRecherche() document.getElementById("nbFilms").textContent = nbFilmAffiche + " / " + nbFilm + " film" + (nbFilm > 1 ? "s" : "") fin = new Date().getTime() - dump ("Temps : " + (fin - debut) / 1000 + "s\r\n\r\n") + document.getElementById("tempsRecherche").textContent = "Temps de la recherche : " + (fin - debut) / 1000 + "s" } /**