Beispiel #1
0
        private void SumarTotales()
        {
            gvDetalle.BeginDataUpdate();
            gvDetalle.RefreshData();


            var totalbruto = VwNotadebitoclidetList.Where(w => w.DataEntityState != DataEntityState.Deleted).Sum(s => s.Cantidad * s.Preciounitario);

            rTotalbruto.EditValue = totalbruto;

            var totalgravado = VwNotadebitoclidetList.Where(w => w.Gravado && w.DataEntityState != DataEntityState.Deleted).Sum(s => s.Importetotal);

            rTotalgravado.EditValue = totalgravado;

            var totalinafecto = VwNotadebitoclidetList.Where(w => w.Inafecto && w.DataEntityState != DataEntityState.Deleted).Sum(s => s.Importetotal);

            rTotalinafecto.EditValue = totalinafecto;

            var totalexonerado = VwNotadebitoclidetList.Where(w => w.Exonerado && w.DataEntityState != DataEntityState.Deleted).Sum(s => s.Importetotal);

            rtotalexonerado.EditValue = totalexonerado;

            var impuestoSel = ImpuestoList.FirstOrDefault(x => x.Idimpuesto == (int)iIdimpuesto.EditValue);

            if (impuestoSel != null)
            {
                var     porcentajeImpuesto = impuestoSel.Porcentajeimpuesto;
                decimal totalImpuesto      = decimal.Round(totalgravado * (porcentajeImpuesto / 100), 2);
                rTotalimpuesto.EditValue = decimal.Round(totalgravado * (porcentajeImpuesto / 100), 2);
                rImportetotal.EditValue  = totalgravado + totalinafecto + totalexonerado + totalImpuesto;

                //Calculo percepcion
                decimal totalValorPercepcion = VwNotadebitoclidetList.Where(
                    w => w.DataEntityState != DataEntityState.Deleted &&
                    w.Porcentajepercepcion > 0).Sum(s => s.Importetotal * (s.Porcentajepercepcion / 100));
                rPorcentajepercepcion.EditValue = totalValorPercepcion > 0 ? SessionApp.EmpresaSel.Porcentajepercepcion : 0m;

                decimal importetotalpercepcion = Math.Round(totalValorPercepcion * (1 + porcentajeImpuesto / 100), 2);
                rImportetotalpercepcion.EditValue = importetotalpercepcion;
                //fin calculo percepcion

                rTotaldocumento.EditValue = (decimal)rImportetotal.EditValue +
                                            (decimal)rImportetotalpercepcion.EditValue;
            }

            gvDetalle.EndDataUpdate();

            gvDetalle.BestFitColumns(true);
        }
Beispiel #2
0
        private void bmItemsDetalle_ItemClick(object sender, ItemClickEventArgs e)
        {
            var subMenu = e.Item as BarSubItem;

            if (subMenu != null)
            {
                return;
            }
            TipoMantenimiento       tipoMantenimientoItem;
            NotadebitocliMntItemFrm cpventaMntItemFrm;
            VwNotadebitoclidet      vwCpventadetMntItem;

            switch (e.Item.Name)
            {
            case "btnAddItem":

                //Asignar el siguiente item
                vwCpventadetMntItem = new VwNotadebitoclidet();

                //Asignar el siguiente item
                var sgtItem = VwNotadebitoclidetList.Where(w => w.DataEntityState != DataEntityState.Deleted)
                              .OrderByDescending(t => t.Numeroitem)
                              .FirstOrDefault();

                vwCpventadetMntItem.Numeroitem = sgtItem == null ? 1 : sgtItem.Numeroitem + 1;

                tipoMantenimientoItem = TipoMantenimiento.Nuevo;
                cpventaMntItemFrm     = new NotadebitocliMntItemFrm(tipoMantenimientoItem, vwCpventadetMntItem);
                cpventaMntItemFrm.ShowDialog();

                if (cpventaMntItemFrm.DialogResult == DialogResult.OK)
                {
                    VwNotadebitoclidetList.Add(vwCpventadetMntItem);
                    SumarTotales();
                    if (!gvDetalle.IsLastRow)
                    {
                        gvDetalle.MoveLastVisible();
                        gvDetalle.Focus();
                        gvDetalle.FocusedColumn = gvDetalle.Columns["Cantidad"];
                    }
                }


                break;

            case "btnEditItem":
                if (gvDetalle.RowCount == 0)
                {
                    break;
                }


                //itemSel = (VwOrdendeventadet)gvDetalle.GetFocusedRow();
                //if (itemSel.IdOrdendeventadet > 0
                //&& Service.CantidadReferenciasItemOrdendeventa(itemSel.IdOrdendeventadet) > 0)
                //{
                //    XtraMessageBox.Show("El item tiene referencia en salida de almacen no puede modificar el valor.", "Atención", MessageBoxButtons.OK,
                //    MessageBoxIcon.Exclamation);
                //    return;
                //}

                vwCpventadetMntItem   = (VwNotadebitoclidet)gvDetalle.GetFocusedRow();
                tipoMantenimientoItem = TipoMantenimiento.Modificar;
                cpventaMntItemFrm     = new NotadebitocliMntItemFrm(tipoMantenimientoItem, vwCpventadetMntItem);
                cpventaMntItemFrm.ShowDialog();
                if (cpventaMntItemFrm.DialogResult == DialogResult.OK)
                {
                    SumarTotales();
                }


                break;

            case "btnDelItem":
                if (gvDetalle.RowCount == 0)
                {
                    break;
                }

                //itemSel = (VwOrdendeventadet)gvDetalle.GetFocusedRow();
                //if (itemSel.IdOrdendeventadet > 0
                //&& Service.CantidadReferenciasItemOrdendeventa(itemSel.IdOrdendeventadet) > 0)
                //{
                //    XtraMessageBox.Show("El item tiene referencia en salida de almacen no puede eliminar.", "Atención", MessageBoxButtons.OK,
                //    MessageBoxIcon.Exclamation);
                //    return;
                //}

                if (DialogResult.Yes == XtraMessageBox.Show("¿Desea eliminar el item seleccionado?",
                                                            "Eliminar producto", MessageBoxButtons.YesNo,
                                                            MessageBoxIcon.Question, MessageBoxDefaultButton.Button1))
                {
                    vwCpventadetMntItem = (VwNotadebitoclidet)gvDetalle.GetFocusedRow();
                    vwCpventadetMntItem.DataEntityState = DataEntityState.Deleted;

                    if (!gvDetalle.IsFirstRow)
                    {
                        gvDetalle.MovePrev();
                    }

                    SumarTotales();
                    ListarCpVentaReferencia();
                }
                break;
            }
        }
