using Exferia_Aplicacion.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.Transactions; using static Exferia_Aplicacion.General.Enumerados; namespace Exferia_KairosPRO._2_Datos { public class KRS_TareasPendientes_Datos : ABS_Datos { #region Listado public override List Obtener_Listado(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { return null; } 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) { return null; } 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) {} #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 private dynamic g_dnm_Modelo_Obtener = null; 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_TareasPendientes.id) + "," + nameof(KRS_TareasPendientes.codigoCliente) + "," + nameof(KRS_TareasPendientes.idEmpleadoEmisor) + "," + nameof(KRS_TareasPendientes.idEmpleadoReceptor) + "," + nameof(KRS_TareasPendientes.fechaEnvio) + "," + nameof(KRS_TareasPendientes.tipo) + "," + nameof(KRS_TareasPendientes.leido) + "," + nameof(KRS_TareasPendientes.idSolicitudAusenciaProgramada) + "," + nameof(KRS_TareasPendientes.idHorasExtrasCalculadasCabecera) + "," + nameof(KRS_TareasPendientes.fechaHorasExtras) + "," + nameof(KRS_TareasPendientes.avisado) + "," + nameof(KRS_TareasPendientes.agrupadoSolicitudHorasExtras) + " FROM " + nameof(KRS_TareasPendientes) + " WHERE " + nameof(KRS_TareasPendientes.id) + "=@id and " + nameof(KRS_TareasPendientes.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(); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Obtener), true); } finally { obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.Dispose(); } return g_dnm_Modelo_Obtener; } public override dynamic Obtener_Registro_PorCampo(string _str_CampoBusqueda, string _str_Filtro) { throw new NotImplementedException(); } public List Obtener_ID_Leidas(long _lng_CodigoCliente, long _lng_idEmpleado) { List lst_ids = new List(); KairosProEntities obj_KairosProEntities = null; try { //Consulta string str_SQL = " SELECT " + nameof(KRS_TareasPendientes.id) + " FROM " + nameof(KRS_TareasPendientes) + //WHERE " WHERE " + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.codigoCliente) + "=@codigoCliente and " + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.idEmpleadoReceptor) + "=@idEmpleadoReceptor and " + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.leido) + "=@leido "; //Parametros List lst_Parametros = new List(); lst_Parametros.Add(new SqlParameter("@codigoCliente", _lng_CodigoCliente)); lst_Parametros.Add(new SqlParameter("@idEmpleadoReceptor", _lng_idEmpleado)); lst_Parametros.Add(new SqlParameter("@leido", true)); object[] arr_Parametros = lst_Parametros.ToArray(); //Conexion obj_KairosProEntities = new KairosProEntities(); obj_KairosProEntities.Configuration.LazyLoadingEnabled = false; //Rellenar el Modelo lst_ids = obj_KairosProEntities.Database.SqlQuery(str_SQL, arr_Parametros).ToList(); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Obtener_ID_Leidas), true); } finally { obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.Dispose(); } return lst_ids; } #endregion #region MODELOS #region Modelo Simple private KRS_TareasPendientes g_mdl_KRS_TareasPendientes = null; public KRS_TareasPendientes Obtener_Modelo_Por_Id(long _lng_id, long _lng_CodigoCliente) { try { string str_SQL = Obtener_Consulta_Modelo() + //WHERE " WHERE " + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.id) + "=@id and " + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.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_TareasPendientes_Datos) + "/" + nameof(Obtener_Modelo_Por_Id), true); } return g_mdl_KRS_TareasPendientes; } 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_TareasPendientes = obj_KairosProEntities.Database.SqlQuery(_str_SQL, _arr_Parametros).FirstOrDefault(); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo), true); } finally { obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.Dispose(); } } #endregion #region Modelo Listado private List g_lst_KRS_TareasPendientes = null; public List Obtener_ModeloListado_Por_Ids(List _lst_Ids) { try { if (_lst_Ids != null && _lst_Ids.Count > 0) { List lst_Parametros = new List(); string str_Filtros_IDS = Funciones.Formar_ContenidoIN_ParaConsultaWhere(nameof(KRS_TareasPendientes), nameof(KRS_TareasPendientes.id), G_ENUM_FORMARCONTENIDOIN_CONDICIONANTES.NADA, _lst_Ids); //Consulta string str_SQL = Obtener_Consulta_Modelo() + //WHERE " WHERE " + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.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); } } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Obtener_ModeloListado_Por_Ids), true); } return g_lst_KRS_TareasPendientes; } public List Obtener_ModeloListado_Por_SolicitudesAusenciasProgramadas(List _lst_IdSolicitudAusenciaProgramada) { try { if (_lst_IdSolicitudAusenciaProgramada != null && _lst_IdSolicitudAusenciaProgramada.Count > 0) { List lst_Parametros = new List(); string str_Filtros_IDS = Funciones.Formar_ContenidoIN_ParaConsultaWhere(nameof(KRS_TareasPendientes), nameof(KRS_TareasPendientes.idSolicitudAusenciaProgramada), G_ENUM_FORMARCONTENIDOIN_CONDICIONANTES.NADA, _lst_IdSolicitudAusenciaProgramada); //Consulta string str_SQL = Obtener_Consulta_Modelo() + //WHERE " WHERE " + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.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); } } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Obtener_ModeloListado_Por_SolicitudesAusenciasProgramadas), true); } return g_lst_KRS_TareasPendientes; } #region Ejecutar Consulta private void Ejecutar_Consulta_Modelo_Listado(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_lst_KRS_TareasPendientes = obj_KairosProEntities.Database.SqlQuery(_str_SQL, _arr_Parametros).ToList(); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo_Listado), true); } finally { obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.Dispose(); } } #endregion #endregion private string Obtener_Consulta_Modelo() { return " SELECT " + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.id) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.codigoCliente) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.idEmpleadoEmisor) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.idEmpleadoReceptor) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.fechaEnvio) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.tipo) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.leido) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.idSolicitudAusenciaProgramada) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.idHorasExtrasCalculadasCabecera) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.fechaHorasExtras) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.avisado) + "," + nameof(KRS_TareasPendientes) + "." + nameof(KRS_TareasPendientes.agrupadoSolicitudHorasExtras) + " FROM " + nameof(KRS_TareasPendientes); } #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_TareasPendientes mdl_KRS_TareasPendientes_AGrabar = (KRS_TareasPendientes)_mdl_obj; KRS_TareasPendientes mdl_KRS_TareasPendientes_DatosViejos = new KRS_TareasPendientes(); KRS_TareasPendientes mdl_KRS_TareasPendientes_Final = Obtener_Modelo_Por_Id(mdl_KRS_TareasPendientes_AGrabar.id, Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO); if (mdl_KRS_TareasPendientes_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_TareasPendientes_AGrabar.codigoCliente = Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO; //Datos viejos para la trazabilidar Funciones.CopiarPropiedadesObjetos(mdl_KRS_TareasPendientes_Final, mdl_KRS_TareasPendientes_DatosViejos, false, false); //Cargar los Datos del modelo Funciones.CopiarPropiedadesObjetos(mdl_KRS_TareasPendientes_AGrabar, mdl_KRS_TareasPendientes_Final, false, false); #region Update string str_SQL_Update = " UPDATE " + nameof(KRS_TareasPendientes) + " SET " + nameof(KRS_TareasPendientes.codigoCliente) + "=@codigoCliente," + nameof(KRS_TareasPendientes.idEmpleadoEmisor) + "=@idEmpleadoEmisor," + nameof(KRS_TareasPendientes.idEmpleadoReceptor) + "=@idEmpleadoReceptor," + nameof(KRS_TareasPendientes.fechaEnvio) + "=@fechaEnvio," + nameof(KRS_TareasPendientes.tipo) + "=@tipo," + nameof(KRS_TareasPendientes.leido) + "=@leido," + nameof(KRS_TareasPendientes.idSolicitudAusenciaProgramada) + "=@idSolicitudAusenciaProgramada," + nameof(KRS_TareasPendientes.idHorasExtrasCalculadasCabecera) + "=@idHorasExtrasCalculadasCabecera, " + nameof(KRS_TareasPendientes.fechaHorasExtras) + "=@fechaHorasExtras, " + nameof(KRS_TareasPendientes.avisado) + "=@avisado, " + nameof(KRS_TareasPendientes.agrupadoSolicitudHorasExtras) + "=@agrupadoSolicitudHorasExtras " + " WHERE " + nameof(KRS_TareasPendientes.id) + "=@id"; //Parametros object[] arr_Parametros_Update = new object[] { new SqlParameter("@codigoCliente", mdl_KRS_TareasPendientes_Final.codigoCliente), new SqlParameter("@idEmpleadoEmisor", mdl_KRS_TareasPendientes_Final.idEmpleadoEmisor), new SqlParameter("@idEmpleadoReceptor", mdl_KRS_TareasPendientes_Final.idEmpleadoReceptor), new SqlParameter("@fechaEnvio", mdl_KRS_TareasPendientes_Final.fechaEnvio), new SqlParameter("@tipo", mdl_KRS_TareasPendientes_Final.tipo), new SqlParameter("@leido", mdl_KRS_TareasPendientes_Final.leido), mdl_KRS_TareasPendientes_Final.idSolicitudAusenciaProgramada != null ? new SqlParameter("@idSolicitudAusenciaProgramada", mdl_KRS_TareasPendientes_Final.idSolicitudAusenciaProgramada.Value) : new SqlParameter("@idSolicitudAusenciaProgramada", DBNull.Value), mdl_KRS_TareasPendientes_Final.idHorasExtrasCalculadasCabecera != null ? new SqlParameter("@idHorasExtrasCalculadasCabecera", mdl_KRS_TareasPendientes_Final.idHorasExtrasCalculadasCabecera.Value) : new SqlParameter("@idHorasExtrasCalculadasCabecera", DBNull.Value), mdl_KRS_TareasPendientes_Final.fechaHorasExtras != null ? new SqlParameter("@fechaHorasExtras", mdl_KRS_TareasPendientes_Final.fechaHorasExtras.Value) : new SqlParameter("@fechaHorasExtras", DBNull.Value), mdl_KRS_TareasPendientes_Final.avisado != null ? new SqlParameter("@avisado", mdl_KRS_TareasPendientes_Final.avisado.Value) : new SqlParameter("@avisado", DBNull.Value), mdl_KRS_TareasPendientes_Final.agrupadoSolicitudHorasExtras != null ? new SqlParameter("@agrupadoSolicitudHorasExtras", mdl_KRS_TareasPendientes_Final.agrupadoSolicitudHorasExtras.Value) : new SqlParameter("@agrupadoSolicitudHorasExtras", DBNull.Value), new SqlParameter("@id", mdl_KRS_TareasPendientes_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_TareasPendientes_Final.id; } else { mdl_KRS_TareasPendientes_Final = new KRS_TareasPendientes(); //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_TareasPendientes_AGrabar.codigoCliente = Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO; //Cargar los Datos del modelo Funciones.CopiarPropiedadesObjetos(mdl_KRS_TareasPendientes_AGrabar, mdl_KRS_TareasPendientes_Final, false, false); #region INSERT string str_SQL_Insert = " INSERT INTO " + nameof(KRS_TareasPendientes) + " (" + nameof(KRS_TareasPendientes.codigoCliente) + "," + nameof(KRS_TareasPendientes.idEmpleadoEmisor) + "," + nameof(KRS_TareasPendientes.idEmpleadoReceptor) + "," + nameof(KRS_TareasPendientes.fechaEnvio) + "," + nameof(KRS_TareasPendientes.tipo) + "," + nameof(KRS_TareasPendientes.leido) + "," + nameof(KRS_TareasPendientes.idSolicitudAusenciaProgramada) + "," + nameof(KRS_TareasPendientes.idHorasExtrasCalculadasCabecera) + "," + nameof(KRS_TareasPendientes.fechaHorasExtras) + "," + nameof(KRS_TareasPendientes.avisado) + "," + nameof(KRS_TareasPendientes.agrupadoSolicitudHorasExtras) + " ) " + " OUTPUT INSERTED." + nameof(KRS_TareasPendientes.id) + " VALUES " + " ( " + "@codigoCliente," + "@idEmpleadoEmisor," + "@idEmpleadoReceptor," + "@fechaEnvio," + "@tipo," + "@leido," + "@idSolicitudAusenciaProgramada," + "@idHorasExtrasCalculadasCabecera," + "@fechaHorasExtras," + "@avisado," + "@agrupadoSolicitudHorasExtras" + " ) "; //Parametros object[] arr_Parametros_Insert = new object[] { new SqlParameter("@codigoCliente", mdl_KRS_TareasPendientes_Final.codigoCliente), new SqlParameter("@idEmpleadoEmisor", mdl_KRS_TareasPendientes_Final.idEmpleadoEmisor), new SqlParameter("@idEmpleadoReceptor", mdl_KRS_TareasPendientes_Final.idEmpleadoReceptor), new SqlParameter("@fechaEnvio", mdl_KRS_TareasPendientes_Final.fechaEnvio), new SqlParameter("@tipo", mdl_KRS_TareasPendientes_Final.tipo), new SqlParameter("@leido", mdl_KRS_TareasPendientes_Final.leido), mdl_KRS_TareasPendientes_Final.idSolicitudAusenciaProgramada != null ? new SqlParameter("@idSolicitudAusenciaProgramada", mdl_KRS_TareasPendientes_Final.idSolicitudAusenciaProgramada.Value) : new SqlParameter("@idSolicitudAusenciaProgramada", DBNull.Value), mdl_KRS_TareasPendientes_Final.idHorasExtrasCalculadasCabecera != null ? new SqlParameter("@idHorasExtrasCalculadasCabecera", mdl_KRS_TareasPendientes_Final.idHorasExtrasCalculadasCabecera.Value) : new SqlParameter("@idHorasExtrasCalculadasCabecera", DBNull.Value), mdl_KRS_TareasPendientes_Final.fechaHorasExtras != null ? new SqlParameter("@fechaHorasExtras", mdl_KRS_TareasPendientes_Final.fechaHorasExtras.Value) : new SqlParameter("@fechaHorasExtras", DBNull.Value), mdl_KRS_TareasPendientes_Final.avisado != null ? new SqlParameter("@avisado", mdl_KRS_TareasPendientes_Final.avisado.Value) : new SqlParameter("@avisado", DBNull.Value), mdl_KRS_TareasPendientes_Final.agrupadoSolicitudHorasExtras != null ? new SqlParameter("@agrupadoSolicitudHorasExtras", mdl_KRS_TareasPendientes_Final.agrupadoSolicitudHorasExtras.Value) : new SqlParameter("@agrupadoSolicitudHorasExtras", 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_TareasPendientes), mdl_KRS_TareasPendientes_DatosViejos, mdl_KRS_TareasPendientes_Final, mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion, obj_KairosProEntities); } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_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_Campo_Leido(List _lst_id) { 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; string str_Filtros_IDS = Funciones.Formar_ContenidoIN_ParaConsultaWhere(nameof(KRS_TareasPendientes), nameof(KRS_TareasPendientes.id), G_ENUM_FORMARCONTENIDOIN_CONDICIONANTES.AND_FIN, _lst_id); #region Update string str_SQL_Update = " UPDATE " + nameof(KRS_TareasPendientes) + " SET " + nameof(KRS_TareasPendientes.leido) + "=@leido " + " WHERE " + str_Filtros_IDS + nameof(KRS_TareasPendientes.codigoCliente) + "=@codigoCliente "; //Parametros object[] arr_Parametros_Update = new object[] { new SqlParameter("@leido", true), new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO) }; #endregion //Update obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Actualizar_Campo_Leido), true); } finally { //Finalizar transaccion obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.Dispose(); } return mdl_INTERNO_ValorDevuelto_Modelo; } public INTERNO_ValorDevuelto_Modelo Actualizar_Campo_Leido(long _lng_idSolicitudAusenciaProgramada, long _lng_CodigoCliente, long _lng_idEmpleadoSupervisor) { 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; #region Update string str_SQL_Update = " UPDATE " + nameof(KRS_TareasPendientes) + " SET " + nameof(KRS_TareasPendientes.leido) + "=@leido " + " WHERE " + nameof(KRS_TareasPendientes.idSolicitudAusenciaProgramada) + "=@idSolicitudAusenciaProgramada and " + (_lng_idEmpleadoSupervisor > -1 ? nameof(KRS_TareasPendientes.idEmpleadoReceptor) + "=@idEmpleadoReceptor and " : "") + nameof(KRS_TareasPendientes.codigoCliente) + "=@codigoCliente "; //Parametros List lst_Parametros = new List(); lst_Parametros.Add(new SqlParameter("@leido", true)); lst_Parametros.Add(new SqlParameter("@idSolicitudAusenciaProgramada", _lng_idSolicitudAusenciaProgramada)); if (_lng_idEmpleadoSupervisor > -1) { lst_Parametros.Add(new SqlParameter("@idEmpleadoReceptor", _lng_idEmpleadoSupervisor)); } lst_Parametros.Add(new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO)); object[] arr_Parametros_Update = lst_Parametros.ToArray(); #endregion //Update obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Actualizar_Campo_Leido), true); } finally { //Finalizar transaccion obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.Dispose(); } return mdl_INTERNO_ValorDevuelto_Modelo; } public INTERNO_ValorDevuelto_Modelo Actualizar_Campo_Leido_HorasExtras(long _lng_idEmpleadoEmisor, long _lng_CodigoCliente, DateTime _dtt_FechaHorasExtras, long _lng_idHorasExtrasCalculadasCabecera, long _lng_idEmpleadoSupervisor) { 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; #region Update string str_SQL_Update = " UPDATE " + nameof(KRS_TareasPendientes) + " SET " + nameof(KRS_TareasPendientes.leido) + "=@leido, " + nameof(KRS_TareasPendientes.idHorasExtrasCalculadasCabecera) + "=@idHorasExtrasCalculadasCabecera " + " WHERE " + nameof(KRS_TareasPendientes.idEmpleadoEmisor) + "=@idEmpleadoEmisor and " + (_lng_idEmpleadoSupervisor > -1 ? nameof(KRS_TareasPendientes.idEmpleadoReceptor) + "=@idEmpleadoReceptor and " : "") + nameof(KRS_TareasPendientes.fechaHorasExtras) + "=@fechaHorasExtras and " + nameof(KRS_TareasPendientes.codigoCliente) + "=@codigoCliente "; //Parametros List lst_Parametros = new List(); lst_Parametros.Add(new SqlParameter("@leido", true)); lst_Parametros.Add(new SqlParameter("@idHorasExtrasCalculadasCabecera", _lng_idHorasExtrasCalculadasCabecera)); lst_Parametros.Add(new SqlParameter("@idEmpleadoEmisor", _lng_idEmpleadoEmisor)); if (_lng_idEmpleadoSupervisor > -1) { lst_Parametros.Add(new SqlParameter("@idEmpleadoReceptor", _lng_idEmpleadoSupervisor)); } lst_Parametros.Add(new SqlParameter("@fechaHorasExtras", _dtt_FechaHorasExtras)); lst_Parametros.Add(new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO)); object[] arr_Parametros_Update = lst_Parametros.ToArray(); #endregion //Update obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Actualizar_Campo_Leido_HorasExtras), 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; try { //Primer Intento de Borrado obj_KairosProEntities = new KairosProEntities(); obj_KairosProEntities.Configuration.LazyLoadingEnabled = false; // Ver si existe ###################################################################### KRS_TareasPendientes mdl_KRS_TareasPendientes = Obtener_Modelo_Por_Id(_lng_id, Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO); //###################################################################################### if (mdl_KRS_TareasPendientes != null ) { #region Delete string str_SQL_Delete = " DELETE FROM " + nameof(KRS_TareasPendientes) + " WHERE " + nameof(KRS_TareasPendientes.id) + "=@id and " + nameof(KRS_TareasPendientes.codigoCliente) + "=@codigoCliente "; //Parametros object[] arr_Parametros_Delete = new object[] { new SqlParameter("@id", _lng_id), new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO) }; #endregion //Delete obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Delete, arr_Parametros_Delete); // Grabar un registro de trazabilidad con los datos de la transaccion realizada. USR_Trazabilidad_Datos.Grabar_Trazabilidad(typeof(KRS_TareasPendientes), null, mdl_KRS_TareasPendientes, G_ENUM_TIPOACCION.INT_ELIMINAR, obj_KairosProEntities); } // 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_TareasPendientes_Datos) + "/" + nameof(Borrar), true); } finally { obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.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_CodigoClienteIdSolicitudAusenciaProgramada(long _lng_CodigoCliente,long _lng_idSolicitudAusenciaProgramada) { 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; try { //Primer Intento de Borrado obj_KairosProEntities = new KairosProEntities(); obj_KairosProEntities.Configuration.LazyLoadingEnabled = false; #region Delete string str_SQL_Delete = " DELETE FROM " + nameof(KRS_TareasPendientes) + " WHERE " + nameof(KRS_TareasPendientes.idSolicitudAusenciaProgramada) + "=@idSolicitudAusenciaProgramada and " + nameof(KRS_TareasPendientes.codigoCliente) + "=@codigoCliente "; //Parametros object[] arr_Parametros_Delete = new object[] { new SqlParameter("@idSolicitudAusenciaProgramada", _lng_idSolicitudAusenciaProgramada), new SqlParameter("@codigoCliente", _lng_CodigoCliente) }; #endregion //Delete obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Delete, arr_Parametros_Delete); } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Borrar_Por_CodigoClienteIdSolicitudAusenciaProgramada), true); } finally { obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.Dispose(); } return mdl_INTERNO_ValorDevuelto_Modelo; } public INTERNO_ValorDevuelto_Modelo Borrar_SolicitudHorasExtras(long _lng_CodigoCliente, long _lng_idTareaPendiente) { 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_TareasPendientes mdl_KRS_TareasPendientes = Obtener_Modelo_Por_Id(_lng_idTareaPendiente, Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO); //###################################################################################### if (mdl_KRS_TareasPendientes != null) { string str_Estado = Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_PENDIENTE.Codigo; //Ver si tiene idHoraExtraCalculadacabecera if (mdl_KRS_TareasPendientes.idHorasExtrasCalculadasCabecera!=null) { //Buscar el modelo dela cabecera KRS_HorasExtrasCalculadasCabecera_Datos obj_KRS_HorasExtrasCalculadasCabecera_Datos = new KRS_HorasExtrasCalculadasCabecera_Datos(); KRS_HorasExtrasCalculadasCabecera mdl_KRS_HorasExtrasCalculadasCabecera = obj_KRS_HorasExtrasCalculadasCabecera_Datos.Obtener_Modelo_Por_Id(mdl_KRS_TareasPendientes.idHorasExtrasCalculadasCabecera.Value, Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO); if (mdl_KRS_HorasExtrasCalculadasCabecera!=null) { str_Estado = mdl_KRS_HorasExtrasCalculadasCabecera.estado; } } //Comprobar que esta pendiente if (str_Estado != Variables_KairosPRO.G_MDL_ESTADOSOLICITUD_PENDIENTE.Codigo) { mdl_INTERNO_ValorDevuelto_Modelo.TodoCorrecto = false; if (str_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 (str_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 { #region Delete string str_SQL_DELETE = " DELETE FROM " + nameof(KRS_TareasPendientes) + " WHERE " + nameof(KRS_TareasPendientes.codigoCliente) + "=@codigoCliente and " + nameof(KRS_TareasPendientes.fechaEnvio) + "=@fechaEnvio AND " + nameof(KRS_TareasPendientes.fechaHorasExtras) + "=@fechaHorasExtras and " + (mdl_KRS_TareasPendientes.agrupadoSolicitudHorasExtras!=null ? nameof(KRS_TareasPendientes.agrupadoSolicitudHorasExtras) + "=@agrupadoSolicitudHorasExtras " : nameof(KRS_TareasPendientes.agrupadoSolicitudHorasExtras) + " is null "); //Parametros List lst_Parametros = new List(); lst_Parametros.Add(new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO)); lst_Parametros.Add(new SqlParameter("@fechaEnvio", mdl_KRS_TareasPendientes.fechaEnvio)); lst_Parametros.Add(new SqlParameter("@fechaHorasExtras", mdl_KRS_TareasPendientes.fechaHorasExtras)); if (mdl_KRS_TareasPendientes.agrupadoSolicitudHorasExtras != null) { lst_Parametros.Add(new SqlParameter("@agrupadoSolicitudHorasExtras", mdl_KRS_TareasPendientes.agrupadoSolicitudHorasExtras.Value)); } object[] arr_Parametros_Update = lst_Parametros.ToArray(); #endregion //dELETE obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_DELETE, arr_Parametros_Update); // Se termina la Transaccion Correctamente transaccion_SQL.Complete(); // Devolver también el Objeto mdl_INTERNO_ValorDevuelto_Modelo.Id = _lng_idTareaPendiente; } } } catch (Control_Errores) { throw; } catch (Exception ex) { throw new Control_Errores("", ex, nameof(KRS_TareasPendientes_Datos) + "/" + nameof(Borrar), true); } finally { obj_KairosProEntities.Database.Connection.Close(); obj_KairosProEntities.Dispose(); // Finalizar transaccion transaccion_SQL.Dispose(); } } return mdl_INTERNO_ValorDevuelto_Modelo; } #endregion } }