OpenConcerto

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

svn://code.openconcerto.org/openconcerto

Rev

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

Rev Author Line No. Line
76 ilm 1
/*
2
 * Créé le 30 mai 2012
3
 */
4
package org.openconcerto.modules.subscription;
5
 
6
import java.util.Calendar;
7
import java.util.Date;
8
import java.util.HashMap;
9
import java.util.List;
10
import java.util.Map;
11
 
12
import org.openconcerto.sql.Configuration;
96 ilm 13
import org.openconcerto.sql.model.AliasedTable;
76 ilm 14
import org.openconcerto.sql.model.SQLRow;
15
import org.openconcerto.sql.model.SQLRowListRSH;
16
import org.openconcerto.sql.model.SQLRowValues;
17
import org.openconcerto.sql.model.SQLRowValuesListFetcher;
18
import org.openconcerto.sql.model.SQLSelect;
19
import org.openconcerto.sql.model.SQLSelectJoin;
20
import org.openconcerto.sql.model.SQLTable;
21
import org.openconcerto.sql.model.TableRef;
22
import org.openconcerto.sql.model.Where;
23
import org.openconcerto.utils.cc.ITransformer;
24
 
25
public class SubscriptionChecker {
26
 
27
    private final String type;
28
    private final SQLTable table;
29
 
30
    public SubscriptionChecker(SQLTable table) {
31
        this.table = table;
32
 
33
        if (this.table.getName().equalsIgnoreCase("SAISIE_VENTE_FACTURE")) {
34
            this.type = "FACTURE";
35
        } else if (this.table.getName().equalsIgnoreCase("DEVIS")) {
36
            this.type = "DEVIS";
37
        } else {
38
            this.type = "COMMANDE";
39
        }
40
    }
41
 
42
    public Map<SQLRow, Calendar> check() {
43
 
44
        // Fectcher pour récupérer la derniere facture ou devis de chaque abonnement
45
        final SQLRowValues vals = new SQLRowValues(this.table);
46
        vals.put(this.table.getKey().getName(), null);
47
        vals.put("NUMERO", null);
48
        vals.put("DATE", null);
49
        vals.put("ID_ABONNEMENT", null);
152 ilm 50
        vals.put("PREVISIONNELLE", null);
51
        vals.put("CREATION_AUTO_VALIDER", null);
76 ilm 52
 
53
        final SQLRowValuesListFetcher fetcher = new SQLRowValuesListFetcher(vals);
54
        fetcher.setSelTransf(new ITransformer<SQLSelect, SQLSelect>() {
55
            @Override
56
            public SQLSelect transformChecked(SQLSelect sel) {
57
 
58
                TableRef tableFAlias = sel.getAlias(SubscriptionChecker.this.table);
96 ilm 59
                SQLSelectJoin join = sel.addJoin("RIGHT", new AliasedTable(SubscriptionChecker.this.table, "f2"), new Where(tableFAlias.getField("ARCHIVE"), "=", 0));
76 ilm 60
                Where w = new Where(join.getJoinedTable().getField("DATE"), "<=", tableFAlias.getField("DATE"));
61
                w = w.and(new Where(join.getJoinedTable().getField("ID_ABONNEMENT"), "=", tableFAlias.getField("ID_ABONNEMENT")));
62
                join.setWhere(w);
63
                sel.setWhere(new Where(tableFAlias.getField("ID_ABONNEMENT"), "IS NOT", (Object) null));
64
 
65
                System.err.println(sel.asString());
66
                return sel;
67
            }
68
        });
69
 
70
        List<SQLRowValues> list = fetcher.fetch();
71
 
72
        Map<Number, SQLRowValues> map = new HashMap<Number, SQLRowValues>();
73
        for (SQLRowValues sqlRow : list) {
74
            map.put(sqlRow.getInt("ID_ABONNEMENT"), sqlRow);
75
        }
76
 
77
        // Verification du renouvellement des abonnements
78
        SQLSelect selAb = new SQLSelect(this.table.getDBSystemRoot(), true);
79
        SQLTable tableAb = Configuration.getInstance().getRoot().findTable("ABONNEMENT");
80
        selAb.addSelectStar(tableAb);
81
        List<SQLRow> rows = SQLRowListRSH.execute(selAb);
82
 
83
        // Liste des abonnements associés à la prochaine date de renouvellement
84
        Map<SQLRow, Calendar> aboFactureRenouvel = new HashMap<SQLRow, Calendar>();
85
 
86
        Date toDay = new Date();
87
 
88
        for (SQLRow sqlRow : rows) {
89
            if (sqlRow.getBoolean("CREATE_" + this.type)) {
90
                int nbMois = sqlRow.getInt("NB_MOIS_" + this.type);
91
 
92
                // On recupere la derniere date de l'abonnement soit la date de debut soit la date
93
                // de la derniere facture
94
                Calendar calStartFact = sqlRow.getDate("DATE_DEBUT_" + this.type);
95
                SQLRowValues rowFact = map.get(sqlRow.getID());
96
                if (rowFact != null) {
152 ilm 97
                    if (rowFact.getObject("PREVISIONNELLE") != null && !rowFact.getBoolean("PREVISIONNELLE")) {
76 ilm 98
                        calStartFact = rowFact.getDate("DATE");
99
                    } else {
100
                        // Si le dernier element de l'abonnement n'a pas été validé on ne crée pas
101
                        // le prochain
102
                        continue;
103
                    }
104
                }
105
 
106
                calStartFact.add(Calendar.MONTH, nbMois);
107
                if (toDay.after(calStartFact.getTime())) {
108
 
109
                    aboFactureRenouvel.put(sqlRow, calStartFact);
110
                }
111
            }
112
        }
113
        return aboFactureRenouvel;
114
    }
115
 
116
}