Beispiel #3
0
        private void bmMntItems_ItemClick(object sender, ItemClickEventArgs e)
        {
            var subMenu = e.Item as BarSubItem;

            if (subMenu != null)
            {
                return;
            }



            switch (e.Item.Name)
            {
            case "btnImportar":

                if (!Validaciones())
                {
                    return;
                }

                var maxItem = VwNotadebitoclidetList.Where(w => w.DataEntityState != DataEntityState.Deleted)
                              .OrderByDescending(t => t.Numeroitem)
                              .FirstOrDefault();

                var sgtItem = maxItem == null ? 1 : maxItem.Numeroitem + 1;

                foreach (var item in _vwCpventaimpndList.Where(x => x.Itemseleccionado))
                {
                    VwNotadebitoclidet vwNotadebitooclidet = new VwNotadebitoclidet();
                    vwNotadebitooclidet.Numeroitem               = sgtItem;
                    vwNotadebitooclidet.Idarticulo               = item.Idarticulo;
                    vwNotadebitooclidet.Codigoarticulo           = item.Codigoarticulo;
                    vwNotadebitooclidet.Codigoproveedor          = item.Codigoproveedor;
                    vwNotadebitooclidet.Idunidadmedida           = item.Idunidadmedida;
                    vwNotadebitooclidet.Idalmacen                = item.Idalmacen;
                    vwNotadebitooclidet.Nombremarca              = item.Nombremarca;
                    vwNotadebitooclidet.Nombrearticulo           = item.Nombrearticulo;
                    vwNotadebitooclidet.Cantidad                 = item.Cantidadaimportar;
                    vwNotadebitooclidet.Idunidadmedida           = item.Idunidadmedida;
                    vwNotadebitooclidet.Abrunidadmedida          = item.Abrunidadmedida;
                    vwNotadebitooclidet.Preciounitario           = item.Preciounitarioneto;
                    vwNotadebitooclidet.Especificacion           = item.Especificacion;
                    vwNotadebitooclidet.Descuento1               = 0;
                    vwNotadebitooclidet.Descuento2               = 0;
                    vwNotadebitooclidet.Descuento3               = 0;
                    vwNotadebitooclidet.Descuento4               = 0;
                    vwNotadebitooclidet.Preciounitarioneto       = 0;
                    vwNotadebitooclidet.Importetotal             = 0;
                    vwNotadebitooclidet.Idimpuesto               = item.Idimpuesto;
                    vwNotadebitooclidet.Idcentrodecosto          = item.Idcentrodecosto;
                    vwNotadebitooclidet.Descripcioncentrodecosto = item.Descripcioncentrodecosto;
                    vwNotadebitooclidet.Porcentajepercepcion     = 0;
                    vwNotadebitooclidet.Idarea         = item.Idarea;
                    vwNotadebitooclidet.Nombrearea     = item.Nombrearea;
                    vwNotadebitooclidet.Idproyecto     = item.Idproyecto;
                    vwNotadebitooclidet.Nombreproyecto = item.Nombreproyecto;
                    vwNotadebitooclidet.Idcpventadet   = item.Idcpventadet;

                    vwNotadebitooclidet.Seriecpventa       = item.Seriecpventa;
                    vwNotadebitooclidet.Numerocpventa      = item.Numerocpventa;
                    vwNotadebitooclidet.Serienumerocpventa = item.Serienumerocp;

                    vwNotadebitooclidet.Idtipoafectacionigv = item.Idtipoafectacionigv;
                    vwNotadebitooclidet.Gravado             = item.Gravado;
                    vwNotadebitooclidet.Exonerado           = item.Exonerado;
                    vwNotadebitooclidet.Inafecto            = item.Inafecto;
                    vwNotadebitooclidet.Exportacion         = item.Exportacion;

                    vwNotadebitooclidet.DataEntityState = DataEntityState.Added;

                    //vwNotacreditoclidet.Createdby = UsuarioAutenticado.UsuarioSel.Idusuario;
                    //vwNotacreditoclidet.Creationdate = DateTime.Now;
                    //vwNotacreditoclidet.Modifiedby = null;
                    //vwNotacreditoclidet.Lastmodified = null;

                    sgtItem++;
                    VwNotadebitoclidetList.Add(vwNotadebitooclidet);
                }

                VwCpventaSel = (VwCpventa)gvConsulta.GetFocusedRow();
                DialogResult = DialogResult.OK;

                break;

            case "btnCancelarItem":
                DialogResult = DialogResult.Cancel;
                break;

            case "btnConsultar":
                if (!ValidacionDatosConsulta())
                {
                    return;
                }
                CargarCpVenta();


                break;

            case "btnCerrar":
                DialogResult = DialogResult.OK;
                break;
            }
        }