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 Obtener_Listado(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { return null; } public override dynamic Obtener_RegistroListado(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo, long _lng_id, List _lst_id) { return null; } protected override void ConsultaRellenar_Listado(KairosProEntities _dbcontext, List _lst_CamposConRelacionABuscar, long _lng_id, List _lst_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { } #endregion #region Listado Secundario private List g_lst_INTERNO_KRSS_Pausas_Listado_Modelo_SECUNDARIO = null; public override List Obtener_Listado_Secundario(List _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { KairosProEntities obj_KairosProEntities = null; List lst_KRS = null; try { obj_KairosProEntities = new KairosProEntities(); obj_KairosProEntities.Configuration.LazyLoadingEnabled = false; //Consulta................................................................. ConsultaRellenar_Listado_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().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 _lst_CamposConRelacionABuscar, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo, long _lng_id, List _lst_id) { KairosProEntities obj_KairosProEntities = null; dynamic dnm_KRS = null; try { obj_KairosProEntities = new KairosProEntities(); obj_KairosProEntities.Configuration.LazyLoadingEnabled = false; //Consulta ...................................................... ConsultaRellenar_Listado_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().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 _lst_CamposConRelacionABuscar, long _lng_id, List _lst_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _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(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 _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { throw new NotImplementedException(); } public override dynamic Obtener_F3_PorId(long _lng_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { throw new NotImplementedException(); } protected override void ConsultaRellenar_F3(KairosProEntities _dbcontext, string _str_CampoBusqueda, string _str_Filtro, long _lng_id, List _lst_INTERNO_Filtro_OpcionPadre_Modelo, List _lst_INTERNO_Filtro_Modelo) { } #endregion #region Obtener #region Obtener Simple private dynamic g_dnm_Modelo_Obtener = null; private static int g_int_TotalHilos_Obtener = 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(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 Obtener_Listado_ParaVerificacionPausas(long _lng_CodigoCliente, long _lng_idEmpleado, DateTime _dtt_FechaDesde, DateTime _dtt_FechaHasta, long _lng_idEmpresa) { KairosProEntities obj_KairosProEntities = null; List 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(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(_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 g_lst_KRSS_Pausas = null; public List Obtener_ModeloListado_Por_Ids(List _lst_Ids) { try { if (_lst_Ids != null && _lst_Ids.Count > 0) { List lst_Parametros = new List(); string str_Filtros_IDS = Funciones.Formar_ContenidoIN_ParaConsultaWhere(nameof(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 Obtener_ModeloListado_Por_EmpleadosFechaEmpresa(List _lst_IdEmpleados, DateTime dtt_Fecha_Inicio, DateTime dtt_Fecha_Fin, long _lng_idEmpresa) { try { if (_lst_IdEmpleados != null && _lst_IdEmpleados.Count > 0) { List lst_Parametros = new List(); 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 Obtener_ModeloListado_Por_EmpleadoFechaEmpresa(long _lng_IdEmpleado, DateTime _dtt_Fecha_Desde, DateTime _dtt_Fecha_Hasta, long _lng_idEmpresa) { try { List lst_Parametros = new List(); //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 Obtener_ModeloListado_Por_CodigoClienteEmpleadoFechaEmpresa(long _lng_CodigoCliente,long _lng_IdEmpleado, DateTime _dtt_Fecha_Desde, DateTime _dtt_Fecha_Hasta, long _lng_idEmpresa) { try { List lst_Parametros = new List(); //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 g_lst_KRSS_DispositivosModelo = null; private List 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(_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(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 } }