From: pifou Date: Mon, 2 Jul 2007 13:46:34 +0000 (+0000) Subject: ADD Fonction pour ouvrir les détails de tous les films affichées X-Git-Url: http://git.euphorik.ch/index.cgi?a=commitdiff_plain;h=728b3f5df7b780aabdaf563f9d93dd3ef4421820;p=pompage.git ADD Fonction pour ouvrir les détails de tous les films affichées 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 --- diff --git a/conception/ouvrir.psd b/conception/ouvrir.psd new file mode 100644 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 index 0000000..3ef5876 Binary files /dev/null and b/conception/random.psd differ diff --git a/css/yopyop.css b/css/yopyop.css index e2fd860..3647e35 100644 --- a/css/yopyop.css +++ b/css/yopyop.css @@ -99,10 +99,28 @@ div.entete form button { width: 25px; border: 0px; background-color: #B1F1A9; - background-image: url(../img/clear.png); background-position: center; background-repeat: no-repeat; vertical-align: top; + margin-left: 2px; +} +div.entete form button:hover { + background-color: #E3FBE0; +} +div.entete form button:active { + background-color: #FFFFFF; +} + +div.entete form button#boutonViderRecherche { + background-image: url(../img/clear.png); +} + +div.entete form button#boutonToutOuvrir { + background-image: url(../img/ouvrir.png); +} + +div.entete form button#boutonAuHasard { + background-image: url(../img/random.png); } div.entete form p { @@ -275,7 +293,7 @@ table#liste table.detail { } table#liste table.detail td { - padding: 3px; + padding: 3px 6px 3px 6px; background-color: #B1F1A9; } diff --git a/doc/todo.txt b/doc/todo.txt index b584fbc..533881c 100644 --- a/doc/todo.txt +++ b/doc/todo.txt @@ -13,10 +13,13 @@ [ok] Corriger les
qui apparaissent dans les synopsis [ok] Certains synopsis sont remplit avec un peu n'importe quoi (html et cie) (voir ben hur) [ok] Les films "vide" ne s'affiche pas bien (il manque une partie du tableau) +[ok] Choisir un film aléatoirement dans la liste des films +[ok] Tout dérouler ou enrouler les films actuellement affichées * Ajouter des options au programme : - Mettre à jour un film en donnant son ID en paramètre - Donner en paramètre un dossier pour les images - Re synchroniser toutes les informations des films (à partir du lien mémorisé dans les films) * Pomper les images (affichettes) +* Parser les langues et sous-titres et les ajouter dans l'xml * 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 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 index 0000000..bfdc8d2 Binary files /dev/null and b/img/random.png differ diff --git a/js/yopyop.js b/js/yopyop.js index da49920..4b48c8a 100644 --- a/js/yopyop.js +++ b/js/yopyop.js @@ -58,6 +58,8 @@ var motifDerniereRecherche = "" var nbPending = 0 +var dernierRandom = 0 + /** * Permet de mettr en queue les requêtes. */ @@ -71,8 +73,10 @@ function doRecherchePending() /** * 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) +function doRecherche(f, r) { // le motif à chercher var motif = document.getElementById("recherche").value @@ -105,30 +109,32 @@ function doRecherche(f) && !document.getElementById("checkRecherchePays").checked) afficherTout = true; - var nbFilm = 0; // pour compter le nombre de film total - var nbFilmAffiche = 0; // pour compter le nombre de film affiché + var liste = document.getElementById("liste") + var lignes = liste.childNodes + + var nbFilmAffiche = 0; // pour compter le nombre de film affiché + var nbFilm = lignes.length / 2; // pour compter le nombre de film total var rechercheRegExp = new RegExp(motif, "i") - var liste = document.getElementById("liste") - var lignes = liste.childNodes for(var i = 0; i < lignes.length; i += 2) - { - nbFilm++; - + { var tableDetails = lignes[i+1].firstChild.firstChild.childNodes - // si le film satisfait la recherche alors on l'affiche sinon ou le cache - if ( - afficherTout || - document.getElementById("checkRechercheTitre").checked && rechercheRegExp.test(lignes[i].childNodes[2].textContent) + // si le film satisfait la recherche alors on l'affiche sinon on le cache + if + ( + afficherTout + || document.getElementById("checkRechercheTitre").checked && rechercheRegExp.test(lignes[i].childNodes[2].textContent) || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.test(tableDetails[0].firstChild.nextSibling.nextSibling.textContent) || document.getElementById("checkRechercheRealisateurs").checked && rechercheRegExp.test(tableDetails[1].firstChild.nextSibling.textContent) || document.getElementById("checkRechercheActeurs").checked && rechercheRegExp.test(tableDetails[2].firstChild.nextSibling.textContent) - || document.getElementById("checkRecherchePays").checked && rechercheRegExp.test(tableDetails[3].firstChild.nextSibling.textContent)) + || document.getElementById("checkRecherchePays").checked && rechercheRegExp.test(tableDetails[3].firstChild.nextSibling.textContent) + ) { lignes[i].style.display = "table-row" lignes[i+1].style.display = "table-row" + nbFilmAffiche++; } else @@ -138,6 +144,29 @@ function doRecherche(f) } } + if (r != null && nbFilmAffiche > 1) + { + var random + do { + random = Math.floor(Math.random() * nbFilmAffiche); + } while (dernierRandom == random) + dernierRandom = random + + var j = 0 + for(var i = 0; i < lignes.length; i += 2) + { + if (lignes[i].style.display == "none") continue; + if (random == j) + lignes[i+1].firstChild.firstChild.style.display = "table" + else + { + lignes[i].style.display = "none" + lignes[i+1].style.display = "none" + } + j += 1 + } + } + // mise à jour de l'affichage du nombre de film total/affiché document.getElementById("nbFilms").textContent = nbFilmAffiche + " / " + nbFilm + " film" + (nbFilm > 1 ? "s" : "") @@ -162,7 +191,35 @@ function viderRecherche() document.getElementById("checkRechercheActeurs").checked = true document.getElementById("checkRecherchePays").checked = true document.getElementById("recherche").value = "" - doRecherche() + doRecherche(true) +} + +/** + * Ouvre toutes les fiches affichées ou les fermes si elles sont ouvertes. + */ +function toutOuvrir() +{ + var lignes = document.getElementById("liste").childNodes + var ouvrir = true + for(var i = 0; i < lignes.length; i += 2) + { + var tableDetails = lignes[i+1].firstChild.firstChild.childNodes + + if (lignes[i+1].style.display = "table-row") + { + if (i == 0 && lignes[i+1].firstChild.firstChild.style.display == "table") + ouvrir = false + lignes[i+1].firstChild.firstChild.style.display = ouvrir ? "table" : "none" + } + } +} + +/** + * Choisi un film au hasard. + */ +function tirerUnFilmAuHasard() +{ + doRecherche(true, true); } /** diff --git a/src/basemodule.rb b/src/basemodule.rb index 38849f2..e67a729 100644 --- a/src/basemodule.rb +++ b/src/basemodule.rb @@ -18,6 +18,5 @@ class Basemodule # appelé lorsque le module n'est plus utile (permet de libérer des ressource par exemple). def finish - end end \ No newline at end of file diff --git a/src/modules/allocine.rb b/src/modules/allocine.rb index d5da08c..893f7ed 100644 --- a/src/modules/allocine.rb +++ b/src/modules/allocine.rb @@ -6,13 +6,17 @@ require 'iconv' require "basemodule.rb" -# un mixin pour allocine +# un module d'importation pour le site "www.allocine.fr" class Allocine < Basemodule - + + def createConnexion + @connexion = Net::HTTP::new('www.allocine.fr') if @connexion.nil? + end + # Voir le parent. def rechercherFilm(titre) - @connexion = Net::HTTP::new('www.allocine.fr') if @connexion.nil? - + createConnexion + donneesHtml = nil begin begin @@ -49,7 +53,7 @@ class Allocine < Basemodule # Voir le parent. def load(id, film) - @connexion = Net::HTTP::new('www.allocine.fr') if @connexion.nil? + createConnexion r, ficheHtml = @connexion.get("/film/fichefilm_gen_cfilm=#{id}.html") diff --git a/xsl/yopyop.xsl b/xsl/yopyop.xsl index 4ca43e9..22225da 100644 --- a/xsl/yopyop.xsl +++ b/xsl/yopyop.xsl @@ -18,7 +18,9 @@

- + + +