/* * This file is part of SGEA - Sistema de Gestão de Eventos Acadêmicos - TADS IFNMG Campus Januária. * * SGEA is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * SGEA is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with SGEA. If not, see <http://www.gnu.org/licenses/>. */ package br.edu.ifnmg.GerenciamentoEventos.Infraestrutura.Dados; import br.edu.ifnmg.DataAccess.DAOGenerico; import br.edu.ifnmg.DomainModel.AreaConhecimento; import br.edu.ifnmg.DomainModel.Pessoa; import br.edu.ifnmg.GerenciamentoEventos.DomainModel.Servicos.AtividadeRepositorio; import br.edu.ifnmg.GerenciamentoEventos.DomainModel.*; import java.util.Calendar; import java.util.Date; import java.util.GregorianCalendar; import java.util.List; import javax.annotation.PostConstruct; import javax.ejb.Singleton; import javax.persistence.EntityManager; import javax.persistence.Query; /** * * @author petronio */ @Singleton public class AtividadeDAO extends DAO<Atividade> implements AtividadeRepositorio { DAO<AtividadeTipo> daoTipo; public AtividadeDAO() { super(Atividade.class); daoTipo = new DAO<>(AtividadeTipo.class); } @PostConstruct public void inicializar() { EntityManager tmp = getManager(); daoTipo.setManager(tmp); } @Override public List<Atividade> Buscar(Atividade filtro) { if (filtro != null) { IgualA("id", filtro.getId()) .Like("nome", filtro.getNome()) .IgualA("evento", filtro.getEvento()) .IgualA("inicio", filtro.getInicio()) .IgualA("local", filtro.getLocal()) .Like("descricao", filtro.getDescricao()) .IgualA("status", filtro.getStatus()) .IgualA("termino", filtro.getTermino()); if (filtro.getTipo() != null) { if (filtro.getTipo().getId() != null && filtro.getTipo().getId() > 0) { IgualA("tipo", filtro.getTipo()); } else { Join("tipo", "t").IgualA("t.publico", filtro.getTipo().getPublico()); } } } return Buscar(); } @Override public boolean Salvar(Atividade obj) { if (obj.getControle() == null) { obj.setControle(new Controle(obj, 0, 0)); } return super.Salvar(obj); } @Override public boolean SalvarTipo(AtividadeTipo obj) { return daoTipo.Salvar(obj); } @Override public boolean ApagarTipo(AtividadeTipo obj) { return daoTipo.Apagar(obj); } @Override public AtividadeTipo AbrirTipo(Long id) { return daoTipo.Abrir(id); } @Override public List<AtividadeTipo> BuscarTipo(AtividadeTipo obj) { if(obj != null) { daoTipo .Like("nome", obj.getNome()) .IgualA("publico", obj.getPublico()); } return daoTipo.Ordenar("nome", "ASC").Buscar(); } @Override public List<Atividade> BuscarAtividadesDoUsuario(Pessoa obj) { Calendar cal = GregorianCalendar.getInstance(); cal.setTime(new Date()); cal.set(Calendar.DAY_OF_MONTH, 1); /* return MaiorOuIgualA("termino", cal.getTime()) .DiferenteDe("status", Status.Cancelado) .DiferenteDe("status", Status.Concluido) .Join("responsaveis", "r").IgualA("r.id", obj.getId()) .Buscar(); */ Query q = getManager() .createNamedQuery("atividades.ativasUsuario") .setParameter("idUsuario", obj.getId()) .setParameter("termino", cal.getTime()) .setParameter("cancelado", Status.Cancelado) .setParameter("concluido", Status.Concluido) .setHint("eclipselink.QUERY_RESULTS_CACHE", "TRUE"); return q.getResultList(); } @Override public List<Atividade> BuscarAtividadesPorEventoETipo(Evento e, AtividadeTipo t) { Query q = getManager() .createNamedQuery("atividades.porTipoEvento") .setParameter("evento", e) .setParameter("tipo", t) .setParameter("pendente", Status.Pendente) .setParameter("emexecucao", Status.EmExecucao) .setHint("eclipselink.QUERY_RESULTS_CACHE", "TRUE"); return q.getResultList(); } @Override public List<AtividadeTipo> BuscarAtividadesTiposPorEvento(Evento e) { Query q = daoTipo.getManager() .createNamedQuery("atividadestipos.publicasPorEvento") .setParameter("evento", e) .setParameter("pendente", Status.Pendente) .setParameter("emexecucao", Status.EmExecucao) .setHint("eclipselink.QUERY_RESULTS_CACHE", "TRUE"); return q.getResultList(); } @Override public List<Atividade> Responsavel(Pessoa obj) { return Join("responsaveis","r") .IgualA("r.id", obj.getId()) .Buscar(); } @Override public List<Atividade> Responsavel(Evento e, Pessoa obj) { Query q = daoTipo.getManager() .createNamedQuery("atividades.responsavel") .setParameter("evento", e) .setParameter("idUsuario", obj.getId()) .setHint("eclipselink.QUERY_RESULTS_CACHE", "TRUE"); return q.getResultList(); } @Override public List<Atividade> BuscarTexto(String filtro) { List<Atividade> list = getManager() .createNativeQuery("SELECT * FROM atividades WHERE MATCH(nome,descricao) AGAINST(? IN BOOLEAN MODE)", Atividade.class) .setParameter(1, filtro+"*") .getResultList(); return list; } public List<AtividadeTipo> BuscarTextoTipo(String filtro) { List<AtividadeTipo> list = getManager() .createNativeQuery("SELECT * FROM atividadestipos WHERE MATCH(nome,descricao) AGAINST(? IN BOOLEAN MODE)", Atividade.class) .setParameter(1, filtro+"*") .getResultList(); return list; } }