BrightSide Workbench Full Report + Source Code
bsfinancials-www/src/main/java/org/turro/financials/contract/HumanResourceCombobox.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.financials.contract;
19 
20 import java.util.LinkedList;
21 import java.util.List;
22 import org.turro.elephant.db.WhereClause;
23 import org.turro.financials.contract.logic.ContractWrapper;
24 import org.turro.financials.db.FinancialsPU;
25 import org.turro.financials.entity.Contract;
26 import org.turro.jpa.Dao;
27 import org.turro.zkoss.input.GenericCombobox;
28 
33 public class HumanResourceCombobox extends GenericCombobox<Contract> {
34 
35  private boolean onlyActive;
36 
37  public boolean isOnlyActive() {
38  return onlyActive;
39  }
40 
41  public void setOnlyActive(boolean onlyActive) {
42  this.onlyActive = onlyActive;
43  }
44 
45  @Override
46  public void populateList(String value, LinkedList list, int nRows) {
47  Dao dao = new FinancialsPU();
48  WhereClause wc = new WhereClause();
49  wc.addClause("select contract from Contract as contract");
50  wc.addClause("left join contract.contractPreferences cp");
51  wc.addClause("where (");
52  wc.addClause(" contract.contractDefinition.id = 26");
53  wc.addClause(" or");
54  wc.addClause(" (contract.contractDefinition.id = 55 and cp.id in (18,51,52))");
55  wc.addClause(")");
56  wc.addLikeFields(new String[] { "contract.name" }, value);
57  wc.addClause("order by contract.name");
58  List<Contract> l = dao.getResultList(wc, nRows);
59  if(onlyActive) {
61  }
62  for(Object o : l) {
63  list.add((Contract) o);
64  }
65  }
66 
67  @Override
68  public String getTextFromObject(Contract value) {
69  return value.getName();
70  }
71 
72 }
void addLikeFields(String[] fields, String value)