X-Git-Url: http://git.euphorik.ch/?a=blobdiff_plain;f=js%2Fyopyop.js;h=7ce234023b0fc09085321f5a7d3e3863e843e1b2;hb=339621e8669fbd4b09e2d0825f5521469503837b;hp=1bad4bd2a487d5277253b0de603010bd5b96c830;hpb=cff6539539a79e014f6ac8df46716cafce2c8472;p=pompage.git diff --git a/js/yopyop.js b/js/yopyop.js index 1bad4bd..7ce2340 100644 --- a/js/yopyop.js +++ b/js/yopyop.js @@ -54,7 +54,6 @@ function detailFilm(id) // la date de la dernière recherche var derniereRecherche = new Date(); derniereRecherche.setMinutes(derniereRecherche.getMinutes() - 1); -var motifDerniereRecherche = "" var nbPending = 0 @@ -63,38 +62,39 @@ 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. - * f : si pas null alors la recherche est quand même effectué même si le moif est le même que la précédente recherche * r : si pas null alors n'affiche qu'un film au hasard dans la sélection */ -function doRecherche(f, r) -{ +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"); @@ -143,7 +143,7 @@ function doRecherche(f, r) lignes[i+1].style.display = "none" } } - + if (r != null && nbFilmAffiche > 1) { var random @@ -191,7 +191,7 @@ function viderRecherche() document.getElementById("checkRechercheActeurs").checked = true document.getElementById("checkRecherchePays").checked = true document.getElementById("recherche").value = "" - doRecherche(true) + doRecherche() } /** @@ -208,7 +208,8 @@ function toutOuvrir() // si le film est affiché if (lignes[i].style.display == "table-row") { - if (ouvrir == null) ouvrir = lignes[i+1].firstChild.firstChild.style.display == "none" + if (ouvrir == null) + ouvrir = lignes[i+1].firstChild.firstChild.style.display == "none" lignes[i+1].firstChild.firstChild.style.display = ouvrir ? "table" : "none" } } @@ -219,7 +220,7 @@ function toutOuvrir() */ function tirerUnFilmAuHasard() { - doRecherche(true, true); + doRecherche(true); } /**