/*
* JasperReports - Free Java Reporting Library.
* Copyright (C) 2001 - 2009 Jaspersoft Corporation. All rights reserved.
* http://www.jaspersoft.com
*
* Unless you have purchased a commercial license agreement from Jaspersoft,
* the following license terms apply:
*
* This program is part of JasperReports.
*
* JasperReports is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* JasperReports 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with JasperReports. If not, see <http://www.gnu.org/licenses/>.
*/
package net.sf.jasperreports.crosstabs;
import net.sf.jasperreports.crosstabs.type.CrosstabTotalPositionEnum;
import net.sf.jasperreports.engine.JRCloneable;
import net.sf.jasperreports.engine.JRVariable;
/**
* Base interface for crosstab row and column groups.
*
* @author Lucian Chirita (lucianc@users.sourceforge.net)
* @version $Id: JRCrosstabGroup.java 3500 2010-03-03 15:56:41Z teodord $
*/
public interface JRCrosstabGroup extends JRCloneable
{
/**
* Returns the name of the group.
*
* @return the name of the group
* @see #getVariable()
*/
public String getName();
/**
* @deprecated Replaced by {@link #getTotalPositionValue()}.
*/
public byte getTotalPosition();
/**
* Returns the position of the total row/column for this group.
* <p>
* A group can have a total row/column summing the values for all the
* entries in the group. E.g. if there is a Year group having Month as
* a subgroup, the total row/column for the Year group would sum the values
* for all the years and the total row/column for the Month group would sum
* the values for all the months of an year.
* <p>
* Possible values for this attribute are:
* <ul>
* <li>{@link CrosstabTotalPositionEnum#NONE CrosstabTotalPositionEnum.NONE}
* - the group will not display a total row/column</li>
* <li>{@link CrosstabTotalPositionEnum#START CrosstabTotalPositionEnum.START}
* - the group will display the total row/column before the group rows/columns</li>
* <li>{@link CrosstabTotalPositionEnum#END CrosstabTotalPositionEnum.END}
* - the group will display the total row/column at the end of the group rows/columns</li>
*
* @return the position of the total row/column for this group
*/
public CrosstabTotalPositionEnum getTotalPositionValue();
/**
* Returns the bucketing information for this group.
* <p>
* The bucketing information consists of grouping expression and
* group ordering.
*
* @return the bucketing information for this group
*/
public JRCrosstabBucket getBucket();
/**
* Returns the group header cell.
* <p>
* The size of the header cell is computed based on the following rules
* (only the row header rules are listed, the ones for columns can be
* deducted by simmetrical duality):
* <ul>
* <li>the width of the header is given by {@link JRCrosstabRowGroup#getWidth() JRCrosstabRowGroup.getWidth()}</li>
* <li>the height of the last row group header is given by the height of the base cell</li>
* <li>the height of a non-last row group header is the sum of the next group header's height and
* the next group total header's height (0 if the next group doesn't have a total header)</li>
* </ul>
* <p>
* Should never return null, but empty cell contents instead.
*
* @return the group header cell
*/
public JRCellContents getHeader();
/**
* Returns the group total header cell.
* <p>
* The size of a row group total header is computed based on the following rules:
* <ul>
* <li>the width is the sum the widths of this and subsequent row groups</li>
* <li>the height is the height of the base cell for this total row</li>
* </ul>
* <p>
* Should never return null, but empty cell contents instead.
*
* @return the group total header cell
*/
public JRCellContents getTotalHeader();
/**
* Returns the variable associated to this group.
* <p>
* Each group in the crosstab has a variable that can be used
* inside the group header as the current group value.
* The variable has the same name as the group and the same type
* as the bucket expression of the group.
*
* @return the variable associated to this group
*/
public JRVariable getVariable();
/**
* Returns whether the group has a total row/column.
* <p>
* This method is currently equivalent to
* <code>getTotalPosition() != Bucket.TOTAL_POSITION_NONE</code> and is therefore
* redundant.
*
* @return whether the group has a total row/column
*/
public boolean hasTotal();
}