コード例 #1
0
 public ECompra Seleccionar(string Serie, string Numero)
 {
     try
     {
         SQLParameter[] parameters = new SQLParameter[2];
         parameters[0] = new SQLParameter("@Serie", Serie, SqlDbType.VarChar);
         parameters[1] = new SQLParameter("@Numero", Numero, SqlDbType.VarChar);
         DataRow row = Conexion.ExecuteProcedureD("USP_S_SeleccionarCompra", parameters).Tables[0].Rows[0];
         ECompra be  = new ECompra
         {
             ID              = Convert.ToInt32(row[0]),
             Proveedor       = Convert.ToInt32(row[1]),
             Empleado        = Convert.ToInt32(row[2]),
             TipoComprobante = row[3].ToString(),
             Serie           = row[4].ToString(),
             Numero          = row[5].ToString(),
             Fecha           = Convert.ToDateTime(row[6]),
             SubTotal        = Convert.ToDouble(row[7]),
             Igv             = Convert.ToDouble(row[8]),
             Total           = Convert.ToDouble(row[9]),
             Estado          = Convert.ToInt32(row[10])
         };
         return(be);
     }
     catch
     {
         ECompra be = new ECompra();
         return(be);
     }
 }
コード例 #2
0
        public List <ECompra> Listar()
        {
            List <ECompra> List = new List <ECompra>();

            try
            {
                DataTable data = new DataTable();
                data = Conexion.ExecuteProcedureD("USP_S_ListarCompras").Tables[0];
                foreach (DataRow row in data.Rows)
                {
                    ECompra be = new ECompra
                    {
                        ID              = Convert.ToInt32(row[0]),
                        Proveedor       = Convert.ToInt32(row[1]),
                        Empleado        = Convert.ToInt32(row[2]),
                        TipoComprobante = row[3].ToString(),
                        Serie           = row[4].ToString(),
                        Numero          = row[5].ToString(),
                        Fecha           = Convert.ToDateTime(row[6]),
                        SubTotal        = Convert.ToDouble(row[7]),
                        Igv             = Convert.ToDouble(row[8]),
                        Total           = Convert.ToDouble(row[9]),
                        Estado          = Convert.ToInt32(row[10])
                    };
                    List.Add(be);
                }
            }
            catch
            {
                Console.WriteLine("No se encontro Procedimiento Almacenado");
            }
            return(List);
        }
コード例 #3
0
 public bool Agregar(ECompra obj)
 {
     SQLParameter[] parameters = new SQLParameter[10];
     parameters[0] = new SQLParameter("@Proveedor", obj.Proveedor, SqlDbType.Int);
     parameters[1] = new SQLParameter("@Empleado", obj.Empleado, SqlDbType.Int);
     parameters[2] = new SQLParameter("@TipoComprobante", obj.TipoComprobante, SqlDbType.VarChar);
     parameters[3] = new SQLParameter("@Serie", obj.Serie, SqlDbType.VarChar);
     parameters[4] = new SQLParameter("@Numero", obj.Numero, SqlDbType.VarChar);
     parameters[5] = new SQLParameter("@Fecha", obj.Fecha, SqlDbType.Date);
     parameters[6] = new SQLParameter("@SubTotal", obj.SubTotal, SqlDbType.Decimal);
     parameters[7] = new SQLParameter("@Igv", obj.Igv, SqlDbType.Decimal);
     parameters[8] = new SQLParameter("@Total", obj.Total, SqlDbType.Decimal);
     parameters[9] = new SQLParameter("@Estado", obj.Estado, SqlDbType.Int);
     Response      = Conexion.ExecuteProcedureB("USP_I_AgregarCompra", parameters);
     return(Response);
 }
コード例 #4
0
        public List <ECompra> BuscarxFecha(DateTime FirstDate, DateTime LastDate)
        {
            List <ECompra> List = new List <ECompra>();

            try
            {
                SQLParameter[] parameters = new SQLParameter[2];
                parameters[0] = new SQLParameter("@FirstDate", FirstDate, SqlDbType.Date);
                parameters[1] = new SQLParameter("@LastDate", LastDate, SqlDbType.Date);
                DataTable data = new DataTable();
                data = Conexion.ExecuteProcedureD("USP_S_ListarCompraxFecha", parameters).Tables[0];
                foreach (DataRow row in data.Rows)
                {
                    ECompra be = new ECompra
                    {
                        ID              = Convert.ToInt32(row[0]),
                        Proveedor       = Convert.ToInt32(row[1]),
                        Empleado        = Convert.ToInt32(row[2]),
                        TipoComprobante = row[3].ToString(),
                        Serie           = row[4].ToString(),
                        Numero          = row[5].ToString(),
                        Fecha           = Convert.ToDateTime(row[6]),
                        SubTotal        = Convert.ToDouble(row[7]),
                        Igv             = Convert.ToDouble(row[8]),
                        Total           = Convert.ToDouble(row[9]),
                        Estado          = Convert.ToInt32(row[10])
                    };
                    List.Add(be);
                }
            }
            catch
            {
                Console.WriteLine("No se encontro Procedimiento Almacenado");
            }
            return(List);
        }
