예제 #1
0
        private void Save()
        {
            itemPedido.Id         = idPdt;
            itemPedido.CProd      = referencia.Text;
            itemPedido.CEan       = codebarras.Text;
            itemPedido.xProd      = descricao.Text;
            itemPedido.Origem     = origem.Text != "" ? origem.Text.Substring(0, 1) : "0";
            itemPedido.Ncm        = ncm.Text;
            itemPedido.Cest       = cest.Text;
            itemPedido.Cfop       = cfop.Text;
            itemPedido.Quantidade = Validation.ConvertToDouble(quantidade.Text);

            itemPedido.ValorCompra  = Validation.ConvertToDouble(valorUnitario.Text);
            itemPedido.DescontoItem = Validation.ConvertToDouble(valorDesconto.Text);
            itemPedido.Frete        = Validation.ConvertToDouble(valorFrete.Text);
            itemPedido.Seguro       = Validation.ConvertToDouble(valorSeguro.Text);
            itemPedido.Despesa      = Validation.ConvertToDouble(vlrDespesa.Text);
            itemPedido.Total        = Validation.ConvertToDouble(valorTotal.Text);

            itemPedido.Icms = Icms.SelectedValue != null?Icms.SelectedValue.ToString() : "";

            itemPedido.IcmsBase = Validation.ConvertToDouble(icmsBase.Text);
            itemPedido.IcmsAliq = Validation.ConvertToDouble(icmsaliq.Text);
            itemPedido.IcmsVlr  = Validation.ConvertToDouble(icmsvlr.Text);

            itemPedido.IcmsStAliq           = Validation.ConvertToDouble(icmsstaliq.Text);
            itemPedido.IcmsStBaseComReducao = Validation.ConvertToDouble(icmsstbasecomreducao.Text);
            itemPedido.IcmsStBase           = Validation.ConvertToDouble(icmsstbase.Text);
            itemPedido.Icmsstvlr            = Validation.ConvertToDouble(icmsstvlr.Text);

            itemPedido.Pis = Pis.SelectedValue != null?Pis.SelectedValue.ToString() : "";

            itemPedido.PisAliq = Validation.ConvertToDouble(pisaliq.Text);
            itemPedido.PisVlr  = Validation.ConvertToDouble(pisvlr.Text);

            itemPedido.Cofins = Cofins.SelectedValue != null?Cofins.SelectedValue.ToString() : "";

            itemPedido.CofinsAliq = Validation.ConvertToDouble(cofinsaliq.Text);
            itemPedido.CofinsVlr  = Validation.ConvertToDouble(cofinsvlr.Text);

            itemPedido.Ipi = Ipi.SelectedValue != null?Ipi.SelectedValue.ToString() : "";

            itemPedido.IpiAliq = Validation.ConvertToDouble(ipialiq.Text);
            itemPedido.IpiVlr  = Validation.ConvertToDouble(ipivlr.Text);

            itemPedido.Federal   = Validation.ConvertToDouble(federal.Text);
            itemPedido.Estadual  = Validation.ConvertToDouble(estadual.Text);
            itemPedido.Municipal = Validation.ConvertToDouble(municipal.Text);

            itemPedido.Info_Adicional     = infoAdicional.Text;
            itemPedido.Pedido_compra      = pedidoCompra.Text;
            itemPedido.Item_Pedido_Compra = itemPedidoCompra.Text;

            if (itemPedido.Save(itemPedido))
            {
                DialogResult = DialogResult.OK;
                Close();
            }
        }
예제 #2
0
        public void margem()
        {
            var itens = GetDataTable();

            foreach (var item in itens)
            {
                GetId(Validation.ConvertToInt32(item.ID));
                if (_pedidoItem != null)
                {
                    if (_pedidoItem.ValorCompra > 0)
                    {
                        _pedidoItem.TotalCompra = Validation.Round(_pedidoItem.ValorCompra * _pedidoItem.Quantidade);
                        _pedidoItem.Save(_pedidoItem);
                    }
                }
            }
        }
