]> git.llucax.com Git - mecon/intranet.git/blobdiff - sistema/www/servicios/bandas/banda_agente.php
Se corrige un bug.
[mecon/intranet.git] / sistema / www / servicios / bandas / banda_agente.php
index 1ce9e550f3f3d14d596679556ef9f5c897153a9a..509d6329c24e45f2ef110ecbf2f60a864f5e6ee4 100644 (file)
@@ -1,46 +1,57 @@
 <?
 <?
-require_once '../../../local_lib/HTML_DietMarco.php';
+require_once 'HTML_DietMarco.php';
+require_once 'HTML_Mensaje.php';
+require_once 'HTML/Table.php';
 require_once 'MECON/HTML/Image.php';
 require_once 'MECON/HTML/Link.php';
 require_once 'MECON/Dependencia.php';
 require_once 'MECON/NovedadesDia.php';
 require_once 'MECON/HTML/Image.php';
 require_once 'MECON/HTML/Link.php';
 require_once 'MECON/Dependencia.php';
 require_once 'MECON/NovedadesDia.php';
-require_once 'BandasNovedades/AgenteBanda.php';
-require_once 'HTML/Table.php';
 require_once 'MECON/HTML/Tabla.php';
 require_once 'MECON/HTML/Tabla.php';
+require_once 'BandasNovedades/AgenteBanda.php';
 require_once 'BandasNovedades/HTML/TablaInfoMes.php';
 require_once 'BandasNovedades/HTML/TablaReferencias.php';
 require_once 'BandasNovedades/HTML/TablaInfoPersonal.php';
 require_once 'BandasNovedades/HTML/TablaInfoMes.php';
 require_once 'BandasNovedades/HTML/TablaReferencias.php';
 require_once 'BandasNovedades/HTML/TablaInfoPersonal.php';
-require_once 'DB.php';
 
 if(!isset($_SESSION['documento']) or !isset($_POST['fecha']))
 {
        header('Location: ../../servicios.php');
 }
 
 
 if(!isset($_SESSION['documento']) or !isset($_POST['fecha']))
 {
        header('Location: ../../servicios.php');
 }
 
-//CREO LA CONEXION A LA BASE DE DATOS
-$dbh = DB::connect("mysql://intranet:intranet@bal747f/bandas",true);
-if (DB::isError($dbh)) {
-    die ($DB->getMessage());
-}
-
 //Seteo las variables generales
 $nrodoc = $_SESSION['documento'];
 setlocale (LC_ALL, 'es_AR');
 $fecha = $_POST['fecha'];
 $fecha_spliteada = split('-',$fecha);
 
 //Seteo las variables generales
 $nrodoc = $_SESSION['documento'];
 setlocale (LC_ALL, 'es_AR');
 $fecha = $_POST['fecha'];
 $fecha_spliteada = split('-',$fecha);
 
-$agente =& new BandasNovedades_AgenteBanda($nrodoc,new date($fecha),$dbh);
-if(!$agente->buscarAgente($nrodoc))
-{
-       echo "El agente no está en las bases de RRHH";
-       die;
-}
 
 /* Instancio DietMarco que sirve para mostrar la pagina dentro del marco de Intranet*/
 $m =& new HTML_DietMarco('servicios','Bandas Horarias');
 
 /* Instancio DietMarco que sirve para mostrar la pagina dentro del marco de Intranet*/
 $m =& new HTML_DietMarco('servicios','Bandas Horarias');
-$m->addTitle('Bandas Horarias');
+//$m->addTitle('Bandas Horarias');
 $m->addStyleSheet('../../css/servicios_bandas.css');
 
 $m->addStyleSheet('../../css/servicios_bandas.css');
 
+$agente =& new BandasNovedades_AgenteBanda($nrodoc,new date($fecha),$DB);
+
+if(!$agente->buscarAgente($nrodoc))
+{
+       $HTML_Mensaje =& new HTML_Mensaje("alerta","El agente no está en las bases de RRHH",450);
+       $m->addStyleSheet($HTML_Mensaje->getCSS());
+       $m->addBodyContent($HTML_Mensaje);
+       $m->display();
+       exit;
+}
+
+
+/* Si el agente es un contratado entonces no muestro la info */
+if(preg_match('/^CON/',$agente->getTipo()))
+{
+       $HTML_Mensaje =& new HTML_Mensaje("alerta","Información no disponible",300);
+       $m->addStyleSheet($HTML_Mensaje->getCSS());
+       $m->addBodyContent($HTML_Mensaje);
+       $m->display();
+       exit;
+}
+
+
 /* Instancio un objeto Table para el cuerpo de la pagina*/
 $tabla_cuerpo =& new HTML_Table(array('width'=>'760','border'=>'0','cellspacing'=>'0','cellpadding'=>'0'));
 
 /* Instancio un objeto Table para el cuerpo de la pagina*/
 $tabla_cuerpo =& new HTML_Table(array('width'=>'760','border'=>'0','cellspacing'=>'0','cellpadding'=>'0'));
 
