OpenConcerto

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

svn://code.openconcerto.org/openconcerto

Rev

Rev 73 | Rev 93 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
18 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.generationEcritures;
15
 
16
import org.openconcerto.erp.core.finance.accounting.element.ComptePCESQLElement;
17
import org.openconcerto.sql.Configuration;
18
import org.openconcerto.sql.model.SQLRow;
19
import org.openconcerto.sql.model.SQLRowValues;
20
import org.openconcerto.sql.model.SQLTable;
21
 
22
import java.sql.SQLException;
23
import java.util.Date;
24
import java.util.List;
25
 
26
public class GenerationMvtSaisieKm extends GenerationEcritures {
27
 
28
    private int idSaisieKm;
29
    private static final String source = "SAISIE_KM";
30
 
31
    public GenerationMvtSaisieKm(int idSaisieKm) {
32
        this.idSaisieKm = idSaisieKm;
33
    }
34
 
73 ilm 35
    public int genereMouvement() throws SQLException {
18 ilm 36
 
37
        SQLRow saisieRow = base.getTable("SAISIE_KM").getRow(this.idSaisieKm);
38
 
39
        // iniatilisation des valeurs de la map
40
        this.date = (Date) saisieRow.getObject("DATE");
41
        this.nom = saisieRow.getObject("NOM").toString();
42
        this.mEcritures.put("DATE", this.date);
43
        this.mEcritures.put("NOM", this.nom);
44
        this.mEcritures.put("ID_JOURNAL", saisieRow.getObject("ID_JOURNAL"));
45
        this.mEcritures.put("ID_MOUVEMENT", new Integer(1));
46
 
47
        // on calcule le nouveau numero de mouvement
48
        getNewMouvement(GenerationMvtSaisieKm.source, this.idSaisieKm, 1, "Saisie au km " + saisieRow.getObject("NOM").toString());
49
 
50
        // gnération des ecritures
51
        SQLTable tableElt = Configuration.getInstance().getRoot().findTable("SAISIE_KM_ELEMENT");
52
        List<SQLRow> set = saisieRow.getReferentRows(tableElt);
53
 
83 ilm 54
        SQLTable tableAssoc = Configuration.getInstance().getRoot().findTable("ASSOCIATION_ANALYTIQUE");
18 ilm 55
 
73 ilm 56
        for (SQLRow rowElement : set) {
18 ilm 57
 
73 ilm 58
            int idCpt = ComptePCESQLElement.getId(rowElement.getString("NUMERO"), rowElement.getString("NOM"));
18 ilm 59
 
73 ilm 60
            // Ajout de l'écriture
61
            this.mEcritures.put("ID_COMPTE_PCE", new Integer(idCpt));
62
            this.mEcritures.put("NOM", rowElement.getString("NOM_ECRITURE"));
63
            this.mEcritures.put("DEBIT", rowElement.getObject("DEBIT"));
64
            this.mEcritures.put("CREDIT", rowElement.getObject("CREDIT"));
83 ilm 65
            SQLRow rowEcr = ajoutEcriture();
66
 
67
            List<SQLRow> assocs = rowElement.getReferentRows(tableAssoc);
68
            for (SQLRow sqlRow : assocs) {
69
                if (!sqlRow.isUndefined()) {
70
                    addAssocAnalytique(rowEcr, sqlRow.getInt("ID_POSTE_ANALYTIQUE"));
71
                }
72
            }
73
 
73 ilm 74
            // Mise à jour de la clef étrangère écriture de l'élément saisie au km
83 ilm 75
            if (rowEcr != null && !rowEcr.isUndefined()) {
73 ilm 76
                SQLRowValues vals = rowElement.createEmptyUpdateRow();
83 ilm 77
                vals.put("ID_ECRITURE", rowEcr.getID());
73 ilm 78
                vals.update();
18 ilm 79
            }
80
        }
81
 
82
        return this.idMvt;
83
    }
84
}