private static Expression <Func <NotadeCompra, bool> > GetQuery(ListarNotasparaAprovacaoQuery request, Usuario usuario)
 {
     return(x =>
            x.Status == StatusNota.Pendente &&
            (x.ValorTotal >= usuario.ValorMinimo && x.ValorTotal <= usuario.ValorMaxino) &&
            ((request.DataInicio == null && request.DataFim == null) || x.DataEmissao >= request.DataInicio && x.DataEmissao <= request.DataFim)
            );
 }
        public async Task <IList <NotadeCompraDTO> > Handle(ListarNotasparaAprovacaoQuery request, CancellationToken cancellationToken)
        {
            var listaresultado = new List <NotadeCompraDTO>();
            var usuario        = _context.Usuarios.SingleOrDefault(x => x.Id == request.IdUsuario);

            if (usuario == null)
            {
                return(listaresultado);
            }

            //teste adm
            if (usuario.Papel == PapelAprovacao.Adm)
            {
                return(await _context.NotadeCompras.ProjectTo <NotadeCompraDTO>(_mapper.ConfigurationProvider).OrderBy(o => o.DataEmissao).ToListAsync(cancellationToken));
            }



            var listadenotas = _context.NotadeCompras.Where(GetQuery(request, usuario)).OrderBy(o => o.DataEmissao).ToList();

            foreach (var nota in listadenotas)
            {
                if (_context.AutorizacaoHistoricos.Any(x => x.Nota.Id == nota.Id && x.Usuario.Id == usuario.Id))
                {
                    continue;
                }
                var hist = _context.AutorizacaoHistoricos.Where(x => x.Nota.Id == nota.Id).ToList();

                if (ValidacoeseVerificacoes.VerificarConfiguracaoAutorizacaoDiponivel(_context, nota, hist, usuario))
                {
                    listaresultado.Add(_mapper.Map <NotadeCompraDTO>(nota));
                    continue;
                }
            }
            return(listaresultado);
        }