git-svn-id: https://192.168.0.254/svn/Proyectos.Incam_Intranet/trunk/src@1 e2b1556b-49f8-d141-9351-52d6861a72d9
924 lines
28 KiB
PHP
924 lines
28 KiB
PHP
<?php
|
||
/*
|
||
* Created on 20/10/2008
|
||
*
|
||
* Representa la vacaciones de un empleado y comprende toda su gesti<74>n.
|
||
*
|
||
* 2008-10-20 (diego): Se crea la clase.
|
||
*/
|
||
|
||
include_once("Empleado.php");
|
||
include_once("ParteActividad.php");
|
||
include_once("./functions_sistema.php");
|
||
include_once("Calendario.php");
|
||
|
||
class Vacaciones{
|
||
|
||
/* Lista de vacaciones */
|
||
private $vacaciones;
|
||
|
||
/* Lista de vacaciones solicitadas */
|
||
private $vacacionesSolicitadas = null;
|
||
|
||
/* Lista de vacaciones aprobadas*/
|
||
private $vacacionesAprobadas = null;
|
||
|
||
/* Lista de vacaciones rechazadas*/
|
||
private $vacacionesRechazadas = null;
|
||
|
||
/* Lista de vacaciones pendientes de anulaci<63>n */
|
||
private $vacacionesAnulables = null;
|
||
|
||
/* Usuario de la sesi<73>n activa */
|
||
private $usuario;
|
||
|
||
/* Mes del calendario a considerar. */
|
||
private $mes;
|
||
|
||
/* A<>o del calendario a considerar. */
|
||
private $anio;
|
||
|
||
/* Identificador del solicitante de vacaciones*/
|
||
private $oid;
|
||
|
||
/* Empleado solicitante de vacaciones */
|
||
private $empleado;
|
||
|
||
/* Calendario para calcular d<>as especiales. */
|
||
private $calendario;
|
||
|
||
/** Idioma */
|
||
private $locale;
|
||
|
||
/**
|
||
* Crea un objeto que representa las vacaciones de un usuario.
|
||
* @param usuario - Usuario con la sesi<73>n activa.
|
||
* @param oid - Identificador del propietario de las vacaciones.
|
||
* @param mes - Mes del a<>o en que se gestionan las vacaciones.
|
||
* @param anio - A<>o para el que se gestionan las vacaciones.
|
||
* @param locale - Idioma en el que mostrar los mensajes.
|
||
*/
|
||
function Vacaciones($usuario,$oid,$mes,$anio, $locale){
|
||
$this->usuario=$usuario;
|
||
if($mes < 10){
|
||
//Me aseguro de que no tenga cero delante
|
||
$mes = $mes + 0;
|
||
//Y le pongo el cero delante.
|
||
$mes = "0".$mes;
|
||
}
|
||
$this->mes=$mes;
|
||
$this->anio=$anio;
|
||
$this->oid = $oid;
|
||
$this->locale = $locale;
|
||
$this->calendario = new Calendario($this->usuario, $this->mes, $this->anio, array(), "", $this->locale);
|
||
if($oid > 0){
|
||
$this->empleado = new Empleado($usuario, $oid);
|
||
}else{
|
||
$error = $this->locale['1534'];
|
||
throw new Exception($error);
|
||
return array();
|
||
exit;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Obtiene una lista de todas las vacaciones del usuario en el mes y a<>o que
|
||
* est<73>n en un determinado estado.
|
||
*
|
||
* @param estado - Estado en el que se busca que est<73>n las vacaciones.
|
||
* @return Una lista con las vacaciones en ese estado.
|
||
* @throws Lanza excepciones si el usuario no tiene permisos.
|
||
*/
|
||
private function cargaVacaciones(){
|
||
if($this->vacaciones == null){
|
||
$this->vacacionesSolicitadas = array();
|
||
$this->vacacionesAprobadas = array();
|
||
$this->vacacionesRechazadas = array();
|
||
$this->vacacionesAnulables = array();
|
||
//Comprobamos permisos:
|
||
$oidP = $this->usuario->getValor("oid");
|
||
//Si no soy yo y no soy admin ni RRHH, no tengo permiso:
|
||
if(($oidP != $this->oid) && (!$this->usuario->tieneRol(1)) && (!$this->usuario->tieneRol(4))){
|
||
$error = $this->locale['3001'];
|
||
throw new Exception($error);
|
||
return array();
|
||
exit;
|
||
//Permisos correctos, sigo.
|
||
}else{
|
||
//Cargo la lista de d<>as:
|
||
$fecha = $this->anio."-".$this->mes."-";
|
||
$consulta = "SELECT fecha, aprobada FROM vacaciones WHERE oid='".$this->oid."' AND fecha like '".$fecha."%'";
|
||
$bd = new BD();
|
||
$array = $bd->keyValueQuery($consulta, "fecha", "aprobada");
|
||
$this->vacaciones = array();
|
||
foreach($array as $fecha => $estado){
|
||
$dia = explode("-", $fecha);
|
||
$dia = $dia[2]+0;
|
||
$this->vacaciones[$dia] = $estado;
|
||
switch($estado){
|
||
case 0:
|
||
$this->vacacionesSolicitadas[] = $dia;
|
||
break;
|
||
case 1:
|
||
$this->vacacionesAprobadas[] = $dia;
|
||
break;
|
||
case 2:
|
||
$this->vacacionesRechazadas[] = $dia;
|
||
break;
|
||
case 3:
|
||
$this->vacacionesAnulables[] = $dia;
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
// $dias=array();
|
||
//
|
||
// //Comprobamos permisos:
|
||
// $oidP = $this->usuario->getValor("oid");
|
||
//
|
||
// //Si no soy yo y no soy admin ni RRHH, no tengo permiso:
|
||
// if(($oidP != $this->oid) && (!$this->usuario->tieneRol(1)) && (!$this->usuario->tieneRol(4))){
|
||
// $error = $this->locale['3001'];
|
||
// throw new Exception($error);
|
||
// return $dias;
|
||
// exit;
|
||
// }else{
|
||
// //Busco los d<>as solicitados:
|
||
// $fecha = $this->anio."-".$this->mes."-";
|
||
// $consulta = "SELECT fecha FROM vacaciones WHERE oid='".$this->oid."' AND aprobada = '".$estado."' AND fecha like '".$fecha."%'";
|
||
// $bd = new BD();
|
||
// $array = $bd->arrayQuery($consulta, "fecha");
|
||
// foreach($array as $elem){
|
||
// $dia = explode("-", $elem);
|
||
// $dias[] = $dia[2]+0;
|
||
// }
|
||
// }
|
||
//
|
||
// return $dias;
|
||
}
|
||
|
||
/**
|
||
* Obtiene una lista de todas las vacaciones del usuario en el mes y a<>o que
|
||
* est<73>n solicitadas.
|
||
*
|
||
* @return Una lista con las vacaciones aprobadas.
|
||
* @throws Lanza excepciones si el usuario no tiene permisos.
|
||
*/
|
||
function getVacSoli(){
|
||
if($this->vacacionesSolicitadas == null){
|
||
$this->cargaVacaciones();
|
||
}
|
||
|
||
return $this->vacacionesSolicitadas;
|
||
}
|
||
|
||
/**
|
||
* Obtiene una lista de todas las vacaciones del usuario en el mes y a<>o que
|
||
* est<73>n aprobadas.
|
||
*
|
||
* @return Una lista con las vacaciones aprobadas.
|
||
* @throws Lanza excepciones si el usuario no tiene permisos.
|
||
*/
|
||
function getVacApro(){
|
||
if($this->vacacionesAprobadas == null){
|
||
$this->cargaVacaciones();
|
||
}
|
||
|
||
return $this->vacacionesAprobadas;
|
||
}
|
||
|
||
/**
|
||
* Obtiene una lista de todas las vacaciones del usuario en el mes y a<>o que
|
||
* est<73>n rechazadas.
|
||
*
|
||
* @return Una lista con las vacaciones rechazadas.
|
||
* @throws Lanza excepciones si el usuario no tiene permisos.
|
||
*/
|
||
function getVacRech(){
|
||
if($this->vacacionesRechazadas == null){
|
||
$this->cargaVacaciones();
|
||
}
|
||
|
||
return $this->vacacionesRechazadas;
|
||
}
|
||
|
||
/**
|
||
* Obtiene una lista de todas las vacaciones del usuario en el mes y a<>o que
|
||
* est<73>n pendientes de anulaci<63>n.
|
||
*
|
||
* @return Una lista con las vacaciones pendientes de anulaci<63>n.
|
||
* @throws Lanza excepciones si el usuario no tiene permisos.
|
||
*/
|
||
function getVacPend(){
|
||
if($this->vacacionesAnulables == null){
|
||
$this->cargaVacaciones();
|
||
}
|
||
|
||
return $this->vacacionesAnulables;
|
||
}
|
||
|
||
/**
|
||
* Calcula el n<>mero de d<>as de vacaciones restantes de un empleado.
|
||
*
|
||
* @return los d<>as restantes de vacaciones dentro del a<>o.
|
||
*/
|
||
public function getVacacionesRestantes(){
|
||
//TODO deber<65>a lanzar excepci<63>n por permisos de consulta.
|
||
$anio_hoy = date("Y");
|
||
$consulta = "SELECT dias FROM vacaciones_oid WHERE oid='".$this->empleado->getValor("oid")."' AND anyo='".$this->anio."'";
|
||
$bd = new BD();
|
||
$dias = $bd->getCampo($consulta);
|
||
//Primero comprobamos si est<73> en la tabla guardado:
|
||
if(($dias >= 0) && ($dias != "")){
|
||
return $dias;
|
||
//Para el a<>o presente se calcula seg<65>n su fecha de alta.
|
||
}else if($this->anio == $anio_hoy){
|
||
$fecha = $this->empleado->getValor("fecha_alta");
|
||
$fecha_array = explode("-", $fecha);
|
||
$anyo = $fecha_array[0];
|
||
$mes = $fecha_array[1];
|
||
$dia = $fecha_array[2];
|
||
$fecha = mktime(0,0,0,$mes,$dia,$anyo);
|
||
$dias_mes = date('t',$fecha);
|
||
$fiestas = constante("fiestas");
|
||
//Si se dio de alta un a<>o anterior al actual tiene todos sus d<>as.
|
||
if($anyo < date('Y')){
|
||
//Se deja fiestas tal y como est<73>.
|
||
//Si no, se calculan seg<65>n la f<>rmula.
|
||
}else{
|
||
$fiestas = (($fiestas/12)*(12-$mes))+(($fiestas/12/$dias_mes)*($dias_mes-$dia));
|
||
round($fiestas);
|
||
}
|
||
//Para a<>os posteriores tiene todos los d<>as.
|
||
}else if($this->anio > $anio_hoy){
|
||
$fiestas = constante("fiestas");
|
||
//Y para a<>os anteriores, devolvemos cero.
|
||
}else{
|
||
$fiestas = 0;
|
||
}
|
||
|
||
//Actualizamos la tabla para ahorrar c<>lculos posteriores:
|
||
$consulta = "INSERT INTO vacaciones_oid (oid, anyo, dias) VALUES ('".$this->oid."', '".$this->anio."', '".$fiestas."')";
|
||
$bd = new BD();
|
||
$bd->execQuery($consulta);
|
||
|
||
return round($fiestas);
|
||
}
|
||
|
||
/**
|
||
* Acceso al mes.
|
||
* @return El mes.
|
||
*/
|
||
function getMes(){
|
||
return $this->mes;
|
||
}
|
||
|
||
/**
|
||
* Acceso al a<>o.
|
||
* @return El a<>o.
|
||
*/
|
||
function getAnio(){
|
||
return $this->anio;
|
||
}
|
||
|
||
/**
|
||
* Asigna el valor de las vacaciones restantes del empleado.
|
||
*
|
||
* @param dias - N<>mero de d<>as de vacaciones restantes a asociar.
|
||
* @return True si se asign<67> correctamente y false en caso contrario.
|
||
* @throws Lanza excepci<63>n si el usuario no tiene permiso.
|
||
*/
|
||
public function setVacacionesRestantes($dias){
|
||
//Comprobamos permisos.
|
||
if($this->usuario->tieneRol(4) || $this->usuario->tieneRol(1)){
|
||
$consulta = "UPDATE vacaciones_oid SET dias='$dias' WHERE oid='".$this->oid."' AND anyo='".$this->anio."'";
|
||
$bd = new BD();
|
||
return $bd->execQuery($consulta);
|
||
}else{
|
||
$error = $this->locale['3001'];
|
||
throw new Exception($error);
|
||
return $dias;
|
||
exit;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Calcula el estado en el que se encuentra un d<>a.
|
||
*
|
||
* @param dia - D<>a dentro del mes y a<>o de las vacaciones.
|
||
* @return El c<>digo de estado si se encuentra el d<>a, -1 en caso contrario.
|
||
*/
|
||
public function getEstadoDia($dia){
|
||
$this->cargaVacaciones();
|
||
$estado = $this->vacaciones[$dia];
|
||
|
||
if($estado == "" || $estado < 0){
|
||
$estado = -1;
|
||
}
|
||
|
||
return $estado;
|
||
}
|
||
|
||
/**
|
||
*
|
||
*/
|
||
private function insertarDias($dias, $estado){
|
||
$oid = $this->oid;
|
||
$bd = new BD();
|
||
foreach($dias as $dia){
|
||
$fecha = $this->anio."-".$this->mes."-".$dia;
|
||
$consulta = "DELETE FROM vacaciones WHERE oid = '".$oid."' AND fecha='".$fecha."'";
|
||
$bd->execQuery($consulta);
|
||
$consulta = "INSERT INTO vacaciones (oid, fecha, aprobada) VALUES ('".$oid."', '".$fecha."', '".$estado."')";
|
||
if(!$bd->execQuery($consulta)){
|
||
return false;
|
||
//Si todo ha ido bien comprobamos el estado a ver si hay que actualizar
|
||
//las vacaciones restantes.
|
||
}else{
|
||
$estadoPrevio = $this->vacaciones[$dia];
|
||
$this->cambiaEstado($dia, $estado);
|
||
$consulta = "";
|
||
/* Efectos de los cambios de estado:
|
||
* Solicitada: sin efectos.
|
||
* Aprobada: restar d<>a de vacaciones y actualizar parte.
|
||
* Rechazada: sin efectos.
|
||
* Pendiente de anulaci<63>n: sin efectos.
|
||
*/
|
||
switch ($estado) {
|
||
case 1:
|
||
//Se quita un d<>a de vacaciones, salvo en el caso de
|
||
//que estemos rechazando una solicitud de anulaci<63>n.
|
||
if($estadoPrevio != 3){
|
||
$this->addVacacionesRestantes(-1);
|
||
}
|
||
// $fecha = $this->anio."-".$this->mes."-".$dia;
|
||
// $consulta = "DELETE FROM partes_actividad WHERE oid = '".$oid."' AND fecha='".$fecha."'";
|
||
// $bd->execQuery($consulta);
|
||
// $consulta = "INSERT INTO partes_actividad (oid, fecha, dato) VALUES ('".$oid."', '".$fecha."', 'V')";
|
||
// if(!$bd->execQuery($consulta)){
|
||
// return false;
|
||
// }
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
return true;
|
||
}
|
||
|
||
private function eliminaDia($dia){
|
||
$this->vacaciones = array_diff($this->vacaciones, array($dia));
|
||
$estadoPrevio = $this->vacaciones[$dia];
|
||
//Lo eliminamos de la lista donde estuviera:
|
||
switch($estadoPrevio){
|
||
case 0:
|
||
$this->vacacionesSolicitadas = array_diff($this->vacacionesSolicitadas, array($dia));
|
||
break;
|
||
case 1:
|
||
$this->vacacionesAprobadas = array_diff($this->vacacionesAprobadas, array($dia));
|
||
break;
|
||
case 2:
|
||
$this->vacacionesRechazadas = array_diff($this->vacacionesRechazadas, array($dia));
|
||
break;
|
||
case 3:
|
||
$this->vacacionesAnulables = array_diff($this->vacacionesAnulables, array($dia));
|
||
break;
|
||
}
|
||
}
|
||
|
||
private function cambiaEstado($dia, $estado){
|
||
$this->cargaVacaciones();
|
||
$estadoPrevio = $this->vacaciones[$dia];
|
||
if($estadoPrevio == "") $estadoPrevio = -1;
|
||
$this->vacaciones[$dia] = $estado;
|
||
//Actuamos s<>lo si hay cambio de estado.
|
||
if($estadoPrevio != $estado){
|
||
//Lo eliminamos de la lista donde estuviera:
|
||
switch($estadoPrevio){
|
||
case 0:
|
||
$this->vacacionesSolicitadas = array_diff($this->vacacionesSolicitadas, array($dia));
|
||
break;
|
||
case 1:
|
||
$this->vacacionesAprobadas = array_diff($this->vacacionesAprobadas, array($dia));
|
||
break;
|
||
case 2:
|
||
$this->vacacionesRechazadas = array_diff($this->vacacionesRechazadas, array($dia));
|
||
break;
|
||
case 3:
|
||
$this->vacacionesAnulables = array_diff($this->vacacionesAnulables, array($dia));
|
||
break;
|
||
}
|
||
//Y lo insertamos en la correspondiente:
|
||
switch($estado){
|
||
case 0:
|
||
$this->vacacionesSolicitadas[] = $dia;
|
||
break;
|
||
case 1:
|
||
$this->vacacionesAprobadas[] = $dia;
|
||
break;
|
||
case 2:
|
||
$this->vacacionesRechazadas[] = $dia;
|
||
break;
|
||
case 3:
|
||
$this->vacacionesAnulables[] = $dia;
|
||
break;
|
||
}
|
||
return true;
|
||
}else{
|
||
return false;
|
||
}
|
||
}
|
||
|
||
private function addVacacionesRestantes($num){
|
||
if($num < 0){
|
||
$num = -1*$num;
|
||
$consulta = "UPDATE vacaciones_oid SET dias=dias-".$num." WHERE oid='".$this->oid."' AND anyo='".$this->anio."'";
|
||
}else{
|
||
$consulta = "UPDATE vacaciones_oid SET dias=dias+".$num." WHERE oid='".$this->oid."' AND anyo='".$this->anio."'";
|
||
}
|
||
$bd = new BD();
|
||
$bd->execQuery($consulta);
|
||
}
|
||
|
||
/**
|
||
* Solicita unos d<>as de vacaciones. Si alguno falla no se solicita ninguno.
|
||
* @return true si se pudieron solicitar todos y false si falla alguno.
|
||
*/
|
||
public function solicitar($dias){
|
||
if(count($dias) <= 0){
|
||
$error = $this->locale['3027'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
$dias_correctos = array();
|
||
$dias_fallidos = array();
|
||
//Comprobamos que estamos recibiendo el argumento bien formado.
|
||
if(gettype($dias) == "array"){
|
||
//Si tiene rol t<>cnico seguimos.
|
||
if(($this->usuario->tieneRol(6)) && ($this->usuario->getValor("oid") == $this->oid)){
|
||
//Si le quedan d<>as restantes seguimos:
|
||
if($this->getVacacionesRestantes() >= count($dias)){
|
||
foreach($dias as $dia){
|
||
if($this->esSolicitable($dia)){
|
||
$dias_correctos[] = $dia;
|
||
$solicitud = $dia.",";
|
||
}else{
|
||
$dias_incorrectos[] = $dia;
|
||
}
|
||
}
|
||
//Comprobamos que todos son solicitables:
|
||
if((count($dias_correctos) == count($dias)) && (count($dias_fallidos) == 0)){
|
||
//Si insertamos todos los d<>as, enviamos el mail con la solicitud.
|
||
if($this->insertarDias($dias_correctos, 0)){
|
||
$nombre = $this->usuario->getValor("nombre");
|
||
$apellidos = $this->usuario->getValor("apellidos");
|
||
$oid = $this->usuario->getValor("oid");
|
||
$email = $this->locale['609']." $nombre $apellidos.\n\n";
|
||
$email .= $solicitud."\n\n";
|
||
$email = $email."\n\n";
|
||
$direccion = constante("email_rrhh");
|
||
if(!envia_correo_empleados($direccion, $this->locale['611'], $email)){
|
||
//TODO <20>Excepci<63>n?
|
||
}
|
||
}
|
||
}else{
|
||
$error = $this->locale['3004'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
}else{
|
||
$error = $this->locale['3004'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3003'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3007'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Comprueba si se puede solicitar un d<>a como vacaciones.
|
||
*
|
||
*/
|
||
public function esSolicitable($dia){
|
||
$plazo = constante("antelacion_vacaciones");
|
||
$fecha = $this->anio."-".$this->mes."-".$dia;
|
||
$estado = $this->getEstadoDia($dia);
|
||
$localidad = $this->empleado->getValor("localidad");
|
||
$oid = $this->oid;
|
||
//Si el plazo es correcto seguimos:
|
||
if(fecha_valida($fecha) > $plazo){
|
||
//Si no est<73>n ya solicitadas ni el d<>a es festivo seguimos:
|
||
$c = $this->calendario;
|
||
|
||
if(($estado == -1) && (!$c->esFestivo($localidad, $dia))){
|
||
//Si se solicita para este a<>o o para el pr<70>ximo dentro del plazo, todo ok:
|
||
if(($this->anio == date("Y")) || (($this->anio == date("Y") + 1) && (fecha_valida(date("Y")."-12-15") <= 0))){
|
||
return true;
|
||
}else{
|
||
$error = $this->locale['3005'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//D<>a solicitado o festivo
|
||
}else{
|
||
$error = $this->locale['3006'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Fecha fuera de plazo.
|
||
}else{
|
||
$error = $this->locale['3005'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
|
||
return false;
|
||
}
|
||
|
||
/**
|
||
* Aprobaci<63>n de una solicitud de vacaciones.
|
||
*/
|
||
public function aprobar($dias){
|
||
$dias_correctos = array();
|
||
$dias_fallidos = array();
|
||
//Comprobamos que estamos recibiendo el argumento bien formado.
|
||
if(gettype($dias) == "array"){
|
||
//Si tiene rol t<>cnico seguimos.
|
||
if($this->usuario->tieneRol(1) || $this->usuario->tieneRol(4)){
|
||
$muestra_dias = "";
|
||
foreach($dias as $dia){
|
||
//S<>lo puedo aprobar vacaciones solicitadas.
|
||
if($this->getEstadoDia($dia) == 0){
|
||
$dias_correctos[] = $dia;
|
||
$muestra_dias .= $dia."-".$this->mes."-".$this->anio." ";
|
||
}else{
|
||
$dias_incorrectos[] = $dia;
|
||
}
|
||
}
|
||
//Comprobamos que todos son aprobables:
|
||
if((count($dias_correctos) == count($dias)) && (count($dias_fallidos) == 0)){
|
||
//Si insertamos todos los d<>as, enviamos el mail con la aprobaci<63>n.
|
||
if($this->insertarDias($dias_correctos, 1)){
|
||
$nombre = $this->usuario->getValor("nombre");
|
||
$apellidos = $this->usuario->getValor("apellidos");
|
||
$email = $this->locale['613']." ".$muestra_dias.$this->locale['614'];
|
||
$direccion = $this->empleado->getValor("email");
|
||
if(!envia_correo_empleados($direccion, $this->locale['605'], $email)){
|
||
//TODO <20>Excepci<63>n?
|
||
}
|
||
}else{
|
||
$error = $this->locale['3011'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no son todos aprobables.
|
||
}else{
|
||
$error = $this->locale['3011'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3010'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3007'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Rechace de una solicitud de vacaciones.
|
||
*/
|
||
function rechazar($dias){
|
||
$dias_correctos = array();
|
||
$dias_fallidos = array();
|
||
//Comprobamos que estamos recibiendo el argumento bien formado.
|
||
if(gettype($dias) == "array"){
|
||
//Si tiene rol t<>cnico seguimos.
|
||
if($this->usuario->tieneRol(1) || $this->usuario->tieneRol(4)){
|
||
foreach($dias as $dia){
|
||
//S<>lo puedo rechazar vacaciones solicitadas.
|
||
if($this->getEstadoDia($dia) == 0){
|
||
$dias_correctos[] = $dia;
|
||
$muestra_dias .= $dia."-".$this->mes."-".$this->anio." ";
|
||
}else{
|
||
$dias_incorrectos[] = $dia;
|
||
}
|
||
}
|
||
//Comprobamos que todos son rechazables:
|
||
if((count($dias_correctos) == count($dias)) && (count($dias_fallidos) == 0)){
|
||
//Si insertamos todos los d<>as, enviamos el mail con las rechazadas.
|
||
if($this->insertarDias($dias_correctos, 2)){
|
||
$nombre = $this->usuario->getValor("nombre");
|
||
$apellidos = $this->usuario->getValor("apellidos");
|
||
$email = $this->locale['613']." ".$muestra_dias.$this->locale['615'];
|
||
$direccion = $this->empleado->getValor("email");
|
||
if(!envia_correo_empleados($direccion, $this->locale['605'], $email)){
|
||
//TODO <20>Excepci<63>n?
|
||
}
|
||
}else{
|
||
$error = $this->locale['3012'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no son todos rechazables.
|
||
}else{
|
||
$error = $this->locale['3012'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3017'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3007'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Rechace de una solicitud de anulaci<63>n de vacaciones.
|
||
*/
|
||
function rechazarAnulacion($dias){
|
||
$dias_correctos = array();
|
||
$dias_fallidos = array();
|
||
//Comprobamos que estamos recibiendo el argumento bien formado.
|
||
if(gettype($dias) == "array"){
|
||
//Si tiene rol t<>cnico seguimos.
|
||
if($this->usuario->tieneRol(1) || $this->usuario->tieneRol(4)){
|
||
foreach($dias as $dia){
|
||
//S<>lo puedo rechazar vacaciones pendientes de anulaci<63>n.
|
||
if($this->getEstadoDia($dia) == 3){
|
||
$dias_correctos[] = $dia;
|
||
}else{
|
||
$dias_incorrectos[] = $dia;
|
||
}
|
||
}
|
||
//Comprobamos que todos son rechazables:
|
||
if((count($dias_correctos) == count($dias)) && (count($dias_fallidos) == 0)){
|
||
//Si insertamos todos los d<>as, enviamos el mail con las rechazadas.
|
||
if($this->insertarDias($dias_correctos, 1)){
|
||
//TODO <20>Necesario?
|
||
}else{
|
||
$error = $this->locale['3029'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no son todos rechazables.
|
||
}else{
|
||
$error = $this->locale['3029'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3017'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3007'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Anulaci<63>n de unas vacaciones aprobadas.
|
||
*/
|
||
function anular($dias){
|
||
$dias_correctos = array();
|
||
$dias_fallidos = array();
|
||
//Comprobamos que estamos recibiendo el argumento bien formado.
|
||
if(gettype($dias) == "array"){
|
||
//Si tiene rol t<>cnico seguimos.
|
||
if($this->usuario->tieneRol(1) || $this->usuario->tieneRol(4)){
|
||
foreach($dias as $dia){
|
||
//S<>lo puedo anular las pendientes de anulaci<63>n.
|
||
if($this->getEstadoDia($dia) == 3){
|
||
$solicitud = $dia.",";
|
||
$dias_correctos[] = $dia;
|
||
}else{
|
||
$dias_incorrectos[] = $dia;
|
||
}
|
||
}
|
||
//Comprobamos que todos son aprobables:
|
||
if((count($dias_correctos) == count($dias)) && (count($dias_fallidos) == 0)){
|
||
//Si insertamos todos los d<>as, enviamos el mail con las anuladas.
|
||
if($this->anularDias($dias_correctos)){
|
||
$nombre = $this->usuario->getValor("nombre");
|
||
$apellidos = $this->usuario->getValor("apellidos");
|
||
$oid = $this->usuario->getValor("oid");
|
||
$email = $this->locale['600']." $nombre $apellidos.\n\n";
|
||
$email .= $solicitud."\n\n";
|
||
$path = "http://portal.selforsistemas.net";
|
||
$link = "<a href='".$path."/detalle_empleado.php?oid=".$oid."'>".$nombre."</a>";
|
||
$email = $email.$link."\n\n";
|
||
$direccion = constante("email_rrhh");
|
||
if(!envia_correo_empleados($direccion, $this->locale['603'], $email)){
|
||
//TODO <20>Excepci<63>n?
|
||
}
|
||
}else{
|
||
$error = $this->locale['3013'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no son todos anulables.
|
||
}else{
|
||
$error = $this->locale['3013'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3018'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3007'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
}
|
||
|
||
private function anularDias($dias){
|
||
$oid = $this->oid;
|
||
$bd = new BD();
|
||
foreach($dias as $dia){
|
||
$fecha = $this->anio."-".$this->mes."-".$dia;
|
||
$consulta = "DELETE FROM vacaciones WHERE oid = '".$oid."' AND fecha='".$fecha."'";
|
||
if(!$bd->execQuery($consulta)){
|
||
return false;
|
||
//Si todo ha ido bien comprobamos el estado a ver si hay que actualizar
|
||
//las vacaciones restantes.
|
||
}else{
|
||
$this->eliminaDia($dia);
|
||
$solicitante->variaVacaciones(1);
|
||
$fecha = $this->anio."-".$this->mes."-".$dia;
|
||
$consulta = "DELETE FROM partes_actividad WHERE oid = '".$oid."' AND fecha='".$fecha."'";
|
||
$bd->execQuery($consulta);
|
||
$consulta = "INSERT INTO partes_actividad (oid, fecha, dato) VALUES ('".$oid."', '".$fecha."', '0')";
|
||
if(!$bd->execQuery($consulta)){
|
||
return false;
|
||
}
|
||
}
|
||
}
|
||
return true;
|
||
}
|
||
|
||
/**
|
||
* Solicitud de anulaci<63>n de unas vacaciones aprobadas.
|
||
*/
|
||
function solicitarAnulacion($dias){
|
||
if(count($dias) <= 0){
|
||
$error = $this->locale['3027'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
$dias_correctos = array();
|
||
$dias_fallidos = array();
|
||
//Comprobamos que estamos recibiendo el argumento bien formado.
|
||
if(gettype($dias) == "array"){
|
||
//Si tiene rol t<>cnico seguimos.
|
||
if(($this->usuario->tieneRol(6)) && ($this->usuario->getValor("oid") == $this->oid)){
|
||
foreach($dias as $dia){
|
||
if($this->esAnulable($dia)){
|
||
$dias_correctos[] = $dia;
|
||
}else{
|
||
$dias_incorrectos[] = $dia;
|
||
}
|
||
}
|
||
//Comprobamos que todos son solicitables:
|
||
if((count($dias_correctos) == count($dias)) && (count($dias_fallidos) == 0)){
|
||
//Si insertamos todos los d<>as, enviamos el mail con la solicitud.
|
||
if($this->insertarDias($dias_correctos, 3)){
|
||
//TODO
|
||
}
|
||
}else{
|
||
$error = $this->locale['3016'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3016'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Si no, lanzamos excepci<63>n.
|
||
}else{
|
||
$error = $this->locale['3007'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
}
|
||
|
||
public function setEmpleado($empleado, $oid){
|
||
$this->empleado = $empleado;
|
||
$this->oid = $oid;
|
||
}
|
||
|
||
/**
|
||
* Comprueba si se puede solicitar un d<>a como vacaciones.
|
||
*
|
||
*/
|
||
public function esAnulable($dia){
|
||
$plazo = constante("antelacion_vacaciones");
|
||
$fecha = $this->anio."-".$this->mes."-".$dia;
|
||
$estado = $this->getEstadoDia($dia);
|
||
$localidad = $this->empleado->getValor("localidad");
|
||
$oid = $this->oid;
|
||
//Si el plazo es correcto seguimos:
|
||
if(fecha_valida($fecha) > $plazo){
|
||
//Si est<73>n aprobadas y el d<>a es festivo seguimos:
|
||
$c = $this->calendario;
|
||
if(($estado == 1) && (!$c->esFestivo($localidad, $dia))){
|
||
//Si se solicita para este a<>o o para el pr<70>ximo dentro del plazo, todo ok:
|
||
if(($this->anio == date("Y")) || (($this->anio == date("Y") + 1) && (fecha_valida(date("Y")."-12-15") <= 0))){
|
||
return true;
|
||
}else{
|
||
$error = $this->locale['3019'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//D<>a solicitado o festivo
|
||
}else{
|
||
$error = $this->locale['3015'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
//Fecha fuera de plazo.
|
||
}else{
|
||
$error = $this->locale['3019'];
|
||
throw new Exception($error);
|
||
return false;
|
||
exit;
|
||
}
|
||
}
|
||
|
||
function getOidPersona(){
|
||
return $this->empleado->getValor("oid");
|
||
}
|
||
|
||
function getNombrePersona(){
|
||
return $this->empleado->getValor("nombre")." ".$this->empleado->getValor("apellidos");
|
||
}
|
||
|
||
}
|
||
?>
|