Bonjour,

Je développe une application de gestion des horaires, qui doit notamment calculer les heures réalisés par semaine, en tenant compte des horaires contractuelles (le nombre d'heure que doit faire un salarié dans la semaine.

J'ai développé cette méthode qui fonctionne si le nombre d'heure contractuelle est 35 ou 23 (qui dans ma base de donnée sont des varchar).

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
 
function doCount2(position){
	//alert("position : "+position);
	//RECUPERATION DES INDEX ET ID PERSONNE
	var chaine = position;
	var tableau=chaine.split("_");
	var index = tableau[0];
	var idPersonne = tableau[1];
	//alert("abs param : "+abs);
 
	var variableNbHeureAfaire = "nbHeureAfaire_"+idPersonne;
	var nbHeureAFaire = document.forms["createForm"].elements[variableNbHeureAfaire].value;
 
 
	var res = 0;
	for (i=1; i<8; i++){
 
		var pres = 'pres'+i+"_"+idPersonne;
		var demiAbs = 'demiab'+i+"_"+idPersonne;
		var abs = 'ab'+i+"_"+idPersonne;
 
		var nomPres = document.getElementById(pres);	
		var demiAbs = document.getElementById(demiAbs);	
		var abs = document.getElementById(abs);	
 
		var debutAM = 'horaire'+i+'dm_'+idPersonne;
		var finAM = 'horaire'+i+'fm_'+idPersonne;
		var debutPM = 'horaire'+i+'da_'+idPersonne;
		var finPM = 'horaire'+i+'fa_'+idPersonne;
 
		//R2cupération des id des absences sélectionné
		var absenceSelectedId = "absenceSelected"+i+"_"+idPersonne;
		var idAbs = document.getElementById(absenceSelectedId).options[document.getElementById(absenceSelectedId).selectedIndex].value;
 
		//alert("abs : "+i+" - "+abs.checked);
		//alert("idAbs : "+idAbs);
 
		//Gestion des demi-absence matin ou après midi
		var horaireApresdebDemiAbs = "horaire"+i+"debApresDemiAbs_"+idPersonne;
		var horairApresfinDemiAbs = "horaire"+i+"finApresDemiAbs_"+idPersonne
		var horaireMatindebDemiAbs = "horaire"+i+"debMatinDemiAbs_"+idPersonne;
		var horairMatinfinDemiAbs = "horaire"+i+"finMatinDemiAbs_"+idPersonne
 
		var debutDemiAbs = '';
		var finDemiAbs = '';
 
		//Durée de l'absnece
		var dureeAbs='';
 
		if(document.getElementById(horaireApresdebDemiAbs)!=null){ 
			debutDemiAbs = horaireApresdebDemiAbs;
 
			//alert("horaireApresdebDemiAbs");
		}
		if(document.getElementById(horairApresfinDemiAbs)!=null){ 
			finDemiAbs = horairApresfinDemiAbs;
 
			//alert("horairApresfinDemiAbs");
		}
 
		if(document.getElementById(horaireMatindebDemiAbs)!=null){ 
			debutDemiAbs = horaireMatindebDemiAbs;
 
			//alert("horaireMatindebDemiAbs");
		}
 
		if(document.getElementById(horairMatinfinDemiAbs)!=null){
			finDemiAbs = horairMatinfinDemiAbs;
 
			//alert("horairMatinfinDemiAbs");
		}
 
		if(nomPres.checked){
			debutDemiAbs = '';
			finDemiAbs = '';
 
		}
 
 
		//alert("debutDemiAbs : "+debutDemiAbs);						
		var debutAM_value = document.getElementById(debutAM).value;
		//alert("debutDemiAbs : "+debutDemiAbs);
		//alert("finDemiAbs : "+finDemiAbs);
 
		var finAM_value = document.getElementById(finAM).value;
		var debutPM_value = document.getElementById(debutPM).value;
		var finPM_value = document.getElementById(finPM).value;
 
		var debutDemiAbs_value = "00:00";
		//alert("document.getElementById(debutDemiAbs) : "+document.getElementById(debutDemiAbs));
 
		// Modification ici
		if(document.getElementById(debutDemiAbs)!=null){ 
 
			debutDemiAbs_value = document.getElementById(debutDemiAbs).value;
 
 
		}
 
		//alert("Existnate : "+document.getElementById(debutDemiAbs_value));
 
		var finDemiAbs_value = "00:00";
		//alert("document.getElementById(finDemiAbs).value ====> "+document.getElementById(finDemiAbs).value);
 
		if(document.getElementById(finDemiAbs)!=null){ 
			//alert("Ma variable finDemiAbs est defini");
			if(document.getElementById(finDemiAbs).value){
			finDemiAbs_value = document.getElementById(finDemiAbs).value;
			//alert("DEMI Fin : "+finDemiAbs_value);
			}
		}
 
		if(debutAM_value == ''){
			debutAM_value = '00:00';
		}
 
		var debutAM_temps = debutAM_value.split(':');
		var debutAM_heure = debutAM_temps[0];
		var debutAM_min = debutAM_temps[1];
 
		var debutAM_min_res = (parseInt(debutAM_heure*60))+parseInt(debutAM_min);
 
		if(finAM_value == ''){
			finAM_value = '00:00';
		}
 
		var finAM_temps = finAM_value.split(':');
		var finAM_heure = finAM_temps[0];
		var finAM_min = finAM_temps[1];
 
		var finAM_min_res = (parseInt(finAM_heure*60))+parseInt(finAM_min);
		//alert('finAM_min_res : '+finAM_min_res);
 
		//calcul du temps effectué le matin en min
		var totalAM_min = finAM_min_res - debutAM_min_res;
 
		if(debutPM_value == ''){
			debutPM_value = '00:00';
		}
 
		var debutPM_temps = debutPM_value.split(':');
 
		var debutPM_heure = debutPM_temps[0];
		var debutPM_min = debutPM_temps[1];
 
		var debutPM_min_res = (parseInt(debutPM_heure*60))+parseInt(debutPM_min);
 
 
		if(finPM_value == ''){
			finPM_value = '00:00';
		}
 
		var finPM_temps = finPM_value.split(':');
		var finPM_heure = finPM_temps[0];
		var finPM_min = finPM_temps[1];
 
		var finPM_min_res = (parseInt(finPM_heure*60))+parseInt(finPM_min);
 
		//calcul du temps effectué l'apres midi en min
		var totalPM_min = finPM_min_res - debutPM_min_res;
 
		if(debutDemiAbs_value == ''){
			debutDemiAbs_value = '00:00';
		}
 
		var debutDemiAbs_temps = debutDemiAbs_value.split(':');
		var debutDemiAbs_heure = debutDemiAbs_temps[0];
		var debutDemiAbs_min = debutDemiAbs_temps[1];
 
		var debutDemiAbs_min_res = (parseInt(debutDemiAbs_heure*60))+parseInt(debutDemiAbs_min);
 
		if(finDemiAbs_value == ''){
			finDemiAbs_value = '00:00';
		}
 
		var finDemiAbs_temps = finDemiAbs_value.split(':');
		var finDemiAbs_heure = finDemiAbs_temps[0];
		var finDemiAbs_min = finDemiAbs_temps[1];
 
		var finDemiAbs_min_res = (parseInt(finDemiAbs_heure*60))+parseInt(finDemiAbs_min);
 
 
 
		if(nomPres.checked){
			finDemiAbs_min_res = '';
			debutDemiAbs_min_res = '';
 
		}
 
		//Gestion des absences
 
		if(abs.checked){
			//alert("abs coché")
			//Si on est pas dans le cas d'un repos : l'id du repos est 3
			if((idAbs !=3)&&(idAbs !=-1)){
				/*alert("nbHeureAFaire "+nbHeureAFaire);
				nbHeureAFaire =(parseInt(nbHeureAFaire);
				alert("nbHeureAFaire 2 "+nbHeureAFaire);*/
				dureeAbs = nbHeureAFaire/5;
				//alert("Valeur de la durée de l'absence : "+dureeAbs);
			}
 
		}
 
 
 
		//calcul du temps effectué durant la demi absence en min
		var totalDemiAbs_min = finDemiAbs_min_res - debutDemiAbs_min_res;
 
 
		//Calcule de la valeur de l'absence    dureeAbs
		var dureeAbs_min = (parseInt(dureeAbs*60));
		//alert("dureeAbs_min_res : "+dureeAbs_min_res);
 
 
 
 
		//calcul total de l'heure effectué
		//alert("*** totalPM_min *** :"+totalPM_min);
		//alert("*** dureeAbs_min_res *** :"+dureeAbs_min);
		//alert("*** parseInt(totalPM_min) *** :"+parseInt(totalPM_min));
 
		var total_Global_min = parseInt(totalAM_min) + parseInt(totalPM_min) + parseInt(totalDemiAbs_min) + parseInt(dureeAbs_min) ;
 
 
		//alert("*** total_Global_min *** :"+total_Global_min);
		/*alert('totalAM_min '+i+' : '+totalAM_min);
		alert('totalPM_min '+i+' : '+totalPM_min);
		alert('totalDemiAbs_min '+i+' : '+totalDemiAbs_min);
		alert('dureeAbs_min '+i+' : '+dureeAbs_min);
		alert('total_Global_min '+i+' : '+total_Global_min);
		*/
		res += total_Global_min;
		/*var total_Global_heure = Math.floor(total_Global_min/60)+":"+(total_Global_min%60);
		alert('totalAM_min : '+total_Global_heure);*/
	}
	var heure_res = Math.floor(res/60);
	if (heure_res == 0 || heure_res < 10) heure_res = "0"+heure_res;
	var min_res = (res%60);
	if (min_res == 0 || min_res < 10) min_res = "0"+min_res;
 
	var total_Global_heure_sem = heure_res+":"+min_res;
	//alert('total_Global_heure_sem : '+total_Global_heure_sem);
 
	var styleCSS="styleCSS";
 
 
 
 
	var champCache = 'nbHeureFaite_'+idPersonne;
	document.getElementById(champCache).value = total_Global_heure_sem;
 
	var div_res = 'div_nbHeureFaite_'+idPersonne;
	document.getElementById(div_res).innerHTML= total_Global_heure_sem;
 
	alert("nbHeureAFaire "+nbHeureAFaire);
	alert("total_Global_heure_sem "+total_Global_heure_sem);
 
 
	//Pour mettre en rouve 
	if (nbHeureAFaire != total_Global_heure_sem){
 
		document.getElementById(div_res).style.color = "red";
 
	}else{
		document.getElementById(div_res).style.color = "black";
	}
 
}
Or je rencontre un problème lorsque que le nombre d'heure contractuelle correspond à 28:00, ou à 17:30.
Au lieu de m'afficher le nombre d'heure réalisé, il m'indique

Je pense que le problème vient du :

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
 
dureeAbs = nbHeureAFaire/5;
En effet, si le nombre d'heure à faire est de 35, çà me fait 35/5 donc la durée de l'absence est de 7 heures (ou 07:00).
Si le nombre d'heure à faire est de 23, çà me fait 23/5 donc la durée de l'absence est de 4,6 heures ce qui me donne ensuite 4:36

Comment dois je faire pour que ma méthode fonctionne quelques soit le format du nombre d'heure à faire (que se soit 35 ou 35:00) ? Que dois je modifier ?

Merci de votre aide et de votre regard avisé.