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 g_lst_INTERNO_KRS_SolicitudesAusenciasProgramadas_Listado_Modelo = null; public override List Obtener_Listado(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { KairosProEntities obj_KairosProEntities = null; List 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().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 _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo, long _lng_id, List _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().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 _lst_CamposConRelacionABuscar, long _lng_id, List _lst_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { try { List lst_Parametros = new List(); //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(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 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 Obtener_Listado_Secundario(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { return null; } public override dynamic Obtener_RegistroListado_Secundario(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo, long _lng_id, List _lst_id) { return null; } protected override void ConsultaRellenar_Listado_Secundario(KairosProEntities _dbcontext, List _lst_CamposConRelacionABuscar, long _lng_id, List _lst_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { } #endregion #region F3 public override dynamic Obtener_F3(string _str_filtro, string _str_CampoBusqueda, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { return null; } public override dynamic Obtener_F3_PorId(long _lng_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { return null; } protected override void ConsultaRellenar_F3(KairosProEntities _dbcontext, string _str_CampoBusqueda, string _str_Filtro, long _lng_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _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(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 Obtener_Registros_Para_Listado_Por_Supervisor(long _lng_idEmpleado_Supervidor,long _lng_CodigoCliente) { KairosProEntities obj_KairosProEntities = null; List 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(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 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 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 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(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(_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 g_lst_KRS_SolicitudesAusenciasProgramadas = null; public List Obtener_ModeloListado_Por_Ids(List _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 lst_Parametros = new List(); 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 Obtener_ModeloListado_Por_EmpleadoAusenciaProgramadaTipoFechas(long _lng_idEmpleado, long _lng_CodigoCliente, long _lng_idAusenciaProgramadaTipo, DateTime _dtt_FechaDesde, DateTime _dtt_FechaHasta, bool _bol_PorHoras) { try { List lst_Parametros = new List(); List lst_Estado = new List(); 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 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 lst_Parametros = new List(); 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 g_lst_KRS_AusenciasProgramadasTipos = null; private List g_lst_KRS_Empleados = null; private List 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(_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(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 } }