]> git.llucax.com Git - mecon/intranet.git/blob - sistema/www/servicios/novedades/novedades.php
- Corregi un bug que se producia cuando el agente no tenia ningun acceso en el mes...
[mecon/intranet.git] / sistema / www / servicios / novedades / novedades.php
1 <?php 
2 /*-----------------------------------------------------------------------------
3 Intranet del Ministerio de Economía
4 Consulta de Novedades de Personal
5 -------------------------------------------------------------------------------
6 Myrna Degano <mdegan@mecon.gov.ar>
7 ------------------------------------------------------------------------------*/
8
9 require_once 'BandasNovedades/Agente.php';
10 require_once 'HTML/Table.php';
11 require_once 'MECON/HTML/Tabla.php';
12 require_once '../../../local_lib/HTML_DietMarco.php';
13 require_once '../../../local_lib/HTML_Mensaje.php';
14 require_once 'MECON/HTML/QuickFormSimple.php';
15 require_once 'MECON/HTML/Image.php';
16 require_once 'MECON/HTML/Link.php';
17 require_once 'DB.php';
18
19 if(!isset($_SESSION['documento'])){
20         header('Location: ../../servicios.php');
21         exit;
22 }
23 $nrodoc = $_SESSION['documento'];
24
25 //Conexión a la BD
26 $dbh = DB::connect("mysql://intranet:intranet@intranet-db/novedades", true);
27 if (DB::isError($dbh)) {
28     die ($dbh->getMessage());
29 }
30
31 //Marco de servicios en intranet
32 $MARCO     = new HTML_DietMarco('servicios', 'Novedades de Personal');
33 $MARCO->addTitle('Novedades de Personal');
34 $MARCO->addStyleSheet('../../css/servicios_novedades.css');
35
36
37 //Datos del agente
38 $agente =& new BandasNovedades_Agente($dbh, $nrodoc);
39
40
41 if (substr($agente->getTipo(), 0, 3) == 'CON'){
42     //El agente es contratado, por lo tanto no se le muestran novedades
43
44     $MSG =& new HTML_Mensaje ('error', 'Novedades de Personal no disponibles', 360); 
45     $MARCO->addBodyContent('<br><br>');
46     $MARCO->addBodyContent($MSG);
47 }
48 else{
49     //Fecha
50     $fecha = getdate();
51     $anio_actual = $fecha['year'];
52     $anio_de_consulta = (isset($_POST['year']))?$_POST['year']:$anio_actual;
53
54     //Imágenes
55     $IMG_Nota =& new MECON_HTML_Image('../../images/servicios_nota.gif', 'Nota');
56     $IMG_Info =& new MECON_HTML_Image('../../images/servicios_info.gif', 'Información');
57     $IMG_Viñeta =& new MECON_HTML_Image('../../images/servicios_flecha_naranja.gif', '>>');
58     $IMG_Mail =& new MECON_HTML_Image('../../images/servicios_mail.gif', 'Consultas');
59
60     //Links
61     $LINK_Mail =& new MECON_HTML_Link('mailto:asistencia@mecon.gov.ar?subject=INTRANET-Novedades de Personal', 'Consultas');
62     $LINK_Novedad =& new MECON_HTML_Link('', '-');
63         $url_detalle = './detalle.php?nrodoc='.$nrodoc.'&anio='.$anio_de_consulta;
64         $attrs = 'width=330,height=350,screenX=50,screenY=50,scrollbars=yes';
65
66     //Elementos del Formulario
67     $FORM =& new MECON_HTML_QuickFormSimple ('form', 'post', './novedades.php');
68     $select_year =& $FORM->addElement ('select', 'year', 'year', 
69                                             array($anio_actual=>$anio_actual, $anio_actual-1=>$anio_actual-1));
70     $select_year->setSelected($anio_de_consulta);
71     $boton =& $FORM->addElement('submit', 'submit', 'ver...');
72
73     //Novedades
74     $nov_diarias = $agente->obtenerNovedades($anio_de_consulta);
75     $nov_prolongadas = $agente->obtenerLicencias($anio_de_consulta);
76     
77     //Tablas
78     $TABLA_Form =& new MECON_HTML_Tabla ('width="300" align="left"', 'oscuro');
79     $TABLA_Form->addRow(array('Año', $select_year->toHtml(), $boton->toHtml()),
80                             array('width'=>'100', 'align'=>'center'));
81     $TABLA_Form->updateColAttributes(0, 'cabecera align="center"');
82
83     $TABLA_Pie =& new HTML_Table ('width="600" border="0"');
84     $TABLA_Pie->addRow(array($IMG_Info->toHtml(),'Información Suministrada por la Dirección General de Recursos Humanos', $IMG_Mail->toHtml(),$LINK_Mail->toHtml()));
85     $TABLA_Pie->updateColAttributes(0, 'width="25" valign="middle"');
86     $TABLA_Pie->updateColAttributes(1, 'width="500" class="servicios_novedades_txt_chicoiz"');
87     $TABLA_Pie->updateColAttributes(2, 'width="25" align="right" valign="middle"');
88     $TABLA_Pie->updateColAttributes(3, 'width="50" class="servicios_novedades_txt_chicoiz"');
89
90     $TABLA_NovDiarias =& new MECON_HTML_Tabla ('width="600" ', 'oscuro');
91     if (count($nov_diarias) > 0){
92         $titulo = 'Novedades Diarias - Totales '.$anio_de_consulta;
93         $titulo.= ($anio_de_consulta == $anio_actual)?' desde comienzo del año hasta la fecha':'';
94         $TABLA_NovDiarias->addRow(array($titulo), array('colspan'=>'3', 'cabecera'=>'1')); 
95         $TABLA_NovDiarias->addRow(array('Código', 'Descripción de la Novedad', 'Cant. días'), array('titulo'=>'1')); 
96
97         foreach ($nov_diarias AS $item){
98             $LINK_Novedad->setContents($item['2']);
99                     $url_detalle.='&codnov='.$item[0];
100                     $attribute = "window.open('$url_detalle', 'detalle', '$attrs');return(false);";
101                 $LINK_Novedad->updateAttributes(array('onClick'=>$attribute));
102             $TABLA_NovDiarias->addRow(array($item[0], $item[1], $LINK_Novedad)); 
103             $TABLA_NovDiarias->updateColAttributes( 2, 'align="center"'); 
104         }
105     }
106     else{
107         $TABLA_NovDiarias->addRow(array('Novedades Diarias'), 'cabecera'); 
108         $TABLA_NovDiarias->addRow(array('No Existen'), 'comun'); 
109     }
110
111     $TABLA_Licencias =& new MECON_HTML_Tabla ('width="600" ', 'oscuro');
112     if (count($nov_prolongadas) > 0){
113         $TABLA_Licencias->addRow(array('Licencias Prolongadas'), array('colspan'=>'4', 'cabecera'=>'1')); 
114         $TABLA_Licencias->addRow(array('Código', 'Descripción de la Novedad', 'Desde', 'Hasta'), array('titulo'=>'1')); 
115         foreach ($nov_prolongadas AS $item){
116             $fecha_desde = substr($item[2], 6, 2).'-'.substr($item[2], 4, 2).'-'.substr($item[2], 0, 4);
117             $fecha_hasta = substr($item[3], 6, 2).'-'.substr($item[3], 4, 2).'-'.substr($item[3], 0, 4);
118             $TABLA_Licencias->addRow(array($item[0], $item[1], $fecha_desde, $fecha_hasta)); 
119             if (substr($item[2], 0, 4) != $anio_de_consulta){
120                 $TABLA_Licencias->updateCellAttributes ($TABLA_Licencias->getRowCount()-1 , 2, 'class="servicios_novedades_resaltar_fecha"');
121             }
122             if (substr($item[3], 0, 4) != $anio_de_consulta){
123                 $TABLA_Licencias->updateCellAttributes ($TABLA_Licencias->getRowCount()-1 , 3, 'class="servicios_novedades_resaltar_fecha"');
124             }
125         }
126     }
127     else{
128         $TABLA_Licencias->addRow(array('Licencias Prolongadas'), 'cabecera'); 
129         $TABLA_Licencias->addRow(array('No Existen'), 'comun'); 
130     }
131
132     $TABLA_Contenido =& new HTML_Table ('width="600" align="center" border="0"');
133     $TABLA_Contenido->addRow(array($IMG_Viñeta->toHtml().$agente->getNombre()), 
134                                  array('class'=>'servicios_novedades_txt_fila', 'align'=>'left'));
135     $TABLA_Contenido->addRow(array('<br>'));
136     $TABLA_Contenido->addRow(array($TABLA_Form->toHtml()), array('align'=>'left'));
137     $TABLA_Contenido->addRow(array('<br>'));
138
139     $TABLA_Contenido->addRow(array($TABLA_NovDiarias->toHtml()), array('align'=>'left'));
140     $TABLA_Contenido->addRow(array('<br>'));
141     $TABLA_Contenido->addRow(array($TABLA_Licencias->toHtml()), array('align'=>'left'));
142     $TABLA_Contenido->addRow(array('<br>'));
143     
144     if ($anio_de_consulta == $anio_actual){
145         //Las vacaciones solamente se muestran si es el año corriente
146         $vacaciones = $agente->obtenerVacaciones($anio_actual);
147
148         if (count($vacaciones) > 0){
149             $TABLA_Vacaciones =& new MECON_HTML_Tabla ('width="600" ', 'oscuro');
150             $TABLA_Vacaciones->addRow(array('Vacaciones'), array('colspan'=>'4', 'cabecera'=>'1')); 
151             $TABLA_Vacaciones->addRow(array('Año', 'Total de Días', 'Días Tomados', 'Saldo'), array('titulo'=>'1')); 
152             foreach ($vacaciones AS $item){
153                 $tomados = $item[1]-$item[2];
154                 $TABLA_Vacaciones->addRow(array($item[0], $item[1], (string) $tomados , $item[2])); 
155             }
156         
157             $TABLA_Contenido->addRow(array($TABLA_Vacaciones->toHtml()), array('align'=>'left'));
158             $TABLA_Contenido->addRow(array('<br>'));
159         }
160     }    
161     $TABLA_Contenido->addRow(array($TABLA_Pie->toHtml()), array('align'=>'left'));
162
163
164     //Contenido de la página
165     $MARCO->addStyleSheet($TABLA_Form->getCss());
166
167     $MARCO->addBodyContent($FORM->getBegin());
168     $MARCO->addBodyContent($TABLA_Contenido);
169     $MARCO->addBodyContent($FORM->getEnd());
170 }
171
172 $MARCO->display();
173 ?>