ADD Amélioration de l'update des films déjà en BD
[pompage.git] / js / yopyop.js
index af553f8..7ce2340 100644 (file)
@@ -54,31 +54,51 @@ function detailFilm(id)
 // la date de la dernière recherche\r
 var derniereRecherche = new Date();\r
 derniereRecherche.setMinutes(derniereRecherche.getMinutes() - 1);\r
-var motifDerniereRecherche = ""\r
+\r
+var nbPending = 0\r
+\r
+var dernierRandom = 0\r
+\r
+/**\r
+  * Permet de mettr en queue les requêtes.\r
+  */\r
+function doRecherchePending(r)\r
+{\r
+   nbPending -= 1;\r
+   if (nbPending == 0) // si c'est la dernière requête en attente on l'effectue\r
+      r == null ? doRecherche() : doRecherche(r);\r
+}\r
+\r
+function doRecherchePendingRandom()\r
+{\r
+   doRecherchePending(true)\r
+}\r
 \r
 /**\r
   * 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
+  * r : si pas null alors n'affiche qu'un film au hasard dans la sélection\r
   */\r
-function doRecherche(f)\r
-{\r
+function doRecherche(r)\r
+{ \r
    // le motif à chercher\r
    var motif = document.getElementById("recherche").value\r
-   if (f == null && motif == motifDerniereRecherche) return;\r
+   motif = trim(motif)\r
    \r
    // empèche de faire deux recherches successive en moins de 800ms\r
    var now = new Date();\r
-   if (now.getTime() < derniereRecherche.getTime() + 800)\r
+   if (now.getTime() - derniereRecherche.getTime() < 800)\r
    {\r
+      nbPending += 1\r
       // si une recherche à était demandé mais n'a pu aboutir alors on la refait dans certain temps\r
-      setTimeout("doRecherche()", 810 - (now.getTime() - derniereRecherche.getTime()));\r
+      setTimeout(r == true ? "doRecherchePendingRandom()" : "doRecherchePending()", 900 - (now.getTime() - derniereRecherche.getTime()));\r
       return;\r
    }\r
-   motifDerniereRecherche = motif;\r
-   derniereRecherche = now;\r
    \r
+   derniereRecherche = now;\r
+      \r
    //dump ("recherche : " + motif + "\r\n");\r
-   //debut = new Date().getTime()\r
+   debut = new Date().getTime()\r
 \r
    var afficherTout = false;\r
    // si aucun choix n'est fait pour la recherche on affiche tout\r
@@ -89,30 +109,32 @@ function doRecherche(f)
       && !document.getElementById("checkRecherchePays").checked)\r
       afficherTout = true;\r
       \r
-   var nbFilm = 0; // pour compter le nombre de film total\r
-   var nbFilmAffiche = 0; // pour compter le nombre de film affiché\r
+   var liste = document.getElementById("liste")\r
+   var lignes = liste.childNodes\r
+   \r
+   var nbFilmAffiche = 0; // pour compter le nombre de film affiché   \r
+   var nbFilm = lignes.length / 2; // pour compter le nombre de film total\r
    \r
    var rechercheRegExp = new RegExp(motif, "i")\r
       \r
-   var liste = document.getElementById("liste")\r
-   var lignes = liste.childNodes\r
    for(var i = 0; i < lignes.length; i += 2)\r
-   {\r
-      nbFilm++;\r
-      \r
+   {      \r
       var tableDetails = lignes[i+1].firstChild.firstChild.childNodes\r
       \r
-      // si le film satisfait la recherche alors on l'affiche sinon ou le cache\r
-      if (\r
-         afficherTout ||\r
-         document.getElementById("checkRechercheTitre").checked && rechercheRegExp.test(lignes[i].childNodes[2].textContent) \r
-         || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.test(tableDetails[0].firstChild.nextSibling.textContent) \r
+      // si le film satisfait la recherche alors on l'affiche sinon on le cache\r
+      if\r
+      (\r
+         afficherTout\r
+         || document.getElementById("checkRechercheTitre").checked && rechercheRegExp.test(lignes[i].childNodes[2].textContent) \r
+         || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.test(tableDetails[0].firstChild.nextSibling.nextSibling.textContent) \r
          || document.getElementById("checkRechercheRealisateurs").checked && rechercheRegExp.test(tableDetails[1].firstChild.nextSibling.textContent)\r
          || document.getElementById("checkRechercheActeurs").checked && rechercheRegExp.test(tableDetails[2].firstChild.nextSibling.textContent) \r
-         || document.getElementById("checkRecherchePays").checked && rechercheRegExp.test(tableDetails[3].firstChild.nextSibling.textContent))      \r
+         || document.getElementById("checkRecherchePays").checked && rechercheRegExp.test(tableDetails[3].firstChild.nextSibling.textContent)\r
+      )\r
       {\r
          lignes[i].style.display = "table-row"  \r
          lignes[i+1].style.display = "table-row" \r
+         \r
          nbFilmAffiche++;\r
       }\r
       else\r
@@ -121,12 +143,35 @@ function doRecherche(f)
          lignes[i+1].style.display = "none"\r
       }\r
    }\r
+\r
+   if (r != null && nbFilmAffiche > 1)\r
+   {\r
+      var random\r
+      do {\r
+         random = Math.floor(Math.random() * nbFilmAffiche);\r
+      } while (dernierRandom == random)\r
+      dernierRandom = random\r
+      \r
+      var j = 0\r
+      for(var i = 0; i < lignes.length; i += 2)\r
+      {\r
+         if (lignes[i].style.display == "none") continue;\r
+         if (random == j)\r
+            lignes[i+1].firstChild.firstChild.style.display = "table"\r
+         else         \r
+         {\r
+            lignes[i].style.display = "none"\r
+            lignes[i+1].style.display = "none"\r
+         }\r
+         j += 1\r
+      }\r
+   }\r
    \r
    // mise à jour de l'affichage du nombre de film total/affiché\r
    document.getElementById("nbFilms").textContent = nbFilmAffiche + " / " + nbFilm + " film" + (nbFilm > 1 ? "s" : "")\r
    \r
-   //fin = new Date().getTime()\r
-   //dump ("Temps : " + (fin - debut) / 1000 + "s\r\n\r\n")\r
+   fin = new Date().getTime()\r
+   document.getElementById("tempsRecherche").textContent = "Temps de la recherche : " + (fin - debut) / 1000 + "s"\r
 }\r
 \r
 /**\r
@@ -149,6 +194,35 @@ function viderRecherche()
    doRecherche()\r
 }\r
 \r
+/**\r
+  * Ouvre toutes les fiches affichées ou les fermes si elles sont ouvertes.\r
+  */\r
+function toutOuvrir()\r
+{\r
+   var lignes = document.getElementById("liste").childNodes\r
+   var ouvrir = null\r
+   for(var i = 0; i < lignes.length; i += 2)\r
+   {      \r
+      var tableDetails = lignes[i+1].firstChild.firstChild.childNodes\r
+      \r
+      // si le film est affiché\r
+      if (lignes[i].style.display == "table-row")\r
+      {\r
+         if (ouvrir == null)\r
+            ouvrir = lignes[i+1].firstChild.firstChild.style.display == "none"\r
+         lignes[i+1].firstChild.firstChild.style.display = ouvrir ? "table" : "none"\r
+      }\r
+   }\r
+}\r
+\r
+/**\r
+  * Choisi un film au hasard.\r
+  */\r
+function tirerUnFilmAuHasard()\r
+{\r
+   doRecherche(true);\r
+}\r
+\r
 /**\r
   * Recherche d'un genre, pays, réalisateur, etc..\r
   * texte [String] : une chaine quelconque à rechercher\r