public void CadastrarNotaFiscal( string nrNotaFiscal, string sGDP, double valorTotal, string chaveAcesso, DateTime dataEmissao, DateTime dataConsultaANP, string veiculo, string placaVeiculo, int numeroFolha, int departamento, List <string> cuponsSelecionados, List <ItemNotaFiscalDto> ItensNotaFiscal) { int mesFAM = dataConsultaANP.Month; int anoFAM = dataConsultaANP.Year; /* * double precoMaximo = 0; * double precoMedio = 0; * TabelaANP tabela = tabelaANPRepo.BuscarDadosANP(sGDP, dataConsultaANP.Month, dataConsultaANP.Year); * * if (tabela != null) * { * precoMaximo = tabela.precoMedio; * precoMedio = tabela.precoMedio; * } * else * { * throw new Exception("Não foi encontrado valores na ANP para este item!"); * } */ notaFiscalRepo.Cadastrar(nrNotaFiscal, sGDP, valorTotal, chaveAcesso, dataEmissao, dataConsultaANP, veiculo, placaVeiculo, numeroFolha, departamento, mesFAM, anoFAM); foreach (var item in ItensNotaFiscal) { if (item != null) { itemNotaFiscalRepo.Cadastrar(nrNotaFiscal, item.Sgdp, item.Produto, item.Quantidade, item.ValorTotal, item.ValorUnitario); } } foreach (var cupom in cuponsSelecionados) { if (string.IsNullOrWhiteSpace(cupom)) { throw new Exception("O número do cupom não foi informado!"); } var cupomSalvo = cupomFiscalRepo.buscarCupomDisponivel(sGDP, cupom); if (cupomSalvo == null) { cupomFiscalRepo.CadastrarCupom(sGDP, cupom, nrNotaFiscal); // Insere um novo Cupom. } else { cupomFiscalRepo.EditarCupom(sGDP, cupom, nrNotaFiscal); // Adicionamos o Número da Nota Fiscal ao Cupom já cadastrado. } } }