EN · DE · RU · FR · ES

#451: ReportObjective.java

projectforge-business/src/main/java/org/projectforge/business/fibu/kost/reporting/ReportObjective.java Typ: Java · Rolle: Finanzbuchhaltung · Quelle: projectforge-business/src/main/java/org/projectforge/business/fibu/kost/reporting/ReportObjective.java 257 Zeilen · 130 Code · 91 Kommentare · 36 leer
Quellcodedatei unter projectforge-business/src/main/java/org/projectforge/business/fibu/kost/reporting/ReportObjective.java mit Java-Code für die Finanzbuchhaltungsebene.

Codestruktur

Paket: org.projectforge.business.fibu.kost.reporting

Klassen: ReportObjective, Pattern, Pattern, Pattern

Methoden (22): getTitle, setTitle, getId, setId, isSuppressOther, setSuppressOther, isSuppressDuplicates, setSuppressDuplicates, getHasChildren, getHasChilds, addChildReportObjective, getChildReportObjectives, getKost1IncludeRegExpList, getKost1ExcludeRegExpList, getKost2IncludeRegExpList, getKost2ExcludeRegExpList, addKost1IncludeRegExp, addKost1ExcludeRegExp, addKost2IncludeRegExp, addKost2ExcludeRegExp, getParent, addRegExp

Felder (9): title, id, suppressOther, suppressDuplicates, kost1IncludeRegExpList, kost1ExcludeRegExpList, kost2IncludeRegExpList, kost2ExcludeRegExpList, childReportObjectives

Importe: 6 Pakete

Quellcode (gekürzt)

package org.projectforge.business.fibu.kost.reporting;

import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamAsAttribute;
import com.thoughtworks.xstream.annotations.XStreamImplicit;
import org.apache.commons.collections4.CollectionUtils;

import java.util.ArrayList;
import java.util.List;

/**
 * Ein Reportobjective, dessen Properties aus einem XML-File geparst werden können. Die Beschreibung des Formats ist im Handbuch zu finden.
 * Ein ReportObjective ist einem Report zugeordnet. Der Report nutzt das ReportObjective, um die Buchungssätze zu filtern. <br/> ACHTUNG:
 * Ein Child-ReportObjective kann die Buchungssätze des Eltern-ReportObjectives immer nur subselektieren, d. h. die Buchungssätze bilden
 * immer eine Untermenge!
 * @author Thomas Landgraf (tl@micromata.de)
 * @author Kai Reinhard
 *
 */
@XStreamAlias("ReportObjective")
public class ReportObjective
{
  @XStreamAsAttribute
  private String title;

  @XStreamAsAttribute
  private String id;

  @XStreamAsAttribute
  private boolean suppressOther;

  @XStreamAsAttribute
  private boolean suppressDuplicates;

  @XStreamImplicit(itemFieldName = "kost1-include")
  private List<String> kost1IncludeRegExpList;

  @XStreamImplicit(itemFieldName = "kost1-exclude")
  private List<String> kost1ExcludeRegExpList;

  @XStreamImplicit(itemFieldName = "kost2-include")
  private List<String> kost2IncludeRegExpList;

  @XStreamImplicit(itemFieldName = "kost2-exclude")
  private List<String> kost2ExcludeRegExpList;

  @XStreamImplicit(itemFieldName = "ReportObjective")
  private List<ReportObjective> childReportObjectives;

  private transient ReportObjective parent;

  public ReportObjective()
  {
  }

  /**
   * Klartexttitel
   */
  public String getTitle()
  {
    return title;
  }

  public void setTitle(String title)
  {
    this.title = title;
  }

  /**
   * Eine fast Klartext ID z.B. "projekt4711" zum Basteln der Hyperlink- bzw. Ordner-Struktur
   */
  public String getId()
  {
    return id;
  }

  public void setId(String id)
  {
    this.id = id;
  }

  /**
   * @return False (default), wenn die sonstigen Buchungssätze als eigenes Child-ReportObjective berücksichtigt werden sollen. Es werden die
   *         Child-ReportObjectives untersucht und von den Children nicht verwendete Buchungssätze dieses ReportObjectives zusammengestellt.
   *         Die Summe aller Buchungssätze / BWAs der Children sollte somit dieser ReportObjective entsprechen (falls keine Duplikate
   *         vorkommen).
   * @see #isSupressDuplicates()
   */
  public boolean isSuppressOther()
  {
    return suppressOther;
  }

  public void setSuppressOther(boolean suppressOther)
  {
    this.suppressOther = suppressOther;
  }

  /**
   * @return False (default), wenn Dupletten, d. h. mehrfach von den Child-ReportObjectives verwendete Buchungssätze, als eigenes
   *         Child-ReportObjective zusammengefasst werden sollen. Über dieses Flag und isOther kann somit die Vollständigkeit und
   *         Duplettenfreiheit von Child-ReportObjectives geprüft werden.
   * @see #isSuppressOther()
   */
  public boolean isSuppressDuplicates()
  {
    return suppressDuplicates;
  }

  public void setSuppressDuplicates(boolean suppressDuplicates)
  {
    this.suppressDuplicates = suppressDuplicates;
  }

  /**
   * @return True, wenn Child-ReportObjectives existieren, sonst false.
   */
  public boolean getHasChildren()
  {
// ... (gekürzt, insgesamt 235 Zeilen)

Git-Verlauf

868d6abb7 2025 -> 2026
ee32b3e3a Code-Deprecations.
63081666f Quellcode-Dateiköpfe: 2024 -> 2025.
b6092df09 Copyright 2023 -> 2024
ab45d51fa Copyright 2001-2022 -> 2001-2023.