X-Git-Url: http://git.euphorik.ch/?a=blobdiff_plain;f=js%2Fyopyop.js;h=6f55fe585cdff59b71a68d58d1cb1cbfd6d78019;hb=2e1cf069cec72c7d77dd305251fe4b5c9201f8f9;hp=38a761f66f44f3dbf2e4347e3d4bc2e089950656;hpb=758f0146355cf0b6c0745d1e73c94c060fc6405c;p=pompage.git diff --git a/js/yopyop.js b/js/yopyop.js index 38a761f..6f55fe5 100644 --- a/js/yopyop.js +++ b/js/yopyop.js @@ -1,10 +1,10 @@ -/** +/** * Voir : http://developer.mozilla.org/fr/docs/R%C3%A9f%C3%A9rence_du_DOM_Gecko:Introduction#DOM_et_JavaScript * et : http://developer.mozilla.org/fr/docs/R%C3%A9f%C3%A9rence_du_DOM_Gecko:element */ /** - * Vire les espaces aux extremités d'une chaine. + * Vire les espaces aux extremité d'une chaine. * s [String] : une chaine */ function trim(s) @@ -13,7 +13,7 @@ function trim(s) } /** - * Vire les espaces au début d'une chaine. + * Vire les espaces au début d'une chaine. * s [String] : une chaine */ function ltrim(s) @@ -25,7 +25,7 @@ function ltrim(s) } /** - * Vire les espaces à la fin d'une chaine. + * Vire les espaces à fin d'une chaine. * s [String] : une chaine */ function rtrim(s) @@ -37,8 +37,23 @@ function rtrim(s) } /** - * Callback appelé lorsque un film est cliqué. - * Affiche ou cache les informations détaillés pour ce film. + * Affiche les fichiers d'un film. + */ +function afficherFichiers(id) +{ + var listeFichiers = document.getElementById("listeFichiers"+id) + listeFichiers.style.display = "block" +} + +function cacherFichiers(id) +{ + var listeFichiers = document.getElementById("listeFichiers"+id) + listeFichiers.style.display = "none" +} + +/** + * Callback appelé lorsque un film est cliqué + * Affiche ou cache les informations de détail pour ce film. * id [int] : l'identificateur du film */ function detailFilm(id) @@ -51,13 +66,35 @@ function detailFilm(id) detail.style.display = "table" } +// la date de la dernière recherche +var derniereRecherche = new Date(); +derniereRecherche.setMinutes(derniereRecherche.getMinutes() - 1); +var motifDerniereRecherche = "" /** - * Effectue une recherche, n'affiche que les films qui contiennent le motif recherché. + * 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. */ -function doRecherche() +function doRecherche(f) { + // le motif à chercher + var motif = document.getElementById("recherche").value + if (f == null && motif == motifDerniereRecherche) return; + + // empèche de faire deux recherches successive en moins de 800ms + var now = new Date(); + if (now.getTime() < derniereRecherche.getTime() + 800) + { + // si une recherche à était demandé mais n'a pu aboutir alors on la refait dans certain temps + setTimeout("doRecherche()", 810 - (now.getTime() - derniereRecherche.getTime())); + return; + } + motifDerniereRecherche = motif; + derniereRecherche = now; + + dump ("recherche : " + motif + "\r\n"); + debut = new Date().getTime() + var afficherTout = false; // si aucun choix n'est fait pour la recherche on affiche tout if (!document.getElementById("checkRechercheTitre").checked @@ -70,13 +107,11 @@ function doRecherche() var nbFilm = 0; // pour compter le nombre de film total var nbFilmAffiche = 0; // pour compter le nombre de film affiché - // le motif à chercher - var motif = document.getElementById("recherche").value - var rechercheRegExp = new RegExp(".*" + motif + ".*", "i") - + var rechercheRegExp = new RegExp(motif, "i") + var liste = document.getElementById("liste") var lignes = liste.childNodes - for(i = 0; i < lignes.length; i += 2) + for(var i = 0; i < lignes.length; i += 2) { nbFilm++; @@ -91,11 +126,11 @@ function doRecherche() // si le film satisfait la recherche alors on l'affiche sinon ou le cache if ( afficherTout || - document.getElementById("checkRechercheTitre").checked && rechercheRegExp.exec(titre) != null - || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.exec(genres) != null - || document.getElementById("checkRechercheRealisateurs").checked && rechercheRegExp.exec(realisateurs) != null - || document.getElementById("checkRechercheActeurs").checked && rechercheRegExp.exec(acteurs) != null - || document.getElementById("checkRecherchePays").checked && rechercheRegExp.exec(pays) != null) + document.getElementById("checkRechercheTitre").checked && rechercheRegExp.test(titre) + || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.test(genres) + || document.getElementById("checkRechercheRealisateurs").checked && rechercheRegExp.test(realisateurs) + || document.getElementById("checkRechercheActeurs").checked && rechercheRegExp.test(acteurs) + || document.getElementById("checkRecherchePays").checked && rechercheRegExp.test(pays)) { lignes[i].style.display = "table-row" lignes[i+1].style.display = "table-row" @@ -108,15 +143,24 @@ function doRecherche() } } - // mise à jour de l'affichage du nombre de film total/affiché + // mise à jour de l'affichage du nombre de film total/affiché document.getElementById("nbFilms").textContent = nbFilmAffiche + " / " + nbFilm + " film" + (nbFilm > 1 ? "s" : "") + + fin = new Date().getTime() + dump ("Temps : " + (fin - debut) / 1000 + "s\r\n\r\n") } /** - * Initialise la recherche. + * Initialise la recherche et referme tous les détails des films. */ function viderRecherche() -{ +{ + var lignes = document.getElementById("liste").childNodes + for(i = 1; i < lignes.length; i += 2) + { + lignes[i].firstChild.firstChild.style.display = "none"; + } + document.getElementById("checkRechercheTitre").checked = true document.getElementById("checkRechercheGenres").checked = true document.getElementById("checkRechercheRealisateurs").checked = true @@ -127,8 +171,8 @@ function viderRecherche() } /** - * Recherche d'un genre, pays, réalisateur, etc.. - * texte [String] : une chaine quelconque à rechercher + * Recherche d'un genre, pays, réalisateur, etc.. + * texte [String] : une chaine quelconque à rechercher * type [String] : dans quel champ porte la recherche. Valeurs possibles : 'Titre', 'Genres', 'Realisateurs', 'Acteurs', 'Pays' */ function rechercheElement(texte, type)