OpenConcerto

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

svn://code.openconcerto.org/openconcerto

Rev

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

Rev Author Line No. Line
20 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.openoffice.style.data;
15
 
16
import org.openconcerto.openoffice.ODPackage;
17
import org.openconcerto.openoffice.XMLVersion;
18
import org.openconcerto.openoffice.spreadsheet.CellStyle;
19
import org.openconcerto.openoffice.spreadsheet.MutableCell;
20
 
21
import java.util.List;
22
 
23
import org.jdom.Element;
24
import org.jdom.Namespace;
25
 
26
// from section 16.27.2 in v1.2-cs01-part1
27
public class NumberStyle extends DataStyle {
28
 
29
    public static final DataStyleDesc<NumberStyle> DESC = new DataStyleDesc<NumberStyle>(NumberStyle.class, XMLVersion.OD, "number-style", "N") {
30
        @Override
31
        public NumberStyle create(ODPackage pkg, Element e) {
32
            return new NumberStyle(pkg, e);
33
        }
34
    };
35
 
36
    public NumberStyle(final ODPackage pkg, Element elem) {
37
        super(pkg, elem, Number.class);
38
    }
39
 
40
    @Override
41
    public String format(Object o, CellStyle defaultStyle, boolean lenient) {
42
        final Number n = (Number) o;
43
        final Namespace numberNS = this.getElement().getNamespace();
44
        final StringBuilder sb = new StringBuilder();
45
        @SuppressWarnings("unchecked")
46
        final List<Element> children = this.getElement().getChildren();
47
        for (final Element elem : children) {
48
            if (elem.getNamespace().equals(numberNS)) {
49
                if (elem.getName().equals("text")) {
50
                    sb.append(elem.getText());
51
                } else if (elem.getName().equals("number") || elem.getName().equals("scientific-number")) {
52
                    sb.append(formatNumberOrScientificNumber(elem, n, defaultStyle));
53
                } else if (elem.getName().equals("fraction")) {
54
                    // TODO fractions
55
                    reportError("Fractions not supported", lenient);
56
                    sb.append(MutableCell.formatNumber(n, defaultStyle));
57
                }
58
            }
59
        }
60
        return sb.toString();
61
    }
62
}