/// <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)); }
/// <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 }); } }