Ejemplo n.º 1
0
        /// <summary>
        /// Realiza a conversão dos dados de rentabilidade do produto da nota para um
        /// registro de rentabilidade.
        /// </summary>
        /// <param name="produtoNfRentabilidade"></param>
        /// <returns></returns>
        private IRegistroRentabilidade ConverterParaRegistroRentabilidade(Data.Model.ProdutoNfRentabilidade produtoNfRentabilidade)
        {
            var tipo = (TipoRegistroRentabilidade)produtoNfRentabilidade.Tipo;

            return(new RegistroRentabilidade(produtoNfRentabilidade.IdRegistro,
                                             ProvedorDescritoresRegistro.ObterDescritor(tipo, produtoNfRentabilidade.IdRegistro), tipo, produtoNfRentabilidade.Valor));
        }
Ejemplo n.º 2
0
        /// <summary>
        /// Recupera um item de rentabilidade para o produto pedido informado.
        /// </summary>
        /// <param name="sessao"></param>
        /// <param name="produtoNf"></param>
        /// <param name="produtoNfCustos">Custos associados.</param>
        /// <param name="prazoMedio"></param>
        /// <param name="produtos"></param>
        /// <returns></returns>
        private IItemRentabilidade <Data.Model.ProdutosNf> ObterItemProdutoNf(
            GDA.GDASession sessao, Data.Model.ProdutosNf produtoNf,
            IEnumerable <Data.Model.ProdutoNfCusto> produtoNfCustos,
            int prazoMedio, IEnumerable <Data.Model.Produto> produtos)
        {
            var registros = new Lazy <IList <Data.Model.ProdutoNfRentabilidade> >(
                () => Data.DAL.ProdutoNfRentabilidadeDAO.Instance.ObterPorProdutoNf(sessao, produtoNf.IdProdNf));

            var criarRegistro = new CriadorRegistroRentabilidade(
                (tipo, nome, valor) =>
            {
                var idRegistro = ProvedorDescritoresRegistro.ObterRegistro(tipo, nome);
                var registro   = registros.Value.FirstOrDefault(f => f.Tipo == (int)tipo && f.IdRegistro == idRegistro);

                if (registro == null)
                {
                    registro = new Data.Model.ProdutoNfRentabilidade
                    {
                        IdProdNf   = (int)produtoNf.IdProdNf,
                        IdRegistro = idRegistro,
                        Tipo       = (int)tipo,
                        Valor      = valor
                    };
                    registros.Value.Add(registro);
                }
                else
                {
                    registro.Valor = valor;
                }

                return(ConverterParaRegistroRentabilidade(registro));
            });

            // Carrega o produto associado
            var produto = produtos.FirstOrDefault(f => f.IdProd == produtoNf.IdProd);

            if (!produtoNfCustos.Any())
            {
                produtoNfCustos = new[]
                {
                    new Data.Model.ProdutoNfCusto
                    {
                        IdProdNf        = produtoNf.IdProdNf,
                        IdProdNfEntrada = 0,
                        Qtde            = (int)produtoNf.Qtde,
                        CustoCompra     = produto.CustoCompra
                    }
                }
            }
            ;

            var qtdeProdutoNfCustos = produtoNfCustos.Count();

            if (qtdeProdutoNfCustos > 1)
            {
                var itens = produtoNfCustos.Select(produtoNfCusto => ObterItemProdutoNfCusto(sessao, produtoNf, produtoNfCusto, prazoMedio, produto));

                return(new ItemRentabilidadeContainer <Data.Model.ProdutosNf, Data.Model.ProdutoNfRentabilidade>(
                           ProvedorIndicadoresFinanceiro, criarRegistro,
                           produtoNf, itens, f => true, registros,
                           ConverterParaRegistroRentabilidade)
                {
                    Descricao = $"Produto ({produto?.CodInterno}) {produto?.Descricao}",
                    PrecoVendaSemIPI = produtoNf.Total + produtoNf.ValorIcmsSt,
                    PrazoMedio = prazoMedio,
                    PercentualComissao = produtoNf.PercComissao / 100m,
                    PercentualRentabilidade = produtoNf.PercentualRentabilidade / 100m,
                    RentabilidadeFinanceira = produtoNf.RentabilidadeFinanceira
                });
            }
            else
            {
                var custoCompra = qtdeProdutoNfCustos == 1 ? produtoNfCustos.First().CustoCompra : produto.CustoCompra;

                // Calcula o custo do produto
                var custoProd = Glass.Global.CalculosFluxo.CalcTotaisItemProdFast(sessao, produto.TipoCalculo,
                                                                                  produtoNf.Altura, produtoNf.Largura, produtoNf.Qtde,
                                                                                  produtoNf.TotM, custoCompra,
                                                                                  produtoNf.AlturaBenef.GetValueOrDefault(2),
                                                                                  produtoNf.LarguraBenef.GetValueOrDefault(2));

                return(new ItemRentabilidade <Data.Model.ProdutosNf, Data.Model.ProdutoNfRentabilidade>(
                           ProvedorIndicadoresFinanceiro, criarRegistro, produtoNf, registros, ConverterParaRegistroRentabilidade)
                {
                    Descricao = $"Produto ({produto?.CodInterno}) {produto?.Descricao}",
                    PrecoVendaSemIPI = produtoNf.Total + produtoNf.ValorIcmsSt, // Não atualizar a configuração do sistema o total do produto não possui o valor do IPI
                    PrecoCusto = custoProd,
                    PrazoMedio = prazoMedio,
                    PercentualICMSCompra = (decimal)(produtoNfCustos.FirstOrDefault()?.AliqIcmsCompra ?? 0f) / 100m,
                    PercentualICMSVenda = (decimal)produtoNf.AliqIcms / 100m,
                    FatorICMSSubstituicao = 0m,
                    PercentualIPICompra = (decimal)(produtoNfCustos.FirstOrDefault()?.AliqIpiCompra ?? 0f) / 100m,
                    PercentualIPIVenda = (decimal)produtoNf.AliqIpi / 100m,
                    PercentualComissao = produtoNf.PercComissao / 100m,
                    CustosExtras = 0m,
                    PercentualRentabilidade = produtoNf.PercentualRentabilidade / 100m,
                    RentabilidadeFinanceira = produtoNf.RentabilidadeFinanceira
                });
            }
        }