X-Git-Url: http://git.euphorik.ch/?a=blobdiff_plain;f=js%2Fyopyop.js;h=7ce234023b0fc09085321f5a7d3e3863e843e1b2;hb=339621e8669fbd4b09e2d0825f5521469503837b;hp=da49920f9d588bddc7959781c152873316bbfb1b;hpb=84fd971104c7cc367ecca4b7ae7073fb7a7e5a7a;p=pompage.git diff --git a/js/yopyop.js b/js/yopyop.js index da49920..7ce2340 100644 --- a/js/yopyop.js +++ b/js/yopyop.js @@ -54,43 +54,47 @@ function detailFilm(id) // la date de la dernière recherche var derniereRecherche = new Date(); derniereRecherche.setMinutes(derniereRecherche.getMinutes() - 1); -var motifDerniereRecherche = "" var nbPending = 0 +var dernierRandom = 0 + /** * Permet de mettr en queue les requêtes. */ -function doRecherchePending() +function doRecherchePending(r) { nbPending -= 1; if (nbPending == 0) // si c'est la dernière requête en attente on l'effectue - doRecherche(); + r == null ? doRecherche() : doRecherche(r); +} + +function doRecherchePendingRandom() +{ + doRecherchePending(true) } /** * 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. + * r : si pas null alors n'affiche qu'un film au hasard dans la sélection */ -function doRecherche(f) -{ +function doRecherche(r) +{ // le motif à chercher var motif = document.getElementById("recherche").value 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) + if (now.getTime() - derniereRecherche.getTime() < 800) { - // si une recherche à était demandé mais n'a pu aboutir alors on la refait dans certain temps - setTimeout("doRecherchePending()", 810 - (now.getTime() - derniereRecherche.getTime())); nbPending += 1 + // si une recherche à était demandé mais n'a pu aboutir alors on la refait dans certain temps + setTimeout(r == true ? "doRecherchePendingRandom()" : "doRecherchePending()", 900 - (now.getTime() - derniereRecherche.getTime())); return; } - motifDerniereRecherche = motif; derniereRecherche = now; //dump ("recherche : " + motif + "\r\n"); @@ -105,30 +109,32 @@ function doRecherche(f) && !document.getElementById("checkRecherchePays").checked) afficherTout = true; - var nbFilm = 0; // pour compter le nombre de film total - var nbFilmAffiche = 0; // pour compter le nombre de film affiché + var liste = document.getElementById("liste") + var lignes = liste.childNodes + + var nbFilmAffiche = 0; // pour compter le nombre de film affiché + var nbFilm = lignes.length / 2; // pour compter le nombre de film total 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++; - + { var tableDetails = lignes[i+1].firstChild.firstChild.childNodes - // si le film satisfait la recherche alors on l'affiche sinon ou le cache - if ( - afficherTout || - document.getElementById("checkRechercheTitre").checked && rechercheRegExp.test(lignes[i].childNodes[2].textContent) + // si le film satisfait la recherche alors on l'affiche sinon on le cache + if + ( + afficherTout + || 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)) + || document.getElementById("checkRecherchePays").checked && rechercheRegExp.test(tableDetails[3].firstChild.nextSibling.textContent) + ) { lignes[i].style.display = "table-row" lignes[i+1].style.display = "table-row" + nbFilmAffiche++; } else @@ -137,6 +143,29 @@ function doRecherche(f) lignes[i+1].style.display = "none" } } + + if (r != null && nbFilmAffiche > 1) + { + var random + do { + random = Math.floor(Math.random() * nbFilmAffiche); + } while (dernierRandom == random) + dernierRandom = random + + var j = 0 + for(var i = 0; i < lignes.length; i += 2) + { + if (lignes[i].style.display == "none") continue; + if (random == j) + lignes[i+1].firstChild.firstChild.style.display = "table" + else + { + lignes[i].style.display = "none" + lignes[i+1].style.display = "none" + } + j += 1 + } + } // mise à jour de l'affichage du nombre de film total/affiché document.getElementById("nbFilms").textContent = nbFilmAffiche + " / " + nbFilm + " film" + (nbFilm > 1 ? "s" : "") @@ -165,6 +194,35 @@ function viderRecherche() doRecherche() } +/** + * Ouvre toutes les fiches affichées ou les fermes si elles sont ouvertes. + */ +function toutOuvrir() +{ + var lignes = document.getElementById("liste").childNodes + var ouvrir = null + for(var i = 0; i < lignes.length; i += 2) + { + var tableDetails = lignes[i+1].firstChild.firstChild.childNodes + + // si le film est affiché + if (lignes[i].style.display == "table-row") + { + if (ouvrir == null) + ouvrir = lignes[i+1].firstChild.firstChild.style.display == "none" + lignes[i+1].firstChild.firstChild.style.display = ouvrir ? "table" : "none" + } + } +} + +/** + * Choisi un film au hasard. + */ +function tirerUnFilmAuHasard() +{ + doRecherche(true); +} + /** * Recherche d'un genre, pays, réalisateur, etc.. * texte [String] : une chaine quelconque à rechercher