@@ -108,30 +119,51 @@ con las referencias de cada color de las celdas
 /* Armo la tabla de la información personal */
 
 $tabla_info_personal =& new BandasNovedades_HTML_TablaInfoPersonal($agente,'oscuro');
 /* Armo la tabla de la información personal */
 
 $tabla_info_personal =& new BandasNovedades_HTML_TablaInfoPersonal($agente,'oscuro');
-
 $m->addStyleSheet($tabla_info_personal->getCSS());
 
 
 /* Agrego la tabla de información personal al cuerpo de la página*/
 $m->addStyleSheet($tabla_info_personal->getCSS());
 
 
 /* Agrego la tabla de información personal al cuerpo de la página*/
-$m->addBodyContent($tabla_info_personal);
-
-$m->addBodyContent('<BR>');
-
-/* Armo la tabla con la gilla horaria*/
-$tabla_info =& new BandasNovedades_HTML_TablaInfoMes($agente,'nov_dia.php','oscuro');
-
-/* Armo la tabla de referencias */
-$tabla_referencias =& new BandasNovedades_HTML_TablaReferencias('oscuro');
-
-/* Agrego las tablas de referencia al cuerpo */
 $t =& new HTML_Table(array('width'=>'760',
                                                        'border'=>'0',
                                                        'cellspacing'=>'0',
                                                        'cellpadding'=>'0'));
 $t =& new HTML_Table(array('width'=>'760',
                                                        'border'=>'0',
                                                        'cellspacing'=>'0',
                                                        'cellpadding'=>'0'));
+
+$t->addRow(array($tabla_info_personal),array('colspan'=>'3'));
+$t->addRow(array('&nbsp;'),array('colspan'=>'3'));
+
+/* Agrego las tablas de referencia al cuerpo */
 $row = array();
 $row = array();
-$row = array($tabla_info,'&nbsp',$tabla_referencias);
+
+if(BandasNovedades_AgenteBanda::tieneCredencial($DB,$_SESSION['documento'],new Date($fecha)))
+{
+       /* Armo la tabla con la gilla horaria*/
+       $tabla_info =& new BandasNovedades_HTML_TablaInfoMes($agente,'nov_dia.php','oscuro');
+
+       /* Armo la tabla de referencias */
+       $tabla_referencias =& new BandasNovedades_HTML_TablaReferencias('oscuro');
+       
+       $row = array($tabla_info,'&nbsp',$tabla_referencias);
+}else
+{
+       $HTML_Mensaje =& new HTML_Mensaje("alerta","El agente no tiene credencial asignada en este mes",450);
+       $m->addStyleSheet($HTML_Mensaje->getCSS());
+       $row = array($HTML_Mensaje);
+}
+
 $t->addRow($row,array('valign'=>'top'));
 
 $t->addRow($row,array('valign'=>'top'));
 
+if($agente->getReduccionHoraria())
+{
+       $IMG_reduccion_horaria =& new MECON_HTML_Image('../../images/servicios_bandas_red_hs.gif',
+                                                                                                       '',
+                                                                                                       array('alt'=>'Agente con reducción horaria'));
+       $row = array('','',$IMG_reduccion_horaria->toHtml());
+}else
+{
+       $row = array('','','');
+}
+$t->addRow($row,array('valign'=>'top','align'=>'center'));
+$t->updateCellAttributes(2,0,array('rowspan'=>2));
 
 /* Esta fila contiene las referencias */
 $row_cuerpo = array($t);
 
 /* Esta fila contiene las referencias */
 $row_cuerpo = array($t);
@@ -160,19 +192,46 @@ $IMG_visto =& new MECON_HTML_Image('../../images/servicios_visto.gif',
                                                                array('width'=>'16','height'=>'10','valign'=>'top'));
 $link_volver =& new MECON_HTML_LINK('./','volver');
 
                                                                array('width'=>'16','height'=>'10','valign'=>'top'));
 $link_volver =& new MECON_HTML_LINK('./','volver');
 
