ADD Fonction pour ouvrir les détails de tous les films affichées
authorpifou <pifou@02bbb61a-6d21-0410-aba0-cb053bdfd66a>
Mon, 2 Jul 2007 13:46:34 +0000 (13:46 +0000)
committerpifou <pifou@02bbb61a-6d21-0410-aba0-cb053bdfd66a>
Mon, 2 Jul 2007 13:46:34 +0000 (13:46 +0000)
ADD Fonction pour choisir un film au hasard parmis ceux affichés

git-svn-id: svn://euphorik.ch/pompage@43 02bbb61a-6d21-0410-aba0-cb053bdfd66a

conception/ouvrir.psd [new file with mode: 0644]
conception/random.psd [new file with mode: 0644]
css/yopyop.css
doc/todo.txt
img/ouvrir.png [new file with mode: 0644]
img/random.png [new file with mode: 0644]
js/yopyop.js
src/basemodule.rb
src/modules/allocine.rb
xsl/yopyop.xsl

diff --git a/conception/ouvrir.psd b/conception/ouvrir.psd
new file mode 100644 (file)
index 0000000..0f3582a
Binary files /dev/null and b/conception/ouvrir.psd differ
diff --git a/conception/random.psd b/conception/random.psd
new file mode 100644 (file)
index 0000000..3ef5876
Binary files /dev/null and b/conception/random.psd differ
index e2fd860..3647e35 100644 (file)
@@ -99,10 +99,28 @@ div.entete form button {
    width: 25px;\r
    border: 0px;\r
    background-color: #B1F1A9;\r
-   background-image: url(../img/clear.png);\r
    background-position: center;\r
    background-repeat: no-repeat;\r
    vertical-align: top;\r
+   margin-left: 2px;\r
+}\r
+div.entete form button:hover {\r
+   background-color: #E3FBE0;\r
+}\r
+div.entete form button:active {\r
+   background-color: #FFFFFF;\r
+}\r
+\r
+div.entete form button#boutonViderRecherche {\r
+   background-image: url(../img/clear.png);\r
+}\r
+\r
+div.entete form button#boutonToutOuvrir {\r
+   background-image: url(../img/ouvrir.png);\r
+}\r
+\r
+div.entete form button#boutonAuHasard {\r
+   background-image: url(../img/random.png);\r
 }\r
 \r
 div.entete form p {\r
@@ -275,7 +293,7 @@ table#liste table.detail {
 }\r
 \r
 table#liste table.detail td {\r
-   padding: 3px;   \r
+   padding: 3px 6px 3px 6px;   \r
    background-color: #B1F1A9;\r
 }\r
 \r
index b584fbc..533881c 100644 (file)
 [ok] Corriger les <br/> qui apparaissent dans les synopsis\r
 [ok] Certains synopsis sont remplit avec un peu n'importe quoi (html et cie) (voir ben hur)\r
 [ok] Les films "vide" ne s'affiche pas bien (il manque une partie du tableau)\r
+[ok] Choisir un film aléatoirement dans la liste des films\r
+[ok] Tout dérouler ou enrouler les films actuellement affichées\r
 \r
 * Ajouter des options au programme :\r
  - Mettre à jour un film en donnant son ID en paramètre\r
  - Donner en paramètre un dossier pour les images\r
  - Re synchroniser toutes les informations des films (à partir du lien mémorisé dans les films)\r
 * Pomper les images (affichettes)\r
+* Parser les langues et sous-titres et les ajouter dans l'xml\r
 * Parser les langues et sous-titres et les ajouter dans l'xml
\ No newline at end of file
diff --git a/img/ouvrir.png b/img/ouvrir.png
new file mode 100644 (file)
index 0000000..f2ccb31
Binary files /dev/null and b/img/ouvrir.png differ
diff --git a/img/random.png b/img/random.png
new file mode 100644 (file)
index 0000000..bfdc8d2
Binary files /dev/null and b/img/random.png differ
index da49920..4b48c8a 100644 (file)
@@ -58,6 +58,8 @@ var motifDerniereRecherche = ""
 \r
 var nbPending = 0\r
 \r
