OpenConcerto

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

svn://code.openconcerto.org/openconcerto

Rev

Rev 73 | Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
67 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.SpreadSheetCellValueProviderManager;
18
import org.openconcerto.map.model.Ville;
19
import org.openconcerto.sql.model.SQLRowAccessor;
20
 
21
public class AdresseFullClientValueProvider extends AdresseClientProvider {
22
 
23
    private int type;
24
 
25
    public AdresseFullClientValueProvider(int type) {
26
        this.type = type;
27
    }
28
 
29
    @Override
30
    public Object getValue(SpreadSheetCellValueContext context) {
31
        SQLRowAccessor r = getAdresse(context.getRow(), this.type);
32
        Ville v = Ville.getVilleFromVilleEtCode(r.getString("VILLE"));
33
        String result = r.getString("RUE");
34
        if (v != null) {
35
            result += "\n" + v.getCodepostal();
36
            result += " ";
37
            result += v.getName();
38
            if (r.getBoolean("HAS_CEDEX")) {
39
                result += " Cedex";
40
                String cedex = r.getString("CEDEX");
41
                if (cedex != null && cedex.trim().length() > 0) {
42
                    result += " " + cedex;
43
                }
44
            }
45
        }
46
 
47
        return result;
48
    }
49
 
50
    public static void register() {
51
        SpreadSheetCellValueProviderManager.put("address.customer.invoice.full", new AdresseFullClientValueProvider(ADRESSE_FACTURATION));
52
        SpreadSheetCellValueProviderManager.put("address.customer.shipment.full", new AdresseFullClientValueProvider(ADRESSE_LIVRAISON));
53
    }
54
}