Subversion Repositories Applications.gtt

Rev

Rev 48 | Rev 73 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
11 jpm 1
<?php
2
class GttCtrlActionGestion extends aControlleurAction {
3
 
4
	public function __construct(Registre $Registre)
5
    {
6
    	$Registre->ajouterEspace('Gestion', 'gestion');
7
    	$Registre->ajouterSquelette('gestion', 'gestion.tpl.html');
8
    }
16 jpm 9
 
11 jpm 10
    public function executer()
11
    {
12
    	$aso_gestion = array();
13
    	$this->getRegistre()->setTitre('Gérer son temps');
14
 
15
    	//+-------------------------------------------------------------------------------------------------+
16
		// GESTION DES CALENDRIERS
17
		//+-------------------------------------------------------------------------------------------------+
18
		// Initialisation des variables pour le calendrier
19
		if (!isset($_GET['annee'])) {
20
			$_GET['annee'] = date('Y');
21
		}
22
		if (!isset($_GET['mois'])) {
23
			$_GET['mois'] = date('m');
24
		}
25
		if (!isset($_GET['semaine'])) {
26
			$_GET['semaine'] = date('W');
27
		}
28
		if (!isset($_GET['jour'])) {
29
			$_GET['jour'] = date('d');
30
		}
31
		// Instanciation de la classe Calendrier France
32
		$Calendrier = new Calendrier($_GET['jour'], $_GET['semaine'], $_GET['mois'], $_GET['annee']);
33
		$tab_jours_feries = $Calendrier->getListeFeries();
34
 
35
		// Create an array of days which are "selected"
36
		// Used for Week::build() below
37
		$CalendrierJourCourrant = new Calendar_Week(date('Y'), date('m'), date('d'));
38
		$aso_gestion['jc']['jour'] = $CalendrierJourCourrant->thisDay();
16 jpm 39
		$aso_gestion['jc']['semaine'] = $CalendrierJourCourrant->thisWeek('n_in_year');
11 jpm 40
		$aso_gestion['jc']['mois'] = $CalendrierJourCourrant->thisMonth();
41
		$aso_gestion['jc']['mois_nom'] = $Calendrier->getNomMois($CalendrierJourCourrant->thisMonth());
42
		$aso_gestion['jc']['annee'] = $CalendrierJourCourrant->thisYear();
43
		$aso_gestion['jc_url'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$aso_gestion['jc']['annee'].'&amp;mois='.$aso_gestion['jc']['mois'].'&amp;semaine='.$aso_gestion['jc']['semaine'].'&amp;jour='.$aso_gestion['jc']['jour'];
16 jpm 44
 
11 jpm 45
		$CalendrierJourCourrant->build();
46
		$CalendrierSemaineCourrante = $CalendrierJourCourrant->thisWeek('object');
47
		$CalendrierSemaineCourrante->build();
48
		$tab_jours = $CalendrierSemaineCourrante->fetchAll();
49
		$aso_gestion['sjc_1']['jour'] = $tab_jours[1]->thisDay();
50
		$aso_gestion['sjc_1']['mois'] = $Calendrier->getNomMois($tab_jours[1]->thisMonth());
51
		$aso_gestion['sjc_1']['annee'] = $tab_jours[1]->thisYear();
52
		$aso_gestion['sjc_7']['jour'] = $tab_jours[7]->thisDay();
53
		$aso_gestion['sjc_7']['mois'] = $Calendrier->getNomMois($tab_jours[7]->thisMonth());
54
		$aso_gestion['sjc_7']['annee'] = $tab_jours[7]->thisYear();
16 jpm 55
 
11 jpm 56
		$aso_gestion['selectedDays'] = array ($CalendrierJourCourrant);
16 jpm 57
 
11 jpm 58
		// Instruct month to build Week objects
59
		// Construction de l'objet mois
60
		$Month = new Calendar_Month_Weeks($_GET['annee'], $_GET['mois']);
61
		$Month->build();
16 jpm 62
 
11 jpm 63
		while ($Week = $Month->fetch()) {
64
			$Week->build($aso_gestion['selectedDays']);
65
			//echo '<pre>'.print_r($Month, true).'</pre>';
66
			$tab_semaine_jours = $Week->fetchAll();
67
			foreach ($tab_semaine_jours as $num => $Day) {
68
				$element = array();
69
				$element['annee'] = $Day->thisYear();
70
				$element['mois'] = $Day->thisMonth();
71
				$element['jour'] = $Day->thisDay();
72
				$element['jour_nom'] = $Calendrier->getNomJours($num);
73
				$element['url'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$Day->thisYear().'&amp;mois='.$Day->thisMonth().'&amp;jour='.$Day->thisDay();
74
				// Check to see if day is selected
75
				if ($Day->isSelected()) {
76
					$element['class'] = 'jour_courrant';
77
				} else if ($Day->isEmpty()) {
78
					$element['class'] = 'jour_vide';
79
				} else {
80
					$element['class'] = 'jour';
81
				}
82
				foreach ($tab_jours_feries as $jour_ferie) {
83
					if ($Day->thisDay(true) ==  $jour_ferie) {
84
						$element['class'] = 'jour_ferie';
85
					}
86
				}
87
				$aso_gestion['elements'][$Week->thisWeek('n_in_year')][$num] = $element;
88
			}
89
		}
16 jpm 90
 
11 jpm 91
		// Construction de l'url pour les mois précédent/suivant
92
		$PMonth = $Month->prevMonth('object');
93
		$aso_gestion['url_mois_precedent'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$PMonth->thisYear().'&amp;mois='.$PMonth->thisMonth().'&amp;jour='.$PMonth->thisDay();
94
		$NMonth = $Month->nextMonth('object');
95
		$aso_gestion['url_mois_suivant'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$NMonth->thisYear().'&amp;mois='.$NMonth->thisMonth().'&amp;jour='.$NMonth->thisDay();
96
		$aso_gestion['mois']['mois'] = $Calendrier->getNomMois($Month->thisMonth());
97
		$aso_gestion['mois']['annee'] = $Month->thisYear();
16 jpm 98
 
11 jpm 99
		// Construction de l'url pour les semaines précédente/suivante
100
		$Week = new Calendar_Week($_GET['annee'], $_GET['mois'], $_GET['jour']);
101
		$aso_gestion['s'] = $Week->thisWeek('n_in_year');
16 jpm 102
 
11 jpm 103
		$PWeek = $Week->prevWeek('object');
104
		$aso_gestion['url_semaine_precedente'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$PWeek->thisYear().'&amp;mois='.$PWeek->thisMonth().'&amp;jour='.$PWeek->thisDay();
16 jpm 105
 
11 jpm 106
		$url_sc_param_date = '&amp;annee='.$Week->thisYear().'&amp;mois='.$Week->thisMonth().'&amp;jour='.$Week->thisDay();
107
		$aso_gestion['url_semaine_courante'] = 'index.php?action='.GTT_ACTION_GESTION.$url_sc_param_date;
16 jpm 108
 
11 jpm 109
		$NWeek = $Week->nextWeek('object');
110
		$aso_gestion['url_semaine_suivante'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$NWeek->thisYear().'&amp;mois='.$NWeek->thisMonth().'&amp;jour='.$NWeek->thisDay();
16 jpm 111
 
11 jpm 112
		$Week->build();
113
		$aso_jours = array();
114
		foreach($Week->fetchAll() as $num => $j) {
115
			$aso_gestion['sj_'.$num]['jour'] = $j->thisDay();
116
			$aso_gestion['sj_'.$num]['mois'] = $Calendrier->getNomMois($j->thisMonth());
117
			$aso_gestion['sj_'.$num]['annee'] = $j->thisYear();
67 jpm 118
			$aso_gestion['sj_'.$num]['mysql'] = $aso_gestion['sj_'.$num]['annee'].'-'.sprintf("%02s", $j->thisMonth()).'-'.sprintf("%02s", $aso_gestion['sj_'.$num]['jour']);
11 jpm 119
			$aso_jours[$aso_gestion['sj_'.$num]['mysql']] = $num;
120
			$aso_tps_w_vide[$num] = '';
121
		}
16 jpm 122
 
11 jpm 123
		//+-------------------------------------------------------------------------------------------------+
124
		// GESTION DES PROJETS
125
		//+-------------------------------------------------------------------------------------------------+
126
    	// Récupération des infos sur l'utilisateur
127
 		$aso_gestion['conges_payes'] = $GLOBALS['_GTT_']['Utilisateur']->getCongesPayes();
128
 		$aso_gestion['rtt'] = $GLOBALS['_GTT_']['Utilisateur']->getQuotaHeuresSupp();
67 jpm 129
 		$aso_gestion['tps_w'] = $GLOBALS['_GTT_']['Utilisateur']->getTempsDeTravailJour();
16 jpm 130
 
11 jpm 131
    	// Récupération des projets sur lesquels l'utilisateur travaille
132
		$UtilsateurAProjet = new UtilisateurAProjet();
133
    	$tab_uap = $UtilsateurAProjet->consulter(UtilisateurAProjet::GUAP_UTILISATEUR, $GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
67 jpm 134
		// Si nous avons des données...
135
		$aso_gestion['bool_projets'] = false;
136
    	if ($tab_uap && count($tab_uap) >= 1) {
137
	    	$aso_gestion['bool_projets'] = true;
138
	    	$tab_projet_id = array();
139
	    	foreach ($tab_uap as $uap) {
140
	    		$tab_projet_id[] = $uap->getIdProjet();
141
	    	}
11 jpm 142
 
67 jpm 143
	    	// Récupération du temps de travail pour un utilisateur à une date donnée
144
	    	$TravailProjet = new TravailProjet();
145
			$cmd = TravailProjet::GTP_ID_UTILISATEUR_DATE_DEB_FIN;
146
			$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_gestion['sj_1']['mysql'], $aso_gestion['sj_7']['mysql']);
147
			$tab_tp = $TravailProjet->consulter($cmd, $param);
148
			if ($tab_tp && count($tab_tp) == 1) {
149
				$tab_tp = array($tab_tp);
150
			}
11 jpm 151
 
67 jpm 152
			// Récupération des infos sur les projets de l'utilisateur
153
	    	$aso_gestion['totaux'] = $aso_tps_w_vide;
154
	    	$Projet = new Projet();
155
	    	$tab_p = $Projet->consulter(Projet::GP_ID_LIST, array(implode(',', $tab_projet_id)));
156
			foreach ($tab_p as $Projet) {
157
 
158
				// Récupération de la catégorie du projet
159
				$ProjetCategorie = new ProjetCategorie();
160
				$cmd = ProjetCategorie::GPC_ID;
161
				$param = $Projet->getCeCategorie();
162
				$Categorie = $ProjetCategorie->consulter($cmd, $param);
163
 
164
				// Nous vérifions le temps de travail pour ce projet pour la semaine courrante
165
				$aso_tps_w = $aso_tps_w_vide;
166
				if (!isset($aso_gestion['categorie_totaux'][$Categorie->getLibelle()])) {
167
					$aso_gestion['categorie_totaux'][$Categorie->getLibelle()] = $aso_tps_w_vide;
168
				}
169
				if ($tab_tp) {
170
					foreach ($tab_tp as $TP) {
171
						if ($TP->getIdProjet() == $Projet->getIdProjet()) {
172
							$num = $aso_jours[$TP->getIdDateTravail()];
173
							$aso_tps_w[$num] = $TP->getDuree();
174
							$aso_gestion['categorie_totaux'][$Categorie->getLibelle()][$num] += $TP->getDuree();
175
							$aso_gestion['totaux'][$num] += $TP->getDuree();
176
						}
11 jpm 177
					}
178
				}
67 jpm 179
 
180
				// Stockage des infos nécessaire pour l'affichage
181
				$aso_gestion['preferences'][$Categorie->getLibelle()][] = array(
182
					'id' => $Projet->getIdProjet(),
183
					'valeur' => $Projet->getIdProjet(),
184
					'nom' => $Projet->getNomProjet(),
185
					'date' => $aso_tps_w);
186
 
187
 
11 jpm 188
			}
189
		}
16 jpm 190
		//+-------------------------------------------------------------------------------------------------+
191
		// GESTION DES ABSENCES
192
		//+-------------------------------------------------------------------------------------------------+
33 jpm 193
		// Récupération des motifs d'absence
194
		$AbsenceMotif = new AbsenceMotif();
195
		$cmd = AbsenceMotif::GAM_TOUS;
196
		$tab_am = $AbsenceMotif->consulter($cmd);
197
		if ($tab_am && count($tab_am) == 1) {
198
			$tab_am = array($tab_am);
199
		}
200
 
16 jpm 201
		// Récupération des absences pour un utilisateur à une date donnée
202
    	$Absence = new Absence();
203
		$cmd = Absence::GA_ID_UTILISATEUR_DATE_DEB_FIN;
204
		$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_gestion['sj_1']['mysql'], $aso_gestion['sj_7']['mysql']);
205
		$tab_a = $Absence->consulter($cmd, $param);
67 jpm 206
		// Si nous avons des absences...
16 jpm 207
		if ($tab_a && count($tab_a) == 1) {
208
			$tab_a = array($tab_a);
209
		}
33 jpm 210
		$aso_gestion['ab_total'] = $aso_tps_w_vide;
211
		if ($tab_am) {
212
			foreach ($tab_am as $AM) {
213
				$aso_gestion['ab_libelle'][$AM->getIdAbsenceMotif()] = $AM->getLibelle();
214
				$aso_gestion['ab'][$AM->getIdAbsenceMotif()] = $aso_tps_w_vide;
215
				if ($tab_a) {
216
					foreach ($tab_a as $A) {
217
						if ($A->getIdAbsenceMotif() == $AM->getIdAbsenceMotif()) {
218
							$num = $aso_jours[$A->getIdDateAbsence()];
219
							$aso_gestion['ab'][$AM->getIdAbsenceMotif()][$num] = $A->getDuree();
220
							$aso_gestion['ab_total'][$num] += $A->getDuree();
221
							$aso_gestion['totaux'][$num] += $A->getDuree();
222
						}
223
					}
16 jpm 224
				}
225
			}
226
		}
67 jpm 227
 
11 jpm 228
		// Création de l'url de réponse du formulaire
229
		$aso_gestion['url_gestion_valider'] = 'index.php?action='.GTT_ACTION_GESTION_VALIDER.$url_sc_param_date;
16 jpm 230
 
33 jpm 231
    	//echo '<pre>ici '.print_r($aso_gestion['ab'], true).'la</pre>';
11 jpm 232
		$this->getRegistre()->ajouterDonnee('gestion', $aso_gestion);
233
    }
16 jpm 234
 
235
    public function verifierValider()
236
    {
237
 
238
    }
239
 
11 jpm 240
	public function executerValider()
241
    {
242
    	//echo '<pre>'.print_r($_POST, true).'</pre>';
16 jpm 243
 
244
    	// Récupération des info sur la semaine courrante
245
		$Week = new Calendar_Week($_GET['annee'], $_GET['mois'], $_GET['jour']);
246
		$Week->build();
247
		$aso_jours = array();
248
		$aso_semaine = array();
249
		foreach($Week->fetchAll() as $num => $j) {
67 jpm 250
			$aso_semaine[$num]['mysql'] = $j->thisYear().'-'.sprintf("%02s", $j->thisMonth()).'-'.sprintf("%02s", $j->thisDay());
16 jpm 251
			$aso_jours[$aso_semaine[$num]['mysql']] = $num;
252
		}
253
 
254
		// Récupération du temps de travail pour un utilisateur à une date donnée
255
    	$TravailProjet = new TravailProjet();
256
		$cmd = TravailProjet::GTP_ID_UTILISATEUR_DATE_DEB_FIN;
257
		$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_semaine[1]['mysql'], $aso_semaine[7]['mysql']);
258
		$tab_tp = $TravailProjet->consulter($cmd, $param);
259
		if ($tab_tp && count($tab_tp) == 1) {
260
			$tab_tp = array($tab_tp);
261
		}
262
 
33 jpm 263
		// Ajout ou Mise à jour des durées de travail
264
		if (isset($_POST['pr'])) {
265
			foreach($_POST['pr'] as $projet_id => $jours) {
266
				//echo '<pre>'.print_r($jours, true).'</pre>';
267
				foreach($jours as $jour_num => $nbr_heure) {
268
					$bool_ajouter = true;
269
					if (!empty($tab_tp)) {
270
						foreach ($tab_tp as $TP) {
271
							if ($TP->getIdDateTravail() == $aso_semaine[$jour_num]['mysql']) {
272
								if ($TP->getIdProjet() == $projet_id) {
273
									$bool_ajouter = false;
274
									if ($TP->getDuree() != $nbr_heure) {
275
										if (empty($nbr_heure)) {
276
											$TP->supprimer();
277
										} else {
278
											$TP->setDuree($nbr_heure);
279
											$TP->modifier();
280
										}
281
									}
16 jpm 282
								}
283
							}
284
						}
285
					}
33 jpm 286
					if ($bool_ajouter && !empty($nbr_heure)) {
287
						$TP = new TravailProjet();
288
						$TP->setDuree((float)$nbr_heure);
289
						$TP->setIdUtilisateur($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
290
						$TP->setIdProjet($projet_id);
291
						$TP->setIdDateTravail((string)$aso_semaine[$jour_num]['mysql']);
292
						$TP->ajouter();
293
					}
16 jpm 294
				}
33 jpm 295
			}
296
		}
297
 
298
		// Récupération des absences pour un utilisateur à une date donnée
299
    	$Absence = new Absence();
300
		$cmd = Absence::GA_ID_UTILISATEUR_DATE_DEB_FIN;
301
		$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_semaine[1]['mysql'], $aso_semaine[7]['mysql']);
302
		$tab_a = $Absence->consulter($cmd, $param);
303
		if ($tab_a && count($tab_a) == 1) {
304
			$tab_a = array($tab_a);
305
		}
306
 
307
		// Ajout ou Mise à jour des durées d'absences pour congés payés
308
		if (isset($_POST['ab'])) {
309
			//echo '<pre>'.print_r($_POST['ab'], true).'</pre>';
310
			foreach($_POST['ab'] as $ab_id => $tab_num_j) {
311
				foreach($tab_num_j as $num_j => $ab_duree) {
312
					$bool_ajouter = true;
313
					if (!empty($tab_a)) {
314
						foreach ($tab_a as $A) {
315
							if ($A->getIdDateAbsence() == $aso_semaine[$num_j]['mysql']) {
316
 
317
								if ($A->getIdAbsenceMotif() == $ab_id) {
318
									$bool_ajouter = false;
319
 
320
									if ($A->getDuree() != $ab_duree) {
321
										if (empty($ab_duree)) {
322
											$A->supprimer();
323
										} else {
324
											$A->setDuree($ab_duree);
325
											$A->modifier();
326
										}
327
									}
328
								}
329
							}
330
						}
331
					}
332
					if ($bool_ajouter && !empty($ab_duree)) {
333
						$A = new Absence();
334
						$A->setDuree((float)$ab_duree);
335
						$A->setIdUtilisateur($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
336
						$A->setIdAbsenceMotif($ab_id);
337
						$A->setIdDateAbsence((string)$aso_semaine[$num_j]['mysql']);
338
						$A->ajouter();
339
					}
16 jpm 340
				}
341
			}
342
		}
343
 
11 jpm 344
    	// Action suivante
345
    	$this->setSuivant('__defaut__');
346
    }
347
}
348
?>