/*
* 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;
}
}