/// <summary> /// Crea y obtiene los Mantenimientos Equipos Aliados Idealease. Crea un nuevo diccionario de datos para los Mantenimientos /// Equipos Aliados. /// </summary> /// <param name="seleccionado">Filtro de Mantenimiento Unidad Idealease.</param> private void LlenarEquiposAliados(MantenimientoUnidadBO seleccionado) { List <EquipoAliadoBO> equiposAliados = new SDNI.Equipos.BR.UnidadBR().ConsultarEquipoAliado(dataContext, seleccionado.IngresoUnidad.Unidad); List <MantenimientoEquipoAliadoBO> mantenimientosEquiposAliados = new MantenimientoUnidadBR().ConsultarMantenimientosEquiposAliados(dataContext, seleccionado).MantenimientoEquiposAliados; DataSet mantenimientosEquipoAliado = new DataSet(); DataTable mantenimientoEquipoAliado = new DataTable(); mantenimientoEquipoAliado.Columns.Add("NumeroEconomico"); mantenimientoEquipoAliado.Columns.Add("Modelo"); mantenimientoEquipoAliado.Columns.Add("Kilometraje"); mantenimientoEquipoAliado.Columns.Add("Horometro"); mantenimientoEquipoAliado.Columns.Add("Cliente"); mantenimientoEquipoAliado.Columns.Add("TipoMantenimiento"); if (equiposAliados != null && equiposAliados.Count > 0) { foreach (EquipoAliadoBO equipoAliado in equiposAliados) { DataRow row = mantenimientoEquipoAliado.NewRow(); mantenimientoEquipoAliado.Rows.Add(getEquipoAliadoToDataRow(row, equipoAliado, mantenimientosEquiposAliados, seleccionado)); } } if (mantenimientoEquipoAliado.Rows.Count == 0) { DataRow row = mantenimientoEquipoAliado.NewRow(); } mantenimientosEquipoAliado.Tables.Add(mantenimientoEquipoAliado); vista.EquiposAliadosMantenimiento = mantenimientosEquipoAliado; vista.MantenimientoToHash = getMantenimientoUnidadToHash(seleccionado); }
/// <summary> /// Realiza la carga de la información a desplegar antes de enviar el Correo. Consulta los Contactos Clientes /// de la Unidad Idealease Seleccionada con la Sucursal de la Unidad. /// </summary> public void CargarDatosMensaje() { try { ctrlMantenimiento = new MantenimientoUnidadBR(); CargarMensaje(); CargarDatosUnidad(); CargarDatosContactoCliente(); } catch (Exception e) { vista.MostrarMensaje("Error al obtener la información para el envío de Correo de Servicio Realizado.", ETipoMensajeIU.ERROR, e.Message); } }
/// <summary> /// Constructor predeterminado para el presentador. /// </summary> /// <param name="vista">Vista que será gestionada por el presentador.</param> public DetalleMantenimientoPRE(IDetalleMantenimientoVIS vista) { try{ this.vista = vista; ctrlMantenimientoUnidad = new MantenimientoUnidadBR(); ctrlMantenimientoEquipoAliado = new MantenimientoEquipoAliadoBR(); dataContext = FacadeBR.ObtenerConexion(); }catch (Exception ex) { this.vista.MostrarMensaje("No se pudieron obtener los datos de conexión", ETipoMensajeIU.ERROR, "No se encontraron los parámetros de conexión en la fuente de datos, póngase en contacto con el administrador del sistema."); } }
/// <summary> /// Inicializa los controladores y vista /// </summary> /// <param name="vista"></param> public RealizarAuditoriaMantenimientoPRE(IRealizarAuditoriaMantenimientoVIS vista) { try { this.vista = vista; this.ctrMantenimientoUnidad = new MantenimientoUnidadBR(); this.ctrMantenimientoEquipoAliado = new MantenimientoEquipoAliadoBR(); this.ctrAuditoriaMantenimiento = new AuditoriaMantenimientoBR(); this.ctrConfiguracionAuditoria = new ConfiguracionAuditoriaMantenimientoBR(); this.dataContext = FacadeBR.ObtenerConexion(); } catch (Exception ex) { this.vista.MostrarMensaje("No se pudieron obtener los datos de conexion", ETipoMensajeIU.ERROR, "No se encontraron los parametros de conexion en la fuente de datos, póngase en contacto con el administrador del sistema. " + ex.ToString()); } }
/// <summary> /// Presenta el detalle de una Cita de Mantenimiento Seleccionada /// </summary> /// <param name="id">Identificador de la cita o el mantenimiento programado</param> /// <param name="esCita">Determina si el ID es para una Cita de Mantenimiento</param> public void PresentarDetalles(int id, bool esCita) { if (this.vista.CitasMantenimiento != null && this.vista.CitasMantenimiento.Any()) { CitaMantenimientoBO cita = null; if (esCita) { cita = this.vista.CitasMantenimiento.FirstOrDefault(x => x.CitaMantenimientoID == id); } else { cita = this.vista.CitasMantenimiento.FirstOrDefault(x => x.MantenimientoProgramado.MantenimientoProgramadoID == id); } BPMO.SDNI.Equipos.BO.UnidadBO unidad = (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad; UnidadBR unidadBR = new UnidadBR(); TramiteProxyBO filter = new TramiteProxyBO() { Activo = true, Tramitable = new BPMO.SDNI.Equipos.BO.UnidadBO { UnidadID = unidad.UnidadID } }; TramiteBR tramiteBR = new TramiteBR(); List <TramiteBO> lstTramites = tramiteBR.ConsultarCompleto(dctx, filter, false); TramiteBO tramitePlacaFederal = lstTramites.Find(p => p.Tipo != null && p.Tipo == ETipoTramite.PLACA_FEDERAL && p.Activo != null && p.Activo == true); TramiteBO tramitePlacaEstatal = lstTramites.Find(p => p.Tipo != null && p.Tipo == ETipoTramite.PLACA_ESTATAL && p.Activo != null && p.Activo == true); String placas = tramitePlacaFederal != null && !String.IsNullOrEmpty(tramitePlacaFederal.Resultado) ? tramitePlacaFederal.Resultado : (tramitePlacaEstatal != null && !String.IsNullOrEmpty(tramitePlacaEstatal.Resultado) ? tramitePlacaEstatal.Resultado : null); var equiposAliados = unidadBR.ConsultarEquipoAliado(dctx, unidad, true); List <MantenimientoProgramadoEquipoAliadoBO> mantenimientosEA = new List <MantenimientoProgramadoEquipoAliadoBO>(); var mantenimientoProgramadoBR = new ConsultarMantenimientoProgramadoBR(); foreach (EquipoAliadoBO equipoAliado in equiposAliados) { var manttosEA = mantenimientoProgramadoBR.Consultar(dctx, new MantenimientoProgramadoBOF() { EsUnidad = false, EquipoID = equipoAliado.EquipoID, Activo = true, EstatusMantenimientoProgramado = EEstatusMantenimientoProgramado.PROGRAMADO }); if (manttosEA != null && manttosEA.Any()) { var manttoEA = manttosEA.FirstOrDefault() as MantenimientoProgramadoEquipoAliadoBO; manttoEA.EquipoAliado = equipoAliado; mantenimientosEA.Add(manttoEA); } else { mantenimientosEA.Add(new MantenimientoProgramadoEquipoAliadoBO() { EquipoAliado = equipoAliado }); } } var nombreSucursal = ""; var nombreTaller = ""; int? kmUltimoServicio = null; DateTime?fechaUltimoServicio = null; string clienteNombre = ""; List <ContactoClienteBO> contactosCliente = new List <ContactoClienteBO>(); if (cita.CitaMantenimientoID != null) { var sucursal = FacadeBR.ConsultarSucursal(dctx, new SucursalBO() { Id = cita.Sucursal.Id }).FirstOrDefault(); if (sucursal != null) { cita.Sucursal.Nombre = sucursal.Nombre; nombreSucursal = sucursal.Nombre; } var taller = FacadeBR.ConsultarTaller(dctx, new TallerBO() { Id = cita.TallerInterno.Id }).FirstOrDefault(); if (taller != null) { cita.TallerInterno.Nombre = taller.Nombre; cita.TallerInterno.NombreCorto = taller.NombreCorto; nombreTaller = taller.Nombre; } } var unidadManttoBR = new MantenimientoUnidadBR(); var mantemiento = unidadManttoBR.Consultar(dctx, new MantenimientoUnidadBO() { IngresoUnidad = new IngresoUnidadBO() { Unidad = (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad }, TipoServicio = new TipoServicioBO() { Id = this.TipoMantenimiento }, Activo = true }).Where(x => x.FechaSalida != null).OrderBy(x => x.FechaSalida).ToList().LastOrDefault(); if (mantemiento != null) { kmUltimoServicio = mantemiento.KilometrajeEntrada; fechaUltimoServicio = mantemiento.FechaSalida.Value; } if ((cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.Cliente != null && (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.Cliente.Id != null) { var clienteIdealeaseBR = new CuentaClienteIdealeaseBR(); var cliente = clienteIdealeaseBR.Consultar(dctx, new CuentaClienteIdealeaseBO() { Cliente = new ClienteBO() { Id = (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.Cliente.Id }, UnidadOperativa = new UnidadOperativaBO() { Id = this.vista.UnidadOperativaID } }).FirstOrDefault(); if (cliente != null) { bool?activo = cita.CitaMantenimientoID != null ? null : (bool?)true; var contactos = new ContactoClienteBR().ConsultarCompleto(dctx, new ContactoClienteBO() { CuentaClienteIdealease = cliente, Activo = activo, Sucursal = cita.Sucursal }); if (contactos != null && contactos.Any()) { contactos.ForEach(contacto => { contacto.Detalles.ForEach(detail => { detail.ContactoCliente.Sucursal = new SucursalBO() { Id = contacto.Sucursal.Id, Nombre = contacto.Sucursal.Nombre }; detail.ContactoCliente.Direccion = contacto.Direccion; }); }); contactosCliente.AddRange(contactos); } clienteNombre = cliente.Cliente.NombreCompleto; } else { var clienteServicio = FacadeBR.ConsultarCliente(dctx, new ClienteBO() { Id = (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.Cliente.Id }).FirstOrDefault(); if (clienteServicio != null) { clienteNombre = clienteServicio.NombreCompleto; } } } var fechaInicial = new DateTime(); if (mantemiento.FechaUltimoServicio.HasValue) { fechaInicial = mantemiento.FechaArranque.Value > mantemiento.FechaUltimoServicio.Value && mantemiento.FechaArranque.Value < mantemiento.FechaProximoServicio.Value ? mantemiento.FechaArranque.Value : DateTime.Today; } else { fechaInicial = DateTime.Today; } var diasRetraso = Convert.ToInt32(Math.Round((fechaInicial - new DateTime(cita.MantenimientoProgramado.Fecha.Value.Year, cita.MantenimientoProgramado.Fecha.Value.Month, cita.MantenimientoProgramado.Fecha.Value.Day)).TotalDays, 2)); this.vista.ClienteNombre = clienteNombre; this.vista.Area = (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.Area.ToString(); this.vista.VINUnidad = (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.NumeroSerie; this.vista.NumeroEconomico = (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.NumeroEconomico; this.vista.KmUltimoServicio = kmUltimoServicio; this.vista.FechaUltimoServicio = fechaUltimoServicio; this.vista.PlacaEstatal = tramitePlacaEstatal != null && !String.IsNullOrEmpty(tramitePlacaEstatal.Resultado) ? tramitePlacaEstatal.Resultado : ""; this.vista.PlacaFederal = tramitePlacaFederal != null && !String.IsNullOrEmpty(tramitePlacaFederal.Resultado) ? tramitePlacaFederal.Resultado : ""; this.vista.FechaSugerida = cita.MantenimientoProgramado.Fecha; this.vista.TipoMantenimiento = (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).TipoMantenimientoNombre; this.vista.NombreSucursalDetalle = nombreSucursal; this.vista.NombreTallerDetalle = nombreTaller; this.vista.ListadoManttoEquiposAliados = mantenimientosEA; this.vista.EstatusMantenimiento = cita.CitaMantenimientoID != null?cita.EstatusCita.ToString() : EEstatusCita.PRECALENDARIZADA.ToString(); this.vista.DiasRetraso = diasRetraso <= 0 ? int.Parse(diasRetraso.ToString("G")) : int.Parse(diasRetraso.ToString()); this.vista.ListadoContactosCliente = contactosCliente; this.vista.EstablecerEquiposAliados(); this.vista.EstablecerContactosCliente(); } else { throw new Exception("No hay citas de mantenimiento para presentar"); } }