コード例 #5
0
        private void GuardarCompra()
        {
            ECompra beCompra = new ECompra
            {
                Proveedor       = Convert.ToInt32(LblIDProveedor.Text),
                Empleado        = Frm_Principal.AccesoUsernameID,
                TipoComprobante = CbxTipoComprobante.SelectedValue.ToString(),
                Serie           = TxtSerie.Text,
                Numero          = TxtNumero.Text,
                Fecha           = Convert.ToDateTime(DtpFecha.Text),
                SubTotal        = Compra_SubTotal,
                Igv             = Compra_Igv,
                Total           = Compra_Total,
                Estado          = 1
            };
            NCompra boCompra = new NCompra();

            if (boCompra.Agregar(beCompra) == true)
            {
                if (MLVDetalle.Items.Count > 0)
                {
                    NDetalleCompra boDetalleCompra = new NDetalleCompra();
                    foreach (ListViewItem items in MLVDetalle.Items)
                    {
                        EDetalleCompra beDetalleCompra = new EDetalleCompra
                        {
                            Serie          = beCompra.Serie,
                            Numero         = beCompra.Numero,
                            Producto       = items.SubItems[0].Text,
                            PrecioUnitario = Convert.ToDouble(items.SubItems[3].Text),
                            Cantidad       = Convert.ToInt32(items.SubItems[4].Text),
                            PrecioTotal    = Convert.ToDouble(items.SubItems[5].Text)
                        };
                        //Agregar dettalle compra
                        if (boDetalleCompra.Agregar(beDetalleCompra) == true)
                        {
                            int    cantidadfinal      = 0;
                            double costounitariofinal = 0;
                            double costototalfinal    = 0;
                            //Obteniendo Ultimo Movimiento
                            NMovimiento boM   = new NMovimiento();
                            EMovimiento datos = boM.SeleccionarUltimoMovimientoProducto(beDetalleCompra.Producto);
                            if (string.IsNullOrEmpty(datos.Producto))
                            {
                                cantidadfinal      = beDetalleCompra.Cantidad;
                                costounitariofinal = beDetalleCompra.PrecioUnitario;
                                costototalfinal    = beDetalleCompra.PrecioTotal;
                            }
                            else
                            {
                                //Si hay datos
                                cantidadfinal      = datos.CantidadFinal + beDetalleCompra.Cantidad;
                                costototalfinal    = datos.CostoTotalFinal + beDetalleCompra.PrecioTotal;
                                costounitariofinal = Math.Round((costototalfinal / cantidadfinal), 2);
                            }
                            EMovimiento beMovimiento = new EMovimiento
                            {
                                Fecha                = DateTime.Now,
                                TipoComprobante      = beCompra.TipoComprobante,
                                Serie                = beCompra.Serie,
                                Numero               = beCompra.Numero,
                                TipoOperacion        = "02",
                                Producto             = beDetalleCompra.Producto,
                                CantidadEntrada      = beDetalleCompra.Cantidad,
                                CostoUnitarioEntrada = beDetalleCompra.PrecioUnitario,
                                CostoTotalEntrada    = beDetalleCompra.PrecioTotal,
                                CantidadSalida       = 0,
                                CostoUnitarioSalida  = 0,
                                CostoTotalSalida     = 0,
                                CantidadFinal        = cantidadfinal,
                                CostoUnitarioFinal   = costounitariofinal,
                                CostoTotalFinal      = costototalfinal
                            };
                            NMovimiento boMovimiento = new NMovimiento();
                            if (boMovimiento.Agregar(beMovimiento) == true)
                            {
                                EInventario beInventario = new EInventario
                                {
                                    Producto        = beMovimiento.Producto,
                                    ValorUnitario   = beMovimiento.CostoUnitarioFinal,
                                    Existencias     = beMovimiento.CantidadFinal,
                                    ValorInventario = beMovimiento.CostoTotalFinal
                                };
                                NInventario boInventario = new NInventario();
                                boInventario.Modificar(beInventario);
                            }
                        }
                    }
                }
                //message
                Frm_Buscar_Compra frm = Owner as Frm_Buscar_Compra;
                frm.Listar();
                Close();
                Frm_Principal.Main.ChangeMessage("La Compra se ingreso correctamente", "Success");
            }
            else
            {
                Frm_Principal.Main.ChangeMessage("Algo salio mal", "Failed");
            }
        }