OpenConcerto

Dépôt officiel du code source de l'ERP OpenConcerto
sonarqube

svn://code.openconcerto.org/openconcerto

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
177 ilm 1
/*
2
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
3
 *
4
 * Copyright 2011 OpenConcerto, by ILM Informatique. All rights reserved.
5
 *
6
 * The contents of this file are subject to the terms of the GNU General Public License Version 3
7
 * only ("GPL"). You may not use this file except in compliance with the License. You can obtain a
8
 * copy of the License at http://www.gnu.org/licenses/gpl-3.0.html See the License for the specific
9
 * language governing permissions and limitations under the License.
10
 *
11
 * When distributing the software, include this License Header Notice in each file.
12
 */
13
 
14
 package org.openconcerto.erp.generationDoc.provider;
15
 
16
import org.openconcerto.erp.generationDoc.SpreadSheetCellValueContext;
17
import org.openconcerto.erp.generationDoc.SpreadSheetCellValueProvider;
18
import org.openconcerto.erp.generationDoc.SpreadSheetCellValueProviderManager;
19
import org.openconcerto.sql.model.SQLRowAccessor;
20
 
21
import java.util.Arrays;
22
import java.util.List;
23
 
24
import com.ibm.icu.math.BigDecimal;
25
 
26
public class FichePayeHeureSupTotalProvider implements SpreadSheetCellValueProvider {
27
 
28
    private boolean cumul = false;
29
 
30
    public FichePayeHeureSupTotalProvider(boolean c) {
31
        this.cumul = c;
32
    }
33
 
34
    @Override
35
    public Object getValue(SpreadSheetCellValueContext context) {
36
 
37
        BigDecimal total = BigDecimal.ZERO;
38
        SQLRowAccessor rowVar = context.getRow().getForeign("ID_VARIABLE_SALARIE");
39
        List<String> fieldHeures = Arrays.asList("HEURE_110", "HEURE_125", "HEURE_150", "HEURE_200");
40
        for (String field : fieldHeures) {
41
            if (cumul) {
42
                field = field + "_CUMUL_VAL";
43
            }
44
 
45
            total = total.add(new BigDecimal(rowVar.getFloat(field)));
46
        }
47
        return total;
48
    }
49
 
50
    public static void register() {
51
        SpreadSheetCellValueProviderManager.put("fichepaye.heure.sup.total", new FichePayeHeureSupTotalProvider(false));
52
        SpreadSheetCellValueProviderManager.put("fichepaye.heure.sup.cumul.total", new FichePayeHeureSupTotalProvider(true));
53
    }
54
 
55
}