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