OpenConcerto

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

svn://code.openconcerto.org/openconcerto

Rev

Rev 174 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 * 
 * Copyright 2011 OpenConcerto, by ILM Informatique. All rights reserved.
 * 
 * The contents of this file are subject to the terms of the GNU General Public License Version 3
 * only ("GPL"). You may not use this file except in compliance with the License. You can obtain a
 * copy of the License at http://www.gnu.org/licenses/gpl-3.0.html See the License for the specific
 * language governing permissions and limitations under the License.
 * 
 * When distributing the software, include this License Header Notice in each file.
 */
 
 package org.openconcerto.erp.generationEcritures;

import org.openconcerto.sql.model.DBRoot;
import org.openconcerto.sql.model.SQLInsert;
import org.openconcerto.sql.model.SQLTable;
import org.openconcerto.sql.users.User;

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class Ecriture {
    private Date date;
    private BigDecimal debit;
    private BigDecimal credit;
    private Mouvement mouvement;
    private String nom;
    private String compteNumero;
    private String compteNom;
    private Number compteID;
    private String journalNom;
    private String journalCode;
    private Number journalID;
    private List<AssociationAnalytique> associations;
    private Number id;
    private Map<String, Object> cookies;
    private boolean cloture;
    private boolean aNouveau;
    private Date dateValidation;
    private Date dateLettrage;
    private String lettrage;

    public Ecriture(Date date, BigDecimal debit, BigDecimal credit) {
        this.date = date;
        this.debit = debit;
        this.credit = credit;
    }

    public SQLInsert createInsert(DBRoot root, User user) {
        final SQLInsert insert = new SQLInsert();
        final SQLTable table = root.getTable("ECRITURE");
        insert.add(table.getField("DATE"), this.date);
        insert.add(table.getField("ID_MOUVEMENT"), this.mouvement.getId().intValue());
        insert.add(table.getField("DEBIT"), this.debit.multiply(new BigDecimal(100)).longValue());
        insert.add(table.getField("CREDIT"), this.credit.multiply(new BigDecimal(100)).longValue());
        insert.add(table.getField("NOM"), this.nom);

        if (this.compteNom == null) {
            throw new IllegalStateException("nom du compte manquant");
        }
        if (this.compteNumero == null || this.compteNumero.isEmpty()) {
            throw new IllegalStateException("numéro du compte manquant");
        }
        insert.add(table.getField("ID_COMPTE_PCE"), this.compteID);
        insert.add(table.getField("COMPTE_NUMERO"), this.compteNumero);
        insert.add(table.getField("COMPTE_NOM"), this.compteNom);
        if (this.journalNom == null) {
            throw new IllegalStateException("nom du journal manquant");
        }
        if (this.journalCode == null || this.journalCode.isEmpty()) {
            throw new IllegalStateException("code du journal manquant");
        }
        insert.add(table.getField("ID_JOURNAL"), this.journalID);
        insert.add(table.getField("JOURNAL_NOM"), this.journalNom);
        insert.add(table.getField("JOURNAL_CODE"), this.journalCode);
        insert.add(table.getField("NOM_PIECE"), this.mouvement.getPiece().getNom());
        insert.add(table.getField("ID_USER_COMMON_CREATE"), user.getId());
        insert.add(table.getField("ID_USER_COMMON_MODIFY"), user.getId());
        insert.add(table.getField("CLOTURE"), this.cloture);
        insert.add(table.getField("RAN"), this.aNouveau);
        if (this.dateValidation != null) {
            insert.add(table.getField("DATE_VALIDE"), this.dateValidation);
            insert.add(table.getField("VALIDE"), Boolean.TRUE);
        } else {
            insert.add(table.getField("DATE_VALIDE"), null);
            insert.add(table.getField("VALIDE"), Boolean.FALSE);
        }
        insert.add(table.getField("DATE_LETTRAGE"), this.dateLettrage);
        insert.add(table.getField("LETTRAGE"), this.lettrage == null || this.lettrage.isEmpty() ? "" : this.lettrage);
        return insert;
    }

    public void setDateValidation(Date dateValidation) {
        this.dateValidation = dateValidation;
    }

    public void setDateLettrage(Date dateLettrage) {
        this.dateLettrage = dateLettrage;
    }

    public void setLettrage(String lettrage) {
        this.lettrage = lettrage;
    }

    public void setCloture(boolean cloture) {
        this.cloture = cloture;
    }

    public void setaNouveau(boolean aNouveau) {
        this.aNouveau = aNouveau;
    }

    public String getNom() {
        return this.nom;
    }

    public void setNom(String nom) {
        this.nom = nom;
    }

    void setId(Number id) {
        this.id = id;
    }

    public Number getId() {
        return this.id;
    }

    public Number getCompteID() {
        return this.compteID;
    }

    public void setCompteID(Number compteID) {
        this.compteID = compteID;
    }

    public void setCompte(String numero, String nom) {
        this.compteNumero = numero;
        this.compteNom = nom;
    }

    public String getCompteNumero() {
        return this.compteNumero;
    }

    public String getCompteNom() {
        return this.compteNom;
    }

    public Number getJournalID() {
        return this.journalID;
    }

    public void setJournalID(Number journalID) {
        this.journalID = journalID;
    }

    public void setJournal(String code, String nom) {
        this.journalCode = code;
        this.journalNom = nom;
    }

    public String getJournalCode() {
        return this.journalCode;
    }

    public String getJournalNom() {
        return this.journalNom;
    }

    public BigDecimal getDebit() {
        return this.debit;
    }

    public BigDecimal getCredit() {
        return this.credit;
    }

    public Date getDate() {
        return this.date;
    }

    public void setMouvement(Mouvement mouvement) {
        this.mouvement = mouvement;
    }

    public List<AssociationAnalytique> getAssociationsAnalytiques() {
        return this.associations;
    }

    public void addAssociationAnalytique(AssociationAnalytique a) {
        if (this.associations == null) {
            this.associations = new ArrayList<>();
        }
        a.setEcriture(this);
        this.associations.add(a);
    }

    public void removeAssociationAnalytique(AssociationAnalytique a) {
        if (this.associations == null) {
            a.setEcriture(null);
            return;
        }
        this.associations.remove(a);
        a.setEcriture(null);
        if (this.associations.isEmpty()) {
            this.associations = null;
        }
    }

    public boolean hasAnalytique() {
        return this.associations != null;
    }

    public void putCookie(String key, Object value) {
        if (this.cookies == null) {
            this.cookies = new HashMap<>();
        }
        this.cookies.put(key, value);
    }

    public Object getCookie(String key) {
        return this.cookies.get(key);
    }

    @Override
    public String toString() {
        return "Ecriture : " + this.nom + ", Compte (id:" + this.compteID + ") " + this.compteNumero + " " + this.compteNom + ", Débit : " + this.debit + ", Crédit:" + this.credit;
    }

}