Ejemplo n.º 1
0
        public async Task <ICollection <RoteiroCategoria> > Busca(RoteiroCategoriaFilter filtro)
        {
            //inicializa a consulta
            var query = _db.RoteiroCategoria
                        .Include(a => a.Roteiro)
                        .Include(a => a.Categoria)
                        .AsQueryable();

            // faz o filtro
            query = Filter(query, filtro);

            //retorna o resultado
            return(await query.ToListAsync());
        }
Ejemplo n.º 2
0
        public async Task <ActionResult> Get([FromBody] RoteiroCategoriaFilter item)
        {
            try
            {
                //carrega o repositorio
                using var repository = new RoteiroCategoriaRepository();

                //efetua a consulta
                var result = await repository.Busca(item);

                //retorna o resultado
                return(Ok(result));
            }
            catch (Exception ex)
            {
                return(BadRequest(new ValidationModel(ex.Message)));
            }
        }
Ejemplo n.º 3
0
        public IQueryable <RoteiroCategoria> Filter(IQueryable <RoteiroCategoria> query, RoteiroCategoriaFilter filter)
        {
            // executa os filtros
            if (filter.Roteiros != null)
            {
                query = query.Where(a => filter.Roteiros.Contains(a.IdRoteiro));
            }

            if (filter.Categorias != null)
            {
                query = query.Where(a => filter.Categorias.Contains(a.IdCategoria));
            }

            // retorna o resultado
            return(query);
        }