Exemple #1
0
        public ActionResult Payment(int proveedorId, decimal monto, string referencia, DateTime fecha)
        {
            var abono = new ProveedoresDetalle()
            {
                Abono = monto, ProveedorId = proveedorId, Fecha = fecha, Referencia = referencia
            };

            db.ProveedoresDetalles.Add(abono);
            var proveedor = db.Proveedors.Find(abono.ProveedorId);

            proveedor.Saldo           = Convert.ToDecimal(proveedor.Saldo) - abono.Abono;
            db.Entry(proveedor).State = EntityState.Modified;
            db.SaveChanges();
            return(RedirectToAction("Index"));
        }
Exemple #2
0
        public string PostCompra(int proveedor, string comentario, DateTime fecha, bool credito, [FromBody] ListaCompras listaCompras)
        {
            var compraNueva = new Compra()
            {
                CodigoProveedor = proveedor, Comentario = comentario, Fecha = fecha, Credito = credito
            };

            db.Compras.Add(compraNueva);
            db.SaveChanges();
            var     compras = listaCompras.Listado; //array con productos
            decimal total   = 0;

            foreach (CompraDetalle compra in compras)
            {
                var compraDetalle = new CompraDetalle()
                {
                    CompraId = compraNueva.Id, CodigoProducto = compra.CodigoProducto, Cantidad = compra.Cantidad, Costo = compra.Costo
                };
                total += compraDetalle.Costo.Value * compra.Cantidad.Value;
                var producto = db.Productos.Find(compraDetalle.CodigoProducto);
                producto.Existencia      = producto.Existencia + int.Parse(compraDetalle.Cantidad.ToString());
                db.Entry(producto).State = System.Data.Entity.EntityState.Modified;
                db.CompraDetalles.Add(compraDetalle);
            }

            if (credito == true)
            {
                var _proveedor = db.Proveedors.Find(proveedor);
                _proveedor.Saldo           = Convert.ToDecimal(_proveedor.Saldo) + total;
                db.Entry(_proveedor).State = System.Data.Entity.EntityState.Modified;

                var proveedorDetalle = new ProveedoresDetalle()
                {
                    Fecha = fecha, ProveedorId = proveedor, Credito = total, Referencia = "Compra # " + compraNueva.Id
                };
                db.ProveedoresDetalles.Add(proveedorDetalle);
            }

            db.SaveChanges();
            return(compraNueva.Id.ToString());
        }