-$row = array(  $IMG_notas,'Nota: Fecha de último cruce con las novedades',
-                               $IMG_anterior->toHtml().' '.$link_volver->toHtml(),
-                               $IMG_visto->toHtml()." <a href=\"\" onClick=\"window.open('./accesos.php?nrodoc=".$nrodoc."&fecha=".$_POST['fecha']."','accesos','scrollbars=yes,width=450,height=500,screenX=10,screenY=10');return(false);\">accesos</a>",
-                               $IMG_visto->toHtml()." <a href=\"\" onClick=\"window.open('./salidas_autorizadas.php?nrodoc=".$nrodoc."&fecha=".$_POST['fecha']."','salidas_autorizadas','scrollbars=yes,width=450,height=500,screenX=10,screenY=10');return(false);\">salidas autorizadas</a>");
-                       
+$MES_ACTUAL =& new date();
+$FECHA_PEDIDA =& new date($fecha);
+if($MES_ACTUAL->getmonth()==$FECHA_PEDIDA->getmonth() && $MES_ACTUAL->getyear()==$FECHA_PEDIDA->getyear())
+{
+       $sql = "Select fecha from FechaActualizacion where tipoActualizacion='DIARIO'
+                       order by fecha desc limit 1";
+       $result = $DB->query($sql);
+
+       if (DB::isError($result))
+               trigger_error($result->getMessage("Query mal hecho"), E_USER_ERROR);
+
+       $FECHA_ACTUALIZACION=$result->fetchRow(DB_FETCHMODE_ASSOC);
+
+       $FECHA=preg_replace('/(\d\d\d\d)(\d\d)(\d\d)(.*)/','$3/$2/$1',$FECHA_ACTUALIZACION['fecha']);
+       $row = array(   $IMG_notas,'Nota: Fecha de actualización '.$FECHA,
+                                       $IMG_anterior->toHtml().' '.$link_volver->toHtml(),
+                                       $IMG_visto->toHtml()." <a href=\"\" onClick=\"window.open('./accesos.php?nrodoc=".$nrodoc."&fecha=".$_POST['fecha']."','accesos','scrollbars=yes,width=450,height=500,screenX=10,screenY=10');return(false);\">accesos</a>",
+                                       $IMG_visto->toHtml()." <a href=\"\" onClick=\"window.open('./salidas_autorizadas.php?nrodoc=".$nrodoc."&fecha=".$_POST['fecha']."','salidas_autorizadas','scrollbars=yes,width=450,height=500,screenX=10,screenY=10');return(false);\">salidas autorizadas</a>");
+}else
+{
+       $row = array(   '','',
+                                       $IMG_anterior->toHtml().' '.$link_volver->toHtml(),
+                                       $IMG_visto->toHtml()." <a href=\"\" onClick=\"window.open('./accesos.php?nrodoc=".$nrodoc."&fecha=".$_POST['fecha']."','accesos','scrollbars=yes,width=450,height=500,screenX=10,screenY=10');return(false);\">accesos</a>",
+                                       $IMG_visto->toHtml()." <a href=\"\" onClick=\"window.open('./salidas_autorizadas.php?nrodoc=".$nrodoc."&fecha=".$_POST['fecha']."','salidas_autorizadas','scrollbars=yes,width=450,height=500,screenX=10,screenY=10');return(false);\">salidas autorizadas</a>");
+
+}
+
 $tabla_notas->addRow($row,array('class'=>'imprimir_bandas',
                                                                                'bgcolor'=>'#FFFFFF'));
 
 $tabla_notas->addRow($row,array('class'=>'imprimir_bandas',
                                                                                'bgcolor'=>'#FFFFFF'));
 
-$tabla_notas->updateCellAttributes(0,0,array('width'=>'24','height'=>'24','class'=>'aclarar'));
-$tabla_notas->updateCellAttributes(0,1,array('width'=>'370','height'=>'30','class'=>'aclarar'));
-$tabla_notas->updateCellAttributes(0,2,array('width'=>'130','class'=>'imprimir_bandas'));
-$tabla_notas->updateCellAttributes(0,3,array('width'=>'130','class'=>'imprimir_bandas'));
-$tabla_notas->updateCellAttributes(0,4,array('width'=>'130','class'=>'imprimir_bandas'));
+$tabla_notas->updateCellAttributes(0,0,array(  'width'=>'25','height'=>'30',
+                                                                                               'align'=>'left','class'=>'aclarar'));
+$tabla_notas->updateCellAttributes(0,1,array(  'width'=>'325',
+                                                                                               'align'=>'right','class'=>'aclarar'));
+$tabla_notas->updateCellAttributes(0,2,array(  'width'=>'145',
+                                                                                               'align'=>'right','class'=>'imprimir_bandas'));
+$tabla_notas->updateCellAttributes(0,3,array(  'width'=>'80',
+                                                                                               'align'=>'right','class'=>'imprimir_bandas'));
+$tabla_notas->updateCellAttributes(0,4,array(  'width'=>'125',
+                                                                                               'align'=>'right','class'=>'imprimir_bandas'));
 
 $m->addBodyContent($tabla_notas);
 $m->display();
 
 $m->addBodyContent($tabla_notas);
 $m->display();