All Downloads are FREE. Search and download functionalities are using the official Maven repository.

gdv.xport.satz.Nachsatz Maven / Gradle / Ivy

Go to download

gdv-xport-lib ist die Java-Bibliothek fuer den Umgang mit dem GDV-Format. Sie erleichtert den Export und Export dieses Datenformats.

There is a newer version: 7.2.2
Show newest version
/*
 * Copyright (c) 2009 - 2023 by Oli B.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express orimplied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 * (c)reated 05.10.2009 by Oli B. ([email protected])
 */

package gdv.xport.satz;

import gdv.xport.feld.*;
import gdv.xport.util.SatzRegistry;
import gdv.xport.util.SatzTyp;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

import java.io.IOException;
import java.math.BigDecimal;

import static gdv.xport.feld.Bezeichner.*;

/**
 * Dies ist der letzte Satz, der Nachsatz eben.
 * 

* Fuer den einfacheren Umgang mit den einzelnen Betraegen, die hier im * Nachsatz zusammengefasst werden, sind jeweils Betrag und Vorzeichen * zusammengefasst und werden als {@link BetragMitVorzeichen} zurueckgegeben. * Ist man nur am Betrag oder Vorzeichen interessiert, kann man sich das * dann ueber {@link BetragMitVorzeichen#getBetrag()} und * {@link BetragMitVorzeichen#getVorzeichen()} abholen. *

* * @author oliver * @since 05.10.2009 */ public final class Nachsatz extends Satz { /** Satzart fuer Nachsatz. */ public static final SatzTyp SATZART = SatzTyp.of("9999"); private static final Logger LOG = LogManager.getLogger(Nachsatz.class); /** * Default-Constructor. */ public Nachsatz() { this(SatzRegistry.getInstance()); } /** * Ueber die mitgegebene Factory wird der Nachsatz genauso aufgebaut, wie * die {@link SatzRegistry} als Vorlage liefert. * * @param factory sollte die Vorlage fuer den Nachsatz liefern. * @since 5.0 */ public Nachsatz(SatzRegistry factory) { this(factory.getSatz(SATZART)); } private Nachsatz(Satz vorlage) { super(vorlage, vorlage.cloneTeildatensaetze()); } /** * Erzeugt einen Nachsatz mit dem angegebenen Inhalt. *

* Anmerkung: Die urspruengliche Implementierung als Konstruktor wurde * in eine statische of()-Methode umgewandelt, da Satz(String) * semantisch eine andere Bedeutung hat - dort repraesentiert der * uebergebene Parameter die Satzart, hier den kompletten Inhalt. *

* * @param content Inhalt des Nachsatz * @return frisch kreierten Nachsatz * @since 5.0 */ public static Nachsatz of(final String content) { Nachsatz nachsatz = new Nachsatz(); try { nachsatz.importFrom(content); LOG.debug("{} created from \"{}\"", nachsatz, content); return nachsatz; } catch (IOException ioe) { throw new IllegalArgumentException("argument too short", ioe); } } /** * Dies ist der Copy-Constructor, mit dem man einen bestehenden Nachsatz * kopieren kann. * * @param other der originale Nachsatz * @since 5.0 */ public Nachsatz(final Nachsatz other) { super(other, other.cloneTeildatensaetze()); } /** * Setzt die Anzahl der Saetze. * * @param n Anzahl der eingeschlossenen Saetze */ public void setAnzahlSaetze(final int n) { this.setFeld(Bezeichner.ANZAHL_SAETZE, n); } /** * @return Anzahl der eingeschlossenen Saetze */ public int getAnzahlSaetze() { return Integer.parseInt(this.getFeld(Bezeichner.ANZAHL_SAETZE) .getInhalt() .trim()); } /** * Anzahl der Saetze um 1 erhoehen. */ public void increaseAnzahlSaetze() { this.setAnzahlSaetze(this.getAnzahlSaetze() + 1); } /** * Setzt den Gesamtbeitrag. * * @param beitrag der neue Gesamtbeitrag * @since 5.0 */ public void setGesamtBeitrag(final String beitrag) { this.setFeld(Bezeichner.GESAMTBEITRAG, beitrag); } /** * Setzt den Gesamtbeitrag. * * @param beitrag der neue Gesamtbeitrag * @deprecated durch {@link #setGesamtBeitrag(BigDecimal)} abgeloest */ @Deprecated public void setGesamtBeitrag(final double beitrag) { this.setGesamtBeitrag(BigDecimal.valueOf(beitrag)); } /** * Setzt den Gesamtbeitrag. * * @param beitrag der neue Gesamtbeitrag * @since 5.0 */ public void setGesamtBeitrag(final BigDecimal beitrag) { this.setFeld(Bezeichner.GESAMTBEITRAG, beitrag.movePointRight(2).toString()); } /** * Erhoeht den Gesamtbeitrag (Feld 4) * * @param beitrag neuer Summand fuer Gesamtbeitrag (in Cents) * @return aufaddierte Summe * @since 5.0 */ public BigDecimal addGesamtBeitrag(final BigDecimal beitrag) { BigDecimal summe = getGesamtBeitrag().add(beitrag); setGesamtBeitrag(summe); return summe; } /** * Diese Methode liefert den Gesamt-Beitrag als {@link Betrag} und nicht * als String zurueck, um die Kompatibilitaet mit v4 zu wahren. * * @return Gesamtbeitrag als Betrag */ public Betrag getGesamtBeitrag() { return Betrag.of(this.getFeld(Bezeichner.GESAMTBEITRAG)); } /** * Setzt den Gesamtbeitrag-Brutto (Inkasso, Feld 5). * * @param beitrag neuer Gesamtbeitrag (Brutto) * @since 5.0 */ public void setGesamtBeitragBruttoMitVorzeichen(final BigDecimal beitrag) { BetragMitVorzeichen bmv = getGesamtBeitragBruttoMitVorzeichen(); bmv.setInhalt(beitrag); setGesamtBeitragBrutto(bmv.getBetrag().getInhalt()); setVorzeichenGesamtbeitragBrutto(Character.toString(bmv.getVorzeichen())); } /** * Setzt den Gesamtbeitrag-Brutto(Inkasso) (Feld 5) * * @param strBeitrag neuer Gesamtbeitrag-Brutto(Inkasso) * @since 5.0 */ public void setGesamtBeitragBrutto(final String strBeitrag) { this.getTeildatensatz(1) .getFeld(5) .setInhalt(strBeitrag); } /** * Erhoeht den Gesamtbeitrag-Brutto(Inkasso) (Feld 5 und Feld 6) * * @param beitrag neuer Summand fuer Gesamtbeitrag-Brutto(Inkasso) * @return aufaddierte Summe * @since 5.0 */ public BigDecimal addGesamtBeitragBrutto(final BigDecimal beitrag) { BigDecimal summe = getGesamtBeitragBruttoMitVorzeichen().add(beitrag); setGesamtBeitragBruttoMitVorzeichen(summe); return summe; } /** * Liefert den Gesamtbeitrag (Brutto). * * @return Gesamtbeitrag-Brutto(Inkasso) (Feld 5) * @since 5.0 */ public BetragMitVorzeichen getGesamtBeitragBruttoMitVorzeichen() { NumFeld brutto = (NumFeld) getFeld(GESAMTBEITRAG_BRUTTO); AlphaNumFeld vorzeichen = (AlphaNumFeld) getFeld(ByteAdresse.of(brutto.getEndAdresse() + 1)); return BetragMitVorzeichen.of(brutto, vorzeichen); } /** * Setzt das Vorzeichen Gesamtbeitrag-Brutto(Inkasso) (Feld 6) * * @param strVorzeichen Vorzeichen * @since 5.0 */ public void setVorzeichenGesamtbeitragBrutto(final String strVorzeichen) { if (("+").equalsIgnoreCase(strVorzeichen) || ("-").equalsIgnoreCase(strVorzeichen)) this.getTeildatensatz(1).getFeld(6).setInhalt(strVorzeichen); else throw new IllegalArgumentException(strVorzeichen + ": kein Vorzeichen"); } /** * Setzt den Gesamtprovisions-Betrag (Feld 7). * * @param strBeitrag neuer Gesamtprovisions-Betrag * @since 5.0 */ public void setGesamtProvisionsBetrag(final String strBeitrag) { this.getTeildatensatz(1) .getFeld(7) .setInhalt(strBeitrag); } /** * Setzt den Gesamtprovisions-Betrag (Feld 7) * * @param betrag neuer Gesamtprovisions-Betrag * @since 5.0 */ public void setGesamtProvisionsBetragMitVorzeichen(final BigDecimal betrag) { BetragMitVorzeichen bmv = getGesamtProvisionsBetragMitVorzeichen(); bmv.setInhalt(betrag); setGesamtProvisionsBetrag(bmv.getBetrag().getInhalt()); setVorzeichenGesamtProvisionsBetrag(Character.toString(bmv.getVorzeichen())); } /** * Erhoeht den Gesamtprovisions-Betrag (Feld 7 und Feld 8) * * @param betrag neuer Summand fuer Gesamtprovisions-Betrag * @return Summe * @since 5.0 */ public BigDecimal addGesamtProvisionsBetrag(final BigDecimal betrag) { BigDecimal summe = getGesamtProvisionsBetragMitVorzeichen().add(betrag); this.setGesamtProvisionsBetragMitVorzeichen(summe); return summe; } /** * Liefert den Gesamt-Provisionsbetrag, inklusive Vorzeichen. * * @return Gesamtprovisions-Betrag (Feld 7) * @since 5.0 */ public BetragMitVorzeichen getGesamtProvisionsBetragMitVorzeichen() { NumFeld brutto = getFeld(GESAMTPROVISIONSBETRAG, NumFeld.class); AlphaNumFeld vorzeichen = (AlphaNumFeld) getFeld(ByteAdresse.of(brutto.getEndAdresse() + 1)); return BetragMitVorzeichen.of(brutto, vorzeichen); } /** * Setzt das Vorzeichen Gesamtprovisions-Betrag (Feld 8). * * @param strVorzeichen Vorzeichen * @since 5.0 */ public void setVorzeichenGesamtProvisionsBetrag(final String strVorzeichen) { if (("+").equalsIgnoreCase(strVorzeichen) || ("-").equalsIgnoreCase( strVorzeichen)) this.getTeildatensatz(1) .getFeld(8) .setInhalt(strVorzeichen); else throw new IllegalArgumentException(strVorzeichen + ": kein Vorzeichen"); } /** * Setzt den Betrag fuer die Versicherungsleistungen. * * @param betrag neuer Betrag * @since 5.0 */ public void setVersicherungsLeistungenMitVorzeichen(final BigDecimal betrag) { BetragMitVorzeichen bmv = getVersicherungsLeistungenMitVorzeichen(); bmv.setInhalt(betrag); setVersicherungsLeistungen(bmv.getBetrag().getInhalt()); setVorzeichenVersicherungsLeistungen(Character.toString(bmv.getVorzeichen())); } /** * Setzt die Versicherungsleistungen (Feld 9) * * @param strBeitrag neue Versicherungsleitungen * @since 5.0 */ public void setVersicherungsLeistungen(final String strBeitrag) { this.getTeildatensatz(1).getFeld(9).setInhalt(strBeitrag); } /** * Erhoeht die VersicherungsLeistungen (Feld 9 und Feld 10) * * @param betrag neuer Summand fuer Versicherungsleitungen * @return Summe * @since 5.0 */ public BigDecimal addVersicherungsLeistungen(final BigDecimal betrag) { BigDecimal summe = getVersicherungsLeistungenMitVorzeichen().add(betrag); this.setVersicherungsLeistungenMitVorzeichen(summe); return summe; } /** * Liefert die Versicherungsleistungen, inklusiv Vorzeichen. * * @return VersicherungsLeistungen (Feld 9) * @since 5.0 */ public BetragMitVorzeichen getVersicherungsLeistungenMitVorzeichen() { NumFeld brutto = (NumFeld) getFeld(VERSICHERUNGSLEISTUNGEN); AlphaNumFeld vorzeichen = (AlphaNumFeld) getFeld(ByteAdresse.of(brutto.getEndAdresse() + 1)); return BetragMitVorzeichen.of(brutto, vorzeichen); } /** * Setzt das Vorzeichen VersicherungsLeistungen (Feld 10) * * @param strVorzeichen Vorzeichen * @since 5.0 */ public void setVorzeichenVersicherungsLeistungen(final String strVorzeichen) { if (("+").equalsIgnoreCase(strVorzeichen) || ("-").equalsIgnoreCase(strVorzeichen)) this.getTeildatensatz(1).getFeld(10).setInhalt(strVorzeichen); else throw new IllegalArgumentException(strVorzeichen + ": kein Vorzeichen"); } /** * Setzt die Schadenbearbeitungskosten. * * @param beitrag neuer Gesamtbeitrag (Brutto) * @since 5.0 */ public void setSchadenbearbeitungskostenMitVorzeichen(final BigDecimal beitrag) { BetragMitVorzeichen bmv = getSchadenbearbeitungskostenMitVorzeichen(); bmv.setInhalt(beitrag); setSchadenbearbeitungskosten(bmv.getBetrag().getInhalt()); setVorzeichenSchadenbearbeitungskosten(Character.toString(bmv.getVorzeichen())); } /** * Setzt die Schadenbearbeitungskosten (Feld 11). * * @param strBeitrag neue Schadenbearbeitungskosten * @since 5.0 */ public void setSchadenbearbeitungskosten(final String strBeitrag) { this.getTeildatensatz(1).getFeld(11).setInhalt(strBeitrag); } /** * Erhoeht die Schadenbearbeitungskosten (Feld 11 und Feld 12) * * @param betrag neuer Summand fuer Schadenbearbeitungskosten * @return Summe * @since 5.0 */ public BigDecimal addSchadenbearbeitungskosten(final BigDecimal betrag) { BigDecimal summe = getSchadenbearbeitungskostenMitVorzeichen().add(betrag); this.setSchadenbearbeitungskostenMitVorzeichen(summe); return summe; } /** * Liefert die Schandenbearbeitunskosten. * * @return Schadenbearbeitungskosten mit Vorzeichen (Feld 11+12) * @since 5.0 */ public BetragMitVorzeichen getSchadenbearbeitungskostenMitVorzeichen() { NumFeld betrag = (NumFeld) getFeld(SCHADENBEARBEITUNGSKOSTEN); AlphaNumFeld vorzeichen = (AlphaNumFeld) getFeld(ByteAdresse.of(betrag.getEndAdresse() + 1)); return BetragMitVorzeichen.of(betrag, vorzeichen); } /** * Setzt das Vorzeichen Schadenbearbeitungskosten (Feld 12) * * @param strVorzeichen Vorzeichen */ public void setVorzeichenSchadenbearbeitungskosten(final String strVorzeichen) { if (("+").equalsIgnoreCase(strVorzeichen) || ("-").equalsIgnoreCase(strVorzeichen)) this.getTeildatensatz(1).getFeld(12).setInhalt(strVorzeichen); else throw new IllegalArgumentException(strVorzeichen + ": kein Vorzeichen"); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy