BrightSide Workbench Full Report + Source Code
PayrollFilter.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.payroll;
19 
20 import java.util.Collection;
21 import java.util.Date;
22 import org.turro.elephant.db.WhereClause;
23 import org.turro.financials.db.FinancialsPU;
24 import org.turro.financials.entity.Document;
25 import org.turro.jpa.Dao;
26 
31 public class PayrollFilter {
32 
33  public Collection<Document> getPayrolls(Date date, boolean newPayrolls) {
34  Dao dao = new FinancialsPU();
35  WhereClause wc = createCriteria(date, newPayrolls);
36  if(newPayrolls) {
37  return new ClonedDocumentAdapter(dao.getResultList(wc));
38  } else {
39  return dao.getResultList(wc);
40  }
41  }
42 
43  private WhereClause createCriteria(Date date, boolean newPayrolls) {
44  WhereClause wc = new WhereClause();
45  wc.addClause("select doc from Document as doc");
46  wc.addClause("where doc.documentDefinition.id = 9");
47  if(newPayrolls) {
48  wc.addClause("and doc.documentDate = (");
49  wc.addClause("select max(doc2.documentDate) from Document as doc2");
50  wc.addClause("where doc2.documentDefinition.id = 9");
51  wc.addClause("and doc2.documentDate <= :date");
52  wc.addNamedValue("date", date);
53  wc.addClause(")");
54  } else {
55  wc.addClause("and doc.documentDate = :date");
56  wc.addNamedValue("date", date);
57  }
58  return wc;
59  }
60 
61 }
void addNamedValue(String name, Object value)
Collection< Document > getPayrolls(Date date, boolean newPayrolls)