private void FrmBase_Load(object sender, EventArgs e) { habilitar(false); rotuladoLabels(); miAccion = acciones.nuevo; eventoLoadForm(); }
public void Update(acciones oAccion) { try { using (cooperativaEntities bd = new cooperativaEntities()) { var editar = (from p in bd.acciones where p.id_accion == oAccion.id_accion select p).Single(); editar.cuotas = oAccion.cuotas; editar.facturadas = oAccion.facturadas; editar.fecha = oAccion.fecha; editar.finalizado = oAccion.finalizado; editar.id_accion = oAccion.id_accion; editar.id_socio = oAccion.id_socio; editar.importe = oAccion.importe; editar.pendientes = oAccion.pendientes; editar.valor_cuota = oAccion.valor_cuota; bd.SaveChanges(); } } catch (Exception ex) { throw ex; } }
public int InsertAccion(acciones accion) { lock (locker) { return(database.Insert(accion)); } }
public IHttpActionResult Putacciones(int id, acciones acciones) { if (!ModelState.IsValid) { return(BadRequest(ModelState)); } if (id != acciones.id) { return(BadRequest()); } db.Entry(acciones).State = EntityState.Modified; try { db.SaveChanges(); } catch (DbUpdateConcurrencyException) { if (!accionesExists(id)) { return(NotFound()); } else { throw; } } return(StatusCode(HttpStatusCode.NoContent)); }
public acciones Get(int id) { try{ acciones oAccion = new acciones(); using (cooperativaEntities bd = new cooperativaEntities()) { var regis = (from p in bd.acciones where p.id_accion == id select p).Single(); oAccion.cuotas = regis.cuotas; oAccion.facturadas = regis.facturadas; oAccion.fecha = regis.fecha; oAccion.finalizado = regis.finalizado; oAccion.id_accion = regis.id_accion; oAccion.id_socio = regis.id_socio; oAccion.importe = regis.importe; oAccion.pendientes = regis.pendientes; oAccion.valor_cuota = regis.valor_cuota; return(oAccion); } } catch (Exception ex) { throw ex; } }
private void Abm_Load(object sender, EventArgs e) { cargarCombo(cboEstadoCivil, "tipo_estado_civil"); cargarCombo(cboTipoDoc, "tipo_documento"); cargarLista("personas"); habilitar(false); miAccion = acciones.editado; }
public IHttpActionResult Getacciones(int id) { acciones acciones = db.acciones.Find(id); if (acciones == null) { return(NotFound()); } return(Ok(acciones)); }
public IHttpActionResult Postacciones(acciones acciones) { if (!ModelState.IsValid) { return(BadRequest(ModelState)); } db.acciones.Add(acciones); db.SaveChanges(); return(CreatedAtRoute("DefaultApi", new { id = acciones.id }, acciones)); }
private void btnGrabar_Click_1(object sender, EventArgs e) { if (validar()) { string sql; if (miAccion == acciones.Nuevo) { Noche noche = new Noche(); noche.Nro_luna = Convert.ToInt32(txtNroLuna.Text); noche.Fecha_horaComienzo = dtpFechaCom.Value; noche.Fecha_horaCierre = dtpHoraCierre.Value; sql = "INSERT INTO NOCHE VALUES ('" + noche.Nro_luna + "','" + noche.Fecha_horaComienzo + "','" + noche.Fecha_horaCierre + "')"; oDatos.actualizarBD(sql); cargarLista("NOCHE"); } if (miAccion == acciones.Modificar) { int i = listBoxNoches.SelectedIndex; if (MessageBox.Show("¿Seguro que desea modificar los datos de la noche " + ArregloNoches[i].Nro_luna + " ?" , "Modificar" , MessageBoxButtons.YesNo , MessageBoxIcon.Warning , MessageBoxDefaultButton.Button2) == DialogResult.Yes) { ArregloNoches[i].Nro_luna = Convert.ToInt32(txtNroLuna.Text); ArregloNoches[i].Fecha_horaComienzo = dtpFechaCom.Value; ArregloNoches[i].Fecha_horaCierre = dtpHoraCierre.Value; sql = "UPDATE NOCHE set nro_luna ='" + ArregloNoches[i].Nro_luna + "', fecha_horaComienzo ='" + ArregloNoches[i].Fecha_horaComienzo + "', fecha_horaCierre ='" + ArregloNoches[i].Fecha_horaCierre + "' Where id_noche=" + ArregloNoches[i].Id_noche; oDatos.actualizarBD(sql); cargarLista("NOCHE"); } } habilitar(false); miAccion = acciones.Ninguna; } }
public IHttpActionResult Deleteacciones(int id) { acciones acciones = db.acciones.Find(id); if (acciones == null) { return(NotFound()); } db.acciones.Remove(acciones); db.SaveChanges(); return(Ok(acciones)); }
public int Save(acciones oAccion) { try { cooperativaEntities bd = new cooperativaEntities(); bd.acciones.AddObject(oAccion); bd.SaveChanges(); return(oAccion.id_accion); } catch (Exception ex) { throw ex; } }
private void Inicializar() { if (_idAccion == 0) { Limpiar(); } else { AccionImplement oAccionImplement = new AccionImplement(); acciones oAccion = new acciones(); oAccion = oAccionImplement.Get(_idAccion); this.txtCuotas.Text = oAccion.cuotas.ToString(); this.txtCuotasAbonadas.Text = (oAccion.cuotas - oAccion.pendientes).ToString(); this.txtImporteTotal.Text = oAccion.importe.ToString(); this.txtValorCuotas.Text = oAccion.valor_cuota.ToString(); } }
private void btnGrabar_Click(object sender, EventArgs e) { string consultaSQL = ""; if (validarDatos()) { Personas p = new Personas(); p.Apellido = txtApellido.Text; p.Nombres = txtNombre.Text; p.Tipo_estado_civil = (int)cboEstadoCivil.SelectedValue; p.Tipo_documento = (int)cboTipoDoc.SelectedValue; p.Documento = int.Parse(txtDocumento.Text); if (rbtMasculino.Checked) { p.Sexo = 1; } else { p.Sexo = 2; } if (miAccion == acciones.nuevo) { consultaSQL = "INSERT INTO personas(apellido,nombres,tipo_documento,documento,tipo_estado_civil,id_sexo)" + "VALUES (@apellido,@nombres,@tipo_documento,@documento,@tipo_estado_civil,@id_sexo)"; aBD.actualizarParametros(consultaSQL, p); cargarLista("personas"); } else { p.Documento = int.Parse(txtDocumento.Text); consultaSQL = "UPDATE personas SET apellido=@apellido, nombres=@nombres" + " WHERE documento=@documento"; aBD.actualizarParametros(consultaSQL, p); cargarLista("personas"); } } miAccion = acciones.editado; habilitar(false); }
private void FrmBase_Load(object sender, EventArgs e) { habilitar(false); rotuladoLabels(); //if (tabla_A != "") // cargarCombo(cboCombo_A, tabla_A, nombre_campo_display_A, nombre_campo_id_A); //if (tabla_B != "") // cargarCombo(cboCombo_B, tabla_B, nombre_campo_display_B, nombre_campo_id_B); //if (tabla_C != "") // cargarCombo(cboCombo_C, tabla_C, nombre_campo_display_C, nombre_campo_id_C); //if (tabla_D != "") // cargarCombo(cboCombo_D, tabla_D, nombre_campo_display_D, nombre_campo_id_D); miAccion = acciones.nuevo; }
public acciones GetByIdSocio(int idSocio) { try { acciones oAccion = new acciones(); using (cooperativaEntities bd = new cooperativaEntities()) { int cant = (from p in bd.acciones where p.id_socio == idSocio select p).Count(); if (cant > 0) { var regis = (from p in bd.acciones where p.id_socio == idSocio select p).FirstOrDefault(); oAccion.cuotas = regis.cuotas; oAccion.facturadas = regis.facturadas; oAccion.fecha = regis.fecha; oAccion.finalizado = regis.finalizado; oAccion.id_accion = regis.id_accion; oAccion.id_socio = regis.id_socio; oAccion.importe = regis.importe; oAccion.pendientes = regis.pendientes; oAccion.valor_cuota = regis.valor_cuota; } else { oAccion = null; } return(oAccion); } } catch (Exception ex) { throw ex; } }
private void Iniciar() { sys_configuracion oSysConfig = new sys_configuracion(); SysConfigImplement oSysConfigImplement = new SysConfigImplement(); oSysConfig = oSysConfigImplement.GetByNombre("CantVencimientos"); int CantUsuarios = 0; decimal NetoConIVA = 0; decimal NetoSinIVA = 0; decimal SubTotal = 0; switch (int.Parse(oSysConfig.valor)) { case 1: //No hace nada porque el primer se establece por defecto break; case 2: for (int i = 1; i <= (int.Parse(this.nudCantidad.Value.ToString()) - 1); i++) { DateTimePicker fecha1 = (DateTimePicker)tcPeriodos.Controls.Find("dtpPrimerVencimiento" + i, true)[0]; DateTimePicker fecha2 = (DateTimePicker)tcPeriodos.Controls.Find("dtpSegundoVencimiento" + i, true)[0]; if (fecha2.Value <= fecha1.Value) { string msg = "Debe establecer las fechas para los 2 vencimientos y éstas " + "no pueden ser iguales, controlar fechas indicadas en el periodo " + (i - 1).ToString(); MessageBox.Show(msg); } } break; case 3: for (int i = 1; i <= (int.Parse(this.nudCantidad.Value.ToString()) + 1); i++) { DateTimePicker fecha1 = (DateTimePicker)tcPeriodos.Controls.Find("dtpPrimerVencimiento" + i, true)[0]; DateTimePicker fecha2 = (DateTimePicker)tcPeriodos.Controls.Find("dtpSegundoVencimiento" + i, true)[0]; if (fecha2.Value <= fecha1.Value) { string msg = "Debe establecer las fechas para los 2 vencimientos y éstas " + "no pueden ser iguales, controlar fechas indicadas en el periodo " + (i - 1).ToString(); MessageBox.Show(msg); } } break; } // Verificar que se hayan cargado los estados de los medidores SocioConexionImplement oSocioConexionImplement = new SocioConexionImplement(); DataTable DTMedidores = oSocioConexionImplement.GetEstadosMedidores(); if (DTMedidores.Rows.Count > 0) { string msg2 = "No se puede efectuar el proceso de facturación porque existen " + "socios de servicio medido que no tienen informado el estado del " + "medidor. \n El estado del medidor debe ser " + "informado siempre, si por algún motivo no se efectuó la lectura, " + "coloque un valor estimado en el campo 'Lectura' pero no informe " + "la fecha de lectura en el campo 'Fecha Lectura', en la factura " + "se informará al socio que el valor de M3 consumidos fué estimado /n" + "El proceso de facturación no puede continuar."; MessageBox.Show(msg2); } // Pide confirmar el proceso de facturación string msj2 = ""; if (int.Parse(this.nudCantidad.Value.ToString()) > 1) { msj2 = "Está Ud. realmente seguro de querer comenzar el proceso de " + "facturación ?. \nEste proceso no puede ser " + "cancelado y al facturarse más de un período sólo puede " + "anularse la facturación del último período pero no de los " + "períodos anteriores"; } else { msj2 = "Está Ud. realmente seguro de querer comenzar el proceso de " + "facturación ?. \nEste proceso no puede ser " + "cancelado, aunque sí es reversible, es decir que una vez " + "finalizado el proceso se puede anular \n toda la facturación " + "y volver a efectuarla"; } DialogResult dialogResult = MessageBox.Show(msj2, "Confirmar facturación", MessageBoxButtons.YesNo); if (dialogResult == DialogResult.Yes) { // Hay que inhabilitar los forms porque el proceso no puede detenerse DeshabilitarControles(); // Guarda la cantidad de usuarios para utilizar la misma cantidad en // todos los períodos a facturar // obtengo solo los conceptos activos IList listaConceptos = new ConceptoImplement().GetActivosAll(); for (int i = 0; i < (int.Parse(this.nudCantidad.Value.ToString())); i++) { TextBox textPeriodo = (TextBox)this.Controls.Find("txtPeriodo" + i, true)[0]; string idPeriodo = textPeriodo.Text.Substring(3, 4) + textPeriodo.Text.Substring(0, 2); DataTable DTUsuariosAFacturar = oSocioConexionImplement.GetSociosAFacturar(idPeriodo); //Repetir el proceso de facturación para todas las solapas (periodos) seleccionados CantUsuarios = DTUsuariosAFacturar.Rows.Count; this.txtUsuariosAFacturar.Text = CantUsuarios.ToString(); this.txtUsuariosFacturados.Text = "0"; this.txtUsuariosFaltantes.Text = CantUsuarios.ToString(); this.pbEstado.Value = 0; // Cartel indicativo del proceso que se está efectuando this.tcPeriodos.TabIndex = i; // Guarda el número 'ProxFactura' del proceso anterior por si se desea // anular la facturación en curso (obviamente luego que termine) //sys_configuracion oSysProxFacturaAnterior = new sys_configuracion(); //oSysProxFacturaAnterior = oSysConfigImplement.GetByNombre("ProxFacturaAnt"); //sys_configuracion oSysProxFactura = new sys_configuracion(); //oSysProxFactura = oSysConfigImplement.GetByNombre("ProxFactura"); //oSysProxFacturaAnterior.valor = oSysProxFactura.valor; //oSysConfigImplement.Update(oSysProxFacturaAnterior); // Guardo las fechas de vencimiento en la tabla periodos periodos oPeriodo = new periodos(); PeriodosImplement oPeriodosImplement = new PeriodosImplement(); oPeriodo = oPeriodosImplement.Get(idPeriodo); this.txtProceso.Text = "Se esta procesando el periodo " + idPeriodo; this.txtProceso.Visible = true; Application.DoEvents(); oPeriodo.fecha_facturacion = this.dtpFecha.Value; DateTimePicker dtpPrimerVenc = (DateTimePicker)this.Controls.Find("dtpPrimerVencimiento" + i, true)[0]; oPeriodo.fecha_primer_venc = dtpPrimerVenc.Value; DateTimePicker dtpSegundoVenc = (DateTimePicker)this.Controls.Find("dtpSegundoVencimiento" + i, true)[0]; if (dtpSegundoVenc.Value.ToString() != "") { oPeriodo.fecha_segundo_venc = dtpSegundoVenc.Value; } oPeriodo.fecha_tercer_venc = null; oPeriodo.facturado = true; FacturasImplement oFacturasImplement = new FacturasImplement(); int cantUsuario = DTUsuariosAFacturar.Rows.Count; this.pbEstado.Maximum = cantUsuario; for (int j = 0; j < cantUsuario; j++) { this.pbEstado.Value = j; facturas oFactura = new facturas(); FacturasImplement oFacturaImplement = new FacturasImplement(); oFactura.id_periodo = idPeriodo; oFactura.id_socio = int.Parse(DTUsuariosAFacturar.Rows[j]["id_socio"].ToString()); //oFactura.id_medicion Ver como soluciono el idMedicion oFactura.id_estadoPago = 1; //Impaga oFactura.id_tarifa = 0; //aun no se carga oFactura.id_convenio = 0; //Aun no se carga oFactura.fechaPago = null; oFactura.cobrado = 0; oFactura.neto1 = 0; oFactura.neto2 = 0; oFactura.importeNeto = 0; oFactura.importeTotal = 0; int idFactura = 0; idFactura = oFacturasImplement.Save(oFactura); /* Si corresponde calcula los consumos estimados, además transfiere * los valores de los campos de datos actuales a los campos de * los datos anteriores*/ int idMedidor = 0; if (DTUsuariosAFacturar.Rows[j]["medidor"].ToString() != "") { socios_mediciones oSocioMedicionActual = new socios_mediciones(); SocioMedicionImplement oSocioMedicionImplement = new SocioMedicionImplement(); oSocioMedicionActual = oSocioMedicionImplement.ultimaMedicion(int.Parse(DTUsuariosAFacturar.Rows[j]["id_socio"].ToString())); socios_mediciones oSocioMedicionNew = new socios_mediciones(); oSocioMedicionNew.fecha_lectura = null; oSocioMedicionNew.id_socio = int.Parse(DTUsuariosAFacturar.Rows[j]["id_socio"].ToString()); if (i <= (int.Parse(this.nudCantidad.Value.ToString()) - 1)) { decimal consumo = 0; if (oSocioMedicionActual != null) { consumo = (decimal)decimal.Parse((oSocioMedicionActual.consumo * 0.75).ToString()); oSocioMedicionNew.consumo = (int)Math.Truncate(consumo); oSocioMedicionNew.lectura = oSocioMedicionActual.lectura + oSocioMedicionNew.consumo; } else { oSocioMedicionNew.consumo = 0; oSocioMedicionNew.lectura = 0; } } else { oSocioMedicionNew.consumo = 0; oSocioMedicionNew.lectura = 0; } idMedidor = oSocioMedicionImplement.Save(oSocioMedicionNew); } oFactura.id_medicion = idMedidor; //Cargo 0 si no tiene medidor // Limpia las variables de subtotales con y sin IVA NetoConIVA = 0; NetoSinIVA = 0; //Para cada socio, recorre toda la base de conceptos foreach (cod_conceptos oConcepto in listaConceptos) { bool CorrespondeFacturar = false; if (oFactura.id_medicion.Value != 0) { //SocioMedicionImplement oSosioMedicionImpl = new SocioMedicionImplement(); //socios_mediciones oSocioMedicion = new socios_mediciones(); //oSocioMedicion = oSosioMedicionImpl.Get(oFactura.id_medicion.Value); } acciones oAccion = new acciones(); conceptos_particulares oConceptoParticular = new conceptos_particulares(); conceptosParticularesImplement oConceptoParticularImplement = new conceptosParticularesImplement(); AccionImplement oAccionesImplement = new AccionImplement(); if (oConcepto.aplicacion == 2) { // si concepto Particular oConceptoParticular = oConceptoParticularImplement.GetByFilter(int.Parse(DTUsuariosAFacturar.Rows[j]["id_socio"].ToString()), oConcepto.id_concepto, oFactura.id_periodo); if (oConceptoParticular != null) { CorrespondeFacturar = true; } else { // No encontrado entonces no corresponde facturar CorrespondeFacturar = false; } } else { //Concepto Activo y no particular entonces corresponde facturar CorrespondeFacturar = true; } if (CorrespondeFacturar) { facturas_detalles oDetalle = new facturas_detalles(); FacturasDetallesImplement oFacturasDetallesImplement = new FacturasDetallesImplement(); //ConvenioImplement oConvenioImplement = new ConvenioImplement(); CalculosFacturacionFormulas oCalculosFacturacionFormulas = new CalculosFacturacionFormulas(); oDetalle = oCalculosFacturacionFormulas.getDetalle(int.Parse(DTUsuariosAFacturar.Rows[j]["id_socio"].ToString()), decimal.Parse(DTUsuariosAFacturar.Rows[j]["cargo_fijo"].ToString()), decimal.Parse(DTUsuariosAFacturar.Rows[j]["abono"].ToString()), decimal.Parse(DTUsuariosAFacturar.Rows[j]["valor_m3"].ToString()), oConcepto, oFactura, oConceptoParticular); if (oDetalle.importe != 0) { oFacturasDetallesImplement.Save(oDetalle); } this.txtUsuariosFacturados.Text = j.ToString(); this.txtUsuariosFaltantes.Text = (int.Parse(this.txtUsuariosAFacturar.Text) - j).ToString(); Application.DoEvents(); // Calcula los subtotales separados para los conceptos con y sin IVA if (oConcepto.aplicar_iva.Value) { NetoConIVA = NetoConIVA + oDetalle.importe; } else { NetoSinIVA = NetoSinIVA + oDetalle.importe; } // Calcula los campos Neto1 y Neto2 utilizados en los // cálculos de intereses if (oConcepto.aplicar_recargo.Value) { oFactura.neto1 = oFactura.neto1.Value + Convert.ToSingle(oDetalle.importe); } else { oFactura.neto2 = oFactura.neto2.Value + Convert.ToSingle(oDetalle.importe); } } } // Obtiene el subtotal general como suma de los // subtotales parciales con y sin IVA SubTotal = NetoConIVA + NetoSinIVA; // Redondea el subtotal a dos dígitos SubTotal = decimal.Round(SubTotal, 2); // Registra el subtotal general oFactura.importeNeto = Convert.ToSingle(SubTotal); // Calcula IVA (sólo para los conceptos que corresponde) facturas_detalles oFacDetalle = new facturas_detalles(); FacturasDetallesImplement oFacDetalleImplement = new FacturasDetallesImplement(); cod_conceptos oConceptoIVA = new cod_conceptos(); ConceptoImplement oConceptoImplement = new ConceptoImplement(); oConceptoIVA = oConceptoImplement.Get(23);//concepto IVA es el 23 oFacDetalle.id_concepto = oConceptoIVA.id_concepto; oFacDetalle.id_factura = oFactura.id_factura; oFacDetalle.idOrden = oConceptoIVA.orden_concepto; oFacDetalle.idTipo = 0; oFacDetalle.importe = decimal.Round(NetoConIVA * decimal.Parse(DTUsuariosAFacturar.Rows[j]["iva"].ToString()) / 100, 2); oFacDetalleImplement.Save(oFacDetalle); // Calcula Total oFactura.importeTotal = oFactura.importeNeto.Value + Convert.ToSingle(oFacDetalle.importe); //este ahi que ver el tipo de dato oFactura.id_factura = idFactura; oFacturaImplement.Update(oFactura); // Generar entradas en la base de CuentasCorrientes CuentaCorrienteImplement oCuentaCorrienteImplement = new CuentaCorrienteImplement(); cuentas_corrientes oCuentaCorriente = new cuentas_corrientes(); oCuentaCorriente.fecha = DateTime.Now; oCuentaCorriente.id_factura = idFactura; oCuentaCorriente.id_movimiento = 1; oCuentaCorriente.id_socio = int.Parse(DTUsuariosAFacturar.Rows[j]["id_socio"].ToString()); oCuentaCorriente.importe_credito = 0; oCuentaCorriente.importe_saldo = 0; oCuentaCorriente.importe_debito = Convert.ToDecimal(oFactura.importeTotal); oCuentaCorriente.id_cobranza = 0; oCuentaCorrienteImplement.Save(oCuentaCorriente); // } } } } }
private void btnCancelar_Click(object sender, EventArgs e) { limpiar(); habilitar(false); miAccion = acciones.Ninguna; }
private void btnGrabar_Click(object sender, EventArgs e) { if (validar()) { string sql; if (miAccion == acciones.Nuevo) { clsGrupoFolklorico elenco = new clsGrupoFolklorico(); elenco.pNombre_grupo = txtNombre.Text; elenco.pCant_integrantes = Convert.ToInt32(txtCantidad.Text); elenco.pProcedencia = txtProcedencia.Text; elenco.pTel_contacto = txtContacto.Text; elenco.pEmail = txtEmail.Text; elenco.pSalario = Convert.ToDouble(txtSalario.Text); sql = "INSERT INTO grupo_folklorico VALUES ('" + elenco.pNombre_grupo + "', '" + elenco.pCant_integrantes + "', '" + elenco.pProcedencia + "', '" + elenco.pTel_contacto + "', '" + elenco.pEmail + "', '" + elenco.pSalario + "')"; oDatos.actualizarBD(sql); cargarLista("grupo_folklorico"); } if (miAccion == acciones.Modificar) { int i = lstGrupo.SelectedIndex; if (MessageBox.Show("¿Seguro que desea modificar los datos del Grupo " + ArregloElenco[i].pNombre_grupo + " ?" , "Modificar" , MessageBoxButtons.YesNo , MessageBoxIcon.Warning , MessageBoxDefaultButton.Button2) == DialogResult.Yes) { ArregloElenco[i].pNombre_grupo = txtNombre.Text; ArregloElenco[i].pCant_integrantes = Convert.ToInt32(txtCantidad.Text); ArregloElenco[i].pProcedencia = txtProcedencia.Text; ArregloElenco[i].pTel_contacto = txtContacto.Text; ArregloElenco[i].pEmail = txtEmail.Text; ArregloElenco[i].pSalario = Convert.ToDouble(txtSalario.Text); sql = "UPDATE grupo_folklorico set nombre_grupo ='" + ArregloElenco[i].pNombre_grupo + "', cant_integrantes ='" + ArregloElenco[i].pCant_integrantes + "', procedencia= '" + ArregloElenco[i].pProcedencia + "', tele_contacto= '" + ArregloElenco[i].pTel_contacto + "', email= '" + ArregloElenco[i].pEmail + "', salario= '" + ArregloElenco[i].pSalario + "' Where id_grupo_folklorico=" + ArregloElenco[i].pId_grupo_folklorico; oDatos.actualizarBD(sql); cargarLista("grupo_folklorico"); } } habilitar(false); miAccion = acciones.Ninguna; } }
private void btnEditar_Click(object sender, EventArgs e) { habilitar(true); miAccion = acciones.Modificar; txtNombre.Focus(); }
private void btnNuevo_Click(object sender, EventArgs e) { habilitar(true); limpiar(); miAccion = acciones.Nuevo; }
private void btnCancelar_Click(object sender, EventArgs e) { habilitar(false); miAccion = acciones.nuevo; }
private void Guardar() { AccionImplement oAccionImplement = new AccionImplement(); acciones oAccion = new acciones(); string Mensaje; Mensaje = ""; if (this.txtCuotas.Text.Length == 0) { Mensaje += "Falta ingresar cuotas." + Environment.NewLine; } ; if (this.dtpFecha.Text.Length == 0) { Mensaje += "Falta ingresar fecha." + Environment.NewLine; } ; if (this.txtImporteTotal.Text.Length == 0) { Mensaje += "Falta ingresar importe total." + Environment.NewLine; } ; if (this.txtCuotasAbonadas.Text.Length == 0) { Mensaje += "Falta ingresar cuotas abonadas." + Environment.NewLine; } ; //txtValorCuotas if (Mensaje.Length > 0) { frmVentanaInformativa ofrmVentanaInformativa = new frmVentanaInformativa(Mensaje); ofrmVentanaInformativa.ShowDialog(); } else { oAccion.cuotas = int.Parse(this.txtCuotas.Text); oAccion.fecha = DateTime.Parse(this.dtpFecha.Text); oAccion.importe = Decimal.Parse(this.txtImporteTotal.Text); oAccion.finalizado = false; oAccion.id_socio = _idSocio; oAccion.valor_cuota = Decimal.Parse(this.txtValorCuotas.Text); if (_idAccion == 0) { oAccion.facturadas = int.Parse(this.txtCuotasAbonadas.Text); oAccion.pendientes = oAccion.cuotas - oAccion.facturadas; if (oAccion.facturadas == oAccion.cuotas) { oAccion.finalizado = true; } oAccionImplement.Save(oAccion); this.Close(); } else { oAccion.facturadas = int.Parse(this.txtCuotasAbonadas.Text); oAccion.pendientes = oAccion.cuotas - oAccion.facturadas; if (oAccion.facturadas == oAccion.cuotas) { oAccion.finalizado = true; } oAccion.id_accion = _idAccion; oAccionImplement.Update(oAccion); this.Close(); } } }
public facturas_detalles getDetalle(int idSocio, decimal cargoFijo, decimal abono, decimal valorM3, cod_conceptos oConcepto, facturas oFactura, conceptos_particulares oConceptoParticular) { SocioMedicionImplement oSocioMedicionImpl = new SocioMedicionImplement(); socios_mediciones oSocioMedicion = new socios_mediciones(); if (oFactura.id_medicion.Value != 0) { oSocioMedicion = oSocioMedicionImpl.Get(oFactura.id_medicion.Value); } acciones oAccion = new acciones(); AccionImplement oAccionesImplement = new AccionImplement(); facturas_detalles oDetalle = new facturas_detalles(); oDetalle.idOrden = oConcepto.orden_concepto; oDetalle.id_concepto = oConcepto.id_concepto; oDetalle.idTipo = 0; oDetalle.id_factura = oFactura.id_factura; ConvenioImplement oConvenioImplement = new ConvenioImplement(); switch (oConcepto.id_formula) { case 0: oDetalle.importe = cargoFijo; break; case 1: if (cargoFijo > 0) { oDetalle.importe = cargoFijo * oConcepto.variable.Value; } else { if (oFactura.id_medicion.Value != 0) { //revisar if ((oSocioMedicion.consumo - abono) <= 0) { // Si no hubo consumo excedente ... oDetalle.importe = abono * valorM3 * oConcepto.variable.Value; } else { // Si hubo consumo excedente ... decimal uno = (abono * valorM3); decimal dos = ((oSocioMedicion.consumo.Value - abono) * valorM3); oDetalle.importe = (uno + dos) * oConcepto.variable.Value; } } else { //Por que no tiene medidor usa el abono oDetalle.importe = abono * valorM3 * oConcepto.variable.Value; } } break; case 2: // Consumo excedente por ValorM3 // (Facturas.Consumo - Socios.Tarifa->Abono) * // Socios.Tarifa->ValorM3 if (oFactura.id_medicion.Value != 0) { oSocioMedicion = oSocioMedicionImpl.Get(oFactura.id_medicion.Value); if ((oSocioMedicion.consumo.Value - abono) > 0) { // ' Calcula sólo sobre el consumo excedente oDetalle.importe = (oSocioMedicion.consumo.Value - abono) * valorM3; } else { // No hubo consumo excedente oDetalle.importe = 0; } } else { oDetalle.importe = 0; } break; case 3: // ' Abono por ValorM3 //' Socios.Tarifa->Abono * Socios.Tarifa->ValorM3 oDetalle.importe = abono * valorM3; break; case 4: //' Consumo por ValorM3 por Variable //' Facturas.Consumo * Socios.Tarifa->ValorM3 * Conceptos.Variable if (oFactura.id_medicion.Value != 0) { oDetalle.importe = oSocioMedicion.consumo.Value * valorM3 * oConcepto.variable.Value; } else { oDetalle.importe = 0; } break; case 5: oAccion = oAccionesImplement.GetByIdSocio(idSocio); if (oAccion != null) { if (oAccion.cuotas > oAccion.facturadas) { oAccion.facturadas = oAccion.facturadas + 1; oAccionesImplement.Update(oAccion); oDetalle.importe = oAccion.valor_cuota; } else { oDetalle.importe = 0; } } else { oDetalle.importe = 0; } break; case 6: // Variable por Cuota Acciones // Acciones.ValorCuota * Conceptos.Variable // Buscar Acciones oAccion = oAccionesImplement.GetByIdSocio(idSocio); // Si encuentra un registro if (oAccion != null) { // Pregunta si no está finalizado if (oAccion.cuotas > oAccion.facturadas) { //Si no ha finalizado se factura una cuota más oAccion.facturadas = oAccion.facturadas + 1; oAccionesImplement.Update(oAccion); oDetalle.importe = oAccion.valor_cuota * oConcepto.variable.Value; } else { oDetalle.importe = 0; } } else { oDetalle.importe = 0; } break; case 7: // Cuota Convenio de pago // Convenios.ValorCuota decimal ImporteConvenios = 0; // Inicializa el campo en cero oDetalle.importe = 0; // Buscar Convenio IList ListConvenios = oConvenioImplement.GetAllBySocio(idSocio); foreach (convenios oConvenio in ListConvenios) { // Verifica que no se trate de un convenio judicial if (!oConvenio.convenio_judicial.Value) { //Pregunta si no está finalizado if (oConvenio.cuotas > oConvenio.facturadas) { //Si no ha finalizado se factura una cuota más oConvenio.facturadas = oConvenio.facturadas + 1; if (oConvenio.cuotas == oConvenio.facturadas) { oConvenio.finalizado = true; } oConvenioImplement.Update(oConvenio); ImporteConvenios = ImporteConvenios + oConvenio.valor_cuota; } } } oDetalle.importe = ImporteConvenios; break; case 8: // Variable por Cuota Convenio // Convenios.ValorCuota * Conceptos.Variable // Buscar Convenio IList ListaConvenios = oConvenioImplement.GetAllBySocio(idSocio); //Si encuentra un registro oDetalle.importe = 0; foreach (convenios oConvenio in ListaConvenios) { // Verifica que no se trate de un convenio judicial if (!oConvenio.convenio_judicial.Value) { //Pregunta si no está finalizado if (oConvenio.cuotas > oConvenio.facturadas) { oConvenio.facturadas = oConvenio.facturadas + 1; oConvenioImplement.Update(oConvenio); oDetalle.importe = oConvenio.valor_cuota * oConcepto.variable.Value; } else { oDetalle.importe = 0; } } else { oDetalle.importe = 0; } } break; case 9: //Importe fijo según concepto // Conceptos.Variable oDetalle.importe = oConcepto.variable.Value; break; case 10: // Importe variable que se calcula en el momento // (NO IMPLEMENTADO) break; case 11: // Importe fijo según Conceptos Particulares // ConceptosPartic.Importe oDetalle.importe = oConceptoParticular.importe; break; } return(oDetalle); }
private void CargarFacturaFutura(string periodo, int idSocio) { decimal NetoConIVA = 0; decimal NetoSinIVA = 0; int idMedidor = 0; facturas oFactura = new facturas(); FacturasImplement oFacturaImplement = new FacturasImplement(); oFactura = oFacturaImplement.Get(_idFactura); _oFactura = new facturas(); _oFactura.id_socio = _idSocio; //oFactura.id_medicion Ver como soluciono el idMedicion _oFactura.id_estadoPago = 1; //Impaga _oFactura.id_tarifa = 0; //aun no se carga _oFactura.id_convenio = 0; //Aun no se carga _oFactura.fechaPago = null; _oFactura.cobrado = 0; _oFactura.neto1 = 0; _oFactura.neto2 = 0; _oFactura.importeNeto = 0; _oFactura.importeTotal = 0; _oFactura.id_medicion = 0; // obtengo solo los conceptos activos IList listaConceptos = new ConceptoImplement().GetActivosAll(); SocioConexionImplement oSocioConexionImpl = new SocioConexionImplement(); DataTable DTUsuariosAFacturar = oSocioConexionImpl.GetSociosAFacturar(periodo, idSocio); if (DTUsuariosAFacturar.Rows[0]["medidor"].ToString() != "") { socios_mediciones oSocioMedicionActual = new socios_mediciones(); SocioMedicionImplement oSocioMedicionImplement = new SocioMedicionImplement(); oSocioMedicionActual = oSocioMedicionImplement.ultimaMedicion(int.Parse(DTUsuariosAFacturar.Rows[0]["id_socio"].ToString())); socios_mediciones oSocioMedicionNew = new socios_mediciones(); oSocioMedicionNew.fecha_lectura = null; oSocioMedicionNew.id_socio = _idSocio; decimal consumo = 0; if (oSocioMedicionActual != null) { consumo = (decimal)decimal.Parse((oSocioMedicionActual.consumo * 0.75).ToString()); oSocioMedicionNew.consumo = (int)Math.Truncate(consumo); oSocioMedicionNew.lectura = oSocioMedicionActual.lectura + oSocioMedicionNew.consumo; } else { oSocioMedicionNew.consumo = 0; oSocioMedicionNew.lectura = 0; } idMedidor = oSocioMedicionImplement.Save(oSocioMedicionNew); } _oFactura.id_medicion = idMedidor;//Cargo 0 si no tiene medidor // recorre toda la base de conceptos foreach (cod_conceptos oConcepto in listaConceptos) { bool CorrespondeFacturar = false; if (_oFactura.id_medicion.Value != 0) { //SocioMedicionImplement oSosioMedicionImpl = new SocioMedicionImplement(); //socios_mediciones oSocioMedicion = new socios_mediciones(); //oSocioMedicion = oSosioMedicionImpl.Get(oFactura.id_medicion.Value); } acciones oAccion = new acciones(); conceptos_particulares oConceptoParticular = new conceptos_particulares(); conceptosParticularesImplement oConceptoParticularImplement = new conceptosParticularesImplement(); AccionImplement oAccionesImplement = new AccionImplement(); if (oConcepto.aplicacion == 2) { // si concepto Particular oConceptoParticular = oConceptoParticularImplement.GetByFilter(idSocio, oConcepto.id_concepto, _oFactura.id_periodo); if (oConceptoParticular != null) { CorrespondeFacturar = true; } else { // No encontrado entonces no corresponde facturar CorrespondeFacturar = false; } } else { //Concepto Activo y no particular entonces corresponde facturar CorrespondeFacturar = true; } if (CorrespondeFacturar) { facturas_detalles oDetalle = new facturas_detalles(); FacturasDetallesImplement oFacturasDetallesImplement = new FacturasDetallesImplement(); //ConvenioImplement oConvenioImplement = new ConvenioImplement(); CalculosFacturacionFormulas oCalculosFacturacionFormulas = new CalculosFacturacionFormulas(); oDetalle = oCalculosFacturacionFormulas.getDetalle(idSocio, decimal.Parse(DTUsuariosAFacturar.Rows[0]["cargo_fijo"].ToString()), decimal.Parse(DTUsuariosAFacturar.Rows[0]["abono"].ToString()), decimal.Parse(DTUsuariosAFacturar.Rows[0]["valor_m3"].ToString()), oConcepto, _oFactura, oConceptoParticular); if (oDetalle.importe != 0) { AgregarDetalle(oDetalle); } // Calcula los subtotales separados para los conceptos con y sin IVA if (oConcepto.aplicar_iva.Value) { NetoConIVA = NetoConIVA + oDetalle.importe; } else { NetoSinIVA = NetoSinIVA + oDetalle.importe; } // Calcula los campos Neto1 y Neto2 utilizados en los // cálculos de intereses if (oConcepto.aplicar_recargo.Value) { oFactura.neto1 = oFactura.neto1.Value + Convert.ToSingle(oDetalle.importe); } else { oFactura.neto2 = oFactura.neto2.Value + Convert.ToSingle(oDetalle.importe); } } } cod_conceptos oConceptoIVA = new cod_conceptos(); ConceptoImplement oConceptoImplement = new ConceptoImplement(); facturas_detalles oDetalleFac = new facturas_detalles(); oConceptoIVA = oConceptoImplement.Get(23);//concepto IVA es el 23 oDetalleFac.id_concepto = oConceptoIVA.id_concepto; oDetalleFac.id_factura = 0; oDetalleFac.idOrden = oConceptoIVA.orden_concepto; oDetalleFac.idTipo = 0; oDetalleFac.importe = decimal.Round(NetoConIVA * decimal.Parse(DTUsuariosAFacturar.Rows[0]["iva"].ToString()) / 100, 2); AgregarDetalle(oDetalleFac); }
private void Refacturar1() { decimal NetoConIVA = 0; decimal NetoSinIVA = 0; decimal SubTotal = 0; SocioConexionImplement oSocioConexionImplement = new SocioConexionImplement(); DataTable DTMedidores = oSocioConexionImplement.GetEstadosMedidores(); IList listaConceptos = new ConceptoImplement().GetActivosAll(); DataTable DTUsuariosAFacturar = oSocioConexionImplement.GetSociosAFacturar(_periodo, _idSocio); _oFactura = new facturas(); _oFactura.id_socio = _idSocio; //oFactura.id_medicion Ver como soluciono el idMedicion _oFactura.id_estadoPago = 1; //Impaga _oFactura.id_tarifa = 0; //aun no se carga _oFactura.id_convenio = 0; //Aun no se carga _oFactura.fechaPago = null; _oFactura.cobrado = 0; _oFactura.neto1 = 0; _oFactura.neto2 = 0; _oFactura.importeNeto = 0; _oFactura.importeTotal = 0; _oFactura.id_medicion = 0; if (DTUsuariosAFacturar.Rows[0]["medidor"].ToString() != "") { //preguntar como hago con la medicion? //socios_mediciones oSocioMedicionActual = new socios_mediciones(); //SocioMedicionImplement oSocioMedicionImplement = new SocioMedicionImplement(); //oSocioMedicionActual = oSocioMedicionImplement.ultimaMedicion(_idSocio); //socios_mediciones oSocioMedicionNew = new socios_mediciones(); //oSocioMedicionNew.fecha_lectura = null; //oSocioMedicionNew.id_socio =_idSocio; NetoConIVA = 0; NetoSinIVA = 0; foreach (cod_conceptos oConcepto in listaConceptos) { bool CorrespondeFacturar = false; if (DTUsuariosAFacturar.Rows[0]["medidor"].ToString() != "") { //SocioMedicionImplement oSosioMedicionImpl = new SocioMedicionImplement(); //socios_mediciones oSocioMedicion = new socios_mediciones(); //oSocioMedicion = oSosioMedicionImpl.Get(oFactura.id_medicion.Value); } acciones oAccion = new acciones(); conceptos_particulares oConceptoParticular = new conceptos_particulares(); conceptosParticularesImplement oConceptoParticularImplement = new conceptosParticularesImplement(); AccionImplement oAccionesImplement = new AccionImplement(); if (oConcepto.aplicacion == 2) { // si concepto Particular oConceptoParticular = oConceptoParticularImplement.GetByFilter(_idSocio, oConcepto.id_concepto, _periodo); if (oConceptoParticular != null) { CorrespondeFacturar = true; } else { // No encontrado entonces no corresponde facturar CorrespondeFacturar = false; } } else { //Concepto Activo y no particular entonces corresponde facturar CorrespondeFacturar = true; } if (CorrespondeFacturar) { facturas_detalles oDetalle = new facturas_detalles(); FacturasDetallesImplement oFacturasDetallesImplement = new FacturasDetallesImplement(); //ConvenioImplement oConvenioImplement = new ConvenioImplement(); CalculosFacturacionFormulas oCalculosFacturacionFormulas = new CalculosFacturacionFormulas(); oDetalle = oCalculosFacturacionFormulas.getDetalle(_idSocio, decimal.Parse(DTUsuariosAFacturar.Rows[0]["cargo_fijo"].ToString()), decimal.Parse(DTUsuariosAFacturar.Rows[0]["abono"].ToString()), decimal.Parse(DTUsuariosAFacturar.Rows[0]["valor_m3"].ToString()), oConcepto, _oFactura, oConceptoParticular); if (oDetalle.importe != 0) { AgregarDetalle(oDetalle); } // Calcula los subtotales separados para los conceptos con y sin IVA if (oConcepto.aplicar_iva.Value) { NetoConIVA = NetoConIVA + oDetalle.importe; } else { NetoSinIVA = NetoSinIVA + oDetalle.importe; } // Calcula los campos Neto1 y Neto2 utilizados en los // cálculos de intereses if (oConcepto.aplicar_recargo.Value) { _oFactura.neto1 = _oFactura.neto1.Value + Convert.ToSingle(oDetalle.importe); } else { _oFactura.neto2 = _oFactura.neto2.Value + Convert.ToSingle(oDetalle.importe); } } } // Obtiene el subtotal general como suma de los // subtotales parciales con y sin IVA SubTotal = NetoConIVA + NetoSinIVA; // Redondea el subtotal a dos dígitos SubTotal = decimal.Round(SubTotal, 2); // Registra el subtotal general _oFactura.importeNeto = Convert.ToSingle(SubTotal); // Calcula IVA (sólo para los conceptos que corresponde) facturas_detalles oFacDetalle = new facturas_detalles(); FacturasDetallesImplement oFacDetalleImplement = new FacturasDetallesImplement(); cod_conceptos oConceptoIVA = new cod_conceptos(); ConceptoImplement oConceptoImplement = new ConceptoImplement(); oConceptoIVA = oConceptoImplement.Get(23);//concepto IVA es el 23 oFacDetalle.id_concepto = oConceptoIVA.id_concepto; oFacDetalle.id_factura = 0; oFacDetalle.idOrden = oConceptoIVA.orden_concepto; oFacDetalle.idTipo = 0; oFacDetalle.importe = decimal.Round(NetoConIVA * decimal.Parse(DTUsuariosAFacturar.Rows[0]["iva"].ToString()) / 100, 2); AgregarDetalle(oFacDetalle); // Calcula Total _oFactura.importeTotal = _oFactura.importeNeto.Value + Convert.ToSingle(oFacDetalle.importe); //este ahi que ver el tipo de dato //// Generar entradas en la base de CuentasCorrientes //CuentaCorrienteImplement oCuentaCorrienteImplement = new CuentaCorrienteImplement(); //cuentas_corrientes oCuentaCorriente = new cuentas_corrientes(); //oCuentaCorriente.fecha = DateTime.Now; //oCuentaCorriente.id_factura = _idFactura; //oCuentaCorriente.id_movimiento = 1; //oCuentaCorriente.id_socio = _idSocio; //oCuentaCorriente.importe_credito = 0; //oCuentaCorriente.importe_saldo = 0; //oCuentaCorriente.importe_debito = Convert.ToDecimal(oFactura.importeTotal); //oCuentaCorriente.id_cobranza = 0; //oCuentaCorrienteImplement.Save(oCuentaCorriente); } }
public facturas_detalles getDetalle(int idSocio, decimal cargoFijo, decimal abono, decimal valorM3, cod_conceptos oConcepto, facturas oFactura, conceptos_particulares oConceptoParticular) { SocioMedicionImplement oSocioMedicionImpl = new SocioMedicionImplement(); socios_mediciones oSocioMedicion = new socios_mediciones(); if (oFactura.id_medicion.Value!=0) oSocioMedicion = oSocioMedicionImpl.Get(oFactura.id_medicion.Value); acciones oAccion = new acciones(); AccionImplement oAccionesImplement = new AccionImplement(); facturas_detalles oDetalle = new facturas_detalles(); oDetalle.idOrden = oConcepto.orden_concepto; oDetalle.id_concepto = oConcepto.id_concepto; oDetalle.idTipo = 0; oDetalle.id_factura = oFactura.id_factura; ConvenioImplement oConvenioImplement = new ConvenioImplement(); switch (oConcepto.id_formula) { case 0: oDetalle.importe = cargoFijo; break; case 1: if (cargoFijo> 0) { oDetalle.importe = cargoFijo * oConcepto.variable.Value; } else { if (oFactura.id_medicion.Value != 0) {//revisar if ((oSocioMedicion.consumo - abono) <= 0) { // Si no hubo consumo excedente ... oDetalle.importe = abono * valorM3 * oConcepto.variable.Value; } else { // Si hubo consumo excedente ... decimal uno = (abono * valorM3); decimal dos = ((oSocioMedicion.consumo.Value - abono) * valorM3); oDetalle.importe = (uno + dos) * oConcepto.variable.Value; } } else { //Por que no tiene medidor usa el abono oDetalle.importe = abono * valorM3 * oConcepto.variable.Value; } } break; case 2: // Consumo excedente por ValorM3 // (Facturas.Consumo - Socios.Tarifa->Abono) * // Socios.Tarifa->ValorM3 if (oFactura.id_medicion.Value != 0) { oSocioMedicion = oSocioMedicionImpl.Get(oFactura.id_medicion.Value); if ((oSocioMedicion.consumo.Value - abono) > 0) { // ' Calcula sólo sobre el consumo excedente oDetalle.importe = (oSocioMedicion.consumo.Value - abono) * valorM3; } else { // No hubo consumo excedente oDetalle.importe = 0; } }else oDetalle.importe = 0; break; case 3: // ' Abono por ValorM3 //' Socios.Tarifa->Abono * Socios.Tarifa->ValorM3 oDetalle.importe = abono * valorM3; break; case 4: //' Consumo por ValorM3 por Variable //' Facturas.Consumo * Socios.Tarifa->ValorM3 * Conceptos.Variable if (oFactura.id_medicion.Value != 0) oDetalle.importe = oSocioMedicion.consumo.Value * valorM3 * oConcepto.variable.Value; else oDetalle.importe = 0; break; case 5: oAccion = oAccionesImplement.GetByIdSocio(idSocio); if (oAccion != null) { if (oAccion.cuotas > oAccion.facturadas) { oAccion.facturadas = oAccion.facturadas + 1; oAccionesImplement.Update(oAccion); oDetalle.importe = oAccion.valor_cuota; } else { oDetalle.importe = 0; } } else { oDetalle.importe = 0; } break; case 6: // Variable por Cuota Acciones // Acciones.ValorCuota * Conceptos.Variable // Buscar Acciones oAccion = oAccionesImplement.GetByIdSocio(idSocio); // Si encuentra un registro if (oAccion != null) { // Pregunta si no está finalizado if (oAccion.cuotas > oAccion.facturadas) { //Si no ha finalizado se factura una cuota más oAccion.facturadas = oAccion.facturadas + 1; oAccionesImplement.Update(oAccion); oDetalle.importe = oAccion.valor_cuota * oConcepto.variable.Value; } else { oDetalle.importe = 0; } } else { oDetalle.importe = 0; } break; case 7: // Cuota Convenio de pago // Convenios.ValorCuota decimal ImporteConvenios = 0; // Inicializa el campo en cero oDetalle.importe = 0; // Buscar Convenio IList ListConvenios = oConvenioImplement.GetAllBySocio(idSocio); foreach (convenios oConvenio in ListConvenios) { // Verifica que no se trate de un convenio judicial if (!oConvenio.convenio_judicial.Value) { //Pregunta si no está finalizado if (oConvenio.cuotas > oConvenio.facturadas) { //Si no ha finalizado se factura una cuota más oConvenio.facturadas = oConvenio.facturadas + 1; if (oConvenio.cuotas == oConvenio.facturadas) { oConvenio.finalizado = true; } oConvenioImplement.Update(oConvenio); ImporteConvenios = ImporteConvenios + oConvenio.valor_cuota; } } } oDetalle.importe = ImporteConvenios; break; case 8: // Variable por Cuota Convenio // Convenios.ValorCuota * Conceptos.Variable // Buscar Convenio IList ListaConvenios = oConvenioImplement.GetAllBySocio(idSocio); //Si encuentra un registro oDetalle.importe = 0; foreach (convenios oConvenio in ListaConvenios) { // Verifica que no se trate de un convenio judicial if (!oConvenio.convenio_judicial.Value) { //Pregunta si no está finalizado if (oConvenio.cuotas > oConvenio.facturadas) { oConvenio.facturadas = oConvenio.facturadas + 1; oConvenioImplement.Update(oConvenio); oDetalle.importe = oConvenio.valor_cuota * oConcepto.variable.Value; } else { oDetalle.importe = 0; } } else { oDetalle.importe = 0; } } break; case 9: //Importe fijo según concepto // Conceptos.Variable oDetalle.importe = oConcepto.variable.Value; break; case 10: // Importe variable que se calcula en el momento // (NO IMPLEMENTADO) break; case 11: // Importe fijo según Conceptos Particulares // ConceptosPartic.Importe oDetalle.importe = oConceptoParticular.importe; break; } return oDetalle; }