6f55fe585cdff59b71a68d58d1cb1cbfd6d78019
[pompage.git] / js / yopyop.js
1 /**
2 * Voir : http://developer.mozilla.org/fr/docs/R%C3%A9f%C3%A9rence_du_DOM_Gecko:Introduction#DOM_et_JavaScript
3 * et : http://developer.mozilla.org/fr/docs/R%C3%A9f%C3%A9rence_du_DOM_Gecko:element
4 */
5
6 /**
7 * Vire les espaces aux extremité d'une chaine.
8 * s [String] : une chaine
9 */
10 function trim(s)
11 {
12 return rtrim(ltrim(s));
13 }
14
15 /**
16 * Vire les espaces au début d'une chaine.
17 * s [String] : une chaine
18 */
19 function ltrim(s)
20 {
21 var l=0;
22 while(l < s.length && s[l] == ' ')
23 { l++; }
24 return s.substring(l, s.length);
25 }
26
27 /**
28 * Vire les espaces à fin d'une chaine.
29 * s [String] : une chaine
30 */
31 function rtrim(s)
32 {
33 var r=s.length -1;
34 while(r > 0 && s[r] == ' ')
35 { r-=1; }
36 return s.substring(0, r+1);
37 }
38
39 /**
40 * Affiche les fichiers d'un film.
41 */
42 function afficherFichiers(id)
43 {
44 var listeFichiers = document.getElementById("listeFichiers"+id)
45 listeFichiers.style.display = "block"
46 }
47
48 function cacherFichiers(id)
49 {
50 var listeFichiers = document.getElementById("listeFichiers"+id)
51 listeFichiers.style.display = "none"
52 }
53
54 /**
55 * Callback appelé lorsque un film est cliqué
56 * Affiche ou cache les informations de détail pour ce film.
57 * id [int] : l'identificateur du film
58 */
59 function detailFilm(id)
60 {
61 var detail = document.getElementById("detail"+id)
62
63 if (detail.style.display == "table")
64 detail.style.display = "none"
65 else
66 detail.style.display = "table"
67 }
68
69 // la date de la dernière recherche
70 var derniereRecherche = new Date();
71 derniereRecherche.setMinutes(derniereRecherche.getMinutes() - 1);
72 var motifDerniereRecherche = ""
73
74 /**
75 * Effectue une recherche, n'affiche que les films qui contiennent le motif recherché
76 * Recherche dans le titre, le realisateur, les acteurs, les genres et les pays en fonction des checkbox respectives.
77 */
78 function doRecherche(f)
79 {
80 // le motif à chercher
81 var motif = document.getElementById("recherche").value
82 if (f == null && motif == motifDerniereRecherche) return;
83
84 // empèche de faire deux recherches successive en moins de 800ms
85 var now = new Date();
86 if (now.getTime() < derniereRecherche.getTime() + 800)
87 {
88 // si une recherche à était demandé mais n'a pu aboutir alors on la refait dans certain temps
89 setTimeout("doRecherche()", 810 - (now.getTime() - derniereRecherche.getTime()));
90 return;
91 }
92 motifDerniereRecherche = motif;
93 derniereRecherche = now;
94
95 dump ("recherche : " + motif + "\r\n");
96 debut = new Date().getTime()
97
98 var afficherTout = false;
99 // si aucun choix n'est fait pour la recherche on affiche tout
100 if (!document.getElementById("checkRechercheTitre").checked
101 && !document.getElementById("checkRechercheGenres").checked
102 && !document.getElementById("checkRechercheRealisateurs").checked
103 && !document.getElementById("checkRechercheActeurs").checked
104 && !document.getElementById("checkRecherchePays").checked)
105 afficherTout = true;
106
107 var nbFilm = 0; // pour compter le nombre de film total
108 var nbFilmAffiche = 0; // pour compter le nombre de film affiché
109
110 var rechercheRegExp = new RegExp(motif, "i")
111
112 var liste = document.getElementById("liste")
113 var lignes = liste.childNodes
114 for(var i = 0; i < lignes.length; i += 2)
115 {
116 nbFilm++;
117
118 // extraction des informations du film courant
119 var titre = lignes[i].firstChild.innerHTML
120 var tableDetails = lignes[i+1].firstChild.firstChild.childNodes
121 var genres = tableDetails[0].firstChild.nextSibling.textContent
122 var realisateurs = tableDetails[1].firstChild.nextSibling.textContent
123 var acteurs = tableDetails[2].firstChild.nextSibling.textContent
124 var pays = tableDetails[3].firstChild.nextSibling.textContent
125
126 // si le film satisfait la recherche alors on l'affiche sinon ou le cache
127 if (
128 afficherTout ||
129 document.getElementById("checkRechercheTitre").checked && rechercheRegExp.test(titre)
130 || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.test(genres)
131 || document.getElementById("checkRechercheRealisateurs").checked && rechercheRegExp.test(realisateurs)
132 || document.getElementById("checkRechercheActeurs").checked && rechercheRegExp.test(acteurs)
133 || document.getElementById("checkRecherchePays").checked && rechercheRegExp.test(pays))
134 {
135 lignes[i].style.display = "table-row"
136 lignes[i+1].style.display = "table-row"
137 nbFilmAffiche++;
138 }
139 else
140 {
141 lignes[i].style.display = "none"
142 lignes[i+1].style.display = "none"
143 }
144 }
145
146 // mise à jour de l'affichage du nombre de film total/affiché
147 document.getElementById("nbFilms").textContent = nbFilmAffiche + " / " + nbFilm + " film" + (nbFilm > 1 ? "s" : "")
148
149 fin = new Date().getTime()
150 dump ("Temps : " + (fin - debut) / 1000 + "s\r\n\r\n")
151 }
152
153 /**
154 * Initialise la recherche et referme tous les détails des films.
155 */
156 function viderRecherche()
157 {
158 var lignes = document.getElementById("liste").childNodes
159 for(i = 1; i < lignes.length; i += 2)
160 {
161 lignes[i].firstChild.firstChild.style.display = "none";
162 }
163
164 document.getElementById("checkRechercheTitre").checked = true
165 document.getElementById("checkRechercheGenres").checked = true
166 document.getElementById("checkRechercheRealisateurs").checked = true
167 document.getElementById("checkRechercheActeurs").checked = true
168 document.getElementById("checkRecherchePays").checked = true
169 document.getElementById("recherche").value = ""
170 doRecherche()
171 }
172
173 /**
174 * Recherche d'un genre, pays, réalisateur, etc..
175 * texte [String] : une chaine quelconque à rechercher
176 * type [String] : dans quel champ porte la recherche. Valeurs possibles : 'Titre', 'Genres', 'Realisateurs', 'Acteurs', 'Pays'
177 */
178 function rechercheElement(texte, type)
179 {
180 texte = trim(texte)
181 document.getElementById("checkRechercheTitre").checked = false
182 document.getElementById("checkRechercheGenres").checked = false
183 document.getElementById("checkRechercheRealisateurs").checked = false
184 document.getElementById("checkRechercheActeurs").checked = false
185 document.getElementById("checkRecherchePays").checked = false
186 document.getElementById("checkRecherche"+type).checked = true
187 document.getElementById("recherche").value = texte
188 doRecherche()
189 }