public void Facturador(int idVenta, DataGridView dtDetalle) { if (this.lblBanderaComprobante.Text != "0") { enviarFormaPago(); int? tipoDoc; string cantidad, codigo, descr, valorUnitario, dcto, importe, nroDoc, nombre; decimal igvUn, afecIgv, valUn; if (this.txtDocumento.Text.Length == 8) { tipoDoc = 1; nroDoc = this.txtDocumento.Text.Trim(); } else if (this.txtDocumento.Text.Length == 11) { tipoDoc = 6; nroDoc = this.txtDocumento.Text.Trim(); } else { tipoDoc = 1; nroDoc = "0"; } if (this.txtNombre.Text == string.Empty) { nombre = "SIN DNI"; } else { nombre = this.txtNombre.Text.Trim(); } string tipoCompr = ""; if (this.lblBanderaComprobante.Text == "1") { tipoCompr = "BOLETA"; } else if (this.lblBanderaComprobante.Text == "2") { tipoCompr = "FACTURA"; } NFacturador.registrarComprobanteCabecera("01", DateTime.Now.ToString("yyyy-MM-dd"), "", tipoDoc, nroDoc, nombre, "PEN", this.lblDctoGeneral.Text.Trim(), "0.00", this.lblDctoGeneral.Text.Trim(), this.lblSubTotal.Text.Trim(), "0.00", "0.00", this.lblIgv.Text.Trim(), "0.00", "0.00", this.lblTotal.Text.Trim(), tipoCompr, idVenta); for (int i = 0; i < dtDetalle.Rows.Count; i++) { cantidad = dtDetalle.Rows[i].Cells[2].Value.ToString(); codigo = dtDetalle.Rows[i].Cells[0].Value.ToString(); descr = dtDetalle.Rows[i].Cells[1].Value.ToString(); valorUnitario = dtDetalle.Rows[i].Cells[3].Value.ToString(); valUn = Convert.ToDecimal(valorUnitario); dcto = dtDetalle.Rows[i].Cells[4].Value.ToString(); igvUn = Convert.ToDecimal(valorUnitario) * (18 / 100); afecIgv = (Convert.ToDecimal(cantidad) * Convert.ToDecimal(valorUnitario)) * 0.18m; importe = dtDetalle.Rows[i].Cells[6].Value.ToString(); decimal mtoDsctoItem = Convert.ToDecimal(dcto) / Convert.ToDecimal(cantidad); decimal mtoPrecioVentaItem = Decimal.Round((Convert.ToDecimal(importe) / 1.18m), 2); decimal mtoIgvItem = Convert.ToDecimal(importe) - mtoPrecioVentaItem; decimal mtoValorUnitario = Decimal.Round(mtoPrecioVentaItem / Convert.ToDecimal(cantidad), 2); NFacturador.registrarComprobanteDetalle("NIU", cantidad, codigo, "", descr, mtoValorUnitario.ToString("#0.00#"), mtoDsctoItem.ToString("#0.00#"), mtoIgvItem.ToString("#0.00#"), "10", "0.00", "", mtoPrecioVentaItem.ToString("#0.00#"), importe, tipoCompr, idVenta); /* NFacturador.registrarComprobanteDetalle("NIU", cantidad, codigo, "", descr, (valUn - igvUn).ToString(), dcto, igvUn.ToString(), "10", "0.00", "", valorUnitario, * importe, tipoCompr, idVenta);¨*/ } } }
private void button1_Click(object sender, EventArgs e) { if (this.lblBandera.Text == "0") { string rpta = ""; rpta = NComprobante.AnularComprobante(Convert.ToInt32(frmMostrarVentas.f1.lblIdVenta.Text)); if (rpta == "OK") { DataTable dtDetalle = new DataTable(); dtDetalle = NDetalleVenta.mostrarIDDetalleVenra((Convert.ToInt32(frmMostrarVentas.f1.lblIdVenta.Text))); for (int i = 0; i < dtDetalle.Rows.Count; i++) { NDetalleVenta.ActualizarStockProd_Anulada(Convert.ToInt32(dtDetalle.Rows[i][0].ToString())); DataTable dtCompuesto = new DataTable(); dtCompuesto = NVenta.mostrarDetalleVentaAnulada(Convert.ToInt32(frmMostrarVentas.f1.lblIdVenta.Text)); if (dtCompuesto.Rows[i][8].ToString() == "C") { DataTable dtDetalleProducto = new DataTable(); dtDetalleProducto = NProducto.mostrarDetalleProducto_Venta(Convert.ToInt32(dtCompuesto.Rows[i][0].ToString())); for (int j = 0; j < dtDetalleProducto.Rows.Count; j++) { int idProducto_Com = Convert.ToInt32(dtDetalleProducto.Rows[j][0].ToString()); int cantRequerida = Convert.ToInt32(dtDetalleProducto.Rows[j][1].ToString()); rpta = NProducto.EditarStock(idProducto_Com, ((cantRequerida * Convert.ToInt32(dtCompuesto.Rows[i][2].ToString()) * -1))); DataTable dtRecetaC = NReceta.Mostrar(Convert.ToInt32(idProducto_Com)); if (dtRecetaC.Rows.Count > 0) { int cantInsumo = Convert.ToInt32(dtCompuesto.Rows[i][2].ToString()); decimal cantTotal; for (int k = 0; k < dtRecetaC.Rows.Count; k++) { cantTotal = cantInsumo * Convert.ToDecimal(dtRecetaC.Rows[k][3].ToString()); rpta = NInsumo.EditarStock(Convert.ToInt32(dtRecetaC.Rows[k][0].ToString()), cantTotal * -1); } } } } DataTable dtReceta = NReceta.Mostrar(Convert.ToInt32(dtDetalle.Rows[i][0].ToString())); if (dtReceta.Rows.Count > 0) { int cantInsumo = Convert.ToInt32(dtDetalle.Rows[i][2].ToString()); decimal cantTotal; for (int k = 0; k < dtReceta.Rows.Count; k++) { cantTotal = cantInsumo * Convert.ToDecimal(dtReceta.Rows[k][3].ToString()); NInsumo.EditarStock(Convert.ToInt32(dtReceta.Rows[k][0].ToString()), ((-1) * cantTotal)); } } } rpta = NComprobanteAnulado.Insertar(Convert.ToInt32(frmMostrarVentas.f1.lblIdComprobante.Text), DateTime.Now, frmMostrarVentas.f1.lblSerie.Text, frmMostrarVentas.f1.lblNumero.Text, "ANULADA", this.txtDescripcion.Text.Trim()); if (rpta == "OK") { string tipoDoc; DataTable dtCorrelativo = NComprobanteAnulado.mostrarCorrelativo(DateTime.Now); DateTime fechaGen = Convert.ToDateTime(frmMostrarVentas.f1.lblFechaGene.Text); string fechaConv = fechaGen.ToString("yyyy-MM-dd"); if (frmMostrarVentas.f1.lblComprobante.Text == "FACTURA") { tipoDoc = "01"; } else { tipoDoc = "03"; } if (cbOrigen.Checked == true) { NCaja.Insertar(Convert.ToInt32(frmMostrarVentas.f1.lblIdUsuario.Text), "1", "EGRESO", Convert.ToDecimal(frmMostrarVentas.f1.lblEfectivo.Text), this.txtDescripcion.Text.Trim(), "EFECTIVO"); } NFacturador.bajaComprobante(frmMostrarVentas.f1.lblComprobante.Text, fechaConv, DateTime.Now.ToString("yyyy-MM-dd"), tipoDoc, frmMostrarVentas.f1.lblNumero.Text, this.txtDescripcion.Text, dtCorrelativo.Rows[0][0].ToString()); MessageBox.Show("Se anuló correctamente"); frmMostrarVentas.f1.MostrarTodo(); frmMostrarVentas.f1.btnEliminar.Enabled = false; frmMostrarVentas.f1.btnCancelar.Enabled = false; this.Close(); } } } else if (lblBandera.Text == "5") { string rpta = ""; if (frmCreditosPendientes.f1.lblBanderaAnulacion.Text == "1") { rpta = NComprobante.AnularComprobante(Convert.ToInt32(frmCreditosPendientes.f1.lblIdVenta.Text)); } else if (frmCreditosPendientes.f1.lblBanderaAnulacion.Text == "0") { rpta = "OK"; } if (rpta == "OK") { DataTable dtDetalle = new DataTable(); dtDetalle = NDetalleVenta.mostrarIDDetalleVenra((Convert.ToInt32(frmCreditosPendientes.f1.lblIdVenta.Text))); for (int i = 0; i < dtDetalle.Rows.Count; i++) { NDetalleVenta.ActualizarStockProd_Anulada(Convert.ToInt32(dtDetalle.Rows[i][0].ToString())); DataTable dtCompuesto = new DataTable(); dtCompuesto = NVenta.mostrarDetalleVenta(Convert.ToInt32(frmCreditosPendientes.f1.lblIdVenta.Text)); if (dtCompuesto.Rows[i][8].ToString() == "C") { DataTable dtDetalleProducto = new DataTable(); dtDetalleProducto = NProducto.mostrarDetalleProducto_Venta(Convert.ToInt32(dtCompuesto.Rows[i][0].ToString())); for (int j = 0; j < dtDetalleProducto.Rows.Count; j++) { int idProducto_Com = Convert.ToInt32(dtDetalleProducto.Rows[j][0].ToString()); int cantRequerida = Convert.ToInt32(dtDetalleProducto.Rows[j][1].ToString()); rpta = NProducto.EditarStock(idProducto_Com, ((cantRequerida * Convert.ToInt32(dtCompuesto.Rows[i][2].ToString()) * -1))); DataTable dtRecetaC = NReceta.Mostrar(Convert.ToInt32(idProducto_Com)); if (dtRecetaC.Rows.Count > 0) { int cantInsumo = Convert.ToInt32(dtCompuesto.Rows[i][2].ToString()); decimal cantTotal; for (int k = 0; k < dtRecetaC.Rows.Count; k++) { cantTotal = cantInsumo * Convert.ToDecimal(dtRecetaC.Rows[k][3].ToString()); rpta = NInsumo.EditarStock(Convert.ToInt32(dtRecetaC.Rows[k][0].ToString()), cantTotal * -1); } } } } DataTable dtReceta = NReceta.Mostrar(Convert.ToInt32(dtDetalle.Rows[i][0].ToString())); if (dtReceta.Rows.Count > 0) { int cantInsumo = Convert.ToInt32(dtDetalle.Rows[i][2].ToString()); decimal cantTotal; for (int k = 0; k < dtReceta.Rows.Count; k++) { cantTotal = cantInsumo * Convert.ToDecimal(dtReceta.Rows[k][3].ToString()); NInsumo.EditarStock(Convert.ToInt32(dtReceta.Rows[k][0].ToString()), ((-1) * cantTotal)); } } } if (frmCreditosPendientes.f1.lblBanderaAnulacion.Text == "1") { rpta = NComprobanteAnulado.Insertar(Convert.ToInt32(frmCreditosPendientes.f1.lblIdComprobante.Text), DateTime.Now, "1", frmCreditosPendientes.f1.lblCorrelativo.Text, "ANULADA", this.txtDescripcion.Text.Trim()); if (rpta == "OK") { string tipoDoc; DataTable dtCorrelativo = NComprobanteAnulado.mostrarCorrelativo(DateTime.Now); DateTime fechaGen = Convert.ToDateTime(frmCreditosPendientes.f1.lblFechaCompr.Text); string fechaConv = fechaGen.ToString("yyyy-MM-dd"); if (frmCreditosPendientes.f1.lblTipoComprobante.Text == "FACTURA") { tipoDoc = "01"; } else { tipoDoc = "03"; } if (cbOrigen.Checked == true) { NCaja.Insertar(Convert.ToInt32(1), "1", "EGRESO", Convert.ToDecimal(frmCreditosPendientes.f1.lblEfectivo.Text), this.txtDescripcion.Text.Trim(), "EFECTIVO"); } NFacturador.bajaComprobante(frmCreditosPendientes.f1.lblTipoComprobante.Text, fechaConv, DateTime.Now.ToString("yyyy-MM-dd"), tipoDoc, frmCreditosPendientes.f1.lblCorrelativo.Text, this.txtDescripcion.Text, dtCorrelativo.Rows[0][0].ToString()); MessageBox.Show("Se anuló correctamente"); frmCreditosPendientes.f1.Mostrar(); frmCreditosPendientes.f1.btnAnular.Enabled = false; frmCreditosPendientes.f1.btnCobrar.Enabled = false; this.Close(); } } } } else { string rpta = ""; rpta = NComprobante.AnularComprobante(Convert.ToInt32(lblIdCompro.Text)); if (rpta == "OK") { rpta = NComprobanteAnulado.Insertar(Convert.ToInt32(lblIdCompro.Text), DateTime.Now, this.lblSerie.Text, this.lblNro.Text, "ANULADA", this.txtDescripcion.Text.Trim()); if (rpta == "OK") { string tipoDoc; DataTable dtCorrelativo = NComprobanteAnulado.mostrarCorrelativo(DateTime.Now); DateTime fechaGen = Convert.ToDateTime(lblFecha.Text); string fechaConv = fechaGen.ToString("yyyy-MM-dd"); if (this.lblComprobante.Text == "Factura") { tipoDoc = "01"; } else { tipoDoc = "03"; } NFacturador.bajaComprobante(this.lblComprobante.Text, fechaConv, DateTime.Now.ToString("yyyy-MM-dd"), tipoDoc, lblNro.Text, this.txtDescripcion.Text, dtCorrelativo.Rows[0][0].ToString()); NDelivery.Eliminar(Convert.ToInt32(frmCobroDelivery.f1.lblIdVenta.Text)); NImprimirComanda.imprimirCom(frmCobroDelivery.f1.lblRepartidos.Text, "DELIVERY", "DELIVERY", frmCobroDelivery.f1.dataCocina, "COMANDA ADICIONAL"); if (cbOrigen.Checked) { NCaja.Insertar(Convert.ToInt32(frmPrincipal.f1.lblIdUsuario.Text), "1", "INGRESO", Convert.ToDecimal(lblVuelto.Text), "ANULACION DELIVERY" + txtDescripcion.Text, "EFECTIVO"); MessageBox.Show("Se anuló correctamente"); this.Close(); frmCobroDelivery.f1.Mostrar(); } } } } }
public void Facturador(int idVenta, DataTable dtDetalle) { int? tipoDoc; string cantidad, codigo, descr, valorUnitario, dcto, importe, nroDoc, nombre; decimal igvUn, afecIgv, valUn; if (this.lblNroDoc.Text.Length == 8) { tipoDoc = 1; nroDoc = this.lblNroDoc.Text.Trim(); } else if (this.lblNroDoc.Text.Length == 11) { tipoDoc = 6; nroDoc = this.lblNroDoc.Text.Trim(); } else { tipoDoc = 1; nroDoc = "0"; } if (this.lblCliente.Text == string.Empty) { nombre = "SIN DNI"; } else { nombre = this.lblCliente.Text.Trim(); } string tipoCompr = ""; if (this.lblTipoComprobante.Text == "Boleta") { tipoCompr = "BOLETA"; } else if (this.lblTipoComprobante.Text == "Factura") { tipoCompr = "FACTURA"; } decimal total = Convert.ToDecimal(this.lblTotal.Text); decimal igv = Decimal.Round(total / 1.18m, 2); decimal subTotal = total - igv; NFacturador.registrarComprobanteCabecera("01", DateTime.Now.ToString("yyyy-MM-dd"), "", tipoDoc, nroDoc, nombre, "PEN", "00.00", "0.00", "00.00", subTotal.ToString(), "00.00", "0.00", igv.ToString(), "0.00", "0.00", this.lblTotal.Text, tipoCompr, idVenta); for (int i = 0; i < dtDetalle.Rows.Count; i++) { cantidad = dtDetalle.Rows[i]["Cant"].ToString(); codigo = dtDetalle.Rows[i]["Cod"].ToString(); descr = dtDetalle.Rows[i]["Descripcion"].ToString(); valorUnitario = dtDetalle.Rows[i]["Precio_Un"].ToString(); valUn = Convert.ToDecimal(valorUnitario); dcto = dtDetalle.Rows[i]["Descuento"].ToString(); igvUn = Convert.ToDecimal(valorUnitario) * (18 / 100); afecIgv = (Convert.ToDecimal(cantidad) * Convert.ToDecimal(valorUnitario)) * 0.18m; importe = dtDetalle.Rows[i]["Importe"].ToString(); decimal mtoDsctoItem = Convert.ToDecimal(dcto) / Convert.ToDecimal(cantidad); decimal mtoPrecioVentaItem = Decimal.Round((Convert.ToDecimal(importe) / 1.18m), 2); decimal mtoIgvItem = Convert.ToDecimal(importe) - mtoPrecioVentaItem; decimal mtoValorUnitario = mtoPrecioVentaItem / Convert.ToDecimal(cantidad); NFacturador.registrarComprobanteDetalle("NIU", cantidad, codigo, "", descr, mtoValorUnitario.ToString("#0.00#"), mtoDsctoItem.ToString("#0.00#"), mtoIgvItem.ToString("#0.00#"), "10", "0.00", "", mtoPrecioVentaItem.ToString("#0.00#"), importe, tipoCompr, idVenta); } }
private void button1_Click(object sender, EventArgs e) { if (this.lblBandera.Text == "0") { string rpta = ""; rpta = NComprobante.AnularComprobante(Convert.ToInt32(frmMostrarVentas.f1.lblIdVenta.Text)); if (rpta == "OK") { DataTable dtDetalle = new DataTable(); dtDetalle = NDetalleVenta.mostrarIDDetalleVenra((Convert.ToInt32(frmMostrarVentas.f1.lblIdVenta.Text))); for (int i = 0; i < dtDetalle.Rows.Count; i++) { NDetalleVenta.ActualizarStockProd_Anulada(Convert.ToInt32(dtDetalle.Rows[i][0].ToString())); } rpta = NComprobanteAnulado.Insertar(Convert.ToInt32(frmMostrarVentas.f1.lblIdComprobante.Text), DateTime.Now, frmMostrarVentas.f1.lblSerie.Text, frmMostrarVentas.f1.lblNumero.Text, "ANULADA", this.txtDescripcion.Text.Trim()); if (rpta == "OK") { string tipoDoc; DataTable dtCorrelativo = NComprobanteAnulado.mostrarCorrelativo(DateTime.Now); DateTime fechaGen = Convert.ToDateTime(frmMostrarVentas.f1.lblFechaGene.Text); string fechaConv = fechaGen.ToString("yyyy-MM-dd"); if (frmMostrarVentas.f1.lblComprobante.Text == "FACTURA") { tipoDoc = "01"; } else { tipoDoc = "03"; } if (cbOrigen.Checked == true) { NCaja.Insertar(Convert.ToInt32(frmMostrarVentas.f1.lblIdUsuario.Text), "1", "EGRESO", Convert.ToDecimal(frmMostrarVentas.f1.lblEfectivo.Text), this.txtDescripcion.Text.Trim(), "EFECTIVO"); } NFacturador.bajaComprobante(frmMostrarVentas.f1.lblComprobante.Text, fechaConv, DateTime.Now.ToString("yyyy-MM-dd"), tipoDoc, frmMostrarVentas.f1.lblNumero.Text, this.txtDescripcion.Text, dtCorrelativo.Rows[0][0].ToString()); MessageBox.Show("Se anuló correctamente"); frmMostrarVentas.f1.MostrarTodo(); frmMostrarVentas.f1.btnEliminar.Enabled = false; frmMostrarVentas.f1.btnCancelar.Enabled = false; this.Hide(); } } } else { string rpta = ""; rpta = NComprobante.AnularComprobante(Convert.ToInt32(lblIdCompro.Text)); if (rpta == "OK") { rpta = NComprobanteAnulado.Insertar(Convert.ToInt32(lblIdCompro.Text), DateTime.Now, this.lblSerie.Text, this.lblNro.Text, "ANULADA", this.txtDescripcion.Text.Trim()); if (rpta == "OK") { string tipoDoc; DataTable dtCorrelativo = NComprobanteAnulado.mostrarCorrelativo(DateTime.Now); DateTime fechaGen = Convert.ToDateTime(lblFecha.Text); string fechaConv = fechaGen.ToString("yyyy-MM-dd"); if (this.lblComprobante.Text == "Factura") { tipoDoc = "01"; } else { tipoDoc = "03"; } NFacturador.bajaComprobante(this.lblComprobante.Text, fechaConv, DateTime.Now.ToString("yyyy-MM-dd"), tipoDoc, lblNro.Text, this.txtDescripcion.Text, dtCorrelativo.Rows[0][0].ToString()); NDelivery.Eliminar(Convert.ToInt32(frmCobroDelivery.f1.lblIdVenta.Text)); NImprimirComanda.imprimirCom(frmCobroDelivery.f1.lblRepartidos.Text, "DELIVERY", "DELIVERY", frmCobroDelivery.f1.dataCocina, "COMANDA ADICIONAL"); MessageBox.Show("Se anuló correctamente"); this.Hide(); frmCobroDelivery.f1.Hide(); } } } }