1593 lines
100 KiB
C#
1593 lines
100 KiB
C#
using Exferia_Aplicacion.General;
|
|
using Exferia_EntityFramework;
|
|
using Exferia_General;
|
|
using Exferia_KairosPRO._1_Modelos;
|
|
using Exferia_KairosPRO._1_Modelos.Herencia.Capas;
|
|
using Exferia_KairosPRO.General;
|
|
using Exferia_KairosPRO_EF;
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Data.SqlClient;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading;
|
|
using System.Transactions;
|
|
using static Exferia_Aplicacion.General.Enumerados;
|
|
|
|
namespace Exferia_KairosPRO._2_Datos
|
|
{
|
|
public class KRS_SolicitudesAusenciasProgramadas_Datos : ABS_Datos
|
|
{
|
|
#region Listado
|
|
private List<INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo> g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo = null;
|
|
|
|
public override List<dynamic> Obtener_Listado(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
List<dynamic> lst_KRS = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Consulta.................................................................
|
|
ConsultaRellenar_Listado(obj_KairosProEntities, _lst_CamposConRelacionABuscar, -1, null, _lst_INTERNO_Filtro_OpcionPadre_Modelo, _lst_INTERNO_Filtro_Modelo);
|
|
//........................................................................
|
|
|
|
if ((g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo != null) && (g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Count() > 0))
|
|
{
|
|
lst_KRS = g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Cast<dynamic>().ToList();
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener_Listado), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
|
|
return lst_KRS;
|
|
}
|
|
public override dynamic Obtener_RegistroListado(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo, long _lng_id, List<long> _lst_id)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
dynamic dnm_KRS = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Consulta ......................................................
|
|
ConsultaRellenar_Listado(obj_KairosProEntities, _lst_CamposConRelacionABuscar, _lng_id, _lst_id, _lst_INTERNO_Filtro_OpcionPadre_Modelo, _lst_INTERNO_Filtro_Modelo);
|
|
//...............................................................
|
|
|
|
if ((g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo != null) && (g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Count() > 0))
|
|
{
|
|
dnm_KRS = g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Cast<dynamic>().ToList();
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener_RegistroListado), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
return dnm_KRS;
|
|
}
|
|
|
|
protected override void ConsultaRellenar_Listado(KairosProEntities _dbcontext, List<string> _lst_CamposConRelacionABuscar, long _lng_id, List<long> _lst_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
try
|
|
{
|
|
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
|
|
|
|
//Datos del Padre si los tuviera .........................
|
|
bool bol_FiltrarEjercicio = false;
|
|
DateTime? dtt_TemporadaInicio = null;
|
|
DateTime? dtt_TemporadaFin = null;
|
|
|
|
long lng_idEmpleado_SegunUsuario = -1;
|
|
if (Variables.G_MDL_USUARIOVALIDADO_MODELO.empleado_Asociado!=null)
|
|
{
|
|
lng_idEmpleado_SegunUsuario=Variables.G_MDL_USUARIOVALIDADO_MODELO.empleado_Asociado.id;
|
|
}
|
|
|
|
|
|
if (_lst_INTERNO_Filtro_OpcionPadre_Modelo != null && _lst_INTERNO_Filtro_OpcionPadre_Modelo.Count > 0)
|
|
{
|
|
foreach (INTERNO_Filtro_OpcionPadre_Modelo mdl_INTERNO_Filtro_OpcionPadre_Modelo in _lst_INTERNO_Filtro_OpcionPadre_Modelo)
|
|
{
|
|
//Ejercicio
|
|
if (mdl_INTERNO_Filtro_OpcionPadre_Modelo.NOMBRE_CAMPO.Equals(nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.idEjercicio)))
|
|
{
|
|
//Buscar el Modelo de Ejercicio
|
|
GEN_EjerciciosActivos_Empresa mdl_GEN_EjerciciosActivos_Empresa = Datos_Generales.GEN_EjerciciosActivos_Empresa_Obtener_Por_Id(mdl_INTERNO_Filtro_OpcionPadre_Modelo.VALOR);
|
|
|
|
if (mdl_GEN_EjerciciosActivos_Empresa != null)
|
|
{
|
|
bol_FiltrarEjercicio = true;
|
|
dtt_TemporadaInicio = mdl_GEN_EjerciciosActivos_Empresa.temporadaFechaInicio;
|
|
dtt_TemporadaFin = mdl_GEN_EjerciciosActivos_Empresa.temporadaFechaFin;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
//............................................................
|
|
|
|
string str_SQL =
|
|
" SELECT " +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.id) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.codigoCliente) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaSolicitud) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaSolicitud) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaDesde) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaHasta) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaHasta) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.observaciones) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.observaciones) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.estado) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.motivoCancelacion) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.motivoCancelacion) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaAceptacionCancelacion) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaAceptacionCancelacion) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaBorrado) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.porHoras) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.porHoras) + "," +
|
|
//ids
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.idEmpleado) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idEmpleado) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.idAusenciaProgramadaTipo) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + "," +
|
|
//AusenciaProgramadaTipo
|
|
(
|
|
(_lst_CamposConRelacionABuscar.Contains(nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.AusenciasProgramadasTipos)))
|
|
?
|
|
(
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.AusenciasProgramadasTipos_Codigo) + " = " + nameof(KRS_AusenciasProgramadasTipos) + "." + nameof(KRS_AusenciasProgramadasTipos.codigo) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.AusenciasProgramadasTipos_Descripcion) + " =" + nameof(KRS_AusenciasProgramadasTipos) + "." + nameof(KRS_AusenciasProgramadasTipos.descripcion)
|
|
|
|
)
|
|
:
|
|
(
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.AusenciasProgramadasTipos_Codigo) + " = ''," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.AusenciasProgramadasTipos_Descripcion) + " = ''"
|
|
)
|
|
) +
|
|
" FROM " + nameof(KRS_SolicitudesAusenciasProgramadas) +
|
|
//AusenciaProgramadaTipo
|
|
(
|
|
(_lst_CamposConRelacionABuscar.Contains(nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.AusenciasProgramadasTipos)))
|
|
?
|
|
(
|
|
" LEFT JOIN " + nameof(KRS_AusenciasProgramadasTipos) + " ON " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + " = " + nameof(KRS_AusenciasProgramadasTipos) + "." + nameof(KRS_AusenciasProgramadasTipos.id)
|
|
)
|
|
: ("")
|
|
) +
|
|
" WHERE " +
|
|
//fechaBorrado
|
|
" ( " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + " is null ) AND " +
|
|
//idEmpleado
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idEmpleado) + "=@idEmpleado AND " +
|
|
//id
|
|
" ( " +
|
|
(
|
|
(_lng_id > -1)
|
|
? (nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + "=@id ")
|
|
: " 1 = 1 "
|
|
) +
|
|
" ) AND " +
|
|
//Ejercicio
|
|
" ( " +
|
|
(
|
|
bol_FiltrarEjercicio == true
|
|
? (nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + " <=@TemporadaFin AND " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + " >=@TemporadaInicio ")
|
|
: " 1 = 1 "
|
|
) +
|
|
" ) ";
|
|
|
|
//Parametros
|
|
lst_Parametros.Add(new SqlParameter("@idEmpleado", lng_idEmpleado_SegunUsuario));
|
|
|
|
if (_lng_id > -1)
|
|
{
|
|
lst_Parametros.Add(new SqlParameter("@id", _lng_id));
|
|
}
|
|
|
|
if (bol_FiltrarEjercicio)
|
|
{
|
|
lst_Parametros.Add(new SqlParameter("@TemporadaFin", dtt_TemporadaFin.Value));
|
|
lst_Parametros.Add(new SqlParameter("@TemporadaInicio", dtt_TemporadaInicio.Value));
|
|
}
|
|
|
|
|
|
object[] arr_Parametros = lst_Parametros.ToArray();
|
|
|
|
//Rellenar el Modelo
|
|
g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo = _dbcontext.Database.SqlQuery<INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo>(str_SQL, arr_Parametros).ToList();
|
|
|
|
//Añadir los Ejercicios
|
|
if (g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo != null && g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Count > 0)
|
|
{
|
|
Agregar_Ejercicios(Variables.G_MDL_INTERNO_VALORESGENERALES_MODELO.lng_idEmpresa);
|
|
}
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(ConsultaRellenar_Listado), true);
|
|
}
|
|
}
|
|
|
|
private void Agregar_Ejercicios(long _lng_idEmpresaSeleccionada)
|
|
{
|
|
try
|
|
{
|
|
List<GEN_EjerciciosActivos_Empresa> lst_GEN_EjerciciosActivos_Empresa = Datos_Generales.GEN_EjerciciosActivos_Empresa_Obtener_Listado_Por_Empresa(_lng_idEmpresaSeleccionada);
|
|
|
|
if (lst_GEN_EjerciciosActivos_Empresa != null)
|
|
{
|
|
//Rellenar el Listado
|
|
foreach (INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo in g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo)
|
|
{
|
|
mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Ejercicios_Empresa = lst_GEN_EjerciciosActivos_Empresa.Where(m => m.temporadaFechaFin >= mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaDesde &&
|
|
m.temporadaFechaInicio <= mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaDesde)
|
|
.FirstOrDefault();
|
|
}
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Agregar_Ejercicios), true);
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
#region Listado Secundario
|
|
public override List<dynamic> Obtener_Listado_Secundario(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
return null;
|
|
}
|
|
public override dynamic Obtener_RegistroListado_Secundario(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo, long _lng_id, List<long> _lst_id)
|
|
{
|
|
return null;
|
|
}
|
|
protected override void ConsultaRellenar_Listado_Secundario(KairosProEntities _dbcontext, List<string> _lst_CamposConRelacionABuscar, long _lng_id, List<long> _lst_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
|
|
}
|
|
#endregion
|
|
|
|
#region F3
|
|
public override dynamic Obtener_F3(string _str_filtro, string _str_CampoBusqueda, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
return null;
|
|
}
|
|
public override dynamic Obtener_F3_PorId(long _lng_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{
|
|
return null;
|
|
}
|
|
protected override void ConsultaRellenar_F3(KairosProEntities _dbcontext, string _str_CampoBusqueda, string _str_Filtro, long _lng_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
|
|
{}
|
|
#endregion
|
|
|
|
#region Obtener
|
|
|
|
#region Obtener Simple
|
|
private dynamic g_dnm_Modelo_Obtener = null;
|
|
private static int g_int_TotalHilos_Obtener = 3;
|
|
private bool[] g_bol_Hilos_Terminados_Obtener = new bool[g_int_TotalHilos_Obtener];
|
|
|
|
public override dynamic Obtener(long _lng_id)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
string str_SQL =
|
|
" SELECT " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idEmpleado) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaSolicitud) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaHasta) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.observaciones) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.motivoCancelacion) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaAceptacionCancelacion) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.porHoras) +
|
|
" FROM " + nameof(KRS_SolicitudesAusenciasProgramadas) +
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + " is null and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.id) + "=@id and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros = new object[]
|
|
{
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO)
|
|
};
|
|
|
|
//Rellenar el Modelo
|
|
g_dnm_Modelo_Obtener = obj_KairosProEntities.Database.SqlQuery<KRS_SolicitudesAusenciasProgramadas>(str_SQL, arr_Parametros).FirstOrDefault();
|
|
|
|
#region Rellenar tablas Relacionadas
|
|
if (g_dnm_Modelo_Obtener != null)
|
|
{
|
|
//reiniciar Valores de los hilos
|
|
for (int int_Contador = 0; int_Contador < g_int_TotalHilos_Obtener; int_Contador++)
|
|
{
|
|
g_bol_Hilos_Terminados_Obtener[int_Contador] = false;
|
|
}
|
|
|
|
//KRS_PresenciasProgramadasTipos ##########################################################################################
|
|
ThreadStart obj_ThreadStart_AUSENCIASPROGRAMADASTIPOS = new ThreadStart(Obtener_AusenciasProgramdasTipos_Modelo_Obtener);
|
|
Thread obj_Thread_AUSENCIASPROGRAMADASTIPOS = new Thread(obj_ThreadStart_AUSENCIASPROGRAMADASTIPOS);
|
|
obj_Thread_AUSENCIASPROGRAMADASTIPOS.Start();
|
|
|
|
//KRS_Empleados ##########################################################################################
|
|
ThreadStart obj_ThreadStart_EMPLEADOS = new ThreadStart(Obtener_Empleados_Modelo_Obtener);
|
|
Thread obj_Thread_EMPLEADOS = new Thread(obj_ThreadStart_EMPLEADOS);
|
|
obj_Thread_EMPLEADOS.Start();
|
|
|
|
//KRS_SolicitudesAusenciasProgramadas_Adjuntos ##########################################################################################
|
|
ThreadStart obj_ThreadStart_ADJUNTOS = new ThreadStart(Obtener_Adjuntos_Modelo_Obtener);
|
|
Thread obj_Thread_ADJUNTOS = new Thread(obj_ThreadStart_ADJUNTOS);
|
|
obj_Thread_ADJUNTOS.Start();
|
|
|
|
//Esperando a que terminen todos los hilos .........................................
|
|
bool bol_Termino = false;
|
|
while (bol_Termino == false)
|
|
{
|
|
bol_Termino = true;
|
|
foreach (bool bol_Termino_Hilo in g_bol_Hilos_Terminados_Obtener)
|
|
{
|
|
if (bol_Termino_Hilo == false)
|
|
{
|
|
bol_Termino = false;
|
|
break;
|
|
}
|
|
}
|
|
|
|
Thread.Sleep(10);
|
|
}
|
|
//.................................................................................
|
|
}
|
|
#endregion
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
return g_dnm_Modelo_Obtener;
|
|
}
|
|
#region Tablas Relacionadas
|
|
private void Obtener_AusenciasProgramdasTipos_Modelo_Obtener()
|
|
{
|
|
try
|
|
{
|
|
KRS_AusenciasProgramadasTipos_Datos obj_KRS_AusenciasProgramadasTipos_Datos = new KRS_AusenciasProgramadasTipos_Datos();
|
|
g_dnm_Modelo_Obtener.KRS_AusenciasProgramadasTipos = obj_KRS_AusenciasProgramadasTipos_Datos.Obtener_Modelo_Por_Id(g_dnm_Modelo_Obtener.idAusenciaProgramadaTipo, g_dnm_Modelo_Obtener.codigoCliente);
|
|
}
|
|
catch (Control_Errores)
|
|
{ }
|
|
finally
|
|
{
|
|
g_bol_Hilos_Terminados_Obtener[0] = true;
|
|
}
|
|
}
|
|
private void Obtener_Empleados_Modelo_Obtener()
|
|
{
|
|
try
|
|
{
|
|
KRS_Empleados_Datos obj_KRS_Empleados_Datos = new KRS_Empleados_Datos();
|
|
g_dnm_Modelo_Obtener.KRS_Empleados = obj_KRS_Empleados_Datos.Obtener_Modelo_Por_Id(g_dnm_Modelo_Obtener.idEmpleado, g_dnm_Modelo_Obtener.codigoCliente, false,false);
|
|
}
|
|
catch (Control_Errores)
|
|
{ }
|
|
finally
|
|
{
|
|
g_bol_Hilos_Terminados_Obtener[1] = true;
|
|
}
|
|
}
|
|
|
|
private void Obtener_Adjuntos_Modelo_Obtener()
|
|
{
|
|
try
|
|
{
|
|
KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos obj_KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos = new KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos();
|
|
g_dnm_Modelo_Obtener.KRS_SolicitudesAusenciasProgramadas_Adjuntos = obj_KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos.Obtener_ModeloListado_Por_IdSolicitudAusenciaProgramada(g_dnm_Modelo_Obtener.id);
|
|
}
|
|
catch (Control_Errores)
|
|
{ }
|
|
finally
|
|
{
|
|
g_bol_Hilos_Terminados_Obtener[2] = true;
|
|
}
|
|
}
|
|
#endregion
|
|
#endregion
|
|
|
|
public override dynamic Obtener_Registro_PorCampo(string _str_CampoBusqueda, string _str_Filtro)
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
|
|
#region Para Listado
|
|
public List<INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo> Obtener_Registros_Para_Listado_Por_Supervisor(long _lng_idEmpleado_Supervidor,long _lng_CodigoCliente)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
List<INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo> lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
string str_SQL = Obtener_Consulta_Para_Listado() +
|
|
//Where
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + " is null and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente and " +
|
|
" ( " +
|
|
" ( " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado_Pendiente and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + " in " +
|
|
" ( " +
|
|
" SELECT " + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.idSolicitudAusenciaProgramada) +
|
|
" FROM " + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) +
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.codigoCliente) + "=@codigoCliente and " +
|
|
" ( " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.solicitud) + "=@solicitud or " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.respuesta) + "=@respuesta " +
|
|
" ) and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.idEmpleado) + "=@idEmpleado " +
|
|
" ) " +
|
|
" ) OR " +
|
|
" ( " +
|
|
" ( " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado_Aceptado or " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado_EnCurso or " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado_Cancelado " +
|
|
" ) and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + " in " +
|
|
" ( " +
|
|
" SELECT " + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.idSolicitudAusenciaProgramada) +
|
|
" FROM " + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) +
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.codigoCliente) + "=@codigoCliente and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.resultado) + "=@resultado and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.idEmpleado) + "=@idEmpleado " +
|
|
" ) " +
|
|
" ) " +
|
|
" ) ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros = new object[]
|
|
{
|
|
new SqlParameter("@codigoCliente", _lng_CodigoCliente),
|
|
new SqlParameter("@estado_Pendiente", Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_PENDIENTE.Codigo),
|
|
new SqlParameter("@estado_EnCurso", Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_ENCURSO.Codigo),
|
|
new SqlParameter("@estado_Aceptado", Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_ACEPTADO.Codigo),
|
|
new SqlParameter("@estado_Cancelado", Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_CANCELADO.Codigo),
|
|
new SqlParameter("@solicitud", true),
|
|
new SqlParameter("@respuesta", true),
|
|
new SqlParameter("@resultado", true),
|
|
new SqlParameter("@idEmpleado", _lng_idEmpleado_Supervidor)
|
|
};
|
|
|
|
//Rellenar el Modelo
|
|
lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo = obj_KairosProEntities.Database.SqlQuery<INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo>(str_SQL, arr_Parametros).ToList();
|
|
|
|
//Adjuntos
|
|
if (lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo!=null && lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Count>0)
|
|
{
|
|
#region PRIMERO BUSCO LOS DATOS DE LAS TABLAS RELACIONADAS
|
|
//Supervisores
|
|
KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos obj_KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos = new KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos();
|
|
List<KRS_SolicitudesAusenciasProgramadas_Supervisores> lst_KRS_SolicitudesAusenciasProgramadas_Supervisores = obj_KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos.Obtener_ModeloListado_Por_IdsSolicitudesAusenciasProgramadas(lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Select(m=>m.id).ToList());
|
|
|
|
//Adjuntos
|
|
KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos obj_KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos = new KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos();
|
|
List<INTERNO_AUX_SolicitudAdjuntosTotal_Modelo> lst_INTERNO_AUX_SolicitudAdjuntosTotal_Modelo = obj_KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos.Obtener_CantidadAdjuntos_Por_SolicitudAusenciaProgramada(lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Select(m => m.id).ToList());
|
|
|
|
//TareasPendientes
|
|
KRS_TareasPendientes_Datos obj_KRS_TareasPendientes_Datos = new KRS_TareasPendientes_Datos();
|
|
List<KRS_TareasPendientes> lst_KRS_TareasPendientes = obj_KRS_TareasPendientes_Datos.Obtener_ModeloListado_Por_SolicitudesAusenciasProgramadas(lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Select(m => m.id).ToList());
|
|
#endregion
|
|
|
|
#region DESPUES SE LO VOY ASIGNANDO A LOS REGISTRO UNO A UNO
|
|
foreach (INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo in lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo)
|
|
{
|
|
//Supervisores #############################################
|
|
if (lst_KRS_SolicitudesAusenciasProgramadas_Supervisores != null &&
|
|
lst_KRS_SolicitudesAusenciasProgramadas_Supervisores.Count > 0)
|
|
{
|
|
mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Supervisores = lst_KRS_SolicitudesAusenciasProgramadas_Supervisores.Where(m => m.idSolicitudAusenciaProgramada == mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.id).ToList();
|
|
}
|
|
|
|
//Adjuntos #############################################
|
|
if (lst_INTERNO_AUX_SolicitudAdjuntosTotal_Modelo != null &&
|
|
lst_INTERNO_AUX_SolicitudAdjuntosTotal_Modelo.Count > 0)
|
|
{
|
|
mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Adjuntos_Cantidad = lst_INTERNO_AUX_SolicitudAdjuntosTotal_Modelo.Where(m => m.IdSolicitudAusenciaProgramada == mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.id).FirstOrDefault();
|
|
}
|
|
|
|
//TareasPendientes #############################################
|
|
if (lst_KRS_TareasPendientes != null &&
|
|
lst_KRS_TareasPendientes.Count > 0)
|
|
{
|
|
mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.KRS_TareasPendientes = lst_KRS_TareasPendientes.Where(m => m.idSolicitudAusenciaProgramada!=null && m.idSolicitudAusenciaProgramada.Value == mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.id).ToList();
|
|
}
|
|
|
|
}
|
|
#endregion
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener_Registros_Para_Listado_Por_Supervisor), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
return lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo;
|
|
}
|
|
public INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo Obtener_Registro_Para_Listado_Por_Id(long _lng_id,long _lng_idEmpleado_Supervidor, long _lng_CodigoCliente)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo = null;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
string str_SQL = Obtener_Consulta_Para_Listado() +
|
|
//Where
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + "=@id and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + " is null and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente and " +
|
|
" ( " +
|
|
" ( " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado_Pendiente and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + " in " +
|
|
" ( " +
|
|
" SELECT " + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.idSolicitudAusenciaProgramada) +
|
|
" FROM " + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) +
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.codigoCliente) + "=@codigoCliente and " +
|
|
" ( " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.solicitud) + "=@solicitud or " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.respuesta) + "=@respuesta " +
|
|
" ) and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.idEmpleado) + "=@idEmpleado " +
|
|
" ) " +
|
|
" ) OR " +
|
|
" ( " +
|
|
" ( " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado_Aceptado or " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado_EnCurso or " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado_Cancelado " +
|
|
" ) and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + " in " +
|
|
" ( " +
|
|
" SELECT " + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.idSolicitudAusenciaProgramada) +
|
|
" FROM " + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) +
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.codigoCliente) + "=@codigoCliente and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.resultado) + "=@resultado and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores) + "." + nameof(KRS_SolicitudesAusenciasProgramadas_Supervisores.idEmpleado) + "=@idEmpleado " +
|
|
" ) " +
|
|
" ) " +
|
|
" ) ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros = new object[]
|
|
{
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", _lng_CodigoCliente),
|
|
new SqlParameter("@estado_Pendiente", Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_PENDIENTE.Codigo),
|
|
new SqlParameter("@estado_EnCurso", Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_ENCURSO.Codigo),
|
|
new SqlParameter("@estado_Aceptado", Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_ACEPTADO.Codigo),
|
|
new SqlParameter("@estado_Cancelado", Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_CANCELADO.Codigo),
|
|
new SqlParameter("@solicitud", true),
|
|
new SqlParameter("@respuesta", true),
|
|
new SqlParameter("@resultado", true),
|
|
new SqlParameter("@idEmpleado", _lng_idEmpleado_Supervidor)
|
|
};
|
|
|
|
//Rellenar el Modelo
|
|
mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo = obj_KairosProEntities.Database.SqlQuery<INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo>(str_SQL, arr_Parametros).FirstOrDefault();
|
|
|
|
//Adjuntos
|
|
if (mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo != null)
|
|
{
|
|
//Supervisores
|
|
KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos obj_KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos = new KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos();
|
|
mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Supervisores = obj_KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos.Obtener_ModeloListado_Por_IdSolicitudAusenciaProgramada(mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.id);
|
|
|
|
//Adjuntos
|
|
KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos obj_KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos = new KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos();
|
|
mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Adjuntos_Cantidad = obj_KRS_SolicitudesAusenciasProgramadas_Adjuntos_Datos.Obtener_CantidadAdjuntos_Por_SolicitudAusenciaProgramada(mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.id);
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener_Registros_Para_Listado_Por_Supervisor), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
return mdl_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo;
|
|
}
|
|
|
|
private string Obtener_Consulta_Para_Listado()
|
|
{
|
|
return
|
|
" SELECT " +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.id) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.codigoCliente) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.idEmpleado) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idEmpleado) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.idAusenciaProgramadaTipo) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaSolicitud) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaSolicitud) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaDesde) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaHasta) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaHasta) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.observaciones) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.observaciones) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.estado) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.porHoras) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.porHoras) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.motivoCancelacion) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.motivoCancelacion) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.fechaAceptacionCancelacion) + " = " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaAceptacionCancelacion) + "," +
|
|
//KRS_AusenciasProgramadasTipos
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.AusenciasProgramadasTipos_Codigo) + " = " + nameof(KRS_AusenciasProgramadasTipos) + "." + nameof(KRS_AusenciasProgramadasTipos.codigo) + "," +
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.AusenciasProgramadasTipos_Descripcion) + " = " + nameof(KRS_AusenciasProgramadasTipos) + "." + nameof(KRS_AusenciasProgramadasTipos.descripcion) + "," +
|
|
//KRS_Empleados
|
|
nameof(INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo.Empleado) + " = " + nameof(KRS_Empleados) + "." + nameof(KRS_Empleados.nombre) +
|
|
" FROM " + nameof(KRS_SolicitudesAusenciasProgramadas) +
|
|
" LEFT JOIN " + nameof(KRS_AusenciasProgramadasTipos) + " ON " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + " = " + nameof(KRS_AusenciasProgramadasTipos) + "." + nameof(KRS_AusenciasProgramadasTipos.id) +
|
|
" LEFT JOIN " + nameof(KRS_Empleados) + " ON " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idEmpleado) + " = " + nameof(KRS_Empleados) + "." + nameof(KRS_Empleados.id) + " and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + " = " + nameof(KRS_Empleados) + "." + nameof(KRS_Empleados.codigoCliente);
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
#endregion
|
|
|
|
#region MODELOS
|
|
|
|
#region Modelo Simple
|
|
private KRS_SolicitudesAusenciasProgramadas g_mdl_KRS_SolicitudesAusenciasProgramadas = null;
|
|
public KRS_SolicitudesAusenciasProgramadas Obtener_Modelo_Por_Id(long _lng_id,long _lng_CodigoCliente)
|
|
{
|
|
try
|
|
{
|
|
string str_SQL = Obtener_Consulta_Modelo() +
|
|
//WHERE
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + "=@id and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros = new object[]
|
|
{
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", _lng_CodigoCliente)
|
|
};
|
|
|
|
//Ejecutar y rellenar el modelo
|
|
Ejecutar_Consulta_Modelo(str_SQL,
|
|
arr_Parametros);
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener_Modelo_Por_Id), true);
|
|
}
|
|
|
|
return g_mdl_KRS_SolicitudesAusenciasProgramadas;
|
|
}
|
|
|
|
public KRS_SolicitudesAusenciasProgramadas Obtener_Modelo_Por_Fecha_AusenciaProgramadaTipoEstado(DateTime _dtt_Fecha,long _lng_idAusenciaProgramadaTipo,string _str_Estado, long _lng_CodigoCliente)
|
|
{
|
|
try
|
|
{
|
|
string str_SQL = Obtener_Consulta_Modelo() +
|
|
//WHERE
|
|
" WHERE " +
|
|
" CONVERT(VARCHAR(10), " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + ",103)=@fecha and " +
|
|
" CONVERT(VARCHAR(10), " + nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaHasta) + ",103)=@fecha and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + "=@idAusenciaProgramadaTipo and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros = new object[]
|
|
{
|
|
new SqlParameter("@fecha", _dtt_Fecha.ToString("dd/MM/yyyy")),
|
|
new SqlParameter("@idAusenciaProgramadaTipo", _lng_idAusenciaProgramadaTipo),
|
|
new SqlParameter("@estado", _str_Estado),
|
|
new SqlParameter("@codigoCliente", _lng_CodigoCliente)
|
|
};
|
|
|
|
//Ejecutar y rellenar el modelo
|
|
Ejecutar_Consulta_Modelo(str_SQL,
|
|
arr_Parametros);
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener_Modelo_Por_Fecha_AusenciaProgramadaTipoEstado), true);
|
|
}
|
|
|
|
return g_mdl_KRS_SolicitudesAusenciasProgramadas;
|
|
}
|
|
|
|
|
|
private void Ejecutar_Consulta_Modelo(string _str_SQL, object[] _arr_Parametros)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
try
|
|
{
|
|
//Conexion
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
|
|
//Rellenar el Modelo
|
|
g_mdl_KRS_SolicitudesAusenciasProgramadas = obj_KairosProEntities.Database.SqlQuery<KRS_SolicitudesAusenciasProgramadas>(_str_SQL, _arr_Parametros).FirstOrDefault();
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Modelo Listado
|
|
private List<KRS_SolicitudesAusenciasProgramadas> g_lst_KRS_SolicitudesAusenciasProgramadas = null;
|
|
|
|
public List<KRS_SolicitudesAusenciasProgramadas> Obtener_ModeloListado_Por_Ids(List<long> _lst_Ids,
|
|
GEN_EjerciciosActivos_Empresa _mdl_GEN_EjerciciosActivos_Empresa,
|
|
bool _bol_Cargar_AusenciasProgramadasTipos,
|
|
bool _bol_Cargar_Empleados)
|
|
{
|
|
try
|
|
{
|
|
|
|
if (_lst_Ids != null && _lst_Ids.Count > 0)
|
|
{
|
|
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
|
|
|
|
string str_Filtros_IDS = Funciones.Formar_ContenidoIN_ParaConsultaWhere(nameof(KRS_SolicitudesAusenciasProgramadas),
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.id),
|
|
G_ENUM_FORMARCONTENIDOIN_CONDICIONANTES.NADA,
|
|
_lst_Ids);
|
|
|
|
|
|
//Consulta
|
|
string str_SQL = Obtener_Consulta_Modelo() +
|
|
//WHERE
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + " is null and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente and " +
|
|
str_Filtros_IDS;
|
|
|
|
//Parametros
|
|
lst_Parametros.Add(new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO));
|
|
object[] arr_Parametros = lst_Parametros.ToArray();
|
|
|
|
//Ejecutar y rellenar el listado
|
|
Ejecutar_Consulta_Modelo_Listado(str_SQL,
|
|
arr_Parametros,
|
|
_bol_Cargar_AusenciasProgramadasTipos,
|
|
_bol_Cargar_Empleados,
|
|
false);
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener_ModeloListado_Por_Ids), true);
|
|
}
|
|
|
|
return g_lst_KRS_SolicitudesAusenciasProgramadas;
|
|
}
|
|
|
|
public List<KRS_SolicitudesAusenciasProgramadas> Obtener_ModeloListado_Por_EmpleadoAusenciaProgramadaTipoFechas(long _lng_idEmpleado, long _lng_CodigoCliente, long _lng_idAusenciaProgramadaTipo, DateTime _dtt_FechaDesde, DateTime _dtt_FechaHasta, bool _bol_PorHoras)
|
|
{
|
|
try
|
|
{
|
|
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
|
|
|
|
List<string> lst_Estado = new List<string>();
|
|
lst_Estado.Add(Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_CANCELADO.Codigo);
|
|
lst_Estado.Add(Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_PENDIENTE.Codigo);
|
|
lst_Estado.Add(Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_ENCURSO.Codigo);
|
|
string str_Filtro_Estado = Funciones.Formar_ContenidoIN_ParaConsultaWhere(lst_Estado);
|
|
|
|
//Consulta
|
|
string str_SQL = Obtener_Consulta_Modelo() +
|
|
//WHERE
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + " is null and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.idEmpleado) + "=@idEmpleado and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + "=@idAusenciaProgramadaTipo and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.estado) + " in (" + str_Filtro_Estado + ") and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + ">=@fechaDesde and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + "<=@fechaHasta and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaHasta) + "<=@fechaHasta and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaHasta) + ">=@fechaDesde and " +
|
|
(_bol_PorHoras
|
|
? " ( not " + nameof(KRS_SolicitudesAusenciasProgramadas.porHoras) + " is null) "
|
|
: nameof(KRS_SolicitudesAusenciasProgramadas.porHoras) + " is null "
|
|
);
|
|
|
|
//Parametros
|
|
lst_Parametros.Add(new SqlParameter("@idEmpleado", _lng_idEmpleado));
|
|
lst_Parametros.Add(new SqlParameter("@codigoCliente", _lng_CodigoCliente));
|
|
lst_Parametros.Add(new SqlParameter("@idAusenciaProgramadaTipo", _lng_idAusenciaProgramadaTipo));
|
|
lst_Parametros.Add(new SqlParameter("@fechaDesde", _dtt_FechaDesde));
|
|
lst_Parametros.Add(new SqlParameter("@fechaHasta", _dtt_FechaHasta));
|
|
|
|
object[] arr_Parametros = lst_Parametros.ToArray();
|
|
|
|
//Ejecutar y rellenar el listado
|
|
Ejecutar_Consulta_Modelo_Listado(str_SQL,
|
|
arr_Parametros,
|
|
false,
|
|
false,
|
|
false);
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener_ModeloListado_Por_EmpleadoAusenciaProgramadaTipoFechas), true);
|
|
}
|
|
|
|
return g_lst_KRS_SolicitudesAusenciasProgramadas;
|
|
}
|
|
|
|
public List<KRS_SolicitudesAusenciasProgramadas> Obtener_ModeloListado_Por_Pendientes(long _lng_CodigoCliente)
|
|
{
|
|
try
|
|
{
|
|
|
|
|
|
//Consulta
|
|
string str_SQL = Obtener_Consulta_Modelo() +
|
|
//WHERE
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + " is null and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado ";
|
|
|
|
//Parametros
|
|
List <SqlParameter> lst_Parametros = new List<SqlParameter>();
|
|
lst_Parametros.Add(new SqlParameter("@estado", Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_PENDIENTE.Codigo));
|
|
lst_Parametros.Add(new SqlParameter("@codigoCliente", _lng_CodigoCliente));
|
|
|
|
object[] arr_Parametros = lst_Parametros.ToArray();
|
|
|
|
//Ejecutar y rellenar el listado
|
|
Ejecutar_Consulta_Modelo_Listado(str_SQL,
|
|
arr_Parametros,
|
|
false,
|
|
false,
|
|
true);
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Obtener_ModeloListado_Por_Pendientes), true);
|
|
}
|
|
|
|
return g_lst_KRS_SolicitudesAusenciasProgramadas;
|
|
}
|
|
|
|
#region Ejecutar Consulta
|
|
//Listado de modelos Relacionados
|
|
private List<KRS_AusenciasProgramadasTipos> g_lst_KRS_AusenciasProgramadasTipos = null;
|
|
private List<KRS_Empleados> g_lst_KRS_Empleados = null;
|
|
private List<KRS_SolicitudesAusenciasProgramadas_Supervisores> g_lst_KRS_SolicitudesAusenciasProgramadas_Supervisores = null;
|
|
|
|
//Hilos
|
|
private static int g_int_TotalHilos_Modelo_Listado = 3;
|
|
private bool[] g_bol_Hilos_Terminados_Modelo_Listado = new bool[g_int_TotalHilos_Modelo_Listado];
|
|
|
|
|
|
private void Ejecutar_Consulta_Modelo_Listado(string _str_SQL,
|
|
object[] _arr_Parametros,
|
|
bool _bol_Cargar_AusenciasProgramadasTipos,
|
|
bool _bol_Cargar_Empleados,
|
|
bool _bol_Cargar_Supervisores)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
try
|
|
{
|
|
//Conexion
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
|
|
//Rellenar el modelo
|
|
g_lst_KRS_SolicitudesAusenciasProgramadas = obj_KairosProEntities.Database.SqlQuery<KRS_SolicitudesAusenciasProgramadas>(_str_SQL, _arr_Parametros).ToList();
|
|
|
|
#region Rellenar tablas Relacionadas
|
|
if (g_lst_KRS_SolicitudesAusenciasProgramadas != null && g_lst_KRS_SolicitudesAusenciasProgramadas.Count > 0)
|
|
{
|
|
//Si tiene que buscar alguna tabla relacionada
|
|
if (_bol_Cargar_AusenciasProgramadasTipos ||
|
|
_bol_Cargar_Empleados ||
|
|
_bol_Cargar_Supervisores)
|
|
{
|
|
#region PRIMERO BUSCO LOS DATOS DE LAS TABLAS RELACIONADAS
|
|
//reiniciar Valores de los hilos
|
|
for (int int_Contador = 0; int_Contador < g_int_TotalHilos_Modelo_Listado; int_Contador++)
|
|
{
|
|
g_bol_Hilos_Terminados_Modelo_Listado[int_Contador] = false;
|
|
}
|
|
|
|
//KRS_AusenciasProgramadasTipos #############################################
|
|
if (_bol_Cargar_AusenciasProgramadasTipos)
|
|
{
|
|
ThreadStart obj_ThreadStart_AUSENCIASPROGRAMADASTIPOS = new ThreadStart(Obtener_AusenciasProgramdasTipos_Modelo_Listado);
|
|
Thread obj_Thread_AUSENCIASPROGRAMADASTIPOS = new Thread(obj_ThreadStart_AUSENCIASPROGRAMADASTIPOS);
|
|
obj_Thread_AUSENCIASPROGRAMADASTIPOS.Start();
|
|
}
|
|
else
|
|
{
|
|
g_bol_Hilos_Terminados_Modelo_Listado[0] = true;
|
|
}
|
|
|
|
//KRS_Empleados #############################################
|
|
if (_bol_Cargar_Empleados)
|
|
{
|
|
ThreadStart obj_ThreadStart_EMPLEADOS = new ThreadStart(Obtener_Empleados_Modelo_Listado);
|
|
Thread obj_Thread_EMPLEADOS = new Thread(obj_ThreadStart_EMPLEADOS);
|
|
obj_Thread_EMPLEADOS.Start();
|
|
}
|
|
else
|
|
{
|
|
g_bol_Hilos_Terminados_Modelo_Listado[1] = true;
|
|
}
|
|
|
|
//KRS_SolicitudesAusenciasProgramadas_Supervisores #############################################
|
|
if (_bol_Cargar_Supervisores)
|
|
{
|
|
ThreadStart obj_ThreadStart_SUPERVISORES = new ThreadStart(Obtener_Supervisores_Modelo_Listado);
|
|
Thread obj_Thread_SUPERVISORES = new Thread(obj_ThreadStart_SUPERVISORES);
|
|
obj_Thread_SUPERVISORES.Start();
|
|
}
|
|
else
|
|
{
|
|
g_bol_Hilos_Terminados_Modelo_Listado[2] = true;
|
|
}
|
|
|
|
|
|
//Esperando a que terminen todos los hilos .........................................
|
|
bool bol_Termino = false;
|
|
while (bol_Termino == false)
|
|
{
|
|
bol_Termino = true;
|
|
foreach (bool bol_Termino_Hilo in g_bol_Hilos_Terminados_Modelo_Listado)
|
|
{
|
|
if (bol_Termino_Hilo == false)
|
|
{
|
|
bol_Termino = false;
|
|
break;
|
|
}
|
|
}
|
|
|
|
Thread.Sleep(10);
|
|
}
|
|
//.................................................................................
|
|
#endregion
|
|
|
|
#region DESPUES SE LO VOY ASIGNANDO A LOS REGISTRO UNO A UNO
|
|
foreach (KRS_SolicitudesAusenciasProgramadas mdl_KRS_SolicitudesAusenciasProgramadas in g_lst_KRS_SolicitudesAusenciasProgramadas)
|
|
{
|
|
//KRS_AusenciasProgramadasTipos #############################################
|
|
if (_bol_Cargar_AusenciasProgramadasTipos &&
|
|
g_lst_KRS_AusenciasProgramadasTipos != null &&
|
|
g_lst_KRS_AusenciasProgramadasTipos.Count > 0)
|
|
{
|
|
mdl_KRS_SolicitudesAusenciasProgramadas.KRS_AusenciasProgramadasTipos = g_lst_KRS_AusenciasProgramadasTipos.Where(m => m.id == mdl_KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo).FirstOrDefault();
|
|
}
|
|
|
|
//KRS_Empleados #############################################
|
|
if (_bol_Cargar_Empleados &&
|
|
g_lst_KRS_Empleados != null &&
|
|
g_lst_KRS_Empleados.Count > 0)
|
|
{
|
|
mdl_KRS_SolicitudesAusenciasProgramadas.KRS_Empleados = g_lst_KRS_Empleados.Where(m => m.id == mdl_KRS_SolicitudesAusenciasProgramadas.idEmpleado).FirstOrDefault();
|
|
}
|
|
|
|
//KRS_SolicitudesAusenciasProgramadas_Supervisores #############################################
|
|
if (_bol_Cargar_Supervisores &&
|
|
g_lst_KRS_SolicitudesAusenciasProgramadas_Supervisores != null &&
|
|
g_lst_KRS_SolicitudesAusenciasProgramadas_Supervisores.Count > 0)
|
|
{
|
|
mdl_KRS_SolicitudesAusenciasProgramadas.KRS_SolicitudesAusenciasProgramadas_Supervisores = g_lst_KRS_SolicitudesAusenciasProgramadas_Supervisores.Where(m => m.idSolicitudAusenciaProgramada == mdl_KRS_SolicitudesAusenciasProgramadas.id).ToList();
|
|
}
|
|
}
|
|
#endregion
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo_Listado), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
}
|
|
#region Tablas relacionadas
|
|
private void Obtener_AusenciasProgramdasTipos_Modelo_Listado()
|
|
{
|
|
try
|
|
{
|
|
KRS_AusenciasProgramadasTipos_Datos obj_KRS_AusenciasProgramadasTipos_Datos = new KRS_AusenciasProgramadasTipos_Datos();
|
|
g_lst_KRS_AusenciasProgramadasTipos= obj_KRS_AusenciasProgramadasTipos_Datos.Obtener_ModeloListado_Por_Ids(g_lst_KRS_SolicitudesAusenciasProgramadas.Select(m => m.idAusenciaProgramadaTipo).ToList());
|
|
}
|
|
catch (Control_Errores)
|
|
{ }
|
|
finally
|
|
{
|
|
g_bol_Hilos_Terminados_Modelo_Listado[0] = true;
|
|
}
|
|
}
|
|
private void Obtener_Empleados_Modelo_Listado()
|
|
{
|
|
try
|
|
{
|
|
KRS_Empleados_Datos obj_KRS_Empleados_Datos = new KRS_Empleados_Datos();
|
|
g_lst_KRS_Empleados = obj_KRS_Empleados_Datos.Obtener_ModeloListado_Por_Ids(g_lst_KRS_SolicitudesAusenciasProgramadas.Select(m => m.idEmpleado).ToList());
|
|
}
|
|
catch (Control_Errores)
|
|
{ }
|
|
finally
|
|
{
|
|
g_bol_Hilos_Terminados_Modelo_Listado[1] = true;
|
|
}
|
|
}
|
|
private void Obtener_Supervisores_Modelo_Listado()
|
|
{
|
|
try
|
|
{
|
|
KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos obj_KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos = new KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos();
|
|
g_lst_KRS_SolicitudesAusenciasProgramadas_Supervisores = obj_KRS_SolicitudesAusenciasProgramadas_Supervisores_Datos.Obtener_ModeloListado_Por_IdsSolicitudesAusenciasProgramadas(g_lst_KRS_SolicitudesAusenciasProgramadas.Select(m => m.id).ToList());
|
|
}
|
|
catch (Control_Errores)
|
|
{ }
|
|
finally
|
|
{
|
|
g_bol_Hilos_Terminados_Modelo_Listado[2] = true;
|
|
}
|
|
}
|
|
#endregion
|
|
#endregion
|
|
|
|
#endregion
|
|
|
|
private string Obtener_Consulta_Modelo()
|
|
{
|
|
return
|
|
" SELECT " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.id) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idEmpleado) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaSolicitud) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaHasta) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.observaciones) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.estado) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.motivoCancelacion) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaAceptacionCancelacion) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + " , " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas) + "." + nameof(KRS_SolicitudesAusenciasProgramadas.porHoras) +
|
|
" FROM " + nameof(KRS_SolicitudesAusenciasProgramadas);
|
|
}
|
|
#endregion
|
|
|
|
#region Grabar
|
|
public override INTERNO_ValorDevuelto_Modelo Grabar(object _mdl_obj)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
INTERNO_ValorDevuelto_Modelo mdl_INTERNO_ValorDevuelto_Modelo = new INTERNO_ValorDevuelto_Modelo();
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = true;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
KRS_SolicitudesAusenciasProgramadas mdl_KRS_SolicitudesAusenciasProgramadas_AGrabar = (KRS_SolicitudesAusenciasProgramadas)_mdl_obj;
|
|
KRS_SolicitudesAusenciasProgramadas mdl_KRS_SolicitudesAusenciasProgramadas_DatosViejos = new KRS_SolicitudesAusenciasProgramadas();
|
|
|
|
KRS_SolicitudesAusenciasProgramadas mdl_KRS_SolicitudesAusenciasProgramadas_Final = Obtener_Modelo_Por_Id(mdl_KRS_SolicitudesAusenciasProgramadas_AGrabar.id, Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO);
|
|
|
|
if (mdl_KRS_SolicitudesAusenciasProgramadas_Final != null)
|
|
{
|
|
//Tipo de Accion que se va a realizar
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_MODIFICAR;
|
|
|
|
//Validado el codigo del cliente, se lo asignamos antes de grabar
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_AGrabar.codigoCliente = Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO;
|
|
|
|
//Datos viejos para la trazabilidad
|
|
Funciones.CopiarPropiedadesObjetos(mdl_KRS_SolicitudesAusenciasProgramadas_Final, mdl_KRS_SolicitudesAusenciasProgramadas_DatosViejos, false, false);
|
|
|
|
//Cargar los Datos del modelo
|
|
Funciones.CopiarPropiedadesObjetos(mdl_KRS_SolicitudesAusenciasProgramadas_AGrabar, mdl_KRS_SolicitudesAusenciasProgramadas_Final, false, false);
|
|
|
|
#region Update
|
|
string str_SQL_Update = " UPDATE " + nameof(KRS_SolicitudesAusenciasProgramadas) +
|
|
" SET " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.idEmpleado) + "=@idEmpleado," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + "=@idAusenciaProgramadaTipo," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaSolicitud) + "=@fechaSolicitud," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + "=@fechaDesde," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaHasta) + "=@fechaHasta," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.observaciones) + "=@observaciones," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.motivoCancelacion) + "=@motivoCancelacion," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaAceptacionCancelacion) + "=@fechaAceptacionCancelacion," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + "=@fechaBorrado, " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.porHoras) + "=@porHoras " +
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.id) + "=@id";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros_Update = new object[]
|
|
{
|
|
new SqlParameter("@codigoCliente", mdl_KRS_SolicitudesAusenciasProgramadas_Final.codigoCliente),
|
|
new SqlParameter("@idEmpleado", mdl_KRS_SolicitudesAusenciasProgramadas_Final.idEmpleado),
|
|
new SqlParameter("@idAusenciaProgramadaTipo", mdl_KRS_SolicitudesAusenciasProgramadas_Final.idAusenciaProgramadaTipo),
|
|
new SqlParameter("@fechaSolicitud", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaSolicitud),
|
|
new SqlParameter("@fechaDesde", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaDesde),
|
|
new SqlParameter("@fechaHasta", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaHasta),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.observaciones != null
|
|
? new SqlParameter("@observaciones", mdl_KRS_SolicitudesAusenciasProgramadas_Final.observaciones)
|
|
: new SqlParameter("@observaciones", DBNull.Value),
|
|
new SqlParameter("@estado", mdl_KRS_SolicitudesAusenciasProgramadas_Final.estado),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.motivoCancelacion != null
|
|
? new SqlParameter("@motivoCancelacion", mdl_KRS_SolicitudesAusenciasProgramadas_Final.motivoCancelacion)
|
|
: new SqlParameter("@motivoCancelacion", DBNull.Value),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaAceptacionCancelacion != null
|
|
? new SqlParameter("@fechaAceptacionCancelacion", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaAceptacionCancelacion.Value)
|
|
: new SqlParameter("@fechaAceptacionCancelacion", DBNull.Value),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaBorrado != null
|
|
? new SqlParameter("@fechaBorrado", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaBorrado.Value)
|
|
: new SqlParameter("@fechaBorrado", DBNull.Value),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.porHoras != null
|
|
? new SqlParameter("@porHoras", mdl_KRS_SolicitudesAusenciasProgramadas_Final.porHoras.Value)
|
|
: new SqlParameter("@porHoras", DBNull.Value),
|
|
new SqlParameter("@id", mdl_KRS_SolicitudesAusenciasProgramadas_Final.id)
|
|
};
|
|
#endregion
|
|
|
|
//Update
|
|
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update);
|
|
|
|
//Id de la tabla
|
|
mdl_INTERNO_ValorDevuelto_Modelo.Id = mdl_KRS_SolicitudesAusenciasProgramadas_Final.id;
|
|
}
|
|
else
|
|
{
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final = new KRS_SolicitudesAusenciasProgramadas();
|
|
|
|
//Tipo de Accion que se va a realizar
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_INSERTAR;
|
|
|
|
//Validado el codigo del cliente, se lo asignamos antes de grabar
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_AGrabar.codigoCliente = Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO;
|
|
|
|
//Cargar los Datos del modelo
|
|
Funciones.CopiarPropiedadesObjetos(mdl_KRS_SolicitudesAusenciasProgramadas_AGrabar, mdl_KRS_SolicitudesAusenciasProgramadas_Final, false, false);
|
|
|
|
#region INSERT
|
|
string str_SQL_Insert = " INSERT INTO " + nameof(KRS_SolicitudesAusenciasProgramadas) +
|
|
" (" +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.idEmpleado) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.idAusenciaProgramadaTipo) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaSolicitud) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaDesde) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaHasta) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.observaciones) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.motivoCancelacion) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaAceptacionCancelacion) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + "," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.porHoras) +
|
|
" ) " +
|
|
" OUTPUT INSERTED." + nameof(KRS_SolicitudesAusenciasProgramadas.id) +
|
|
" VALUES " +
|
|
" ( " +
|
|
"@codigoCliente," +
|
|
"@idEmpleado," +
|
|
"@idAusenciaProgramadaTipo," +
|
|
"@fechaSolicitud," +
|
|
"@fechaDesde," +
|
|
"@fechaHasta," +
|
|
"@observaciones," +
|
|
"@estado," +
|
|
"@motivoCancelacion," +
|
|
"@fechaAceptacionCancelacion," +
|
|
"@fechaBorrado, " +
|
|
"@porHoras " +
|
|
" ) ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros_Insert = new object[]
|
|
{
|
|
new SqlParameter("@codigoCliente", mdl_KRS_SolicitudesAusenciasProgramadas_Final.codigoCliente),
|
|
new SqlParameter("@idEmpleado", mdl_KRS_SolicitudesAusenciasProgramadas_Final.idEmpleado),
|
|
new SqlParameter("@idAusenciaProgramadaTipo", mdl_KRS_SolicitudesAusenciasProgramadas_Final.idAusenciaProgramadaTipo),
|
|
new SqlParameter("@fechaSolicitud", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaSolicitud),
|
|
new SqlParameter("@fechaDesde", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaDesde),
|
|
new SqlParameter("@fechaHasta", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaHasta),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.observaciones != null
|
|
? new SqlParameter("@observaciones", mdl_KRS_SolicitudesAusenciasProgramadas_Final.observaciones)
|
|
: new SqlParameter("@observaciones", DBNull.Value),
|
|
new SqlParameter("@estado", mdl_KRS_SolicitudesAusenciasProgramadas_Final.estado),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.motivoCancelacion != null
|
|
? new SqlParameter("@motivoCancelacion", mdl_KRS_SolicitudesAusenciasProgramadas_Final.motivoCancelacion)
|
|
: new SqlParameter("@motivoCancelacion", DBNull.Value),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaAceptacionCancelacion != null
|
|
? new SqlParameter("@fechaAceptacionCancelacion", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaAceptacionCancelacion.Value)
|
|
: new SqlParameter("@fechaAceptacionCancelacion", DBNull.Value),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaBorrado != null
|
|
? new SqlParameter("@fechaBorrado", mdl_KRS_SolicitudesAusenciasProgramadas_Final.fechaBorrado.Value)
|
|
: new SqlParameter("@fechaBorrado", DBNull.Value),
|
|
mdl_KRS_SolicitudesAusenciasProgramadas_Final.porHoras != null
|
|
? new SqlParameter("@porHoras", mdl_KRS_SolicitudesAusenciasProgramadas_Final.porHoras.Value)
|
|
: new SqlParameter("@porHoras", DBNull.Value),
|
|
};
|
|
#endregion
|
|
|
|
//Id de la tabla
|
|
mdl_INTERNO_ValorDevuelto_Modelo.Id = obj_KairosProEntities.Database.SqlQuery<long>(str_SQL_Insert, arr_Parametros_Insert).Single();
|
|
|
|
}
|
|
|
|
// Grabar un registro de trazabilidad con los datos de la transaccion realizada.
|
|
USR_Trazabilidad_Datos.Grabar_Trazabilidad(typeof(KRS_SolicitudesAusenciasProgramadas), mdl_KRS_SolicitudesAusenciasProgramadas_DatosViejos, mdl_KRS_SolicitudesAusenciasProgramadas_Final, mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion, obj_KairosProEntities);
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Grabar), true);
|
|
}
|
|
finally
|
|
{
|
|
//Finalizar transaccion
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
|
|
return mdl_INTERNO_ValorDevuelto_Modelo;
|
|
}
|
|
|
|
public INTERNO_ValorDevuelto_Modelo Actualizar_Estado(long _lng_id, long _lng_CodigoCliente, string _str_Estado,string _str_MotivoCancelacion, DateTime? _dtt_FechaAceptacionCancelacion)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
INTERNO_ValorDevuelto_Modelo mdl_INTERNO_ValorDevuelto_Modelo = new INTERNO_ValorDevuelto_Modelo();
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = true;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Tipo de Accion que se va a realizar
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_INSERTAR;
|
|
|
|
string str_SQL_Update = " UPDATE " + nameof(KRS_SolicitudesAusenciasProgramadas) +
|
|
" SET " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.estado) + "=@estado," +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.motivoCancelacion) + "=@motivoCancelacion, " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaAceptacionCancelacion) + "=@fechaAceptacionCancelacion " +
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.id) + "=@id and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros_Update = new object[]
|
|
{
|
|
new SqlParameter("@estado", _str_Estado),
|
|
new SqlParameter("@motivoCancelacion", _str_MotivoCancelacion),
|
|
_dtt_FechaAceptacionCancelacion != null
|
|
? new SqlParameter("@fechaAceptacionCancelacion", _dtt_FechaAceptacionCancelacion.Value)
|
|
: new SqlParameter("@fechaAceptacionCancelacion", DBNull.Value),
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", _lng_CodigoCliente),
|
|
};
|
|
|
|
//Actualizar
|
|
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update);
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Actualizar_Estado), true);
|
|
}
|
|
finally
|
|
{
|
|
//Finalizar transaccion
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
|
|
return mdl_INTERNO_ValorDevuelto_Modelo;
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Borrar
|
|
public override INTERNO_ValorDevuelto_Modelo Borrar(long _lng_id)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
INTERNO_ValorDevuelto_Modelo mdl_INTERNO_ValorDevuelto_Modelo = new INTERNO_ValorDevuelto_Modelo();
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = true;
|
|
|
|
//Tipo de Accion que se va a realizar
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_ELIMINAR;
|
|
// Se utiliza la transaccion por la llamada al procedimiento de almacenado
|
|
using (TransactionScope transaccion_SQL = new TransactionScope(TransactionScopeOption.Required))
|
|
{
|
|
try
|
|
{
|
|
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
// Ver si existe ######################################################################
|
|
KRS_SolicitudesAusenciasProgramadas mdl_KRS_SolicitudesAusenciasProgramadas = Obtener_Modelo_Por_Id(_lng_id, Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO);
|
|
//######################################################################################
|
|
|
|
if (mdl_KRS_SolicitudesAusenciasProgramadas != null)
|
|
{
|
|
//Comprobar que esta pendiente
|
|
if (mdl_KRS_SolicitudesAusenciasProgramadas.estado!=Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_PENDIENTE.Codigo)
|
|
{
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = false;
|
|
if (mdl_KRS_SolicitudesAusenciasProgramadas.estado.Equals(Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_CANCELADO.Codigo))
|
|
{
|
|
mdl_INTERNO_ValorDevuelto_Modelo.Mensaje = Mensajes.G_STR_SOLICITUDAUSENCIAPROGRAMADA_VALIDACION_ESTADONOPENDIENTE_BORRAR(Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_CANCELADO.Descripcion);
|
|
}
|
|
else if (mdl_KRS_SolicitudesAusenciasProgramadas.estado.Equals(Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_ENCURSO.Codigo))
|
|
{
|
|
mdl_INTERNO_ValorDevuelto_Modelo.Mensaje = Mensajes.G_STR_SOLICITUDAUSENCIAPROGRAMADA_VALIDACION_ESTADONOPENDIENTE_BORRAR(Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_ENCURSO.Descripcion);
|
|
}
|
|
else
|
|
{
|
|
mdl_INTERNO_ValorDevuelto_Modelo.Mensaje = Mensajes.G_STR_SOLICITUDAUSENCIAPROGRAMADA_VALIDACION_ESTADONOPENDIENTE_BORRAR(Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_ACEPTADO.Descripcion);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//Borrar Tareas pendientes Asociadas
|
|
KRS_TareasPendientes_Datos obj_KRS_TareasPendientes_Datos = new KRS_TareasPendientes_Datos();
|
|
obj_KRS_TareasPendientes_Datos.Borrar_Por_CodigoClienteIdSolicitudAusenciaProgramada(Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO,_lng_id);
|
|
|
|
#region Update
|
|
string str_SQL_Update = " UPDATE " + nameof(KRS_SolicitudesAusenciasProgramadas) +
|
|
" SET " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + "=@fechaBorrado " +
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.id) + "=@id and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente ";
|
|
//Parametros
|
|
object[] arr_Parametros_Update = new object[]
|
|
{
|
|
new SqlParameter("@fechaBorrado", DateTime.Now),
|
|
new SqlParameter("@id", _lng_id),
|
|
new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO)
|
|
};
|
|
#endregion
|
|
|
|
//Update
|
|
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update);
|
|
|
|
// Grabar un registro de trazabilidad con los datos de la transaccion realizada.
|
|
USR_Trazabilidad_Datos.Grabar_Trazabilidad(typeof(KRS_SolicitudesAusenciasProgramadas), null, mdl_KRS_SolicitudesAusenciasProgramadas, G_ENUM_TIPOACCION.INT_ELIMINAR, obj_KairosProEntities);
|
|
|
|
// Se termina la Transaccion Correctamente
|
|
transaccion_SQL.Complete();
|
|
|
|
// Devolver también el Objeto
|
|
mdl_INTERNO_ValorDevuelto_Modelo.Id = _lng_id;
|
|
}
|
|
}
|
|
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Borrar), true);
|
|
}
|
|
finally
|
|
{
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
|
|
// Finalizar transaccion
|
|
transaccion_SQL.Dispose();
|
|
|
|
|
|
}
|
|
}
|
|
|
|
return mdl_INTERNO_ValorDevuelto_Modelo;
|
|
}
|
|
public override INTERNO_ValorDevuelto_Modelo Borrar(object _mdl_obj)
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
public override INTERNO_ValorDevuelto_Modelo Borrar(long _lng_id, long _lng_idAuxiliar)
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
|
|
public INTERNO_ValorDevuelto_Modelo Borrar_Por_AusenciaProgramada(KRS_AusenciasProgramadas _mdl_KRS_AusenciasProgramadas)
|
|
{
|
|
KairosProEntities obj_KairosProEntities = null;
|
|
|
|
INTERNO_ValorDevuelto_Modelo mdl_INTERNO_ValorDevuelto_Modelo = new INTERNO_ValorDevuelto_Modelo();
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = true;
|
|
|
|
try
|
|
{
|
|
obj_KairosProEntities = new KairosProEntities();
|
|
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
|
|
|
|
//Tipo de Accion que se va a realizar
|
|
mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion = G_ENUM_TIPOACCION.INT_ELIMINAR;
|
|
|
|
//Buscar la Solicitud si la hubiera
|
|
KRS_SolicitudesAusenciasProgramadas mdl_KRS_SolicitudesAusenciasProgramadas = Obtener_Modelo_Por_Fecha_AusenciaProgramadaTipoEstado(_mdl_KRS_AusenciasProgramadas.fechaDesde, _mdl_KRS_AusenciasProgramadas.idAusenciaProgramadaTipo, Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_ACEPTADO.Codigo, _mdl_KRS_AusenciasProgramadas.codigoCliente);
|
|
if (mdl_KRS_SolicitudesAusenciasProgramadas != null)
|
|
{
|
|
string str_SQL_Update = " UPDATE " + nameof(KRS_SolicitudesAusenciasProgramadas) +
|
|
" SET " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.fechaBorrado) + "=@fechaBorrado" +
|
|
" WHERE " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.id) + "=@id and " +
|
|
nameof(KRS_SolicitudesAusenciasProgramadas.codigoCliente) + "=@codigoCliente ";
|
|
|
|
//Parametros
|
|
object[] arr_Parametros_Update = new object[]
|
|
{
|
|
new SqlParameter("@fechaBorrado", DateTime.Now),
|
|
new SqlParameter("@id", mdl_KRS_SolicitudesAusenciasProgramadas.id),
|
|
new SqlParameter("@codigoCliente", mdl_KRS_SolicitudesAusenciasProgramadas.codigoCliente)
|
|
};
|
|
|
|
//Actualizar
|
|
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update);
|
|
}
|
|
}
|
|
catch (Control_Errores)
|
|
{
|
|
throw;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
throw new Control_Errores("", ex, nameof(KRS_SolicitudesAusenciasProgramadas_Datos) + "/" + nameof(Borrar_Por_AusenciaProgramada), true);
|
|
}
|
|
finally
|
|
{
|
|
//Finalizar transaccion
|
|
obj_KairosProEntities.Database.Connection.Close();
|
|
obj_KairosProEntities.Dispose();
|
|
}
|
|
|
|
return mdl_INTERNO_ValorDevuelto_Modelo;
|
|
}
|
|
#endregion
|
|
}
|
|
}
|