1401 lines
73 KiB
C#
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
|
|
}
|
|
}
|