private void btnGuardar_Click(object sender, EventArgs e) { llave = new LlaveFactura(); llave.txtNroAutorizacion = txtNroAutorizacion.Text; llave.txtLlave = @txtLlave.Text; llave.dateFechaLimite = Convert.ToDateTime(dtFechaLimite.Text); LlaveFacturaBLL.InsertObjetoLlaveFactura(llave, 1); MessageBox.Show("El registro se ha inserto correctamente"); this.Dispose(); }
public frmVentas() { this.Text = "Realizar Venta"; InitializeComponent(); txtNombreCliente.GotFocus += txtNombreCliente_Click; objLiteral = new NumeralToLiteral(); fecha = DateTime.Now.Year + ""; fecha += DateTime.Now.Month + ""; fecha += DateTime.Now.Day + ""; llave = LlaveFacturaBLL.GetLastLlaveFactura(); lastFactura = FacturaBLL.GetLastFactura(); lastLibroVenta = LibroVentasBLL.GetLastLibroVentas(); listaProductos = new List <Producto>(); cargarBoxDescuentos(); sumaReal = 0; sumaDescuentos = 0; }
private void btnGuardar_Click(object sender, EventArgs e) { if (validarStock() == true) { if (txtNitCliente.Text != "" && txtNombreCliente.Text != "" && tblDetalleVenta.RowCount > 0) { string nroFact = getNroFactura().ToString(); int idCliente; if (objCliente == null) { int idPersona = PersonaBLL.InsertDatosPersona(txtNitCliente.Text, txtNombreCliente.Text, "", "", "", "", 1); idCliente = ClienteBLL.InsertDatosCliente(idPersona, 1); } else { idCliente = objCliente.pkCliente; } int idFactura = 0; if (llave != null && llave.txtLlave != "") { idFactura = FacturaBLL.InsertarFactura(0, idCliente, 2, Convert.ToInt32(boxDescuentos.SelectedValue), 1, nroFact, llave.txtNroAutorizacion, llave.txtLlave, Convert.ToDecimal(sumarTotalVenta()), 1); } else { MessageBox.Show("USTED NO HA INGRESADO LA LLAVE NI EL CODIGO DE AUTORIZACIÓN DE LA FACTURA"); return; } foreach (DataGridViewRow fila in tblDetalleVenta.Rows) { if (Convert.ToInt32(fila.Cells["txtCantidad"].Value.ToString()) > 0) { if (fila.Cells["idProducto"] != null) { GananciasDTO ganancias = new GananciasDTO(); ganancias.fkProducto = Convert.ToInt32(fila.Cells["idProducto"].Value.ToString()); ganancias.intCantidad = Convert.ToInt32(fila.Cells["txtCantidad"].Value.ToString()); Producto pro = ProductoBLL.GetProductById(ganancias.fkProducto); ganancias.decValorVenta = pro.decValorVenta; ganancias.decValorCompra = pro.decValorCompra; ganancias.decTotal = Convert.ToDecimal(fila.Cells["txtSubTotal"].Value.ToString()); DetalleVentaBLL.InsertarDetalleVenta(0, Convert.ToInt32(fila.Cells["idProducto"].Value.ToString()), idFactura, Convert.ToInt32(fila.Cells["txtCantidad"].Value.ToString()), Convert.ToDecimal(fila.Cells["txtSubTotal"].Value.ToString())); GananciasBLL.InsertObjetoGanancias(ganancias); Producto auxProducto = getProductoOfList(fila.Cells["idProducto"].Value.ToString()); auxProducto.intCantidad -= Convert.ToInt32(fila.Cells["txtCantidad"].Value.ToString()); ProductoBLL.UpdateProducto(auxProducto); sumaReal += (double)auxProducto.decValorVenta * Convert.ToInt32(fila.Cells["txtCantidad"].Value.ToString()); sumaDescuentos += Convert.ToDouble(fila.Cells["txtSubTotal"].Value.ToString()); } } else { MessageBox.Show("Usted a ingresado una cantidad de 0"); return; } } if (lastLibroVenta != null) { if (lastLibroVenta.txtMes == DateTime.Now.Month.ToString() && lastLibroVenta.txtAño == DateTime.Now.Year.ToString()) { List <DetalleLibroVentas> lista = DetalleLibroVentasBLL.GetDetalleLibroVentasByIdLibro(lastLibroVenta.pkLibro); int lastNro = 0; if (lista.Count != 0) { lastNro = lista[(lista.Count - 1)].intNro; } if (sumaReal == sumaDescuentos) { sumaDescuentos = 0; } double dif = sumaReal - sumaDescuentos; double db = 0; if (dif == sumaReal) { db = sumaReal * 13 / 100; } else { db = (sumaReal - dif) * 13 / 100; } DetalleLibroVentasBLL.InsertDatosDetalleLibroVentas(lastNro + 1, DateTime.Now, nroFact, llave.txtNroAutorizacion, txtNitCliente.Text, txtNombreCliente.Text, Convert.ToDecimal(sumaReal), 0, 0, 0, Convert.ToDecimal(sumaReal), (dif == sumaReal) ? 0 : Convert.ToDecimal(dif), (dif == sumaReal) ? Convert.ToDecimal(sumaReal) : Convert.ToDecimal(sumaReal - dif), Convert.ToDecimal(db), getCodigoControl(), lastLibroVenta.pkLibro, 1); } else { int pkLibro = LibroVentasBLL.InsertDatosLibroVentas(DateTime.Now.Month.ToString(), DateTime.Now.Year.ToString()); int lastNro = 0; if (sumaReal == sumaDescuentos) { sumaDescuentos = 0; } double dif = sumaReal - sumaDescuentos; double db = 0; if (dif == sumaReal) { db = sumaReal * 13 / 100; } else { db = (sumaReal - dif) * 13 / 100; } DetalleLibroVentasBLL.InsertDatosDetalleLibroVentas(lastNro + 1, DateTime.Now, nroFact, llave.txtNroAutorizacion, txtNitCliente.Text, txtNombreCliente.Text, Convert.ToDecimal(sumaReal), 0, 0, 0, Convert.ToDecimal(sumaReal), (dif == sumaReal) ? 0 : Convert.ToDecimal(dif), (dif == sumaReal) ? Convert.ToDecimal(sumaReal) : Convert.ToDecimal(sumaReal - dif), Convert.ToDecimal(db), getCodigoControl(), pkLibro, 1); } } else { int pkLibro = LibroVentasBLL.InsertDatosLibroVentas(DateTime.Now.Month.ToString(), DateTime.Now.Year.ToString()); int lastNro = 0; if (sumaReal == sumaDescuentos) { sumaDescuentos = 0; } double dif = sumaReal - sumaDescuentos; double db = 0; if (dif == sumaReal) { db = sumaReal * 13 / 100; } else { db = (sumaReal - dif) * 13 / 100; } DetalleLibroVentasBLL.InsertDatosDetalleLibroVentas(lastNro + 1, DateTime.Now, nroFact, llave.txtNroAutorizacion, txtNitCliente.Text, txtNombreCliente.Text, Convert.ToDecimal(sumaReal), 0, 0, 0, Convert.ToDecimal(sumaReal), (dif == sumaReal) ? 0 : Convert.ToDecimal(dif), (dif == sumaReal) ? Convert.ToDecimal(sumaReal) : Convert.ToDecimal(sumaReal - dif), Convert.ToDecimal(db), getCodigoControl(), pkLibro, 1); } if (original == " COPIA") { original = "ORIGINAL"; } imprimirFactura(); original = " COPIA"; imprimirFactura(); tblDetalleVenta.RowCount = 0; txtNitCliente.Text = ""; txtNombreCliente.Text = ""; sumaReal = 0; sumaDescuentos = 0; lastFactura = FacturaBLL.GetLastFactura(); llave = LlaveFacturaBLL.GetLastLlaveFactura(); lastFactura = FacturaBLL.GetLastFactura(); lastLibroVenta = LibroVentasBLL.GetLastLibroVentas(); listaProductos = new List <Producto>(); } else { MessageBox.Show("Debe ingresar el nit, el nombre del cliente y al menos un producto"); } } }
public string generarCuerpoFactura(string nro, string autorizacion, string fecha, string hora, string nit, string nombre, List <DetalleVenta> productos, string total, string codigo) { string factura = ""; factura += " MINILULIS" + "\n"; factura += " BARRIO URBARI AV. BARRIENTOS NRO.24" + "\n"; factura += " COND. TORRE MANGABEIRA P.B. OF. 2" + "\n"; factura += " TELÉFONO: 3599175" + "\n"; factura += " SANTA CRUZ - BOLIVIA" + "\n"; factura += " FACTURA" + "\n"; factura += " " + original + "\n"; factura += "------------------------------------------------------------------" + "\n"; factura += " NIT: 4648284010" + "\n"; factura += " NRO. FACTURA: " + rellenarConCeros(5, nro) + "\n"; factura += " NRO. AUTORIZACIÓN: " + autorizacion + "\n"; factura += "------------------------------------------------------------------" + "\n"; factura += " COMERCIO MINORISTA" + "\n"; factura += "------------------------------------------------------------------" + "\n"; factura += " FECHA: " + fecha + " " + hora + "\n"; factura += " NIT/CI: " + nit + "\n"; factura += " SEÑOR(ES): " + nombre + "\n"; factura += "------------------------------------------------------------------" + "\n"; factura += String.Format("{0,-20} {1,-20} {2}", "CANT.", "PRODUCTO", "SUB-TOTAL") + "\n"; factura += "------------------------------------------------------------------" + "\n"; foreach (DetalleVenta item in productos) { Producto auxProd = ProductoBLL.GetProductById(item.fkProducto); string nam = ""; if (auxProd.txtNombre.Length >= 12) { nam = auxProd.txtNombre.Substring(0, 12) + "..."; } else { nam = auxProd.txtNombre; if (rellenarDecimales(item.decimalTotal + "").Length == 5) { while (nam.Length < 20) { nam += " "; } nam += "..."; } else { while (nam.Length < 15) { nam += " "; } nam += "..."; } } factura += String.Format(" {0,-20} {1,-20} {2,17}", item.intCantidad, nam, rellenarDecimales(item.decimalTotal + "")) + "\n"; } factura += "------------------------------------------------------------------" + "\n"; if (total.Length == 7) { factura += " TOTAL BS. " + rellenarDecimales(total) + "\n"; } else { factura += " TOTAL BS. " + rellenarDecimales(total) + "\n"; } factura += "------------------------------------------------------------------" + "\n"; factura += " SON: " + objLiteral.Convertir(rellenarDecimales(total), true) + "\n"; factura += " CÓDIGO DE CONTROL: " + codigo + "\n"; LlaveFactura llave = LlaveFacturaBLL.GetLlaveFacturaByAutorizacion(autorizacion); factura += " FECHA LÍMITE DE EMISIÓN: " + llave.dateFechaLimite.ToShortDateString() + "\n"; return(factura); }