/* * This file is part of gwap, an open platform for games with a purpose * * Copyright (C) 2013 * Project play4science * Lehr- und Forschungseinheit für Programmier- und Modellierungssprachen * Ludwig-Maximilians-Universität München * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package gwap.mit; import gwap.model.Person; import gwap.model.action.Bet; import gwap.model.resource.Resource; import gwap.model.resource.Statement; import gwap.tools.AbstractPaginatedList; import java.io.Serializable; import java.util.List; import javax.persistence.EntityManager; import javax.persistence.Query; import org.jboss.seam.ScopeType; import org.jboss.seam.annotations.Create; import org.jboss.seam.annotations.In; import org.jboss.seam.annotations.Logger; import org.jboss.seam.annotations.Name; import org.jboss.seam.annotations.Observer; import org.jboss.seam.annotations.Out; import org.jboss.seam.annotations.Scope; import org.jboss.seam.log.Log; /** * @author Fabian Kneißl */ @Name("mitBetList") @Scope(ScopeType.PAGE) public class BetList extends AbstractPaginatedList implements Serializable { private static final long serialVersionUID = 1L; @Logger protected Log log; @In protected EntityManager entityManager; @In protected Person person; @In protected PokerScoring mitPokerScoring; @Create public void create() { log.info("Creating"); } @Out(required=false) protected Bet selectedBet; protected List<Bet> betList; public List<Bet> getBetList() { if (betList == null) { updateList(); } return betList; } @Observer("mit.betList.update") public void updateList() { long start = System.currentTimeMillis(); Query q = entityManager.createNamedQuery("bet.byPerson") .setParameter("person", person); betList = q.getResultList(); paginationControl.setNumResults(betList.size()); if (paginationControl.getNumPages() > 1) { q.setFirstResult(paginationControl.getFirstResult()); q.setMaxResults(paginationControl.getResultsPerPage()); betList = q.getResultList(); } for (Bet bet : betList) { Resource resource = bet.getResource(); if (resource instanceof Statement) ((Statement) resource).getStatementTokens().size(); if (bet.getCurrentMatch() == null || bet.getScore() == null) mitPokerScoring.updateScoreForBet(bet); } log.info("Created betList with #0 statements in #1ms", betList.size(), System.currentTimeMillis() - start); if (betList.size() > 0) selectedBet = betList.get(resultNumber); } public void showDetail(Long selectedBetId) { List<Bet> aux = getBetList(); for(int i = 0; i<aux.size(); i++){ if(selectedBetId.equals(aux.get(i).getId())){ setResultNumber(i); selectedBet = aux.get(i); } } log.info("Ausgewählte id in showDetail(): " + selectedBet.getId()); } public Bet getSelectedBet() { // log.info("MYSELECTEDBET: " + selectedBet.getResource().getId()); return selectedBet; } public List<Bet> retrieveBetsFromStatement(Statement statement){ Query q = entityManager.createNamedQuery("bet.byResource"); q.setParameter("resource", statement); betList = q.getResultList(); return betList; } }