+var dernierRandom = 0\r
+\r
 /**\r
   * Permet de mettr en queue les requêtes.\r
   */\r
@@ -71,8 +73,10 @@ function doRecherchePending()
 /**\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
+  * 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
+  * r : si pas null alors n'affiche qu'un film au hasard dans la sélection\r
   */\r
-function doRecherche(f)\r
+function doRecherche(f, r)\r
 {\r
    // le motif à chercher\r
    var motif = document.getElementById("recherche").value\r
@@ -105,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
+      // 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
@@ -138,6 +144,29 @@ function doRecherche(f)
       }\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
@@ -162,7 +191,35 @@ function viderRecherche()
    document.getElementById("checkRechercheActeurs").checked = true\r
    document.getElementById("checkRecherchePays").checked = true\r
    document.getElementById("recherche").value = ""\r
-   doRecherche()\r
+   doRecherche(true)\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 = true\r
+   for(var i = 0; i < lignes.length; i += 2)\r
+   {      \r
+      var tableDetails = lignes[i+1].firstChild.firstChild.childNodes\r
+      \r
+      if (lignes[i+1].style.display = "table-row")\r
+      {\r
+         if (i == 0 && lignes[i+1].firstChild.firstChild.style.display == "table")\r
+             ouvrir = false\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, true);\r
 }\r
 \r
 /**\r
index 38849f2..e67a729 100644 (file)
@@ -18,6 +18,5 @@ class Basemodule
     \r
    # appelé lorsque le module n'est plus utile (permet de libérer des ressource par exemple).\r
    def finish\r
-      \r
    end\r
 end
\ No newline at end of file
index d5da08c..893f7ed 100644 (file)
@@ -6,13 +6,17 @@ require 'iconv'
 \r
 require "basemodule.rb"\r
 \r
-# un mixin pour allocine\r
+# un module d'importation pour le site "www.allocine.fr"\r
 class Allocine  < Basemodule\r
-      \r
+   \r
+   def createConnexion\r
+      @connexion = Net::HTTP::new('www.allocine.fr') if @connexion.nil?      \r
+   end\r
+   \r
    # Voir le parent.\r
    def rechercherFilm(titre)\r
-      @connexion = Net::HTTP::new('www.allocine.fr') if @connexion.nil?\r
-      \r
+      createConnexion\r
+\r
       donneesHtml = nil\r
       begin\r
          begin\r
@@ -49,7 +53,7 @@ class Allocine  < Basemodule
    \r
    # Voir le parent.\r
    def load(id, film)      \r
-      @connexion = Net::HTTP::new('www.allocine.fr') if @connexion.nil?\r
+      createConnexion\r
 \r
       r, ficheHtml = @connexion.get("/film/fichefilm_gen_cfilm=#{id}.html") \r
       \r
index 4ca43e9..22225da 100644 (file)
@@ -18,7 +18,9 @@
      <form class="formulaireRecherche">\r
       <p>\r
        <input type="text" onkeyup="doRecherche()" id="recherche" />\r
-       <button onclick="viderRecherche()" ></button>\r
+       <button onclick="viderRecherche()" id="boutonViderRecherche" title="Réinitialiser la recherche" ></button>\r
+       <button onclick="toutOuvrir()" id="boutonToutOuvrir" title="Voir / Cacher le détail des films" ></button>\r
+       <button onclick="tirerUnFilmAuHasard()" id="boutonAuHasard" title="Tirer un film au hasard" ></button>\r
       </p>\r
       <p>\r
        <input onclick="doRecherche(true)" id="checkRechercheTitre" type="checkbox" checked="checked" /><label for="checkRechercheTitre">titre</label>\r