MOD Amélioration de la recherche (encore)
[pompage.git] / js / yopyop.js
index 6f55fe5..c4b2af0 100644 (file)
@@ -36,21 +36,6 @@ function rtrim(s)
        return s.substring(0, r+1);\r
 }\r
 \r
-/**\r
-  * Affiche les fichiers d'un film.\r
-  */\r
-function afficherFichiers(id)\r
-{\r
-   var listeFichiers = document.getElementById("listeFichiers"+id)\r
-   listeFichiers.style.display = "block"\r
-}\r
-\r
-function cacherFichiers(id)\r
-{\r
-   var listeFichiers = document.getElementById("listeFichiers"+id)\r
-   listeFichiers.style.display = "none"\r
-}\r
-\r
 /**\r
   * Callback appelé lorsque un film est cliqué\r
   * Affiche ou cache les informations de détail pour ce film.\r
@@ -71,6 +56,18 @@ var derniereRecherche = new Date();
 derniereRecherche.setMinutes(derniereRecherche.getMinutes() - 1);\r
 var motifDerniereRecherche = ""\r
 \r
+var nbPending = 0\r
+\r
+/**\r
+  * Permet de mettr en queue les requêtes.\r
+  */\r
+function doRecherchePending()\r
+{\r
+   nbPending -= 1;\r
+   if (nbPending == 0) // si c'est la dernière requête en attente on l'effectue\r
+      doRecherche();\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
@@ -79,20 +76,24 @@ function doRecherche(f)
 {\r
    // le motif à chercher\r
    var motif = document.getElementById("recherche").value\r
-   if (f == null && motif == motifDerniereRecherche) return;\r
+   motif = trim(motif)\r
    \r
+   if (f == null && motif == motifDerniereRecherche) return;\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
    {\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("doRecherchePending()", 810 - (now.getTime() - derniereRecherche.getTime()));\r
+      nbPending += 1\r
       return;\r
    }\r
+   \r
    motifDerniereRecherche = motif;\r
    derniereRecherche = now;\r
-   \r
-   dump ("recherche : " + motif + "\r\n");\r
+      \r
+   //dump ("recherche : " + motif + "\r\n");\r
    debut = new Date().getTime()\r
 \r
    var afficherTout = false;\r
@@ -105,8 +106,8 @@ function doRecherche(f)
       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
-      \r
+   var nbFilmAffiche = 0; // pour compter le nombre de film affiché\r
+   \r
    var rechercheRegExp = new RegExp(motif, "i")\r
       \r
    var liste = document.getElementById("liste")\r
@@ -115,22 +116,16 @@ function doRecherche(f)
    {\r
       nbFilm++;\r
       \r
-      // extraction des informations du film courant\r
-      var titre = lignes[i].firstChild.innerHTML\r
       var tableDetails = lignes[i+1].firstChild.firstChild.childNodes\r
-      var genres = tableDetails[0].firstChild.nextSibling.textContent\r
-      var realisateurs = tableDetails[1].firstChild.nextSibling.textContent\r
-      var acteurs = tableDetails[2].firstChild.nextSibling.textContent\r
-      var pays = tableDetails[3].firstChild.nextSibling.textContent\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(titre\r
-         || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.test(genres\r
-         || document.getElementById("checkRechercheRealisateurs").checked && rechercheRegExp.test(realisateurs)\r
-         || document.getElementById("checkRechercheActeurs").checked && rechercheRegExp.test(acteurs\r
-         || document.getElementById("checkRecherchePays").checked && rechercheRegExp.test(pays))      \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
+         || 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
       {\r
          lignes[i].style.display = "table-row"  \r
          lignes[i+1].style.display = "table-row" \r
@@ -147,7 +142,7 @@ function doRecherche(f)
    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
+   document.getElementById("tempsRecherche").textContent = "Temps de la recherche : " + (fin - debut) / 1000 + "s"\r
 }\r
 \r
 /**\r