예제 #3
0
        /// <summary>
        /// Adiciona item ao pedido, controla o estoque e atualiza os totais.
        /// </summary>
        private void AddItem()
        {
            if (collection.Lookup(nomeProduto()[0]) > 0 && String.IsNullOrEmpty(PedidoModalItens.NomeProduto))
            {
                var        itemId = collection.Lookup(nomeProduto()[0]);
                Model.Item item   = _mItem.FindById(itemId).WhereFalse("excluir").Where("tipo", "Produtos").FirstOrDefault <Model.Item>();

                if (ModoRapAva == 0)
                {
                    Medidas.SelectedItem = item.Medida;
                }

                double QuantidadeTxt          = Validation.ConvertToDouble(Quantidade.Text);
                double DescontoReaisTxt       = Validation.ConvertToDouble(DescontoReais.Text);
                double DescontoPorcentagemTxt = Validation.ConvertToDouble(DescontoPorcentagem.Text);
                string MedidaTxt = Medidas.Text;
                double PriceTxt  = Validation.ConvertToDouble(Preco.Text);

                #region Controle de estoque
                var controlarEstoque = IniFile.Read("ControlarEstoque", "Comercial");
                if (!string.IsNullOrEmpty(controlarEstoque) && controlarEstoque == "True")
                {
                    if (item.EstoqueAtual <= 0)
                    {
                        Alert.Message("Opps", "Você está sem estoque desse produto.", Alert.AlertType.warning);
                        return;
                    }
                }

                if (PriceTxt == 0)
                {
                    if (DescontoReaisTxt > item.ValorVenda || DescontoReaisTxt > item.Limite_Desconto || DescontoPorcentagemTxt > 101)
                    {
                        Alert.Message("Opps", "Não é permitido dar um desconto maior que o valor do item.", Alert.AlertType.warning);
                        return;
                    }
                }

                if (PriceTxt > 0)
                {
                    if (DescontoReaisTxt > PriceTxt || DescontoPorcentagemTxt >= 101)
                    {
                        Alert.Message("Opps", "Não é permitido dar um desconto maior que o valor do item.", Alert.AlertType.warning);
                        return;
                    }
                }

                double LimiteDescontoIni = 0;
                if (!String.IsNullOrEmpty(IniFile.Read("LimiteDesconto", "Comercial")))
                {
                    LimiteDescontoIni = Validation.ConvertToDouble(IniFile.Read("LimiteDesconto", "Comercial"));
                }

                if (item.Limite_Desconto != 0)
                {
                    if (DescontoReaisTxt > item.Limite_Desconto)
                    {
                        Alert.Message("Opps", "Não é permitido dar um desconto maior que o permitido.", Alert.AlertType.warning);
                        return;
                    }

                    if (PriceTxt > 0)
                    {
                        var porcentagemValor = (PriceTxt / 100 * DescontoPorcentagemTxt);
                        if (porcentagemValor > item.Limite_Desconto)
                        {
                            Alert.Message("Opps", "Não é permitido dar um desconto maior que o permitido.", Alert.AlertType.warning);
                            return;
                        }
                    }

                    if (PriceTxt == 0)
                    {
                        var porcentagemValor = (item.ValorVenda / 100 * DescontoPorcentagemTxt);
                        if (porcentagemValor > item.Limite_Desconto)
                        {
                            Alert.Message("Opps", "Não é permitido dar um desconto maior que o permitido.", Alert.AlertType.warning);
                            return;
                        }
                    }
                }
                else
                {
                    if (LimiteDescontoIni != 0)
                    {
                        if (DescontoReaisTxt > LimiteDescontoIni)
                        {
                            Alert.Message("Opps", "Não é permitido dar um desconto maior que o permitido.", Alert.AlertType.warning);
                            return;
                        }

                        if (PriceTxt == 0)
                        {
                            var porcentagemValor = (item.ValorVenda / 100 * DescontoPorcentagemTxt);
                            if (porcentagemValor > LimiteDescontoIni)
                            {
                                Alert.Message("Opps", "Não é permitido dar um desconto maior que o permitido.", Alert.AlertType.warning);
                                return;
                            }
                        }

                        if (PriceTxt > 0)
                        {
                            var porcentagemValor = (PriceTxt / 100 * DescontoPorcentagemTxt);
                            if (porcentagemValor > LimiteDescontoIni)
                            {
                                Alert.Message("Opps", "Não é permitido dar um desconto maior que o permitido.", Alert.AlertType.warning);
                                return;
                            }
                        }
                    }
                }
                #endregion

                var pedidoItem = new Model.PedidoItem();
                pedidoItem.SetId(0)
                .SetTipo("Produtos")
                .SetPedidoId(_mNota.id_pedido)
                .SetAdicionalNomePdt(nomeProduto()[1])
                .SetItem(item)
                .SetQuantidade(QuantidadeTxt)
                .SetMedida(MedidaTxt)
                .SetDescontoReal(DescontoReaisTxt);

                if (!pedidoItem.SetValorVenda(PriceTxt))
                {
                    if (ModoRapAva == 0)
                    {
                        AlterarModo();
                        ModoRapAvaConfig = 1;
                    }

                    Preco.Select();
                    Preco.Focus();
                    return;
                }

                pedidoItem.SetDescontoPorcentagens(DescontoPorcentagemTxt);
                pedidoItem.SomarTotal();
                pedidoItem.Save(pedidoItem);

                if (item.Tipo == "Produtos")
                {
                    new Controller.Imposto().SetImposto(pedidoItem.GetLastId());

                    // Class Estoque -> Se for igual 'Compras', adiciona a quantidade no estoque do Item, se não Remove a quantidade do estoque do Item
                    if (Home.pedidoPage == "Compras" || Home.pedidoPage == "Devoluções")
                    {
                        new Controller.Estoque(pedidoItem.GetLastId(), Home.pedidoPage, "Adicionar Produto").Add().Item();
                    }
                    else
                    {
                        new Controller.Estoque(pedidoItem.GetLastId(), Home.pedidoPage, "Adicionar Produto").Remove().Item();
                    }
                }

                new Controller.Imposto().SetImposto(pedidoItem.GetLastId());

                // Carrega a Grid com o Item adicionado acima.
                GetDataTableItens(GridListaProdutos, _mNota.id_pedido);

                // Atualiza o total do pedido, e os totais da tela
                LoadTotais();

                // Limpa os campos
                ClearForms();

                // Verifica se modo é avançado e altera para modo simples, apenas se modo simples for padrão
                if (ModoRapAva == 1 && ModoRapAvaConfig == 1)
                {
                    AlterarModo();
                    ModoRapAvaConfig = 0;
                }

                BuscarProduto.Select();
            }
        }
