public ConsultarTramitesPRE(IConsultarTramitesVIS vista) { try { this.vista = vista; dctx = FacadeBR.ObtenerConexion(); tramiteBR = new TramiteBR(); } catch (Exception ex) { this.MostrarMensaje("Inconsistencias en la configuración", ETipoMensajeIU.ERROR, this.nombreClase + ".Page_Load: " + ex.Message); } }
public ucTramitesActivosPRE(IucTramitesActivosVIS view) { try { this.vista = view; this.controlador = new TramiteBR(); this.dctx = FacadeBR.ObtenerConexion(); this.EstablecerTipoAdjunto(); this.vista.EstablecerIdentificadorListaArchivos(nombreClase); } catch (Exception ex) { this.vista.MostrarMensaje("Inconsistencias en los parámetros de configuración", ETipoMensajeIU.ERROR, this.nombreClase + ".ucTramitesUnidadPRE:" + ex.Message); } }
/// <summary> /// Despliega los datos de la unidad a la interfaz /// </summary> /// <param name="unidad"></param> private void DatosAInterfazUsuario(UnidadBO unidad) { UnidadBO consultada = ObtenerUnidad(unidad); #region Se obtiene la información completa de la unidad y sus trámites List <TramiteBO> lstTramites = new List <TramiteBO>(); if (consultada != null && (consultada.UnidadID != null || consultada.EquipoID != null)) { lstTramites = new TramiteBR().ConsultarCompleto(dataContext, new TramiteProxyBO() { Activo = true, Tramitable = consultada }, false); } #endregion if (consultada == null) { consultada = new Equipos.BO.UnidadBO(); } if (consultada.Modelo == null) { consultada.Modelo = new ModeloBO(); } if (consultada.Modelo.Marca == null) { consultada.Modelo.Marca = new MarcaBO(); } if (consultada.Sucursal == null) { consultada.Sucursal = new SucursalBO(); } if (consultada.CaracteristicasUnidad == null) { consultada.CaracteristicasUnidad = new CaracteristicasUnidadBO(); } if (consultada == null) { throw new Exception("No se ha proporcionado una unidad a agregar"); } vista.UnidadID = consultada.UnidadID; vista.EquipoID = consultada.EquipoID; vista.VIN = !string.IsNullOrEmpty(consultada.NumeroSerie) ? consultada.NumeroSerie : string.Empty; vista.NumeroEconocimico = !string.IsNullOrEmpty(consultada.NumeroEconomico) ? consultada.NumeroEconomico : string.Empty; vista.SucursalID = consultada.Sucursal.Id; vista.Sucursal = !string.IsNullOrEmpty(consultada.Sucursal.Nombre) ? consultada.Sucursal.Nombre : string.Empty; vista.ModeloID = consultada.Modelo.Id; vista.Modelo = consultada.Modelo.Nombre; vista.Marca = consultada.Modelo.Marca.Nombre; this.vista.UnidadCapacidadTanque = consultada.CombustibleConsumidoTotal; vista.Anio = consultada.Anio; //Información de los Trámites de la Unidad y Deducible TramiteBO tramite = null; #region Placa Estatal tramite = lstTramites.Find(p => p.Tipo != null && p.Tipo == ETipoTramite.PLACA_ESTATAL && p.Activo != null && p.Activo == true); if (tramite != null && tramite.Resultado != null && tramite.Resultado.Trim().CompareTo("") != 0) { this.vista.UnidadPlacaEstatal = tramite.Resultado; } else { this.vista.UnidadPlacaEstatal = null; } #endregion this.vista.EArea = consultada.Area; //Información de los Equipos Aliados de la Unidad DataTable dt = new DataTable(); dt.Columns.Add(new DataColumn("NumeroSerie")); dt.Columns.Add(new DataColumn("Anio")); dt.Columns.Add(new DataColumn("Dimensiones")); dt.Columns.Add(new DataColumn("PBV")); dt.Columns.Add(new DataColumn("PBC")); dt.Columns.Add(new DataColumn("Modelo")); if (consultada.EquiposAliados != null) { foreach (EquipoAliadoBO ea in consultada.EquiposAliados) { DataRow dr = dt.NewRow(); dr["NumeroSerie"] = ea.NumeroSerie; dr["Anio"] = ea.Anio; dr["Dimensiones"] = ea.Dimension; dr["PBV"] = ea.PBV; dr["PBC"] = ea.PBC; if (ea.Modelo != null) { dr["Modelo"] = ea.Modelo.Nombre; } dt.Rows.Add(dr); } } dt.AcceptChanges(); this.vista.EstablecerEquiposAliadoUnidad(dt); }
public void SeleccionarUnidad(Equipos.BO.UnidadBO unidad) { try { #region Se obtiene la información completa de la unidad y sus trámites List <TramiteBO> lstTramites = new List <TramiteBO>(); if (unidad != null && (unidad.UnidadID != null || unidad.EquipoID != null)) { List <Equipos.BO.UnidadBO> lst = new UnidadBR().ConsultarCompleto(this.dctx, new Equipos.BO.UnidadBO() { UnidadID = unidad.UnidadID, EquipoID = unidad.EquipoID }, true); if (lst.Count <= 0) { throw new Exception("No se encontró la información completa de la unidad seleccionada."); } unidad = lst[0]; lstTramites = new TramiteBR().ConsultarCompleto(this.dctx, new TramiteProxyBO() { Activo = true, Tramitable = unidad }, false); bool esValido = ((EAreaConstruccion)unidad.Area == EAreaConstruccion.RO || (EAreaConstruccion)unidad.Area == EAreaConstruccion.ROC); if (this.vista.UnidadOperativaID == (int)ETipoEmpresa.Construccion && esValido) { CatalogoBaseBO catalogoBase = unidad.TipoEquipoServicio; unidad.TipoEquipoServicio = FacadeBR.ConsultarTipoUnidad(dctx, catalogoBase).FirstOrDefault(); ContratoPSLBR Contratobr = new ContratoPSLBR(); ETipoUnidad? tipo = Contratobr.ObtenerTipoUnidadPorClave(dctx, unidad.TipoEquipoServicio.NombreCorto, null); if (tipo == null) { this.vista.HabilitarBotonTerminar(false); this.vista.MostrarMensaje(this.nombreClase + ".SeleccionarUnidad: " + "No es posible seleccionar la unidad " + unidad.NumeroSerie + " debido a que no existe un checklist para su tipo (" + unidad.TipoEquipoServicio.NombreCorto + ")", ETipoMensajeIU.ADVERTENCIA, null); return; } else { this.vista.HabilitarBotonTerminar(true); } } else { this.vista.HabilitarBotonTerminar(true); } } #endregion #region Dato a Interfaz de Usuario //Información de la Unidad if (unidad == null) { unidad = new Equipos.BO.UnidadBO(); } if (unidad.Modelo == null) { unidad.Modelo = new BPMO.Servicio.Catalogos.BO.ModeloBO(); } if (unidad.Modelo.Marca == null) { unidad.Modelo.Marca = new BPMO.Servicio.Catalogos.BO.MarcaBO(); } if (unidad.Sucursal == null) { unidad.Sucursal = new SucursalBO(); } if (unidad.CaracteristicasUnidad == null) { unidad.CaracteristicasUnidad = new CaracteristicasUnidadBO(); } #endregion } catch (Exception ex) { throw new Exception(this.nombreClase + ".SeleccionarUnidad: " + ex.Message); } }
private void EstablecerLineaContrato(LineaContratoManttoBO linea, bool edicion = false) { try { if (linea == null) { linea = new LineaContratoManttoBO(); } if (linea.Equipo == null) { linea.Equipo = new Equipos.BO.UnidadBO(); } if (!(linea.Equipo is Equipos.BO.UnidadBO)) { throw new Exception("El equipo de la línea de contrato no es una unidad."); } List <TramiteBO> lstTramites = new List <TramiteBO>(); #region Se obtiene la información completa de la unidad y sus trámites if (((Equipos.BO.UnidadBO)linea.Equipo).UnidadID != null) { Equipos.BO.UnidadBO bo = (Equipos.BO.UnidadBO)linea.Equipo; //SC_0051: cambie de consultar completo a consultar detalle List <Equipos.BO.UnidadBO> lst = new UnidadBR().ConsultarDetalle(this.dctx, new Equipos.BO.UnidadBO() { UnidadID = bo.UnidadID, EquipoID = bo.EquipoID }, true); if (lst.Count <= 0) { throw new Exception("No se encontró la información completa de la unidad seleccionada."); } if (!edicion) { bo = lst[0]; } if (bo.Sucursal != null)//SC_0051 { if (bo.Sucursal.Id.HasValue) { var lstUnis = FacadeBR.ConsultarSucursal(dctx, bo.Sucursal); var sucUni = lstUnis.FirstOrDefault(x => x.Id == bo.Sucursal.Id); if (sucUni != null) { bo.Sucursal = sucUni; } } } lstTramites = new TramiteBR().ConsultarCompleto(this.dctx, new TramiteProxyBO() { Activo = true, Tramitable = bo }, false); linea.Equipo = bo; } #endregion #region Se completa la información de la sub-línea de contrato con los equipos aliados de la unidad if (linea.SubLineasContrato != null) { foreach (SubLineaContratoManttoBO sublinea in linea.SubLineasContrato) { if (sublinea.EquipoAliado == null) { sublinea.EquipoAliado = new EquipoAliadoBO(); } if (sublinea.EquipoAliado.EquipoAliadoID != null && ((Equipos.BO.UnidadBO)linea.Equipo).EquiposAliados != null) { EquipoAliadoBO eaTemp = ((Equipos.BO.UnidadBO)linea.Equipo).EquiposAliados.Find(p => p.EquipoAliadoID == sublinea.EquipoAliado.EquipoAliadoID); if (eaTemp != null) { sublinea.EquipoAliado = eaTemp; } } } } else { if (linea.Equipo != null && linea.Equipo is Equipos.BO.UnidadBO && ((Equipos.BO.UnidadBO)linea.Equipo).EquiposAliados != null) { linea.SubLineasContrato = new List <SubLineaContratoManttoBO>(); foreach (EquipoAliadoBO ea in ((Equipos.BO.UnidadBO)linea.Equipo).EquiposAliados) { SubLineaContratoManttoBO subLinea = new SubLineaContratoManttoBO(); subLinea.EquipoAliado = ea; subLinea.Mantenimiento = false; linea.SubLineasContrato.Add(subLinea); } } } #endregion this.DatoAInterfazUsuario(lstTramites); this.DatoAInterfazUsuario(linea); } catch (Exception ex) { throw new Exception(this.nombreClase + ".EstablecerLineaContrato: " + ex.Message); } }
/// <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(CitaMantenimientoBO citaMantenimiento) { if (citaMantenimiento != null) { CitaMantenimientoBO cita = citaMantenimiento; 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 }); } } List <ContactoClienteBO> contactosCliente = new List <ContactoClienteBO>(); 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); } (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.Cliente.NombreCompleto = cliente.Cliente.NombreCompleto; } else { var clienteServicio = FacadeBR.ConsultarCliente(dctx, new ClienteBO() { Id = (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.Cliente.Id }).FirstOrDefault(); if (clienteServicio != null) { (cita.MantenimientoProgramado as MantenimientoProgramadoUnidadBO).Unidad.Cliente.NombreCompleto = clienteServicio.NombreCompleto; } } } this.ObjetoAInterfazUsuario(cita, mantenimientosEA, contactosCliente, tramitePlacaFederal != null && !String.IsNullOrEmpty(tramitePlacaFederal.Resultado) ? tramitePlacaFederal.Resultado : String.Empty, tramitePlacaEstatal != null && !String.IsNullOrEmpty(tramitePlacaEstatal.Resultado) ? tramitePlacaEstatal.Resultado : String.Empty); } else { throw new Exception("No hay citas de mantenimiento para presentar"); } }
/// <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"); } }