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

1401 lines
73 KiB
C#

using Exferia_KairosPRO._1_Modelos.Herencia.Capas;
using System;
using System.Collections.Generic;
using System.Linq;
using Exferia_Aplicacion.General;
using Exferia_KairosPRO_EF;
using Exferia_KairosPRO._1_Modelos;
using static Exferia_Aplicacion.General.Enumerados;
using Exferia_Aplicacion.Modelos_Informes;
using System.Data.SqlClient;
using System.Threading;
namespace Exferia_KairosPRO._2_Datos
{
public class KRSS_Pausas_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
private List<INTERNO_KRSS_Pausas_Listado_Modelo> g_lst_INTERNO_KRSS_Pausas_Listado_Modelo_SECUNDARIO = null;
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)
{
KairosProEntities obj_KairosProEntities = null;
List<dynamic> lst_KRS = null;
try
{
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
//Consulta.................................................................
ConsultaRellenar_Listado_Secundario(obj_KairosProEntities, _lst_CamposConRelacionABuscar, -1, null, _lst_INTERNO_Filtro_OpcionPadre_Modelo, _lst_INTERNO_Filtro_Modelo);
//........................................................................
if ((g_lst_INTERNO_KRSS_Pausas_Listado_Modelo_SECUNDARIO != null) && (g_lst_INTERNO_KRSS_Pausas_Listado_Modelo_SECUNDARIO.Count() > 0))
{
lst_KRS = g_lst_INTERNO_KRSS_Pausas_Listado_Modelo_SECUNDARIO.Cast<dynamic>().ToList();
}
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Obtener_Listado_Secundario), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return lst_KRS;
}
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)
{
KairosProEntities obj_KairosProEntities = null;
dynamic dnm_KRS = null;
try
{
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
//Consulta ......................................................
ConsultaRellenar_Listado_Secundario(obj_KairosProEntities, _lst_CamposConRelacionABuscar, _lng_id, _lst_id, _lst_INTERNO_Filtro_OpcionPadre_Modelo, _lst_INTERNO_Filtro_Modelo);
//...............................................................
if ((g_lst_INTERNO_KRSS_Pausas_Listado_Modelo_SECUNDARIO != null) && (g_lst_INTERNO_KRSS_Pausas_Listado_Modelo_SECUNDARIO.Count() > 0))
{
dnm_KRS = g_lst_INTERNO_KRSS_Pausas_Listado_Modelo_SECUNDARIO.Cast<dynamic>().ToList();
}
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Obtener_RegistroListado_Secundario), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return dnm_KRS;
}
protected override void ConsultaRellenar_Listado_Secundario(KairosProEntities _obj_KairosProEntities, List<string> _lst_CamposConRelacionABuscar, long _lng_id, List<long> _lst_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
try
{
//Datos del Padre si los tuviera .........................
long lng_idEmpleado_Kairos = -1;
string str_Opcion_Empleado_Kairos = "";
long lng_idEmpresa = -1;
string str_Opcion_Empresa = "";
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)
{
//EMPLEADO
if (mdl_INTERNO_Filtro_OpcionPadre_Modelo.NOMBRE_CAMPO.Equals(Variables.G_STR_OPCION_KRS_EMPLEADOS))
{
str_Opcion_Empleado_Kairos = mdl_INTERNO_Filtro_OpcionPadre_Modelo.NOMBRE_CAMPO;
lng_idEmpleado_Kairos = mdl_INTERNO_Filtro_OpcionPadre_Modelo.VALOR;
}
//EMPRESA
else if (mdl_INTERNO_Filtro_OpcionPadre_Modelo.NOMBRE_CAMPO.Equals(Variables.G_STR_OPCION_GEN_EMPRESA))
{
str_Opcion_Empresa = mdl_INTERNO_Filtro_OpcionPadre_Modelo.NOMBRE_CAMPO;
lng_idEmpresa = mdl_INTERNO_Filtro_OpcionPadre_Modelo.VALOR;
}
}
}
string str_SQL =
" SELECT " +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.id) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.id) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.idEmpleado) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpleado) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.idPausaTipo) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idPausaTipo) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.idTerminal) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idTerminal) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.idDispositivoModelo) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idDispositivoModelo) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.codigoCliente) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.codigoCliente) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.fechaHora) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.observaciones) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.observaciones) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.gps_Posicion_Latitud) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_Posicion_Latitud) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.gps_Posicion_Longitud) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_Posicion_Longitud) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.gps_FechaHora) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_FechaHora) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.gps_Proveedor) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_Proveedor) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.gps_Altitud) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_Altitud) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.modificado) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.modificado) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.anulado) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.anulado) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.validado) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.validado) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.tipoDispositivo) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.tipoDispositivo) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.entradaSalida) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.entradaSalida) + "," +
nameof(INTERNO_KRSS_Pausas_Listado_Modelo.idEmpresa) + " = " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpresa) +
" FROM " + nameof(KRSS_Pausas) +
" WHERE " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpresa) + "=@idEmpresa and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.codigoCliente) + "=@codigoCliente AND " +
(str_Opcion_Empleado_Kairos != "" ? (nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpleado) + "=@idEmpleado") : " 1 = 1 ");
//Parametros
object[] arr_Parametros = new object[]
{
new SqlParameter("@idEmpresa", lng_idEmpresa),
new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO),
new SqlParameter("@idEmpleado", lng_idEmpleado_Kairos)
};
//Rellenar el Modelo
g_lst_INTERNO_KRSS_Pausas_Listado_Modelo_SECUNDARIO = _obj_KairosProEntities.Database.SqlQuery<INTERNO_KRSS_Pausas_Listado_Modelo>(str_SQL, arr_Parametros).ToList();
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(ConsultaRellenar_Listado_Secundario), true);
}
}
#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)
{
throw new NotImplementedException();
}
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)
{
throw new NotImplementedException();
}
protected override void ConsultaRellenar_F3(KairosProEntities _dbcontext, string _str_CampoBusqueda, string _str_Filtro, long _lng_id, List<INTERNO_Filtro_OpcionPadre_Modelo> _lst_INTERNO_Filtro_OpcionPadre_Modelo, List<INTERNO_Filtro_Modelo> _lst_INTERNO_Filtro_Modelo)
{
}
#endregion
#region Obtener
#region Obtener Simple
private dynamic g_dnm_Modelo_Obtener = null;
private static int g_int_TotalHilos_Obtener = 4;
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(KRSS_Pausas.id) + " , " +
nameof(KRSS_Pausas.idEmpleado) + " , " +
nameof(KRSS_Pausas.codigoCliente) + " , " +
nameof(KRSS_Pausas.idPausaTipo) + " , " +
nameof(KRSS_Pausas.fechaHora) + " , " +
nameof(KRSS_Pausas.observaciones) + " , " +
nameof(KRSS_Pausas.gps_Posicion_Latitud) + " , " +
nameof(KRSS_Pausas.gps_Posicion_Longitud) + " , " +
nameof(KRSS_Pausas.gps_FechaHora) + " , " +
nameof(KRSS_Pausas.gps_Proveedor) + " , " +
nameof(KRSS_Pausas.gps_Altitud) + " , " +
nameof(KRSS_Pausas.idTerminal) + " , " +
nameof(KRSS_Pausas.idDispositivoModelo) + " , " +
nameof(KRSS_Pausas.modificado) + " , " +
nameof(KRSS_Pausas.anulado) + " , " +
nameof(KRSS_Pausas.validado) + " , " +
nameof(KRSS_Pausas.tipoDispositivo) + " , " +
nameof(KRSS_Pausas.entradaSalida) + " , " +
nameof(KRSS_Pausas.idEmpresa) +
" FROM " + nameof(KRSS_Pausas) +
" WHERE " +
nameof(KRSS_Pausas.id) + "=@id and " +
nameof(KRSS_Pausas.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<KRSS_Pausas>(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_Empleados ##########################################################################################
ThreadStart obj_ThreadStart_EMPLEADOS = new ThreadStart(Obtener_Empleado_Modelo_Obtener);
Thread obj_Thread_EMPLEADOS = new Thread(obj_ThreadStart_EMPLEADOS);
obj_Thread_EMPLEADOS.Start();
//KRS_PausasTipos ##########################################################################################
ThreadStart obj_ThreadStart_PAUSATIPO = new ThreadStart(Obtener_PausasTipo_Modelo_Obtener);
Thread obj_Thread_PAUSATIPO = new Thread(obj_ThreadStart_PAUSATIPO);
obj_Thread_PAUSATIPO.Start();
//KRS_Terminales ##########################################################################################
if (g_dnm_Modelo_Obtener.idTerminal != null)
{
ThreadStart obj_ThreadStart_TERMINALES = new ThreadStart(Obtener_Terminales_Modelo_Obtener);
Thread obj_Thread_TERMINALES = new Thread(obj_ThreadStart_TERMINALES);
obj_Thread_TERMINALES.Start();
}
else
{
g_bol_Hilos_Terminados_Obtener[2] = true;
}
//KRSS_DispositivosModelo ##########################################################################################
ThreadStart obj_ThreadStart_DISPOSITIVOMODELO = new ThreadStart(Obtener_DispositivoModelo_Modelo_Obtener);
Thread obj_Thread_DISPOSITIVOMODELO = new Thread(obj_ThreadStart_DISPOSITIVOMODELO);
obj_Thread_DISPOSITIVOMODELO.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 (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Obtener), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return g_dnm_Modelo_Obtener;
}
#region Tablas Relacionadas
private void Obtener_Empleado_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[0] = true;
}
}
private void Obtener_PausasTipo_Modelo_Obtener()
{
try
{
KRS_PausasTipos_Datos obj_KRS_PausasTipos_Datos = new KRS_PausasTipos_Datos();
g_dnm_Modelo_Obtener.KRS_PausasTipos = obj_KRS_PausasTipos_Datos.Obtener_Modelo_Por_Id(g_dnm_Modelo_Obtener.idPausaTipo, g_dnm_Modelo_Obtener.codigoCliente);
}
catch (Control_Errores)
{ }
finally
{
g_bol_Hilos_Terminados_Obtener[1] = true;
}
}
private void Obtener_Terminales_Modelo_Obtener()
{
try
{
KRS_Terminales_Datos obj_KRS_Terminales_Datos = new KRS_Terminales_Datos();
g_dnm_Modelo_Obtener.KRS_Terminales = obj_KRS_Terminales_Datos.Obtener_Modelo_Por_Id(g_dnm_Modelo_Obtener.idTerminal, g_dnm_Modelo_Obtener.codigoCliente);
}
catch (Control_Errores)
{ }
finally
{
g_bol_Hilos_Terminados_Obtener[2] = true;
}
}
private void Obtener_DispositivoModelo_Modelo_Obtener()
{
try
{
KRSS_DispositivosModelo_Datos obj_KRSS_DispositivosModelo_Datos = new KRSS_DispositivosModelo_Datos();
g_dnm_Modelo_Obtener.KRSS_DispositivosModelo = obj_KRSS_DispositivosModelo_Datos.Obtener_Modelo_Por_Id(g_dnm_Modelo_Obtener.idDispositivoModelo, g_dnm_Modelo_Obtener.codigoCliente);
}
catch (Control_Errores)
{ }
finally
{
g_bol_Hilos_Terminados_Obtener[3] = true;
}
}
#endregion
#endregion
public override dynamic Obtener_Registro_PorCampo(string _str_CampoBusqueda, string _str_Filtro)
{
throw new NotImplementedException();
}
#endregion
#region Procedimientos para VerificacionPausas ServicioWindows
public List<INTERNO_VerificacionPausas_KRSS_Pausas_Modelo> Obtener_Listado_ParaVerificacionPausas(long _lng_CodigoCliente, long _lng_idEmpleado, DateTime _dtt_FechaDesde, DateTime _dtt_FechaHasta, long _lng_idEmpresa)
{
KairosProEntities obj_KairosProEntities = null;
List<INTERNO_VerificacionPausas_KRSS_Pausas_Modelo> lst_INTERNO_VerificacionPausas_KRSS_Pausas_Modelo = null;
try
{
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
string str_SQL =
" SELECT " +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.id) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.id) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.idEmpleado) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpleado) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.codigoCliente) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.codigoCliente) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.idPausaTipo) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idPausaTipo) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.fechaHora) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.observaciones) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.observaciones) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.gps_Posicion_Latitud) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_Posicion_Latitud) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.gps_Posicion_Longitud) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_Posicion_Longitud) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.gps_FechaHora) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_FechaHora) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.gps_Proveedor) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_Proveedor) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.gps_Altitud) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.gps_Altitud) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.idTerminal) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idTerminal) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.idDispositivoModelo) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idDispositivoModelo) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.validado) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.validado) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.entradaSalida) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.entradaSalida) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.idEmpresa) + "=" + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpresa) + "," +
nameof(INTERNO_VerificacionPausas_KRSS_Pausas_Modelo.PausaTipo) + "=" + nameof(KRS_PausasTipos) + "." + nameof(KRS_PausasTipos.descripcion) +
" FROM " + nameof(KRSS_Pausas) +
" INNER JOIN " + nameof(KRS_PausasTipos) + " ON " + nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idPausaTipo) + "=" + nameof(KRS_PausasTipos) + "." + nameof(KRS_PausasTipos.id) +
" WHERE " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpleado) + "=@idEmpleado and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpresa) + "=@idEmpresa and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.codigoCliente) + "=@codigoCliente and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + ">=@fechaDesde and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + "<=@fechaHasta and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.anulado) + " IS null ";
//Parametros
object[] arr_Parametros = new object[]
{
new SqlParameter("@idEmpleado", _lng_idEmpleado),
new SqlParameter("@idEmpresa", _lng_idEmpresa),
new SqlParameter("@codigoCliente", _lng_CodigoCliente),
new SqlParameter("@fechaDesde", _dtt_FechaDesde),
new SqlParameter("@fechaHasta", _dtt_FechaHasta),
};
//Rellenar el Modelo
lst_INTERNO_VerificacionPausas_KRSS_Pausas_Modelo = obj_KairosProEntities.Database.SqlQuery<INTERNO_VerificacionPausas_KRSS_Pausas_Modelo>(str_SQL, arr_Parametros).ToList();
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Obtener_Listado_ParaVerificacionPausas), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return lst_INTERNO_VerificacionPausas_KRSS_Pausas_Modelo;
}
#endregion
#region MODELOS
#region Modelo Simple
private KRSS_Pausas g_mdl_KRSS_Pausas = null;
public KRSS_Pausas Obtener_Modelo_Por_Id(long _lng_id,
long _lng_CodigoCliente,
bool _bol_Cargar_DispositivoModelo,
bool _bol_Cargar_PausasFotos)
{
try
{
string str_SQL = Obtener_Consulta_Modelo() +
//WHERE
" WHERE " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.id) + "=@id and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.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,
_bol_Cargar_DispositivoModelo,
_bol_Cargar_PausasFotos);
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Obtener_Modelo_Por_Id), true);
}
return g_mdl_KRSS_Pausas;
}
#region Ejercutar Consulta Modelo
private static int g_int_TotalHilos_Modelo = 2;
private bool[] g_bol_Hilos_Terminados_Modelo = new bool[g_int_TotalHilos_Modelo];
private void Ejecutar_Consulta_Modelo(string _str_SQL,
object[] _arr_Parametros,
bool _bol_Cargar_DispositivoModelo,
bool _bol_Cargar_PausasFotos)
{
KairosProEntities obj_KairosProEntities = null;
try
{
//Conexion
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
//Rellenar el Modelo
g_mdl_KRSS_Pausas = obj_KairosProEntities.Database.SqlQuery<KRSS_Pausas>(_str_SQL, _arr_Parametros).FirstOrDefault();
#region Rellenar Tablas Relacionadas
if (g_mdl_KRSS_Pausas != null)
{
//reiniciar Valores de los hilos
for (int int_Contador = 0; int_Contador < g_int_TotalHilos_Modelo; int_Contador++)
{
g_bol_Hilos_Terminados_Modelo[int_Contador] = false;
}
//KRSS_DispositivosModelo ##########################################################################################
if (_bol_Cargar_DispositivoModelo)
{
ThreadStart obj_ThreadStart_DISPOSITIVOMODELO = new ThreadStart(Obtener_DispositivosModelo_Modelo);
Thread obj_Thread_DISPOSITIVOMODELO = new Thread(obj_ThreadStart_DISPOSITIVOMODELO);
obj_Thread_DISPOSITIVOMODELO.Start();
}
else
{
g_bol_Hilos_Terminados_Modelo[0] = true;
}
//KRSS_PausasFotos ##########################################################################################
if (_bol_Cargar_PausasFotos)
{
ThreadStart obj_ThreadStart_PausasFOTOS = new ThreadStart(Obtener_PausasFotos_Modelo);
Thread obj_Thread_PausasFOTOS = new Thread(obj_ThreadStart_PausasFOTOS);
obj_Thread_PausasFOTOS.Start();
}
else
{
g_bol_Hilos_Terminados_Modelo[1] = 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)
{
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(KRSS_Pausas_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
}
#region Tablas Relacionadas
private void Obtener_DispositivosModelo_Modelo()
{
try
{
KRSS_DispositivosModelo_Datos obj_KRSS_DispositivosModelo_Datos = new KRSS_DispositivosModelo_Datos();
g_mdl_KRSS_Pausas.KRSS_DispositivosModelo = obj_KRSS_DispositivosModelo_Datos.Obtener_Modelo_Por_Id(g_mdl_KRSS_Pausas.idDispositivoModelo, g_mdl_KRSS_Pausas.codigoCliente);
}
catch (Control_Errores)
{ }
finally
{
g_bol_Hilos_Terminados_Modelo[0] = true;
}
}
private void Obtener_PausasFotos_Modelo()
{
try
{
KRSS_PausasFotos_Datos obj_KRSS_PausasFotos_Datos = new KRSS_PausasFotos_Datos();
g_mdl_KRSS_Pausas.KRSS_PausasFotos = obj_KRSS_PausasFotos_Datos.Obtener_ModeloListado_Por_Pausa(g_mdl_KRSS_Pausas.id);
}
catch (Control_Errores)
{ }
finally
{
g_bol_Hilos_Terminados_Modelo[1] = true;
}
}
#endregion
#endregion
#endregion
#region Modelo Listado
private List<KRSS_Pausas> g_lst_KRSS_Pausas = null;
public List<KRSS_Pausas> 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(KRSS_Pausas),
nameof(KRSS_Pausas.id),
G_ENUM_FORMARCONTENIDOIN_CONDICIONANTES.NADA,
_lst_Ids);
//Consulta
string str_SQL = Obtener_Consulta_Modelo() +
//WHERE
" WHERE " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.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,
false,
true);
}
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Obtener_ModeloListado_Por_Ids), true);
}
return g_lst_KRSS_Pausas;
}
public List<KRSS_Pausas> Obtener_ModeloListado_Por_EmpleadosFechaEmpresa(List<long> _lst_IdEmpleados, DateTime dtt_Fecha_Inicio, DateTime dtt_Fecha_Fin, long _lng_idEmpresa)
{
try
{
if (_lst_IdEmpleados != null && _lst_IdEmpleados.Count > 0)
{
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
string str_Filtros_IDS = Funciones.Formar_ContenidoIN_ParaConsultaWhere(nameof(KRSS_Pausas),
nameof(KRSS_Pausas.idEmpleado),
G_ENUM_FORMARCONTENIDOIN_CONDICIONANTES.NADA,
_lst_IdEmpleados);
//Consulta
string str_SQL = Obtener_Consulta_Modelo() +
//WHERE
" WHERE " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpresa) + "=@idEmpresa and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.codigoCliente) + "=@codigoCliente and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + ">=@Fecha_Desde and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + "<=@Fecha_Hasta and " +
str_Filtros_IDS;
//Parametros
lst_Parametros.Add(new SqlParameter("@idEmpresa", _lng_idEmpresa));
lst_Parametros.Add(new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO));
lst_Parametros.Add(new SqlParameter("@Fecha_Desde", dtt_Fecha_Inicio));
lst_Parametros.Add(new SqlParameter("@Fecha_Hasta", dtt_Fecha_Fin));
object[] arr_Parametros = lst_Parametros.ToArray();
//Ejecutar y rellenar el listado
Ejecutar_Consulta_Modelo_Listado(str_SQL,
arr_Parametros,
true,
true);
}
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Obtener_ModeloListado_Por_EmpleadosFechaEmpresa), true);
}
return g_lst_KRSS_Pausas;
}
public List<KRSS_Pausas> Obtener_ModeloListado_Por_EmpleadoFechaEmpresa(long _lng_IdEmpleado, DateTime _dtt_Fecha_Desde, DateTime _dtt_Fecha_Hasta, long _lng_idEmpresa)
{
try
{
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
//Consulta
string str_SQL = Obtener_Consulta_Modelo() +
//WHERE
" WHERE " +
(_lng_IdEmpleado > -1 ? nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpleado) + "=@idEmpleado and " : " " ) +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpresa) + "=@idEmpresa and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.codigoCliente) + "=@codigoCliente and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + ">@Fecha_Desde and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + "<@Fecha_Hasta ";
//Parametros
lst_Parametros.Add(new SqlParameter("@idEmpleado", _lng_IdEmpleado));
lst_Parametros.Add(new SqlParameter("@idEmpresa", _lng_idEmpresa));
lst_Parametros.Add(new SqlParameter("@codigoCliente", Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO));
lst_Parametros.Add(new SqlParameter("@Fecha_Desde", _dtt_Fecha_Desde));
lst_Parametros.Add(new SqlParameter("@Fecha_Hasta", _dtt_Fecha_Hasta));
object[] arr_Parametros = lst_Parametros.ToArray();
//Ejecutar y rellenar el listado
Ejecutar_Consulta_Modelo_Listado(str_SQL,
arr_Parametros,
false,
true);
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Obtener_ModeloListado_Por_EmpleadoFechaEmpresa), true);
}
return g_lst_KRSS_Pausas;
}
public List<KRSS_Pausas> Obtener_ModeloListado_Por_CodigoClienteEmpleadoFechaEmpresa(long _lng_CodigoCliente,long _lng_IdEmpleado, DateTime _dtt_Fecha_Desde, DateTime _dtt_Fecha_Hasta, long _lng_idEmpresa)
{
try
{
List<SqlParameter> lst_Parametros = new List<SqlParameter>();
//Consulta
string str_SQL = Obtener_Consulta_Modelo() +
//WHERE
" WHERE " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpleado) + "=@idEmpleado and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.idEmpresa) + "=@idEmpresa and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.codigoCliente) + "=@codigoCliente and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + ">=@Fecha_Desde and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.fechaHora) + "<=@Fecha_Hasta and " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.anulado) + " is null " +
" ORDER BY " +
nameof(KRSS_Pausas) + "." + nameof(KRSS_Pausas.id) + " ASC ";
//Parametros
lst_Parametros.Add(new SqlParameter("@idEmpleado", _lng_IdEmpleado));
lst_Parametros.Add(new SqlParameter("@idEmpresa", _lng_idEmpresa));
lst_Parametros.Add(new SqlParameter("@codigoCliente", _lng_CodigoCliente));
lst_Parametros.Add(new SqlParameter("@Fecha_Desde", _dtt_Fecha_Desde));
lst_Parametros.Add(new SqlParameter("@Fecha_Hasta", _dtt_Fecha_Hasta));
object[] arr_Parametros = lst_Parametros.ToArray();
//Ejecutar y rellenar el listado
Ejecutar_Consulta_Modelo_Listado(str_SQL,
arr_Parametros,
true,
true);
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Obtener_ModeloListado_Por_CodigoClienteEmpleadoFechaEmpresa), true);
}
return g_lst_KRSS_Pausas;
}
#region Ejecutar Consulta
//Listado de modelos Relacionados
private List<KRSS_DispositivosModelo> g_lst_KRSS_DispositivosModelo = null;
private List<KRS_PausasTipos> g_lst_KRS_PausasTipos = null;
//Hilos
private static int g_int_TotalHilos_Modelo_Listado = 2;
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_DispositivoModelo,
bool _bol_Cargar_PausasTipo)
{
KairosProEntities obj_KairosProEntities = null;
try
{
//Conexion
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
//Rellenar el modelo
g_lst_KRSS_Pausas = obj_KairosProEntities.Database.SqlQuery<KRSS_Pausas>(_str_SQL, _arr_Parametros).ToList();
#region Rellenar tablas Relacionadas
if (g_lst_KRSS_Pausas != null && g_lst_KRSS_Pausas.Count > 0)
{
//Si tiene que buscar alguna tabla relacionada
if (_bol_Cargar_DispositivoModelo ||
_bol_Cargar_PausasTipo)
{
#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;
}
//KRSS_DispositivosModelo #############################################
if (_bol_Cargar_DispositivoModelo)
{
ThreadStart obj_ThreadStart_DISPOSITIVOMODELO = new ThreadStart(Obtener_DispositivoModelo_Modelo_Listado);
Thread obj_Thread_DISPOSITIVOMODELO = new Thread(obj_ThreadStart_DISPOSITIVOMODELO);
obj_Thread_DISPOSITIVOMODELO.Start();
}
else
{
g_bol_Hilos_Terminados_Modelo_Listado[0] = true;
}
//KRS_PausasTipos #############################################
if (_bol_Cargar_PausasTipo)
{
ThreadStart obj_ThreadStart_PAUSASTIPO = new ThreadStart(Obtener_PausasTipo_Modelo_Listado);
Thread obj_Thread_PAUSASTIPO = new Thread(obj_ThreadStart_PAUSASTIPO);
obj_Thread_PAUSASTIPO.Start();
}
else
{
g_bol_Hilos_Terminados_Modelo_Listado[1] = 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 (KRSS_Pausas mdl_KRSS_Pausas in g_lst_KRSS_Pausas)
{
//KRSS_DispositivosModelo #############################################
if (_bol_Cargar_DispositivoModelo &&
g_lst_KRSS_DispositivosModelo != null &&
g_lst_KRSS_DispositivosModelo.Count > 0)
{
mdl_KRSS_Pausas.KRSS_DispositivosModelo = g_lst_KRSS_DispositivosModelo.Where(m => m.id == mdl_KRSS_Pausas.idDispositivoModelo).FirstOrDefault();
}
//KRS_PausasTipos #############################################
if (_bol_Cargar_PausasTipo &&
g_lst_KRS_PausasTipos != null &&
g_lst_KRS_PausasTipos.Count > 0)
{
mdl_KRSS_Pausas.KRS_PausasTipos = g_lst_KRS_PausasTipos.Where(m => m.id == mdl_KRSS_Pausas.idPausaTipo).FirstOrDefault();
}
}
#endregion
}
}
#endregion
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Ejecutar_Consulta_Modelo_Listado), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
}
#region Tablas Relacionadas
private void Obtener_DispositivoModelo_Modelo_Listado()
{
try
{
KRSS_DispositivosModelo_Datos obj_KRSS_DispositivosModelo_Datos = new KRSS_DispositivosModelo_Datos();
g_lst_KRSS_DispositivosModelo = obj_KRSS_DispositivosModelo_Datos.Obtener_ModeloListado_Por_Ids(g_lst_KRSS_Pausas.Select(m => m.idDispositivoModelo).ToList());
}
catch (Control_Errores)
{ }
finally
{
g_bol_Hilos_Terminados_Modelo_Listado[0] = true;
}
}
private void Obtener_PausasTipo_Modelo_Listado()
{
try
{
KRS_PausasTipos_Datos obj_KRS_PausasTipos_Datos = new KRS_PausasTipos_Datos();
g_lst_KRS_PausasTipos = obj_KRS_PausasTipos_Datos.Obtener_ModeloListado_Por_Ids(g_lst_KRSS_Pausas.Select(m => m.idPausaTipo).ToList());
}
catch (Control_Errores)
{ }
finally
{
g_bol_Hilos_Terminados_Modelo_Listado[1] = true;
}
}
#endregion
#endregion
#endregion
private string Obtener_Consulta_Modelo()
{
return
" SELECT " +
nameof(KRSS_Pausas.id) + " , " +
nameof(KRSS_Pausas.idEmpleado) + " , " +
nameof(KRSS_Pausas.codigoCliente) + " , " +
nameof(KRSS_Pausas.idPausaTipo) + " , " +
nameof(KRSS_Pausas.fechaHora) + " , " +
nameof(KRSS_Pausas.observaciones) + " , " +
nameof(KRSS_Pausas.gps_Posicion_Latitud) + " , " +
nameof(KRSS_Pausas.gps_Posicion_Longitud) + " , " +
nameof(KRSS_Pausas.gps_FechaHora) + " , " +
nameof(KRSS_Pausas.gps_Proveedor) + " , " +
nameof(KRSS_Pausas.gps_Altitud) + " , " +
nameof(KRSS_Pausas.idTerminal) + " , " +
nameof(KRSS_Pausas.idDispositivoModelo) + " , " +
nameof(KRSS_Pausas.modificado) + " , " +
nameof(KRSS_Pausas.anulado) + " , " +
nameof(KRSS_Pausas.validado) + " , " +
nameof(KRSS_Pausas.tipoDispositivo) + " , " +
nameof(KRSS_Pausas.entradaSalida) + " , " +
nameof(KRSS_Pausas.idEmpresa) +
" FROM " + nameof(KRSS_Pausas);
}
#endregion
#region Grabar, Anular Fichaje, DesAnularFichaje
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;
KRSS_Pausas mdl_KRSS_Pausas_AGrabar = (KRSS_Pausas)_mdl_obj;
KRSS_Pausas mdl_KRSS_Pausas_DatosViejos = new KRSS_Pausas();
KRSS_Pausas mdl_KRSS_Pausas_Final = Obtener_Modelo_Por_Id(mdl_KRSS_Pausas_AGrabar.id, Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO,false,false);
if (mdl_KRSS_Pausas_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_KRSS_Pausas_AGrabar.codigoCliente = Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO;
//Datos viejos para la trazabilidar
Funciones.CopiarPropiedadesObjetos(mdl_KRSS_Pausas_Final, mdl_KRSS_Pausas_DatosViejos, false, false);
//Cargar los Datos del modelo
Funciones.CopiarPropiedadesObjetos(mdl_KRSS_Pausas_AGrabar, mdl_KRSS_Pausas_Final, false, false);
#region Update
string str_SQL_Update = " UPDATE " + nameof(KRSS_Pausas) +
" SET " +
nameof(KRSS_Pausas.idEmpleado) + "=@idEmpleado," +
nameof(KRSS_Pausas.codigoCliente) + "=@codigoCliente," +
nameof(KRSS_Pausas.idPausaTipo) + "=@idPausaTipo," +
nameof(KRSS_Pausas.fechaHora) + "=@fechaHora," +
nameof(KRSS_Pausas.observaciones) + "=@observaciones," +
nameof(KRSS_Pausas.gps_Posicion_Latitud) + "=@gps_Posicion_Latitud," +
nameof(KRSS_Pausas.gps_Posicion_Longitud) + "=@gps_Posicion_Longitud," +
nameof(KRSS_Pausas.gps_FechaHora) + "=@gps_FechaHora," +
nameof(KRSS_Pausas.gps_Proveedor) + "=@gps_Proveedor," +
nameof(KRSS_Pausas.gps_Altitud) + "=@gps_Altitud," +
nameof(KRSS_Pausas.idTerminal) + "=@idTerminal," +
nameof(KRSS_Pausas.idDispositivoModelo) + "=@idDispositivoModelo," +
nameof(KRSS_Pausas.modificado) + "=@modificado," +
nameof(KRSS_Pausas.anulado) + "=@anulado," +
nameof(KRSS_Pausas.validado) + "=@validado," +
nameof(KRSS_Pausas.tipoDispositivo) + "=@tipoDispositivo," +
nameof(KRSS_Pausas.entradaSalida) + "=@entradaSalida," +
nameof(KRSS_Pausas.idEmpresa) + "=@idEmpresa " +
" WHERE " +
nameof(KRSS_Pausas.id) + "=@id";
//Parametros
object[] arr_Parametros_Update = new object[]
{
new SqlParameter("@idEmpleado", mdl_KRSS_Pausas_Final.idEmpleado),
new SqlParameter("@codigoCliente", mdl_KRSS_Pausas_Final.codigoCliente),
new SqlParameter("@idPausaTipo", mdl_KRSS_Pausas_Final.idPausaTipo),
new SqlParameter("@fechaHora", mdl_KRSS_Pausas_Final.fechaHora),
mdl_KRSS_Pausas_Final.observaciones != null
? new SqlParameter("@observaciones", mdl_KRSS_Pausas_Final.observaciones)
: new SqlParameter("@observaciones", DBNull.Value),
new SqlParameter("@gps_Posicion_Latitud", mdl_KRSS_Pausas_Final.gps_Posicion_Latitud),
new SqlParameter("@gps_Posicion_Longitud", mdl_KRSS_Pausas_Final.gps_Posicion_Longitud),
mdl_KRSS_Pausas_Final.gps_FechaHora != null
? new SqlParameter("@gps_FechaHora", mdl_KRSS_Pausas_Final.gps_FechaHora.Value)
: new SqlParameter("@gps_FechaHora", DBNull.Value),
new SqlParameter("@gps_Proveedor", mdl_KRSS_Pausas_Final.gps_Proveedor),
mdl_KRSS_Pausas_Final.gps_Altitud != null
? new SqlParameter("@gps_Altitud", mdl_KRSS_Pausas_Final.gps_Altitud)
: new SqlParameter("@gps_Altitud", DBNull.Value),
mdl_KRSS_Pausas_Final.idTerminal != null
? new SqlParameter("@idTerminal", mdl_KRSS_Pausas_Final.idTerminal)
: new SqlParameter("@idTerminal", DBNull.Value),
new SqlParameter("@idDispositivoModelo", mdl_KRSS_Pausas_Final.idDispositivoModelo),
mdl_KRSS_Pausas_Final.modificado != null
? new SqlParameter("@modificado", mdl_KRSS_Pausas_Final.modificado.Value)
: new SqlParameter("@modificado", DBNull.Value),
mdl_KRSS_Pausas_Final.anulado != null
? new SqlParameter("@anulado", mdl_KRSS_Pausas_Final.anulado.Value)
: new SqlParameter("@anulado", DBNull.Value),
mdl_KRSS_Pausas_Final.validado != null
? new SqlParameter("@validado", mdl_KRSS_Pausas_Final.validado.Value)
: new SqlParameter("@validado", DBNull.Value),
mdl_KRSS_Pausas_Final.tipoDispositivo != null
? new SqlParameter("@tipoDispositivo", mdl_KRSS_Pausas_Final.tipoDispositivo.Value)
: new SqlParameter("@tipoDispositivo", DBNull.Value),
new SqlParameter("@entradaSalida", mdl_KRSS_Pausas_Final.entradaSalida),
mdl_KRSS_Pausas_Final.idEmpresa != null
? new SqlParameter("@idEmpresa", mdl_KRSS_Pausas_Final.idEmpresa.Value)
: new SqlParameter("@idEmpresa", DBNull.Value),
new SqlParameter("@id", mdl_KRSS_Pausas_Final.id),
};
#endregion
//Update
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update);
//Id de la tabla
mdl_INTERNO_ValorDevuelto_Modelo.Id = mdl_KRSS_Pausas_Final.id;
}
else
{
mdl_KRSS_Pausas_Final = new KRSS_Pausas();
//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_KRSS_Pausas_AGrabar.codigoCliente = Variables.G_LNG_IDCLIENTE_LICENCIAVALIDADO;
//Cargar los Datos del modelo
Funciones.CopiarPropiedadesObjetos(mdl_KRSS_Pausas_AGrabar, mdl_KRSS_Pausas_Final, false, false);
#region INSERT
string str_SQL_Insert = " INSERT INTO " + nameof(KRSS_Pausas) +
" (" +
nameof(KRSS_Pausas.idEmpleado) + "," +
nameof(KRSS_Pausas.codigoCliente) + "," +
nameof(KRSS_Pausas.idPausaTipo) + "," +
nameof(KRSS_Pausas.fechaHora) + "," +
nameof(KRSS_Pausas.observaciones) + "," +
nameof(KRSS_Pausas.gps_Posicion_Latitud) + "," +
nameof(KRSS_Pausas.gps_Posicion_Longitud) + "," +
nameof(KRSS_Pausas.gps_FechaHora) + "," +
nameof(KRSS_Pausas.gps_Proveedor) + "," +
nameof(KRSS_Pausas.gps_Altitud) + "," +
nameof(KRSS_Pausas.idTerminal) + "," +
nameof(KRSS_Pausas.idDispositivoModelo) + "," +
nameof(KRSS_Pausas.modificado) + "," +
nameof(KRSS_Pausas.anulado) + "," +
nameof(KRSS_Pausas.validado) + "," +
nameof(KRSS_Pausas.tipoDispositivo) + "," +
nameof(KRSS_Pausas.entradaSalida) + "," +
nameof(KRSS_Pausas.idEmpresa) +
" ) " +
" OUTPUT INSERTED." + nameof(KRSS_Pausas.id) +
" VALUES " +
" ( " +
"@idEmpleado," +
"@codigoCliente," +
"@idPausaTipo," +
"@fechaHora," +
"@observaciones," +
"@gps_Posicion_Latitud," +
"@gps_Posicion_Longitud," +
"@gps_FechaHora," +
"@gps_Proveedor," +
"@gps_Altitud," +
"@idTerminal," +
"@idDispositivoModelo," +
"@modificado," +
"@anulado," +
"@validado," +
"@tipoDispositivo," +
"@entradaSalida," +
"@idEmpresa" +
" ) ";
//Parametros
object[] arr_Parametros_Insert = new object[]
{
new SqlParameter("@idEmpleado", mdl_KRSS_Pausas_Final.idEmpleado),
new SqlParameter("@codigoCliente", mdl_KRSS_Pausas_Final.codigoCliente),
new SqlParameter("@idPausaTipo", mdl_KRSS_Pausas_Final.idPausaTipo),
new SqlParameter("@fechaHora", mdl_KRSS_Pausas_Final.fechaHora),
mdl_KRSS_Pausas_Final.observaciones != null
? new SqlParameter("@observaciones", mdl_KRSS_Pausas_Final.observaciones)
: new SqlParameter("@observaciones", DBNull.Value),
new SqlParameter("@gps_Posicion_Latitud", mdl_KRSS_Pausas_Final.gps_Posicion_Latitud),
new SqlParameter("@gps_Posicion_Longitud", mdl_KRSS_Pausas_Final.gps_Posicion_Longitud),
mdl_KRSS_Pausas_Final.gps_FechaHora != null
? new SqlParameter("@gps_FechaHora", mdl_KRSS_Pausas_Final.gps_FechaHora.Value)
: new SqlParameter("@gps_FechaHora", DBNull.Value),
new SqlParameter("@gps_Proveedor", mdl_KRSS_Pausas_Final.gps_Proveedor),
mdl_KRSS_Pausas_Final.gps_Altitud != null
? new SqlParameter("@gps_Altitud", mdl_KRSS_Pausas_Final.gps_Altitud)
: new SqlParameter("@gps_Altitud", DBNull.Value),
mdl_KRSS_Pausas_Final.idTerminal != null
? new SqlParameter("@idTerminal", mdl_KRSS_Pausas_Final.idTerminal)
: new SqlParameter("@idTerminal", DBNull.Value),
new SqlParameter("@idDispositivoModelo", mdl_KRSS_Pausas_Final.idDispositivoModelo),
mdl_KRSS_Pausas_Final.modificado != null
? new SqlParameter("@modificado", mdl_KRSS_Pausas_Final.modificado.Value)
: new SqlParameter("@modificado", DBNull.Value),
mdl_KRSS_Pausas_Final.anulado != null
? new SqlParameter("@anulado", mdl_KRSS_Pausas_Final.anulado.Value)
: new SqlParameter("@anulado", DBNull.Value),
mdl_KRSS_Pausas_Final.validado != null
? new SqlParameter("@validado", mdl_KRSS_Pausas_Final.validado.Value)
: new SqlParameter("@validado", DBNull.Value),
mdl_KRSS_Pausas_Final.tipoDispositivo != null
? new SqlParameter("@tipoDispositivo", mdl_KRSS_Pausas_Final.tipoDispositivo.Value)
: new SqlParameter("@tipoDispositivo", DBNull.Value),
new SqlParameter("@entradaSalida", mdl_KRSS_Pausas_Final.entradaSalida),
mdl_KRSS_Pausas_Final.idEmpresa != null
? new SqlParameter("@idEmpresa", mdl_KRSS_Pausas_Final.idEmpresa.Value)
: new SqlParameter("@idEmpresa", 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(KRSS_Pausas), mdl_KRSS_Pausas_DatosViejos, mdl_KRSS_Pausas_Final, mdl_INTERNO_ValorDevuelto_Modelo.TipoAccion, obj_KairosProEntities);
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Grabar), true);
}
finally
{
//Finalizar transaccion
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return mdl_INTERNO_ValorDevuelto_Modelo;
}
public INTERNO_ValorDevuelto_Modelo Anular_Pausa(long _lng_id, DateTime _dtt_Hoy)
{
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(KRSS_Pausas) +
" SET " +
nameof(KRSS_Pausas.anulado) + "=@fechaanulado, " +
nameof(KRSS_Pausas.modificado) + "=@fechamodificado " +
" WHERE " +
nameof(KRSS_Pausas.id) + "=@id and " +
nameof(KRSS_Pausas.codigoCliente) + "=@codigoCliente ";
//Parametros
object[] arr_Parametros_Update = new object[]
{
new SqlParameter("@fechaanulado", _dtt_Hoy),
new SqlParameter("@fechamodificado", _dtt_Hoy),
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);
//Devolver tambien el objeto
mdl_INTERNO_ValorDevuelto_Modelo.Id = _lng_id;
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Anular_Pausa), true);
}
finally
{
//Finalizar transaccion
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return mdl_INTERNO_ValorDevuelto_Modelo;
}
public INTERNO_ValorDevuelto_Modelo DesAnular_Pausa(long _lng_id,DateTime _dtt_Hoy)
{
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(KRSS_Pausas) +
" SET " +
nameof(KRSS_Pausas.anulado) + "=@fechaanulado, " +
nameof(KRSS_Pausas.modificado) + "=@fechamodificado " +
" WHERE " +
nameof(KRSS_Pausas.id) + "=@id and " +
nameof(KRSS_Pausas.codigoCliente) + "=@codigoCliente ";
//Parametros
object[] arr_Parametros_Update = new object[]
{
new SqlParameter("@fechaanulado", DBNull.Value),
new SqlParameter("@fechamodificado", _dtt_Hoy),
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);
//Devolver tambien el objeto
mdl_INTERNO_ValorDevuelto_Modelo.Id = _lng_id;
}
catch (Control_Errores)
{
throw;
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(DesAnular_Pausa), true);
}
finally
{
//Finalizar transaccion
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
return mdl_INTERNO_ValorDevuelto_Modelo;
}
public void Actualizar_ParaVerificacionPausas(long _lng_idPausa, int _int_Validado, long _lng_CodigoCliente)
{
KairosProEntities obj_KairosProEntities = null;
try
{
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
obj_KairosProEntities = new KairosProEntities();
obj_KairosProEntities.Configuration.LazyLoadingEnabled = false;
#region Update
string str_SQL_Update = " UPDATE " + nameof(KRSS_Pausas) +
" SET " +
nameof(KRSS_Pausas.validado) + "=@validado " +
" WHERE " +
nameof(KRSS_Pausas.id) + "=@id and " +
nameof(KRSS_Pausas.codigoCliente) + "=@codigoCliente ";
//Parametros
object[] arr_Parametros_Update = new object[]
{
new SqlParameter("@validado", _int_Validado),
new SqlParameter("@id", _lng_idPausa),
new SqlParameter("@codigoCliente", _lng_CodigoCliente)
};
#endregion
//Update
obj_KairosProEntities.Database.ExecuteSqlCommand(str_SQL_Update, arr_Parametros_Update);
}
catch (Exception ex)
{
throw new Control_Errores("", ex, nameof(KRSS_Pausas_Datos) + "/" + nameof(Actualizar_ParaVerificacionPausas), true);
}
finally
{
obj_KairosProEntities.Database.Connection.Close();
obj_KairosProEntities.Dispose();
}
}
#endregion
#region Borrar
public override INTERNO_ValorDevuelto_Modelo Borrar(long _lng_id)
{
throw new NotImplementedException();
}
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();
}
#endregion
}
}