Subversion Repositories Applications.gtt

Rev

Rev 103 | Rev 110 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 103 Rev 106
1
<?php
1
<?php
2
class GttCtrlActionGestion extends aControlleurAction {
2
class GttCtrlActionGestion extends aControlleurAction {
3
 
3
 
4
	public function __construct(Registre $Registre)
4
	public function __construct(Registre $Registre)
5
    {
5
    {
6
    	$Registre->ajouterEspace('Gestion', 'gestion');
6
    	$Registre->ajouterEspace('Gestion', 'gestion');
7
    	$Registre->ajouterSquelette('gestion', 'gestion.tpl.html');
7
    	$Registre->ajouterSquelette('gestion', 'gestion.tpl.html');
8
    	$Registre->ajouterEspace('ZoneCalendrier', 'zone_calendrier');
8
    	$Registre->ajouterEspace('ZoneCalendrier', 'zone_calendrier');
9
    	$Registre->ajouterSquelette('zone_calendrier', 'calendrier_mini.tpl.html');
9
    	$Registre->ajouterSquelette('zone_calendrier', 'calendrier_mini.tpl.html');
10
    }
10
    }
11
 
11
 
12
    public function executer()
12
    public function executer()
13
    {
13
    {
14
    	$aso_gestion = array();
14
    	$aso_gestion = array();
15
    	$this->getRegistre()->setTitre('Gérer son temps');
15
    	$this->getRegistre()->setTitre('Gérer son temps');
16
 
16
 
17
    	//+-------------------------------------------------------------------------------------------------+
17
    	//+-------------------------------------------------------------------------------------------------+
18
		// GESTION DES CALENDRIERS
18
		// GESTION DES CALENDRIERS
19
		//+-------------------------------------------------------------------------------------------------+
19
		//+-------------------------------------------------------------------------------------------------+
20
		// Initialisation des variables pour le calendrier
20
		// Initialisation des variables pour le calendrier
21
		if (!isset($_GET['annee'])) {
21
		if (!isset($_GET['annee'])) {
22
			$_GET['annee'] = date('Y');
22
			$_GET['annee'] = date('Y');
23
		}
23
		}
24
		if (!isset($_GET['mois'])) {
24
		if (!isset($_GET['mois'])) {
25
			$_GET['mois'] = date('m');
25
			$_GET['mois'] = date('m');
26
		}
26
		}
27
		if (!isset($_GET['semaine'])) {
27
		if (!isset($_GET['semaine'])) {
28
			$_GET['semaine'] = date('W');
28
			$_GET['semaine'] = date('W');
29
		}
29
		}
30
		if (!isset($_GET['jour'])) {
30
		if (!isset($_GET['jour'])) {
31
			$_GET['jour'] = date('d');
31
			$_GET['jour'] = date('d');
32
		}
32
		}
33
		// Instanciation de la classe Calendrier France
33
		// Instanciation de la classe Calendrier France
34
		$Calendrier = new Calendrier($_GET['jour'], $_GET['semaine'], $_GET['mois'], $_GET['annee']);
34
		$Calendrier = new Calendrier($_GET['jour'], $_GET['semaine'], $_GET['mois'], $_GET['annee']);
35
		$tab_jours_feries = $Calendrier->getListeFeries();
35
		$tab_jours_feries = $Calendrier->getListeFeries();
36
 
36
 
37
		// Create an array of days which are "selected"
37
		// Create an array of days which are "selected"
38
		// Used for Week::build() below
38
		// Used for Week::build() below
39
		$CalendrierJourCourrant = new Calendar_Week(date('Y'), date('m'), date('d'));
39
		$CalendrierJourCourrant = new Calendar_Week(date('Y'), date('m'), date('d'));
40
		$aso_gestion['jc']['jour'] = $CalendrierJourCourrant->thisDay();
40
		$aso_gestion['jc']['jour'] = $CalendrierJourCourrant->thisDay();
41
		$aso_gestion['jc']['semaine'] = $CalendrierJourCourrant->thisWeek('n_in_year');
41
		$aso_gestion['jc']['semaine'] = $CalendrierJourCourrant->thisWeek('n_in_year');
42
		$aso_gestion['jc']['mois'] = $CalendrierJourCourrant->thisMonth();
42
		$aso_gestion['jc']['mois'] = $CalendrierJourCourrant->thisMonth();
43
		$aso_gestion['jc']['mois_nom'] = $Calendrier->getNomMois($CalendrierJourCourrant->thisMonth());
43
		$aso_gestion['jc']['mois_nom'] = $Calendrier->getNomMois($CalendrierJourCourrant->thisMonth());
44
		$aso_gestion['jc']['annee'] = $CalendrierJourCourrant->thisYear();
44
		$aso_gestion['jc']['annee'] = $CalendrierJourCourrant->thisYear();
45
		$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'];
45
		$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'];
46
 
46
 
47
		$CalendrierJourCourrant->build();
47
		$CalendrierJourCourrant->build();
48
		$CalendrierSemaineCourrante = $CalendrierJourCourrant->thisWeek('object');
48
		$CalendrierSemaineCourrante = $CalendrierJourCourrant->thisWeek('object');
49
		$CalendrierSemaineCourrante->build();
49
		$CalendrierSemaineCourrante->build();
50
		$tab_jours = $CalendrierSemaineCourrante->fetchAll();
50
		$tab_jours = $CalendrierSemaineCourrante->fetchAll();
51
		$aso_gestion['sjc_1']['jour'] = $tab_jours[1]->thisDay();
51
		$aso_gestion['sjc_1']['jour'] = $tab_jours[1]->thisDay();
52
		$aso_gestion['sjc_1']['mois'] = $Calendrier->getNomMois($tab_jours[1]->thisMonth());
52
		$aso_gestion['sjc_1']['mois'] = $Calendrier->getNomMois($tab_jours[1]->thisMonth());
53
		$aso_gestion['sjc_1']['annee'] = $tab_jours[1]->thisYear();
53
		$aso_gestion['sjc_1']['annee'] = $tab_jours[1]->thisYear();
54
		$aso_gestion['sjc_7']['jour'] = $tab_jours[7]->thisDay();
54
		$aso_gestion['sjc_7']['jour'] = $tab_jours[7]->thisDay();
55
		$aso_gestion['sjc_7']['mois'] = $Calendrier->getNomMois($tab_jours[7]->thisMonth());
55
		$aso_gestion['sjc_7']['mois'] = $Calendrier->getNomMois($tab_jours[7]->thisMonth());
56
		$aso_gestion['sjc_7']['annee'] = $tab_jours[7]->thisYear();
56
		$aso_gestion['sjc_7']['annee'] = $tab_jours[7]->thisYear();
57
 
57
 
58
		$aso_gestion['selectedDays'] = array ($CalendrierJourCourrant);
58
		$aso_gestion['selectedDays'] = array ($CalendrierJourCourrant);
59
 
59
 
60
		// Instruct month to build Week objects
60
		// Instruct month to build Week objects
61
		// Construction de l'objet mois
61
		// Construction de l'objet mois
62
		$Month = new Calendar_Month_Weeks($_GET['annee'], $_GET['mois']);
62
		$Month = new Calendar_Month_Weeks($_GET['annee'], $_GET['mois']);
63
		$Month->build();
63
		$Month->build();
64
 
64
 
65
		while ($Week = $Month->fetch()) {
65
		while ($Week = $Month->fetch()) {
66
			$Week->build($aso_gestion['selectedDays']);
66
			$Week->build($aso_gestion['selectedDays']);
67
			//echo '<pre>'.print_r($Month, true).'</pre>';
67
			//echo '<pre>'.print_r($Month, true).'</pre>';
68
			$tab_semaine_jours = $Week->fetchAll();
68
			$tab_semaine_jours = $Week->fetchAll();
69
			foreach ($tab_semaine_jours as $num => $Day) {
69
			foreach ($tab_semaine_jours as $num => $Day) {
70
				$element = array();
70
				$element = array();
71
				$element['annee'] = $Day->thisYear();
71
				$element['annee'] = $Day->thisYear();
72
				$element['mois'] = $Day->thisMonth();
72
				$element['mois'] = $Day->thisMonth();
73
				$element['jour'] = $Day->thisDay();
73
				$element['jour'] = $Day->thisDay();
74
				$element['jour_nom'] = $Calendrier->getNomJours($num);
74
				$element['jour_nom'] = $Calendrier->getNomJours($num);
75
				$element['url'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$Day->thisYear().'&amp;mois='.$Day->thisMonth().'&amp;jour='.$Day->thisDay();
75
				$element['url'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$Day->thisYear().'&amp;mois='.$Day->thisMonth().'&amp;jour='.$Day->thisDay();
76
				// Check to see if day is selected
76
				// Check to see if day is selected
77
				if ($Day->isSelected()) {
77
				if ($Day->isSelected()) {
78
					$element['class'] = 'jour_courrant';
78
					$element['class'] = 'jour_courrant';
79
				} else if ($Day->isEmpty()) {
79
				} else if ($Day->isEmpty()) {
80
					$element['class'] = 'jour_vide';
80
					$element['class'] = 'jour_vide';
81
				} else {
81
				} else {
82
					$element['class'] = 'jour';
82
					$element['class'] = 'jour';
83
				}
83
				}
84
				foreach ($tab_jours_feries as $jour_ferie) {
84
				foreach ($tab_jours_feries as $jour_ferie) {
85
					if ($Day->thisDay(true) ==  $jour_ferie) {
85
					if ($Day->thisDay(true) ==  $jour_ferie) {
86
						$element['class'] = 'jour_ferie';
86
						$element['class'] = 'jour_ferie';
87
					}
87
					}
88
				}
88
				}
89
				$aso_gestion['elements'][$Week->thisWeek('n_in_year')][$num] = $element;
89
				$aso_gestion['elements'][$Week->thisWeek('n_in_year')][$num] = $element;
90
			}
90
			}
91
		}
91
		}
92
 
92
 
93
		// Construction de l'url pour les mois précédent/suivant
93
		// Construction de l'url pour les mois précédent/suivant
94
		$PMonth = $Month->prevMonth('object');
94
		$PMonth = $Month->prevMonth('object');
95
		$aso_gestion['url_mois_precedent'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$PMonth->thisYear().'&amp;mois='.$PMonth->thisMonth().'&amp;jour='.$PMonth->thisDay();
95
		$aso_gestion['url_mois_precedent'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$PMonth->thisYear().'&amp;mois='.$PMonth->thisMonth().'&amp;jour='.$PMonth->thisDay();
96
		$NMonth = $Month->nextMonth('object');
96
		$NMonth = $Month->nextMonth('object');
97
		$aso_gestion['url_mois_suivant'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$NMonth->thisYear().'&amp;mois='.$NMonth->thisMonth().'&amp;jour='.$NMonth->thisDay();
97
		$aso_gestion['url_mois_suivant'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$NMonth->thisYear().'&amp;mois='.$NMonth->thisMonth().'&amp;jour='.$NMonth->thisDay();
98
		$aso_gestion['mois']['mois'] = $Calendrier->getNomMois($Month->thisMonth());
98
		$aso_gestion['mois']['mois'] = $Calendrier->getNomMois($Month->thisMonth());
99
		$aso_gestion['mois']['annee'] = $Month->thisYear();
99
		$aso_gestion['mois']['annee'] = $Month->thisYear();
100
 
100
 
101
		// Construction de l'url pour les semaines précédente/suivante
101
		// Construction de l'url pour les semaines précédente/suivante
102
		$Week = new Calendar_Week($_GET['annee'], $_GET['mois'], $_GET['jour']);
102
		$Week = new Calendar_Week($_GET['annee'], $_GET['mois'], $_GET['jour']);
103
		$aso_gestion['s'] = $Week->thisWeek('n_in_year');
103
		$aso_gestion['s'] = $Week->thisWeek('n_in_year');
104
 
104
 
105
		$PWeek = $Week->prevWeek('object');
105
		$PWeek = $Week->prevWeek('object');
106
		$aso_gestion['url_semaine_precedente'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$PWeek->thisYear().'&amp;mois='.$PWeek->thisMonth().'&amp;jour='.$PWeek->thisDay();
106
		$aso_gestion['url_semaine_precedente'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$PWeek->thisYear().'&amp;mois='.$PWeek->thisMonth().'&amp;jour='.$PWeek->thisDay();
107
 
107
 
108
		$url_sc_param_date = '&amp;annee='.$Week->thisYear().'&amp;mois='.$Week->thisMonth().'&amp;jour='.$Week->thisDay();
108
		$url_sc_param_date = '&amp;annee='.$Week->thisYear().'&amp;mois='.$Week->thisMonth().'&amp;jour='.$Week->thisDay();
109
		$aso_gestion['url_semaine_courante'] = 'index.php?action='.GTT_ACTION_GESTION.$url_sc_param_date;
109
		$aso_gestion['url_semaine_courante'] = 'index.php?action='.GTT_ACTION_GESTION.$url_sc_param_date;
110
 
110
 
111
		$NWeek = $Week->nextWeek('object');
111
		$NWeek = $Week->nextWeek('object');
112
		$aso_gestion['url_semaine_suivante'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$NWeek->thisYear().'&amp;mois='.$NWeek->thisMonth().'&amp;jour='.$NWeek->thisDay();
112
		$aso_gestion['url_semaine_suivante'] = 'index.php?action='.GTT_ACTION_GESTION.'&amp;annee='.$NWeek->thisYear().'&amp;mois='.$NWeek->thisMonth().'&amp;jour='.$NWeek->thisDay();
113
 
113
 
114
		$Week->build();
114
		$Week->build();
115
		$aso_jours = array();
115
		$aso_jours = array();
116
		foreach($Week->fetchAll() as $num => $j) {
116
		foreach($Week->fetchAll() as $num => $j) {
117
			$aso_gestion['sj_'.$num]['jour'] = $j->thisDay();
117
			$aso_gestion['sj_'.$num]['jour'] = $j->thisDay();
118
			$aso_gestion['sj_'.$num]['mois'] = $Calendrier->getNomMois($j->thisMonth());
118
			$aso_gestion['sj_'.$num]['mois'] = $Calendrier->getNomMois($j->thisMonth());
119
			$aso_gestion['sj_'.$num]['annee'] = $j->thisYear();
119
			$aso_gestion['sj_'.$num]['annee'] = $j->thisYear();
120
			$aso_gestion['sj_'.$num]['mysql'] = $aso_gestion['sj_'.$num]['annee'].'-'.sprintf("%02s", $j->thisMonth()).'-'.sprintf("%02s", $aso_gestion['sj_'.$num]['jour']);
120
			$aso_gestion['sj_'.$num]['mysql'] = $aso_gestion['sj_'.$num]['annee'].'-'.sprintf("%02s", $j->thisMonth()).'-'.sprintf("%02s", $aso_gestion['sj_'.$num]['jour']);
121
			$aso_jours[$aso_gestion['sj_'.$num]['mysql']] = $num;
121
			$aso_jours[$aso_gestion['sj_'.$num]['mysql']] = $num;
122
			$aso_tps_w_vide[$num] = '';
122
			$aso_tps_w_vide[$num] = '';
123
		}
123
		}
124
 
124
 
125
		//+-------------------------------------------------------------------------------------------------+
125
		//+-------------------------------------------------------------------------------------------------+
126
		// GESTION DES PROJETS
126
		// GESTION DES PROJETS
127
		//+-------------------------------------------------------------------------------------------------+
127
		//+-------------------------------------------------------------------------------------------------+
128
    	// Récupération des projets sur lesquels l'utilisateur travaille
128
    	// Récupération des projets sur lesquels l'utilisateur travaille
129
		$UtilsateurAProjet = new UtilisateurAProjet();
129
		$UtilsateurAProjet = new UtilisateurAProjet();
130
    	$tab_uap = $UtilsateurAProjet->consulter(UtilisateurAProjet::GUAP_UTILISATEUR, $GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
130
    	$tab_uap = $UtilsateurAProjet->consulter(UtilisateurAProjet::GUAP_UTILISATEUR, $GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
131
		// Si nous avons des données...
131
		// Si nous avons des données...
132
		$aso_gestion['bool_projets'] = false;
132
		$aso_gestion['bool_projets'] = false;
133
    	if ($tab_uap && count($tab_uap) >= 1) {
133
    	if ($tab_uap && count($tab_uap) >= 1) {
134
	    	$aso_gestion['bool_projets'] = true;
134
	    	$aso_gestion['bool_projets'] = true;
135
	    	$tab_projet_id = array();
135
	    	$tab_projet_id = array();
136
	    	foreach ($tab_uap as $uap) {
136
	    	foreach ($tab_uap as $uap) {
137
	    		$tab_projet_id[] = $uap->getIdProjet();
137
	    		$tab_projet_id[] = $uap->getIdProjet();
138
	    	}
138
	    	}
139
 
139
 
140
	    	// Récupération du temps de travail pour un utilisateur à une date donnée
140
	    	// Récupération du temps de travail pour un utilisateur à une date donnée
141
	    	$TravailProjet = new TravailProjet();
141
	    	$TravailProjet = new TravailProjet();
142
			$cmd = TravailProjet::GTP_ID_UTILISATEUR_DATE_DEB_FIN;
142
			$cmd = TravailProjet::GTP_ID_UTILISATEUR_DATE_DEB_FIN;
143
			$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_gestion['sj_1']['mysql'], $aso_gestion['sj_7']['mysql']);
143
			$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_gestion['sj_1']['mysql'], $aso_gestion['sj_7']['mysql']);
144
			$tab_tp = $TravailProjet->consulter($cmd, $param);
144
			$tab_tp = $TravailProjet->consulter($cmd, $param);
145
 
145
 
146
			// Récupération des infos sur les projets de l'utilisateur
146
			// Récupération des infos sur les projets de l'utilisateur
147
	    	$aso_gestion['totaux'] = $aso_tps_w_vide;
147
	    	$aso_gestion['totaux'] = $aso_tps_w_vide;
148
	    	$Projet = new Projet();
148
	    	$Projet = new Projet();
149
	    	$tab_p = $Projet->consulter(Projet::GP_ID_LIST, array(implode(',', $tab_projet_id)));
149
	    	$tab_p = $Projet->consulter(Projet::GP_ID_LIST, array(implode(',', $tab_projet_id)));
150
			foreach ($tab_p as $Projet) {
150
			foreach ($tab_p as $Projet) {
151
	
151
	
152
				// Récupération de la catégorie du projet
152
				// Récupération de la catégorie du projet
153
				$ProjetCategorie = new ProjetCategorie();
153
				$ProjetCategorie = new ProjetCategorie();
154
				$Categorie = current($ProjetCategorie->consulter(ProjetCategorie::GPC_ID, $Projet->getCeCategorie()));
154
				$Categorie = current($ProjetCategorie->consulter(ProjetCategorie::GPC_ID, $Projet->getCeCategorie()));
155
	
155
	
156
				// Nous vérifions le temps de travail pour ce projet pour la semaine courrante
156
				// Nous vérifions le temps de travail pour ce projet pour la semaine courrante
157
				$aso_tps_w = $aso_tps_w_vide;
157
				$aso_tps_w = $aso_tps_w_vide;
158
				if (!isset($aso_gestion['categorie_totaux'][$Categorie->getLibelle()])) {
158
				if (!isset($aso_gestion['categorie_totaux'][$Categorie->getLibelle()])) {
159
					$aso_gestion['categorie_totaux'][$Categorie->getLibelle()] = $aso_tps_w_vide;
159
					$aso_gestion['categorie_totaux'][$Categorie->getLibelle()] = $aso_tps_w_vide;
160
				}
160
				}
161
				if ($tab_tp) {
161
				if ($tab_tp) {
162
					foreach ($tab_tp as $TP) {
162
					foreach ($tab_tp as $TP) {
163
						if ($TP->getIdProjet() == $Projet->getIdProjet()) {
163
						if ($TP->getIdProjet() == $Projet->getIdProjet()) {
164
							$num = $aso_jours[$TP->getIdDateTravail()];
164
							$num = $aso_jours[$TP->getIdDateTravail()];
165
							$aso_tps_w[$num] = $TP->getDuree();
165
							$aso_tps_w[$num] = $TP->getDuree();
166
							$aso_gestion['categorie_totaux'][$Categorie->getLibelle()][$num] += $TP->getDuree();
166
							$aso_gestion['categorie_totaux'][$Categorie->getLibelle()][$num] += $TP->getDuree();
167
							$aso_gestion['totaux'][$num] += $TP->getDuree();
167
							$aso_gestion['totaux'][$num] += $TP->getDuree();
168
						}
168
						}
169
					}
169
					}
170
				}
170
				}
171
	
171
	
172
				// Stockage des infos nécessaire pour l'affichage
172
				// Stockage des infos nécessaire pour l'affichage
173
				$aso_gestion['preferences'][$Categorie->getLibelle()][] = array(
173
				$aso_gestion['preferences'][$Categorie->getLibelle()][] = array(
174
					'id' => $Projet->getIdProjet(),
174
					'id' => $Projet->getIdProjet(),
175
					'valeur' => $Projet->getIdProjet(),
175
					'valeur' => $Projet->getIdProjet(),
176
					'nom' => $Projet->getNom(),
176
					'nom' => $Projet->getNom(),
177
					'date' => $aso_tps_w);
177
					'date' => $aso_tps_w);
178
	
178
	
179
	
179
	
180
			}
180
			}
181
		}
181
		}
182
		//+-------------------------------------------------------------------------------------------------+
182
		//+-------------------------------------------------------------------------------------------------+
183
		// GESTION DES ABSENCES
183
		// GESTION DES ABSENCES
184
		//+-------------------------------------------------------------------------------------------------+
184
		//+-------------------------------------------------------------------------------------------------+
185
		// Récupération des motifs d'absence
185
		// Récupération des motifs d'absence
186
		$AbsenceMotif = new AbsenceMotif();
186
		$AbsenceMotif = new AbsenceMotif();
187
		$cmd = AbsenceMotif::GAM_TOUS;
187
		$cmd = AbsenceMotif::GAM_TOUS;
188
		$tab_am = $AbsenceMotif->consulter($cmd);
188
		$tab_am = $AbsenceMotif->consulter($cmd);
189
 
189
 
190
		// Récupération des absences pour un utilisateur à une date donnée
190
		// Récupération des absences pour un utilisateur à une date donnée
191
    	$Absence = new Absence();
191
    	$Absence = new Absence();
192
		$cmd = Absence::GA_ID_UTILISATEUR_DATE_DEB_FIN;
192
		$cmd = Absence::GA_ID_UTILISATEUR_DATE_DEB_FIN;
193
		$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_gestion['sj_1']['mysql'], $aso_gestion['sj_7']['mysql']);
193
		$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_gestion['sj_1']['mysql'], $aso_gestion['sj_7']['mysql']);
194
		$tab_a = $Absence->consulter($cmd, $param);
194
		$tab_a = $Absence->consulter($cmd, $param);
195
		// Si nous avons des absences...
195
		// Si nous avons des absences...
196
 
196
 
197
		$aso_gestion['ab_total'] = $aso_tps_w_vide;
197
		$aso_gestion['ab_total'] = $aso_tps_w_vide;
198
		if ($tab_am) {
198
		if ($tab_am) {
199
			foreach ($tab_am as $AM) {
199
			foreach ($tab_am as $AM) {
200
				$aso_gestion['ab_libelle'][$AM->getIdAbsenceMotif()] = $AM->getLibelle();
200
				$aso_gestion['ab_libelle'][$AM->getIdAbsenceMotif()] = $AM->getLibelle();
201
				$aso_gestion['ab'][$AM->getIdAbsenceMotif()] = $aso_tps_w_vide;
201
				$aso_gestion['ab'][$AM->getIdAbsenceMotif()] = $aso_tps_w_vide;
202
				if ($tab_a) {
202
				if ($tab_a) {
203
					foreach ($tab_a as $A) {
203
					foreach ($tab_a as $A) {
204
						if ($A->getIdAbsenceMotif() == $AM->getIdAbsenceMotif()) {
204
						if ($A->getIdAbsenceMotif() == $AM->getIdAbsenceMotif()) {
205
							$num = $aso_jours[$A->getIdDateAbsence()];
205
							$num = $aso_jours[$A->getIdDateAbsence()];
-
 
206
							if ($A->getDuree() < 0) {
-
 
207
								$A->setDuree(0);
-
 
208
							}
206
							$aso_gestion['ab'][$AM->getIdAbsenceMotif()][$num] = $A->getDuree();
209
							$aso_gestion['ab'][$AM->getIdAbsenceMotif()][$num] = $A->getDuree();
207
							$aso_gestion['ab_total'][$num] += $A->getDuree();
210
							$aso_gestion['ab_total'][$num] += $A->getDuree();
208
							$aso_gestion['totaux'][$num] += $A->getDuree();
211
							$aso_gestion['totaux'][$num] += $A->getDuree();
209
						}
212
						}
210
					}
213
					}
211
				}
214
				}
212
			}
215
			}
213
		}
216
		}
214
		
217
		
215
		// Création de l'url de réponse du formulaire
218
		// Création de l'url de réponse du formulaire
216
		$aso_gestion['url_gestion_valider'] = 'index.php?action='.GTT_ACTION_GESTION_VALIDER.$url_sc_param_date;
219
		$aso_gestion['url_gestion_valider'] = 'index.php?action='.GTT_ACTION_GESTION_VALIDER.$url_sc_param_date;
217
 
220
 
218
    	//echo '<pre>ici '.print_r($aso_gestion['ab'], true).'la</pre>';
221
    	//echo '<pre>ici '.print_r($aso_gestion['ab'], true).'la</pre>';
219
		$this->getRegistre()->ajouterDonnee('gestion', $aso_gestion);
222
		$this->getRegistre()->ajouterDonnee('gestion', $aso_gestion);
220
		$this->getRegistre()->ajouterDonnee('zone_calendrier', $aso_gestion);
223
		$this->getRegistre()->ajouterDonnee('zone_calendrier', $aso_gestion);
221
    }
224
    }
222
 
225
 
223
    public function verifierValider()
226
    public function verifierValider()
224
    {
227
    {
225
 
228
 
226
    }
229
    }
227
 
230
 
228
	public function executerValider()
231
	public function executerValider()
229
    {
232
    {
230
    	//echo '<pre>'.print_r($_POST, true).'</pre>';
233
    	//echo '<pre>'.print_r($_POST, true).'</pre>';
231
 
234
 
232
    	// Récupération des info sur la semaine courrante
235
    	// Récupération des info sur la semaine courrante
233
		$Week = new Calendar_Week($_GET['annee'], $_GET['mois'], $_GET['jour']);
236
		$Week = new Calendar_Week($_GET['annee'], $_GET['mois'], $_GET['jour']);
234
		$Week->build();
237
		$Week->build();
235
		$aso_jours = array();
238
		$aso_jours = array();
236
		$aso_semaine = array();
239
		$aso_semaine = array();
237
		foreach($Week->fetchAll() as $num => $j) {
240
		foreach($Week->fetchAll() as $num => $j) {
238
			$aso_semaine[$num]['mysql'] = $j->thisYear().'-'.sprintf("%02s", $j->thisMonth()).'-'.sprintf("%02s", $j->thisDay());
241
			$aso_semaine[$num]['mysql'] = $j->thisYear().'-'.sprintf("%02s", $j->thisMonth()).'-'.sprintf("%02s", $j->thisDay());
239
			$aso_jours[$aso_semaine[$num]['mysql']] = $num;
242
			$aso_jours[$aso_semaine[$num]['mysql']] = $num;
240
		}
243
		}
241
 
244
 
242
		// Récupération du temps de travail pour un utilisateur à une date donnée
245
		// Récupération du temps de travail pour un utilisateur à une date donnée
243
    	$TravailProjet = new TravailProjet();
246
    	$TravailProjet = new TravailProjet();
244
		$cmd = TravailProjet::GTP_ID_UTILISATEUR_DATE_DEB_FIN;
247
		$cmd = TravailProjet::GTP_ID_UTILISATEUR_DATE_DEB_FIN;
245
		$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_semaine[1]['mysql'], $aso_semaine[7]['mysql']);
248
		$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_semaine[1]['mysql'], $aso_semaine[7]['mysql']);
246
		$tab_tp = $TravailProjet->consulter($cmd, $param);
249
		$tab_tp = $TravailProjet->consulter($cmd, $param);
247
 
250
 
248
		// Récupération des infos sur l'utilisateur courrant
251
		// Récupération des infos sur l'utilisateur courrant
249
		$tps_w_jour = $GLOBALS['_GTT_']['Utilisateur']->getTempsDeTravailJour();
252
		$tps_w_jour = $GLOBALS['_GTT_']['Utilisateur']->getTempsDeTravailJour();
250
		// Création d'un utilisateur pour les mises à jour des CP et RTT
253
		// Création d'un utilisateur pour les mises à jour des CP et RTT
251
		$Utilisateur = new Utilisateur();
254
		$Utilisateur = new Utilisateur();
252
		$Utilisateur->setIdUtilisateur($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
255
		$Utilisateur->setIdUtilisateur($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
253
		$Utilisateur->setQuotaHeuresSupp($GLOBALS['_GTT_']['Utilisateur']->getQuotaHeuresSupp());
256
		$Utilisateur->setQuotaHeuresSupp($GLOBALS['_GTT_']['Utilisateur']->getQuotaHeuresSupp());
254
		$Utilisateur->setCongesPayes($GLOBALS['_GTT_']['Utilisateur']->getCongesPayes());
257
		$Utilisateur->setCongesPayes($GLOBALS['_GTT_']['Utilisateur']->getCongesPayes());
255
		$Utilisateur->setTempsDeTravailJour(null);
258
		$Utilisateur->setTempsDeTravailJour(null);
256
		$Utilisateur->setTempsDeTravailMois(null);
259
		$Utilisateur->setTempsDeTravailMois(null);
257
		$Utilisateur->setMarkAdmin(null);
260
		$Utilisateur->setMarkAdmin(null);
258
		$Utilisateur->setMarkRecapitulatif(null);
261
		$Utilisateur->setMarkRecapitulatif(null);
259
 
262
 
260
		// Initialisation de la variable pour la gestion des heures sup
263
		// Initialisation de la variable pour la gestion des heures sup
261
		$jours_w_semaine = array_flip(explode(',', GTT_SEMAINE_JOUR_W_NBRE));
264
		$jours_w_semaine = array_flip(explode(',', GTT_SEMAINE_JOUR_W_NBRE));
262
		foreach ($jours_w_semaine as $c => $v) {
265
		foreach ($jours_w_semaine as $c => $v) {
263
			$jours_w_semaine[$c] = array('act' => 0, 'pre' => 0);
266
			$jours_w_semaine[$c] = array('act' => 0, 'pre' => 0, 'act_a' => 0, 'pre_a' => 0, 'mod' => false);
264
		}
267
		}
265
 
268
 
266
		// Ajout ou Mise à jour des durées de travail
269
		// Ajout ou Mise à jour des durées de travail
267
		if (isset($_POST['pr'])) {
270
		if (isset($_POST['pr'])) {
268
			foreach($_POST['pr'] as $projet_id => $jours) {
271
			foreach($_POST['pr'] as $projet_id => $jours) {
269
				//echo '<pre>'.print_r($jours, true).'</pre>';
272
				//echo '<pre>'.print_r($jours, true).'</pre>';
270
				foreach($jours as $jour_num => $nbr_heure) {
273
				foreach($jours as $jour_num => $nbr_heure) {
271
					if (isset($jours_w_semaine[$jour_num])) {
274
					if (isset($jours_w_semaine[$jour_num])) {
272
						$jours_w_semaine[$jour_num]['act'] += $nbr_heure;
275
						$jours_w_semaine[$jour_num]['act'] += $nbr_heure;
273
					}
276
					}
274
					$bool_ajouter = true;
277
					$bool_ajouter = true;
275
					if (!empty($tab_tp)) {
278
					if (!empty($tab_tp)) {
276
						foreach ($tab_tp as $TP) {
279
						foreach ($tab_tp as $TP) {
277
							if ($TP->getIdDateTravail() == $aso_semaine[$jour_num]['mysql']) {
280
							if ($TP->getIdDateTravail() == $aso_semaine[$jour_num]['mysql']) {
278
								if ($TP->getIdProjet() == $projet_id) {
281
								if ($TP->getIdProjet() == $projet_id) {
279
									$bool_ajouter = false;
282
									$bool_ajouter = false;
280
									if (isset($jours_w_semaine[$jour_num])) {
283
									$jours_w_semaine[$jour_num]['pre'] += $TP->getDuree();
281
										$jours_w_semaine[$jour_num]['pre'] += $TP->getDuree();
284
									$jours_w_semaine[$jour_num]['mod'] = true;
282
									}
-
 
283
									if ($TP->getDuree() != $nbr_heure) {
285
									if ($TP->getDuree() != $nbr_heure) {
284
										if (empty($nbr_heure)) {
286
										if (empty($nbr_heure)) {
-
 
287
											// Une fois des données saisie dans un jour, on ne supprime pas la ligne mais
-
 
288
											// on met la durée 0
-
 
289
											$TP->setDuree(0);
285
											$TP->supprimer();
290
											$TP->modifier();
286
										} else {
291
										} else {
287
											$TP->setDuree($nbr_heure);
292
											$TP->setDuree($nbr_heure);
288
											$TP->modifier();
293
											$TP->modifier();
289
										}
294
										}
290
									}
295
									}
291
								}
296
								}
292
							}
297
							}
293
						}
298
						}
294
					}
299
					}
295
					if ($bool_ajouter && !empty($nbr_heure)) {
300
					if ($bool_ajouter && !empty($nbr_heure)) {
296
						$TP = new TravailProjet();
301
						$TP = new TravailProjet();
297
						$TP->setDuree((float)$nbr_heure);
302
						$TP->setDuree((float)$nbr_heure);
298
						$TP->setIdUtilisateur($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
303
						$TP->setIdUtilisateur($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
299
						$TP->setIdProjet($projet_id);
304
						$TP->setIdProjet($projet_id);
300
						$TP->setIdDateTravail((string)$aso_semaine[$jour_num]['mysql']);
305
						$TP->setIdDateTravail((string)$aso_semaine[$jour_num]['mysql']);
301
						$TP->ajouter();
306
						$TP->ajouter();
302
					}
307
					}
303
				}
308
				}
304
			}
309
			}
305
		}
310
		}
306
 
311
 
307
		// Récupération des absences pour un utilisateur à une date donnée
312
		// Récupération des absences pour un utilisateur à une date donnée
308
    	$Absence = new Absence();
313
    	$Absence = new Absence();
309
		$cmd = Absence::GA_ID_UTILISATEUR_DATE_DEB_FIN;
314
		$cmd = Absence::GA_ID_UTILISATEUR_DATE_DEB_FIN;
310
		$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_semaine[1]['mysql'], $aso_semaine[7]['mysql']);
315
		$param = array($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur(), $aso_semaine[1]['mysql'], $aso_semaine[7]['mysql']);
311
		$tab_a = $Absence->consulter($cmd, $param);
316
		$tab_a = $Absence->consulter($cmd, $param);
312
 
317
 
313
		// Ajout ou Mise à jour des durées d'absences pour congés payés
318
		// Ajout ou Mise à jour des durées d'absences pour congés payés
314
		$cp_h_modif = 0;
319
		$cp_h_modif = 0;
315
		$hs_h_modif = 0;
320
		$hs_h_modif = 0;
316
		if (isset($_POST['ab'])) {
321
		if (isset($_POST['ab'])) {
317
			//echo '<pre>'.print_r($_POST['ab'], true).'</pre>';
322
			//echo '<pre>'.print_r($_POST['ab'], true).'</pre>';
318
			foreach($_POST['ab'] as $ab_id => $tab_num_j) {
323
			foreach($_POST['ab'] as $ab_id => $tab_num_j) {
319
				// Création du motif d'absence pour voir si on doit diminuer les congés payés
324
				// Création du motif d'absence pour voir si on doit diminuer les congés payés
320
				$AbsenceMotif = new AbsenceMotif();
325
				$AbsenceMotif = new AbsenceMotif();
321
				$AbsenceMotif->consulter(AbsenceMotif::GAM_ID, $ab_id, true);
326
				$AbsenceMotif->consulter(AbsenceMotif::GAM_ID, $ab_id, true);
322
 
327
 
323
				foreach($tab_num_j as $num_j => $ab_duree) {
328
				foreach($tab_num_j as $num_j => $ab_duree) {
-
 
329
					// Gestion des heures sup en fonction du type d'absence
324
					if (isset($jours_w_semaine[$num_j])) {
330
					if (isset($jours_w_semaine[$num_j])) {
-
 
331
						if ($AbsenceMotif->getMarkHsDiminuer()) {
-
 
332
							$jours_w_semaine[$num_j]['act_a'] += $ab_duree;
-
 
333
						} else {
325
						$jours_w_semaine[$num_j]['act'] += $ab_duree;
334
							$jours_w_semaine[$num_j]['act'] += $ab_duree;
-
 
335
						}
326
					}
336
					}
327
					$bool_ajouter = true;
337
					$bool_ajouter = true;
328
					if (!empty($tab_a)) {
338
					if (!empty($tab_a)) {
329
						foreach ($tab_a as $A) {
339
						foreach ($tab_a as $A) {
330
							if ($A->getIdDateAbsence() == $aso_semaine[$num_j]['mysql']) {
340
							if ($A->getIdDateAbsence() == $aso_semaine[$num_j]['mysql']) {
331
 
-
 
332
								if ($A->getIdAbsenceMotif() == $ab_id) {
341
								if ($A->getIdAbsenceMotif() == $ab_id) {
333
									$bool_ajouter = false;
342
									$bool_ajouter = false;
-
 
343
									// Gestion des heures sup en fonction du type d'absence
334
									if (isset($jours_w_semaine[$num_j])) {
344
									if ($AbsenceMotif->getMarkHsDiminuer()) {
-
 
345
										$jours_w_semaine[$num_j]['pre_a'] += $A->getDuree();
-
 
346
									} else {
335
										$jours_w_semaine[$num_j]['pre'] += $A->getDuree();
347
										$jours_w_semaine[$num_j]['pre'] += $A->getDuree();
-
 
348
										$jours_w_semaine[$num_j]['mod'] = true;
336
									}
349
									}
337
									if ($A->getDuree() != $ab_duree) {
350
									if ($A->getDuree() != $ab_duree) {
338
										if (empty($ab_duree)) {
351
										if (empty($ab_duree)) {
339
											$A->supprimer();
-
 
340
											if ($AbsenceMotif->getMarkCpDiminuer()) {
352
											if ($AbsenceMotif->getMarkCpDiminuer()) {
341
												$cp_h_modif -= $A->getDuree();
353
												$cp_h_modif -= $A->getDuree();
342
											}
354
											}
343
											if ($AbsenceMotif->getMarkHsDiminuer()) {
355
											if ($AbsenceMotif->getMarkHsDiminuer()) {
344
												$hs_h_modif -= $A->getDuree();
356
												$hs_h_modif -= $A->getDuree();
345
											}
357
											}
-
 
358
											// Une fois des données saisie dans un jour, on ne supprime pas la ligne mais
-
 
359
											// on met la durée 0
-
 
360
											$A->setDuree(0);
-
 
361
											$A->modifier();
346
										} else {
362
										} else {
347
											$ab_duree_tmp = $A->getDuree();
363
											$ab_duree_tmp = $A->getDuree();
348
											$A->setDuree($ab_duree);
364
											$A->setDuree($ab_duree);
349
											$A->modifier();
365
											$A->modifier();
350
											if ($AbsenceMotif->getMarkCpDiminuer()) {
366
											if ($AbsenceMotif->getMarkCpDiminuer()) {
351
												$cp_h_modif -= $ab_duree_tmp - $ab_duree;
367
												$cp_h_modif -= $ab_duree_tmp - $ab_duree;
352
											}
368
											}
353
											if ($AbsenceMotif->getMarkHsDiminuer()) {
369
											if ($AbsenceMotif->getMarkHsDiminuer()) {
354
												$hs_h_modif -= $ab_duree_tmp - $ab_duree;
370
												$hs_h_modif -= $ab_duree_tmp - $ab_duree;
355
											}
371
											}
356
										}
372
										}
357
									}
373
									}
358
								}
374
								}
359
							}
375
							}
360
						}
376
						}
361
					}
377
					}
362
					if ($bool_ajouter && !empty($ab_duree)) {
378
					if ($bool_ajouter && !empty($ab_duree)) {
363
						$A = new Absence();
379
						$A = new Absence();
364
						$A->setDuree((float)$ab_duree);
380
						$A->setDuree((float)$ab_duree);
365
						$A->setIdUtilisateur($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
381
						$A->setIdUtilisateur($GLOBALS['_GTT_']['Utilisateur']->getIdUtilisateur());
366
						$A->setIdAbsenceMotif($ab_id);
382
						$A->setIdAbsenceMotif($ab_id);
367
						$A->setIdDateAbsence((string)$aso_semaine[$num_j]['mysql']);
383
						$A->setIdDateAbsence((string)$aso_semaine[$num_j]['mysql']);
368
						$A->ajouter();
384
						$A->ajouter();
369
						if ($AbsenceMotif->getMarkCpDiminuer()) {
385
						if ($AbsenceMotif->getMarkCpDiminuer()) {
370
							$cp_h_modif += $ab_duree;
386
							$cp_h_modif += $ab_duree;
371
						}
387
						}
372
						if ($AbsenceMotif->getMarkHsDiminuer()) {
388
						if ($AbsenceMotif->getMarkHsDiminuer()) {
373
							$hs_h_modif += $ab_duree;
389
							$hs_h_modif += $ab_duree;
374
						}
390
						}
375
					}
391
					}
376
				}
392
				}
377
			}
393
			}
378
			
394
			
379
			// Gestion de la mise à jour des congés payés
395
			// Gestion de la mise à jour des congés payés
380
			if ($cp_h_modif > 0) {
396
			if ($cp_h_modif > 0) {
381
				$Utilisateur->diminuerCongesPayes($cp_h_modif);
397
				$Utilisateur->diminuerCongesPayes($cp_h_modif);
382
			}
398
			}
383
			if ($cp_h_modif < 0) {
399
			if ($cp_h_modif < 0) {
384
				$Utilisateur->augmenterCongesPayes(abs($cp_h_modif));
400
				$Utilisateur->augmenterCongesPayes($cp_h_modif);
385
			}
401
			}
-
 
402
			// Gestion de la mise à jour des heures sup
386
			if ($hs_h_modif > 0) {
403
			if ($hs_h_modif > 0) {
387
				$Utilisateur->diminuerQuotaHeuresSup($hs_h_modif);
404
				$Utilisateur->diminuerQuotaHeuresSup($hs_h_modif);
388
			}
405
			}
389
			if ($hs_h_modif < 0) {
406
			if ($hs_h_modif < 0) {
390
				$Utilisateur->augmenterQuotaHeuresSup(abs($hs_h_modif));
407
				$Utilisateur->augmenterQuotaHeuresSup($hs_h_modif);
391
			}
408
			}
392
			$Utilisateur->modifier();
409
			$Utilisateur->modifier();
393
		}
410
		}
394
 
411
 
395
		// Gestion de la mise à jour des heures sup
412
		// Gestion de la mise à jour des heures sup
396
		foreach ($jours_w_semaine as $c => $j) {
413
		foreach ($jours_w_semaine as $c => $j) {
397
			if (($j['pre'] - $j['act']) != 0) {// Modification sur le temps travaillé pour le jour courant
414
			if (($j['pre'] != 0 || $j['act'] != 0) ) {// Modification sur le temps travaillé pour le jour courant
398
				$heure_sup_pre = $j['pre'] - $tps_w_jour;// -7 = 0 - 7
415
				$heure_sup_pre = $j['pre'] - ($tps_w_jour - $j['pre_a']);// -7 = 0 - 7
399
				$heure_sup_act = $j['act'] - $tps_w_jour;// -5 = 2 - 7
416
				$heure_sup_act = $j['act'] - ($tps_w_jour - $j['act_a']);// -5 = 2 - 7
400
				$heure_sup_dif = $heure_sup_act - $heure_sup_pre;// 2 = -5 - -7  
417
				$heure_sup_dif = $heure_sup_act - $heure_sup_pre ;// 2 =  -5 - -7  
401
				if (abs($heure_sup_pre) == $tps_w_jour) {// Premiere modifier du temps travaillé pour le jour courrant
418
				if ($j['mod'] == false) {// Première fois que l'on modifie le jour
402
					if ($heure_sup_act < 0) {
419
					if ($heure_sup_act < 0) {
403
						$Utilisateur->diminuerQuotaHeuresSup(abs($heure_sup_act));
420
						$Utilisateur->diminuerQuotaHeuresSup($heure_sup_act);
404
					}
421
					}
405
					if ($heure_sup_act > 0) {
422
					if ($heure_sup_act > 0) {
406
						$Utilisateur->augmenterQuotaHeuresSup($heure_sup_act);
423
						$Utilisateur->augmenterQuotaHeuresSup($heure_sup_act);
407
					}
424
					}					
408
				} else {
425
				} else  {// Les heures sup ont déjà été comptabilisées
409
					if ($heure_sup_dif < 0) {
426
					if ($heure_sup_dif < 0) {
410
						$Utilisateur->diminuerQuotaHeuresSup(abs($heure_sup_dif));
427
						$Utilisateur->diminuerQuotaHeuresSup($heure_sup_dif);
411
					}
428
					}
412
					if ($heure_sup_dif > 0) {
429
					if ($heure_sup_dif > 0) {
413
						$Utilisateur->augmenterQuotaHeuresSup($heure_sup_dif);
430
						$Utilisateur->augmenterQuotaHeuresSup($heure_sup_dif);
414
					}
431
					}					
415
				}
432
				}
416
			}
433
			}
417
		}
434
		}
418
		
-
 
419
		trigger_error(print_r($jours_w_semaine, true), E_USER_NOTICE);//$heure_sup_pre.'/'.$heure_sup_act.'-'.$total_jours
-
 
420
		$Utilisateur->modifier();
435
		$Utilisateur->modifier();
421
 
436
 
422
		// Mise à jour de la vue Identité pour les congés payés et RTT
437
		// Mise à jour de la vue Identité pour les congés payés et RTT
423
		$GttCtrlActionIdentification = new GttCtrlActionIdentification($this->getRegistre());
438
		$GttCtrlActionIdentification = new GttCtrlActionIdentification($this->getRegistre());
424
		$GttCtrlActionIdentification->setSuivant('__defaut__');
439
		$GttCtrlActionIdentification->setSuivant('__defaut__');
425
		$this->setSuivant($GttCtrlActionIdentification);
440
		$this->setSuivant($GttCtrlActionIdentification);
426
 
441
 
427
    	// Action suivante
442
    	// Action suivante
428
    	$this->setSuivant('__defaut__');
443
    	$this->setSuivant('__defaut__');
429
    }
444
    }
430
}
445
}
431
?>
446
?>