BrightSide Workbench Full Report + Source Code
OwnedAptitudeCombobox.java
Go to the documentation of this file.
1 /*
2  * TurrĂ³ i Cutiller Foundation. License notice.
3  * Copyright (C) 2011 Lluis TurrĂ³ Cutiller <http://www.turro.org/>
4  *
5  * This program is free software: you can redistribute it and/or modify
6  * it under the terms of the GNU Affero General Public License as published by
7  * the Free Software Foundation, either version 3 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU Affero General Public License for more details.
14  *
15  * You should have received a copy of the GNU Affero General Public License
16  * along with this program. If not, see <http://www.gnu.org/licenses/>.
17  */
18 package org.turro.erp.humanres;
19 
20 import java.util.LinkedList;
21 import java.util.List;
22 import javax.persistence.EntityManager;
23 import javax.persistence.Query;
24 import org.turro.elephant.db.SQLHelper;
25 import org.turro.elephant.db.WhereClause;
26 import org.turro.erp.db.ErpPU;
27 import org.turro.erp.entity.OwnedAptitude;
28 import org.turro.zkoss.input.GenericCombobox;
29 
34 public class OwnedAptitudeCombobox extends GenericCombobox<OwnedAptitude> {
35 
36  private boolean onlyActive = true;
37 
38  public boolean isOnlyActive() {
39  return onlyActive;
40  }
41 
42  public void setOnlyActive(boolean onlyActive) {
43  this.onlyActive = onlyActive;
44  }
45 
46  @Override
47  public void populateList(String value, LinkedList list, int nRows) {
48  EntityManager em = new ErpPU().getEntityManager();
49  try {
50  WhereClause wc = SQLHelper.getWhereClause(new String[]{
51  "res.humanResource.name"
52  }, value);
53  Query q = em.createQuery(
54  "select res from OwnedAptitude res " +
55  "where res.humanResource.active = :active " +
56  wc.getClause() +
57  " order by res.humanResource.name"
58  );
59  wc.addNamedValue("active", onlyActive);
60  q.setMaxResults(nRows);
61  wc.setNamedParameters(q);
62  List<OwnedAptitude> l = q.getResultList();
63  for(Object o : l) {
64  list.add(((OwnedAptitude) o).getName());
65  }
66  } finally {
67  em.close();
68  }
69  }
70 
71  @Override
72  public String getTextFromObject(OwnedAptitude value) {
73  return value.getName();
74  }
75 
76 }
static WhereClause getWhereClause(String[] fields, String value)
Definition: SQLHelper.java:64
void addNamedValue(String name, Object value)
void populateList(String value, LinkedList list, int nRows)
EntityManager getEntityManager()
Definition: Dao.java:202