예제 #4
0
        public void SetImposto(int idPedidoItem, int idImposto = 0, string tipo = "", string NCM = "")
        {
            _modelpedidoItem = _modelpedidoItem.FindById(idPedidoItem).FirstOrDefault <Model.PedidoItem>();
            _modelItem       = _modelItem.FindById(_modelpedidoItem.Item).FirstOrDefault <Model.Item>();

            #region IMPOSTO

            if (idImposto == 0)
            {
                if (_modelItem.Count() != 0)
                {
                    switch (tipo)
                    {
                    case "CFe":

                        if (_modelItem.Impostoidcfe == 0)
                        {
                            break;
                        }

                        _modelImposto = _modelImposto.FindById(_modelItem.Impostoidcfe)
                                        .FirstOrDefault <Model.Imposto>();
                        break;

                    default:
                        if (_modelItem.Impostoid == 0)
                        {
                            break;
                        }

                        _modelImposto = _modelImposto.FindById(_modelItem.Impostoid)
                                        .FirstOrDefault <Model.Imposto>();
                        break;
                    }
                }
            }
            else
            {
                _modelImposto = _modelImposto.FindById(idImposto).FirstOrDefault <Model.Imposto>();
            }

            #endregion IMPOSTO

            #region NCM | CEST | ORIGEM

            _modelpedidoItem.Ncm    = string.IsNullOrEmpty(NCM) ? _modelItem.Ncm : NCM;
            _modelpedidoItem.Cest   = _modelItem.Cest;
            _modelpedidoItem.Origem = _modelItem.Origem;

            #endregion NCM | CEST | ORIGEM

            #region CFOP

            _modelpedidoItem.Cfop = _modelImposto.Cfop;

            #endregion CFOP

            #region ICMS

            _modelpedidoItem.Icms = _modelImposto.Icms;

            switch (_modelImposto.Icms)
            {
                #region REGIME NORMAL

            //00 = Tributada integralmente.
            //10 = Tributada e com cobrança do ICMS por substituição tributária
            //20 = Com redução de base de cálculo
            //30 = Isenta ou não tributada e com cobrança do ICMS por substituição tributária
            //40 = Isenta
            //41 = Não tributada
            //50 = Suspensão
            //51 = Diferimento
            //60 = ICMS cobrado anteriormente por substituição tributária
            //70 = Com redução de base de cálculo e cobrança do ICMS por substituição tributária
            //90 = Outros

            case "00":
            case "90":
                _modelpedidoItem.IcmsBase = _modelpedidoItem.Total;
                _modelpedidoItem.IcmsAliq = Validation.RoundAliquotas(_modelImposto.IcmsAliq / 100);
                _modelpedidoItem.IcmsVlr  = Validation.Round(_modelpedidoItem.IcmsBase * _modelpedidoItem.IcmsAliq);
                break;

                #endregion REGIME NORMAL

                #region SIMPLES NACIONAL

            //101 = Tributada pelo Simples Nacional com permissão de crédito
            //102 = Tributada pelo Simples Nacional sem permissão de crédito
            //103 = Isenção do ICMS no Simples Nacional para faixa de receita bruta
            //201 = Tributada pelo Simples Nacional com permissão de crédito e com cobrança do ICMS por Substituição Tributária202 = Tributada pelo Simples Nacional sem permissão de crédito e com cobrança do ICMS por Substituição Tributária
            //202
            //203 = Isenção do ICMS nos Simples Nacional para faixa de receita bruta e com cobrança do ICMS por Substituição Tributária
            //300 = Imune
            //400 = Não tributada pelo Simples Nacional
            //500 = ICMS cobrado anteriormente por substituição tributária (substituído) ou por antecipação
            //900 = Outros

            case "101":
                _modelpedidoItem.Icms101Aliq = Validation.RoundAliquotas(_modelImposto.IcmsAliq / 100);
                _modelpedidoItem.Icms101Vlr  =
                    Validation.Round(_modelpedidoItem.Total * _modelpedidoItem.Icms101Aliq);
                break;

            case "201":
            case "202":
                //---------------ICMS
                _modelpedidoItem.IcmsBase = _modelpedidoItem.Total;
                _modelpedidoItem.IcmsAliq = Validation.RoundAliquotas(_modelImposto.IcmsAliq / 100);
                _modelpedidoItem.IcmsVlr  = Validation.Round(_modelpedidoItem.IcmsBase * _modelpedidoItem.IcmsAliq);
                //---------------ICMS ST
                _modelpedidoItem.IcmsStBase =
                    Validation.Round(_modelpedidoItem.IcmsBase +
                                     _modelpedidoItem.IcmsBase * (_modelImposto.IcmsStIva / 100));
                _modelpedidoItem.IcmsStAliq = Validation.RoundAliquotas(_modelImposto.IcmsStAliq / 100);
                if (_modelImposto.IcmsStReducaoAliq > 0)
                {
                    _modelpedidoItem.IcmsStBase = Validation.Round(
                        _modelpedidoItem.IcmsStBase -
                        _modelpedidoItem.IcmsStBase * (_modelImposto.IcmsStReducaoAliq / 100));
                }
                _modelpedidoItem.Icmsstvlr =
                    Validation.Round(_modelpedidoItem.IcmsStBase * _modelpedidoItem.IcmsStAliq);

                //---------------ICMS ST - ICMS
                _modelpedidoItem.Icmsstvlr =
                    Validation.Round(_modelpedidoItem.Icmsstvlr - _modelpedidoItem.IcmsVlr);

                _modelpedidoItem.IcmsBase = 0;
                _modelpedidoItem.IcmsAliq = 0;
                _modelpedidoItem.IcmsVlr  = 0;
                break;

            case "900":
                break;

                #endregion SIMPLES NACIONAL

            default:

                _modelpedidoItem.IcmsBase = 0;
                _modelpedidoItem.IcmsAliq = 0;
                _modelpedidoItem.IcmsVlr  = 0;

                _modelpedidoItem.IcmsStAliq           = 0;
                _modelpedidoItem.IcmsStBase           = 0;
                _modelpedidoItem.IcmsStBaseComReducao = 0;
                _modelpedidoItem.IcmsStReducaoAliq    = 0;

                break;
            }

            if (_modelpedidoItem.IcmsAliq > 0)
            {
                _modelpedidoItem.IcmsAliq = _modelpedidoItem.IcmsAliq * 100;
            }

            if (_modelpedidoItem.IcmsStAliq > 0)
            {
                _modelpedidoItem.IcmsStAliq = _modelpedidoItem.IcmsStAliq * 100;
            }

            #endregion ICMS

            #region IPI

            _modelpedidoItem.Ipi = _modelImposto.Ipi;

            switch (_modelImposto.Ipi)
            {
            case "50":
            case "99":
                if (_modelImposto.IpiAliq > 0)
                {
                    _modelpedidoItem.IpiAliq = Validation.RoundAliquotas(_modelImposto.IpiAliq / 100);
                    _modelpedidoItem.IpiVlr  = Validation.Round(_modelpedidoItem.Total * _modelpedidoItem.IpiAliq);
                }

                break;

            default:
                _modelpedidoItem.Ipi     = "0";
                _modelpedidoItem.IpiAliq = 0;
                _modelpedidoItem.IpiVlr  = 0;
                break;
            }

            #endregion IPI

            #region PIS

            _modelpedidoItem.Pis = _modelImposto.Pis;

            switch (_modelImposto.Pis)
            {
            case "01":
            case "99":
                if (_modelImposto.PisAliq > 0)
                {
                    _modelpedidoItem.PisAliq = Validation.RoundAliquotas(_modelImposto.PisAliq / 100);
                    _modelpedidoItem.PisVlr  = Validation.Round(_modelpedidoItem.Total * _modelpedidoItem.PisAliq);
                }

                break;

            default:
                _modelpedidoItem.PisAliq = 0;
                _modelpedidoItem.PisVlr  = 0;
                break;
            }

            if (_modelpedidoItem.PisAliq > 0)
            {
                _modelpedidoItem.PisAliq = _modelpedidoItem.PisAliq * 100;
            }

            if (string.IsNullOrEmpty(_modelpedidoItem.Pis))
            {
                _modelpedidoItem.Pis = "0";
            }

            #endregion PIS

            #region COFINS

            _modelpedidoItem.Cofins = _modelImposto.Cofins;

            switch (_modelImposto.Cofins)
            {
            case "01":
            case "99":
                if (_modelImposto.CofinsAliq > 0)
                {
                    _modelpedidoItem.CofinsAliq = Validation.RoundAliquotas(_modelImposto.CofinsAliq / 100);
                    _modelpedidoItem.CofinsVlr  =
                        Validation.Round(_modelpedidoItem.Total * _modelpedidoItem.CofinsAliq);
                }

                break;

            default:
                _modelpedidoItem.CofinsAliq = 0;
                _modelpedidoItem.CofinsVlr  = 0;
                break;
            }

            if (_modelpedidoItem.CofinsAliq > 0)
            {
                _modelpedidoItem.CofinsAliq = _modelpedidoItem.CofinsAliq * 100;
            }

            if (string.IsNullOrEmpty(_modelpedidoItem.Cofins))
            {
                _modelpedidoItem.Cofins = "0";
            }

            #endregion COFINS

            #region vTotTrib

            _modelpedidoItem.Federal =
                Validation.Round(_modelpedidoItem.Total * Validation.Round(_modelItem.AliqFederal / 100));
            _modelpedidoItem.Estadual =
                Validation.Round(_modelpedidoItem.Total * Validation.Round(_modelItem.AliqEstadual / 100));
            _modelpedidoItem.Municipal =
                Validation.Round(_modelpedidoItem.Total * Validation.Round(_modelItem.AliqMunicipal / 100));

            #endregion vTotTrib

            _modelpedidoItem.Save(_modelpedidoItem);
        }