/* * This file is part of jHaushalt. * jHaushalt is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * jHaushalt is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * You should have received a copy of the GNU General Public License * along with jHaushalt; if not, see <http://www.gnu.org/licenses/>. * (C)opyright 2002-2010 Dr. Lars H. Hahn */ package haushalt.auswertung; import haushalt.auswertung.bloecke.LeererBlock; import haushalt.auswertung.bloecke.TabellenBlock; import haushalt.auswertung.bloecke.TextBlock; import haushalt.daten.Datenbasis; import haushalt.daten.EinzelKategorie; import haushalt.daten.Euro; import haushalt.daten.zeitraum.AbstractZeitraum; import haushalt.daten.zeitraum.Jahr; import haushalt.gui.Haushalt; import haushalt.gui.TextResource; import haushalt.gui.generischerdialog.AbstractGDPane; import haushalt.gui.generischerdialog.EinOderAlleRegisterGDP; import haushalt.gui.generischerdialog.MehrereKategorienGDP; import haushalt.gui.generischerdialog.ProzentGDP; import haushalt.gui.generischerdialog.ZeitraumGDP; import java.awt.Font; /** * @author Dr. Lars H. Hahn * @version 2.5.3/2008.03.19 */ /* * 2008.03.19 BugFix: Breite erste Spalte jetzt Integer * 2007.05.30 Internationalisierung * 2007.02.20 Erweiterung: Festlegen der Breite der ersten Spalte * 2006.06.11 BugFix: Nur die ausgewählten Kategorien werden * berechnet * 2004.08.22 Erste Version */ public class BAAbsoluterVergleich extends AbstractBlockAuswertung { public static final String UEBERSCHRIFT = TextResource.get().getString("headline_absolute_comparison"); private static final long serialVersionUID = 1L; private static final TextResource RES = TextResource.get(); public BAAbsoluterVergleich(final Haushalt haushalt, final Datenbasis db, final String name) { super(haushalt, db, name); final AbstractGDPane[] panes = new AbstractGDPane[5]; panes[0] = new ZeitraumGDP(RES.getString("first_period") + ":", new Jahr(2006)); panes[1] = new ZeitraumGDP(RES.getString("second_period") + ":", new Jahr(2007)); panes[2] = new EinOderAlleRegisterGDP(RES.getString("register") + ":", db, null); panes[3] = new MehrereKategorienGDP(RES.getString("categories") + ":", db); panes[4] = new ProzentGDP(RES.getString("width_first_column") + ":"); erzeugeEigenschaften(haushalt.getFrame(), UEBERSCHRIFT, panes); } @Override protected String berechneAuswertung(final Object[] werte) { final AbstractZeitraum zeitraum1 = (AbstractZeitraum) werte[0]; final AbstractZeitraum zeitraum2 = (AbstractZeitraum) werte[1]; final String register = (String) werte[2]; final EinzelKategorie[] kategorien = (EinzelKategorie[]) werte[3]; final double prozentErsteSpalte = ((Integer) werte[4]).doubleValue(); final int anzKat = kategorien.length; final boolean unterkategorienVerwenden = ((MehrereKategorienGDP) this.getPanes()[3]).getUnterkategorienVerwenden(); final Euro[] summen1 = getDb().getKategorieSalden(kategorien, zeitraum1, register, unterkategorienVerwenden); final Euro[] summen2 = getDb().getKategorieSalden(kategorien, zeitraum2, register, unterkategorienVerwenden); setTabelle(new String[anzKat + 2][4]); setTabelleContent(0, 0, RES.getString("category")); setTabelleContent(0, 1, "" + zeitraum1); setTabelleContent(0, 2, "" + zeitraum2); setTabelleContent(0, 3, RES.getString("difference")); setTabelleContent(anzKat + 1, 0, RES.getString("total")); final Euro summe1 = new Euro(); final Euro summe2 = new Euro(); for (int i = 0; i < anzKat; i++) { setTabelleContent(i + 1, 0, "" + kategorien[i]); setTabelleContent(i + 1, 1, "" + summen1[i]); setTabelleContent(i + 1, 2, "" + summen2[i]); setTabelleContent(i + 1, 3, "" + summen1[i].sub(summen2[i])); summe1.sum(summen1[i]); summe2.sum(summen2[i]); } setTabelleContent(anzKat + 1, 1, "" + summe1); setTabelleContent(anzKat + 1, 2, "" + summe2); setTabelleContent(anzKat + 1, 3, "" + summe1.sub(summe2)); // Vorhandene Blöcke löschen und neu berechnete einfügen String titel = RES.getString("absolute_comparison") + " (" + getTabelle()[0][1] + " " + RES.getString("and") + " " + getTabelle()[0][2]; if (register == null) { titel += ")"; } else { titel += ", " + register + ")"; } loescheBloecke(); final TextBlock block1 = new TextBlock(titel); block1.setFont(new Font(this.getHaushalt().getFontname(), Font.BOLD, this.getHaushalt().getFontgroesse() + 6)); addDokumentenBlock(block1); addDokumentenBlock(new LeererBlock(1)); final TabellenBlock block2 = new TabellenBlock(getTabelle()); block2.setFont(new Font(this.getHaushalt().getFontname(), Font.PLAIN, this.getHaushalt().getFontgroesse())); final TabellenBlock.Ausrichtung[] attribute = { TabellenBlock.Ausrichtung.LINKS, TabellenBlock.Ausrichtung.RECHTS, TabellenBlock.Ausrichtung.RECHTS, TabellenBlock.Ausrichtung.RECHTS}; block2.setAusrichtung(attribute); if (prozentErsteSpalte > 0.0D) { final double rest = (100.0D - prozentErsteSpalte) / 3.0D; final double[] relTabs = {0.0D, prozentErsteSpalte, prozentErsteSpalte + rest, prozentErsteSpalte + rest * 2.0D,}; block2.setRelTabs(relTabs); } addDokumentenBlock(block2); return titel; } }