Exferia/Exferia_KairosPro/Exferia_KairosPRO/2_Datos/KRS_TareasPendientes_Datos.cs

973 lines
50 KiB
C#

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<dynamic> Obtener_Listado(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
return null;
}
public override dynamic Obtener_RegistroListado(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo, long _lng_id, List<long> _lst_id)
{
return null;
}
protected override void ConsultaRellenar_Listado(KairosProEntities _dbcontext, List<string> _lst_CamposConRelacionABuscar, long _lng_id, List<long> _lst_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{}
#endregion
#region Listado Secundario
public override List<dynamic> Obtener_Listado_Secundario(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
return null;
}
public override dynamic Obtener_RegistroListado_Secundario(List<string> _lst_CamposConRelacionABuscar, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo, long _lng_id, List<long> _lst_id)
{
return null;
}
protected override void ConsultaRellenar_Listado_Secundario(KairosProEntities _dbcontext, List<string> _lst_CamposConRelacionABuscar, long _lng_id, List<long> _lst_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
}
#endregion
#region F3
public override dynamic Obtener_F3(string _str_filtro, string _str_CampoBusqueda, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
return null;
}
public override dynamic Obtener_F3_PorId(long _lng_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
return null;
}
protected override void ConsultaRellenar_F3(KairosProEntities _dbcontext, string _str_CampoBusqueda, string _str_Filtro, long _lng_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{ }
#endregion
#region Obtener
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<KRS_TareasPendientes>(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<long> Obtener_ID_Leidas(long _lng_CodigoCliente, long _lng_idEmpleado)
{
List<long> lst_ids = new List<long>();
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<SqlParameter> lst_Parametros = new List<SqlParameter>();
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<long>(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<KRS_TareasPendientes>(_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<KRS_TareasPendientes> g_lst_KRS_TareasPendientes = null;
public List<KRS_TareasPendientes> Obtener_ModeloListado_Por_Ids(List<long> _lst_Ids)
{
try
{
if (_lst_Ids != null && _lst_Ids.Count > 0)
{
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
string str_Filtros_IDS = Funciones.Formar_ContenidoIN_ParaConsultaWhere(nameof(KRS_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<KRS_TareasPendientes> Obtener_ModeloListado_Por_SolicitudesAusenciasProgramadas(List<long> _lst_IdSolicitudAusenciaProgramada)
{
try
{
if (_lst_IdSolicitudAusenciaProgramada != null && _lst_IdSolicitudAusenciaProgramada.Count > 0)
{
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
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<KRS_TareasPendientes>(_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<long>(str_SQL_Insert, arr_Parametros_Insert).Single();
}
//Grabar un registro de trazabilidad con los datos de la transaccion realizada
USR_Trazabilidad_Datos.Grabar_Trazabilidad(typeof(KRS_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<long> _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<SqlParameter> lst_Parametros = new List<SqlParameter>();
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<SqlParameter> lst_Parametros = new List<SqlParameter>();
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<SqlParameter> lst_Parametros = new List<SqlParameter>();
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
}
}