BrightSide Workbench Full Report + Source Code
DossierDescriptionCombobox.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.dossier.dossier;
19 
20 import java.util.LinkedList;
21 import org.turro.dossier.db.DossierPU;
22 import org.turro.dossier.entity.Dossier;
23 import org.turro.elephant.db.WhereClause;
24 import org.turro.jpa.Dao;
25 import org.turro.zkoss.input.GenericCombobox;
26 
31 public class DossierDescriptionCombobox extends GenericCombobox<String> {
32 
33  private Dossier dossier;
34 
35  public void setDossier(Dossier dossier) {
36  this.dossier = dossier;
37  //Constraint c = getConstraint();
38  //setConstraint((Constraint) null);
39  setObjectValue(dossier.getDescription());
40  refreshModel();
41  //setConstraint(c);
42  }
43 
44  @Override
45  public void populateList(String value, LinkedList list, int nRows) {
46  Dao dao = new DossierPU();
47  WhereClause wc = new WhereClause();
48  wc.addClause("select distinct dossier.description from Dossier as dossier");
49  wc.addClause("where 1=1");
50  if(dossier != null) {
51  wc.addClause("and dossier.category = :category");
52  wc.addNamedValue("category", dossier.getCategory());
53  }
54  wc.addLikeFields(new String[] {"dossier.description"}, value);
55  wc.addClause("order by dossier.description");
56  list.addAll(dao.getResultList(wc, nRows));
57  }
58 
59  @Override
60  public String getTextFromObject(String value) {
61  return value;
62  }
63 
64 }
void populateList(String value, LinkedList list, int nRows)
void addLikeFields(String[] fields, String value)
void addNamedValue(String name, Object value)