f9ad7f17471180c542f8a4f13847aa602340290b
[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 * Callback appelé lorsque un film est cliqué
41 * Affiche ou cache les informations de détail pour ce film.
42 * id [int] : l'identificateur du film
43 */
44 function detailFilm(id)
45 {
46 var detail = document.getElementById("detail"+id)
47
48 if (detail.style.display == "table")
49 detail.style.display = "none"
50 else
51 detail.style.display = "table"
52 }
53
54
55 /**
56 * Effectue une recherche, n'affiche que les films qui contiennent le motif recherché
57 * Recherche dans le titre, le realisateur, les acteurs, les genres et les pays en fonction des checkbox respectives.
58 */
59 function doRecherche()
60 {
61 var afficherTout = false;
62 // si aucun choix n'est fait pour la recherche on affiche tout
63 if (!document.getElementById("checkRechercheTitre").checked
64 && !document.getElementById("checkRechercheGenres").checked
65 && !document.getElementById("checkRechercheRealisateurs").checked
66 && !document.getElementById("checkRechercheActeurs").checked
67 && !document.getElementById("checkRecherchePays").checked)
68 afficherTout = true;
69
70 var nbFilm = 0; // pour compter le nombre de film total
71 var nbFilmAffiche = 0; // pour compter le nombre de film affiché
72
73 // le motif à chercher
74 var motif = document.getElementById("recherche").value
75 var rechercheRegExp = new RegExp(".*" + motif + ".*", "i")
76
77 var liste = document.getElementById("liste")
78 var lignes = liste.childNodes
79 for(i = 0; i < lignes.length; i += 2)
80 {
81 nbFilm++;
82
83 // extraction des informations du film courant
84 var titre = lignes[i].firstChild.innerHTML
85 var tableDetails = lignes[i+1].firstChild.firstChild.childNodes
86 var genres = tableDetails[0].firstChild.nextSibling.textContent
87 var realisateurs = tableDetails[1].firstChild.nextSibling.textContent
88 var acteurs = tableDetails[2].firstChild.nextSibling.textContent
89 var pays = tableDetails[3].firstChild.nextSibling.textContent
90
91 // si le film satisfait la recherche alors on l'affiche sinon ou le cache
92 if (
93 afficherTout ||
94 document.getElementById("checkRechercheTitre").checked && rechercheRegExp.exec(titre) != null
95 || document.getElementById("checkRechercheGenres").checked && rechercheRegExp.exec(genres) != null
96 || document.getElementById("checkRechercheRealisateurs").checked && rechercheRegExp.exec(realisateurs) != null
97 || document.getElementById("checkRechercheActeurs").checked && rechercheRegExp.exec(acteurs) != null
98 || document.getElementById("checkRecherchePays").checked && rechercheRegExp.exec(pays) != null)
99 {
100 lignes[i].style.display = "table-row"
101 lignes[i+1].style.display = "table-row"
102 nbFilmAffiche++;
103 }
104 else
105 {
106 lignes[i].style.display = "none"
107 lignes[i+1].style.display = "none"
108 }
109 }
110
111 // mise à jour de l'affichage du nombre de film total/affiché
112 document.getElementById("nbFilms").textContent = nbFilmAffiche + " / " + nbFilm + " film" + (nbFilm > 1 ? "s" : "")
113 }
114
115 /**
116 * Initialise la recherche et referme tous les détails des films.
117 */
118 function viderRecherche()
119 {
120 var lignes = document.getElementById("liste").childNodes
121 for(i = 1; i < lignes.length; i += 2)
122 {
123 lignes[i].firstChild.firstChild.style.display = "none";
124 }
125
126 document.getElementById("checkRechercheTitre").checked = true
127 document.getElementById("checkRechercheGenres").checked = true
128 document.getElementById("checkRechercheRealisateurs").checked = true
129 document.getElementById("checkRechercheActeurs").checked = true
130 document.getElementById("checkRecherchePays").checked = true
131 document.getElementById("recherche").value = ""
132 doRecherche()
133 }
134
135 /**
136 * Recherche d'un genre, pays, réalisateur, etc..
137 * texte [String] : une chaine quelconque à rechercher
138 * type [String] : dans quel champ porte la recherche. Valeurs possibles : 'Titre', 'Genres', 'Realisateurs', 'Acteurs', 'Pays'
139 */
140 function rechercheElement(texte, type)
141 {
142 texte = trim(texte)
143 document.getElementById("checkRechercheTitre").checked = false
144 document.getElementById("checkRechercheGenres").checked = false
145 document.getElementById("checkRechercheRealisateurs").checked = false
146 document.getElementById("checkRechercheActeurs").checked = false
147 document.getElementById("checkRecherchePays").checked = false
148 document.getElementById("checkRecherche"+type).checked = true
149 document.getElementById("recherche").value = texte
150 doRecherche()
151 }