BrightSide Workbench Full Report + Source Code
ResourceCombobox.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.resource;
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.Resource;
28 import org.turro.zkoss.input.GenericCombobox;
29 
34 public class ResourceCombobox extends GenericCombobox<Resource> {
35 
36  private boolean onlyActive = true;
37  private long contractId;
38 
39  public boolean isOnlyActive() {
40  return onlyActive;
41  }
42 
43  public void setOnlyActive(boolean onlyActive) {
44  this.onlyActive = onlyActive;
45  }
46 
47  public long getContractId() {
48  return contractId;
49  }
50 
51  public void setContractId(long contractId) {
52  this.contractId = contractId;
53  }
54 
55  @Override
56  public void populateList(String value, LinkedList list, int nRows) {
57  EntityManager em = new ErpPU().getEntityManager();
58  try {
59  WhereClause wc = SQLHelper.getWhereClause(new String[]{
60  "res.name"
61  }, value);
62  Query q = em.createQuery(
63  "select res from Resource res " +
64  "where active = :active " +
65  (contractId > 0 ? "and (res.idContract = " + contractId + " or res.idContract == 0) " : "") +
66  wc.getClause() +
67  " order by res.name"
68  );
69  wc.addNamedValue("active", onlyActive);
70  q.setMaxResults(nRows);
71  wc.setNamedParameters(q);
72  List<Resource> l = q.getResultList();
73  for(Object o : l) {
74  list.add(((Resource) o).getName());
75  }
76  } finally {
77  em.close();
78  }
79  }
80 
81  @Override
82  public String getTextFromObject(Resource value) {
83  return value.getName();
84  }
85 
86 }
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