MOD Amélioration de la recherche (encore)
[pompage.git] / js / yopyop.js
index 7232cc9..c4b2af0 100644 (file)
@@ -1,11 +1,45 @@
-/**\r
+/**\r
   * Voir : http://developer.mozilla.org/fr/docs/R%C3%A9f%C3%A9rence_du_DOM_Gecko:Introduction#DOM_et_JavaScript\r
   * et : http://developer.mozilla.org/fr/docs/R%C3%A9f%C3%A9rence_du_DOM_Gecko:element\r
   */\r
 \r
 /**\r
-  * Callback appelé lorsque un film est clické.\r
-  * Affiche ou cache les informations détaillés pour ce film.\r
+  * Vire les espaces aux extremité d'une chaine.\r
+  * s [String] : une chaine\r
+  */\r
+function trim(s)\r
+{\r
+       return rtrim(ltrim(s));\r
+}\r
+\r
+/**\r
+  * Vire les espaces au début d'une chaine.\r
+  * s [String] : une chaine\r
+  */\r
+function ltrim(s)\r
+{\r
+       var l=0;\r
+       while(l < s.length && s[l] == ' ')\r
+       {       l++; }\r
+       return s.substring(l, s.length);\r
+}\r
+\r
+/**\r
+  * Vire les espaces à fin d'une chaine.\r
+  * s [String] : une chaine\r
+  */\r
+function rtrim(s)\r
+{\r
+       var r=s.length -1;\r
+       while(r > 0 && s[r] == ' ')\r
+       {       r-=1;   }\r
+       return s.substring(0, r+1);\r
+}\r
+\r
+/**\r
+  * Callback appelé lorsque un film est cliqué\r
+  * Affiche ou cache les informations de détail pour ce film.\r
+  * id [int] : l'identificateur du film\r
   */\r
 function detailFilm(id)\r
 {\r
@@ -17,34 +51,134 @@ function detailFilm(id)
       detail.style.display = "table"\r
 }\r
 \r
+// 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
+/**\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é.\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
-function doRecherche()\r
+function doRecherche(f)\r
 {\r
+   // le motif à chercher\r
    var motif = document.getElementById("recherche").value\r
-   var rechercheRegExp = new RegExp(".*" + motif + ".*", "i")\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("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
+   debut = new Date().getTime()\r
 \r
+   var afficherTout = false;\r
+   // si aucun choix n'est fait pour la recherche on affiche tout\r
+   if (!document.getElementById("checkRechercheTitre").checked \r
+      && !document.getElementById("checkRechercheGenres").checked\r
+      && !document.getElementById("checkRechercheRealisateurs").checked\r
+      && !document.getElementById("checkRechercheActeurs").checked\r
+      && !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
+   \r
+   var rechercheRegExp = new RegExp(motif, "i")\r
+      \r
    var liste = document.getElementById("liste")\r
    var lignes = liste.childNodes\r
-   for(i = 1; i < lignes.length; i += 2)\r
+   for(var i = 0; i < lignes.length; i += 2)\r
    {\r
-      var titre = lignes[i].firstChild.innerHTML\r
-      if (rechercheRegExp.exec(titre) == null)      \r
+      nbFilm++;\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
+         || 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 = "none"\r
-         lignes[i+1].firstChild.firstChild.style.display = "none"\r
+         lignes[i].style.display = "table-row"  \r
+         lignes[i+1].style.display = "table-row" \r
+         nbFilmAffiche++;\r
       }\r
       else\r
       {\r
-         lignes[i].style.display = "table-row"   \r
+         lignes[i].style.display = "none"\r
+         lignes[i+1].style.display = "none"\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
+   document.getElementById("tempsRecherche").textContent = "Temps de la recherche : " + (fin - debut) / 1000 + "s"\r
 }\r
 \r
+/**\r
+  * Initialise la recherche et referme tous les détails des films.\r
+  */\r
 function viderRecherche()\r
-{\r
+{      \r
+   var lignes = document.getElementById("liste").childNodes\r
+   for(i = 1; i < lignes.length; i += 2)\r
+   {\r
+      lignes[i].firstChild.firstChild.style.display = "none";\r
+   }\r
+   \r
+   document.getElementById("checkRechercheTitre").checked = true\r
+   document.getElementById("checkRechercheGenres").checked = true\r
+   document.getElementById("checkRechercheRealisateurs").checked = true\r
+   document.getElementById("checkRechercheActeurs").checked = true\r
+   document.getElementById("checkRecherchePays").checked = true\r
    document.getElementById("recherche").value = ""\r
    doRecherche()\r
+}\r
+\r
+/**\r
+  * Recherche d'un genre, pays, réalisateur, etc..\r
+  * texte [String] : une chaine quelconque à rechercher\r
+  * type [String] : dans quel champ porte la recherche. Valeurs possibles : 'Titre', 'Genres', 'Realisateurs', 'Acteurs', 'Pays'\r
+  */ \r
+function rechercheElement(texte, type)\r
+{\r
+   texte = trim(texte)\r
+   document.getElementById("checkRechercheTitre").checked = false\r
+   document.getElementById("checkRechercheGenres").checked = false\r
+   document.getElementById("checkRechercheRealisateurs").checked = false\r
+   document.getElementById("checkRechercheActeurs").checked = false\r
+   document.getElementById("checkRecherchePays").checked = false\r
+   document.getElementById("checkRecherche"+type).checked = true\r
+   document.getElementById("recherche").value = texte\r
+   doRecherche()\r
 }
\ No newline at end of file