EN · DE · RU · FR · ES

#451 : ReportObjective.java

projectforge-business/src/main/java/org/projectforge/business/fibu/kost/reporting/ReportObjective.java Type : Java · Rôle : Comptabilité financière · Source : projectforge-business/src/main/java/org/projectforge/business/fibu/kost/reporting/ReportObjective.java 257 lignes · 130 code · 91 commentaires · 36 vides
Fichier source à projectforge-business/src/main/java/org/projectforge/business/fibu/kost/reporting/ReportObjective.java contenant du code Java pour la couche Comptabilité financière.

Structure du code

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

Classes : ReportObjective, Pattern, Pattern, Pattern

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

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

Importations : 6 packages

Code source (abrégé)

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;

/**
 * Un ReportObjective dont les propriétés peuvent être analysées à partir d'un fichier XML. La description du format se trouve dans le manuel.
 * Un ReportObjective est associé à un rapport. Le rapport utilise le ReportObjective pour filtrer les écritures comptables. <br/> ATTENTION :
 * Un ReportObjective enfant ne peut que sous-sélectionner les écritures comptables du ReportObjective parent, c'est-à-dire que les écritures comptables
 * forment toujours un sous-ensemble !
 * @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()
  {
  }

  /**
   * Titre en texte clair
   */
  public String getTitle()
  {
    return title;
  }

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

  /**
   * Un ID quasi en texte clair, p. ex. "projet4711" pour construire la structure des hyperliens ou des dossiers
   */
  public String getId()
  {
    return id;
  }

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

  /**
   * @return False (par défaut), si les autres écritures comptables doivent être prises en compte comme un ReportObjective enfant distinct. Les
   *         ReportObjectives enfants sont examinés et les écritures comptables de ce ReportObjective non utilisées par les enfants sont compilées.
   *         La somme de toutes les écritures comptables / BWAs des enfants devrait ainsi correspondre à ce ReportObjective (en l'absence de doublons).
   * @see #isSupressDuplicates()
   */
  public boolean isSuppressOther()
  {
    return suppressOther;
  }

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

  /**
   * @return False (par défaut), si les doublons, c'est-à-dire les écritures comptables utilisées plusieurs fois par les ReportObjectives enfants,
   *         doivent être regroupés dans un ReportObjective enfant distinct. Ce flag et isOther permettent ainsi de vérifier l'exhaustivité et
   *         l'absence de doublons des ReportObjectives enfants.
   * @see #isSuppressOther()
   */
  public boolean isSuppressDuplicates()
  {
    return suppressDuplicates;
  }

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

  /**
   * @return True si des ReportObjectives enfants existent, sinon false.
   */
  public boolean getHasChildren()
  {
// ... (tronqué, total 235 lignes)

Historique Git

868d6abb7 2025 -> 2026
ee32b3e3a Dépréciations de code.
63081666f En-têtes de fichiers source : 2024 -> 2025.
b6092df09 Copyright 2023 -> 2024
ab45d51fa Copyright 2001-2022 -> 2001-2023.