Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* JasperReports - Free Java Reporting Library.
* Copyright (C) 2001 - 2016 TIBCO Software Inc. 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 .
*/
/*
* Contributors:
* Greg Hilton
*/
package net.sf.jasperreports.engine.export;
import static java.lang.Math.max;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_COLUMN_WIDTH_RATIO;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_DEFINED_NAMES_PREFIX;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_FIRST_PAGE_NUMBER;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_IGNORE_CELL_BACKGROUND;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_IGNORE_CELL_BORDER;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_PAGE_SCALE;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_PRINT_FOOTER_MARGIN;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_PRINT_HEADER_MARGIN;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_PRINT_PAGE_BOTTOM_MARGIN;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_PRINT_PAGE_LEFT_MARGIN;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_PRINT_PAGE_RIGHT_MARGIN;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_PRINT_PAGE_TOP_MARGIN;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_SHEET_FOOTER_CENTER;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_SHEET_FOOTER_LEFT;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_SHEET_FOOTER_RIGHT;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_SHEET_HEADER_CENTER;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_SHEET_HEADER_LEFT;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_SHEET_HEADER_RIGHT;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_SHEET_TAB_COLOR;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_SHOW_GRIDLINES;
import static net.sf.jasperreports.export.XlsReportConfiguration.PROPERTY_WHITE_PAGE_BACKGROUND;
import java.util.List;
import java.util.Map;
import java.util.SortedMap;
import java.util.TreeMap;
import net.sf.jasperreports.charts.type.EdgeEnum;
import net.sf.jasperreports.engine.JRGenericPrintElement;
import net.sf.jasperreports.engine.JRPrintElement;
import net.sf.jasperreports.engine.JRPrintFrame;
import net.sf.jasperreports.engine.JRPrintText;
import net.sf.jasperreports.engine.JRPropertiesUtil;
import net.sf.jasperreports.engine.JRPropertiesUtil.PropertySuffix;
import net.sf.jasperreports.engine.JasperReportsContext;
/**
* @author Teodor Danciu ([email protected])
*/
public class JRXlsAbstractExporterNature extends AbstractExporterNature
{
/**
* @deprecated Replaced by {@link JRXlsAbstractExporter#PROPERTY_BREAK_BEFORE_ROW}.
*/
public static final String PROPERTY_BREAK_BEFORE_ROW = JRXlsAbstractExporter.PROPERTY_BREAK_BEFORE_ROW;
/**
* @deprecated Replaced by {@link JRXlsAbstractExporter#PROPERTY_BREAK_AFTER_ROW}.
*/
public static final String PROPERTY_BREAK_AFTER_ROW = JRXlsAbstractExporter.PROPERTY_BREAK_AFTER_ROW;
protected boolean isIgnoreGraphics;
protected boolean isIgnorePageMargins;
/**
*
*/
protected JRXlsAbstractExporterNature(
JasperReportsContext jasperReportsContext,
ExporterFilter filter,
boolean isIgnoreGraphics,
boolean isIgnorePageMargins
)
{
super(jasperReportsContext, filter);
this.isIgnoreGraphics = isIgnoreGraphics;
this.isIgnorePageMargins = isIgnorePageMargins;
}
@Override
public JRPropertiesUtil getPropertiesUtil()
{
return propertiesUtil;
}
@Override
public boolean isToExport(JRPrintElement element)
{
return
(!isIgnoreGraphics || (element instanceof JRPrintText) || (element instanceof JRPrintFrame) || (element instanceof JRGenericPrintElement))
&& (filter == null || filter.isToExport(element));
}
@Override
public boolean isDeep(JRPrintFrame frame)
{
return true;
}
@Override
public boolean isSpanCells()
{
return true;
}
@Override
public boolean isIgnoreLastRow()
{
return false;
}
@Override
public boolean isHorizontallyMergeEmptyCells()
{
return false;
}
/**
* Specifies whether empty page margins should be ignored
*/
@Override
public boolean isIgnorePageMargins()
{
return isIgnorePageMargins;
}
@Override
public boolean isBreakBeforeRow(JRPrintElement element)
{
return element.hasProperties()
&& JRPropertiesUtil.asBoolean(element.getPropertiesMap().getProperty(JRXlsAbstractExporter.PROPERTY_BREAK_BEFORE_ROW));
}
@Override
public boolean isBreakAfterRow(JRPrintElement element)
{
return element.hasProperties()
&& JRPropertiesUtil.asBoolean(element.getPropertiesMap().getProperty(JRXlsAbstractExporter.PROPERTY_BREAK_AFTER_ROW));
}
/**
*
*/
public Boolean getRowAutoFit(JRPrintElement element)
{
if (
element.hasProperties()
&& element.getPropertiesMap().containsProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_ROW)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getBooleanProperty(element, JRXlsAbstractExporter.PROPERTY_AUTO_FIT_ROW, false);
}
return null;
}
/**
*
*/
public Boolean getColumnAutoFit(JRPrintElement element)
{
if (
element.hasProperties()
&& element.getPropertiesMap().containsProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_COLUMN)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getBooleanProperty(element, JRXlsAbstractExporter.PROPERTY_AUTO_FIT_COLUMN, false);
}
return null;
}
/**
*
*/
public Boolean getShowGridlines(JRPrintElement element)
{
if (
element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_SHOW_GRIDLINES)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getBooleanProperty(element, PROPERTY_SHOW_GRIDLINES, true);
}
return null;
}
public Boolean getIgnoreCellBackground(JRPrintElement element)
{
if (
element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_IGNORE_CELL_BACKGROUND)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getBooleanProperty(element, PROPERTY_IGNORE_CELL_BACKGROUND, false);
}
return null;
}
public Boolean getIgnoreCellBorder(JRPrintElement element)
{
if (
element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_IGNORE_CELL_BORDER)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getBooleanProperty(element, PROPERTY_IGNORE_CELL_BORDER, false);
}
return null;
}
public Boolean getWhitePageBackground(JRPrintElement element)
{
if (
element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_WHITE_PAGE_BACKGROUND)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getBooleanProperty(element, PROPERTY_WHITE_PAGE_BACKGROUND, false);
}
return null;
}
public Integer getCustomColumnWidth(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(JRXlsAbstractExporter.PROPERTY_COLUMN_WIDTH)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getIntegerProperty(element, JRXlsAbstractExporter.PROPERTY_COLUMN_WIDTH, 0);
}
return null;
}
public Float getColumnWidthRatio(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_COLUMN_WIDTH_RATIO)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getFloatProperty(element, PROPERTY_COLUMN_WIDTH_RATIO, 0f);
}
return null;
}
public List getRowLevelSuffixes(JRPrintElement element)
{
if (element.hasProperties())
{
return JRPropertiesUtil.getProperties(element,JRXlsAbstractExporter.PROPERTY_ROW_OUTLINE_LEVEL_PREFIX);
}
return null;
}
public String getSheetName(JRPrintElement element)
{
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(JRXlsAbstractExporter.PROPERTY_SHEET_NAME)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getProperty(element, JRXlsAbstractExporter.PROPERTY_SHEET_NAME);
}
return null;
}
public EdgeEnum getFreezeRowEdge(JRPrintElement element)
{
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(JRXlsAbstractExporter.PROPERTY_FREEZE_ROW_EDGE)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return EdgeEnum.getByName(getPropertiesUtil().getProperty(element, JRXlsAbstractExporter.PROPERTY_FREEZE_ROW_EDGE));
}
return null;
}
public EdgeEnum getFreezeColumnEdge(JRPrintElement element)
{
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(JRXlsAbstractExporter.PROPERTY_FREEZE_COLUMN_EDGE)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return EdgeEnum.getByName(getPropertiesUtil().getProperty(element, JRXlsAbstractExporter.PROPERTY_FREEZE_COLUMN_EDGE));
}
return null;
}
public String getSheetTabColor(JRPrintElement element)
{
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_SHEET_TAB_COLOR)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getProperty(element, PROPERTY_SHEET_TAB_COLOR);
}
return null;
}
public Integer getPageScale(JRPrintElement element)
{
if (
element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_PAGE_SCALE)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getIntegerProperty(element, PROPERTY_PAGE_SCALE, 0);
}
return null;
}
public Integer getFirstPageNumber(JRPrintElement element)
{
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_FIRST_PAGE_NUMBER)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getIntegerProperty(element, PROPERTY_FIRST_PAGE_NUMBER, 0);
}
return null;
}
public PropertySuffix[] getDefinedNames(JRPrintElement element)
{
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_DEFINED_NAMES_PREFIX)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
List propertySuffixes = propertiesUtil.getProperties(PROPERTY_DEFINED_NAMES_PREFIX);
if (propertySuffixes != null && !propertySuffixes.isEmpty())
{
return propertySuffixes.toArray(new PropertySuffix[propertySuffixes.size()]);
}
}
return null;
}
@Override
public void setXProperties(CutsInfo xCuts, JRPrintElement element, int row1, int col1, int row2, int col2)
{
Map xCutsProperties = xCuts.getPropertiesMap();
Cut cut = xCuts.getCut(col1);
Boolean columnAutoFit = getColumnAutoFit(element);
if (columnAutoFit != null)
{
if(!cut.hasProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_COLUMN))
{
cut.setProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_COLUMN, columnAutoFit);
}
else
{
cut.setProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_COLUMN, (Boolean)cut.getProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_COLUMN) && columnAutoFit);
}
}
Integer columnCustomWidth = getCustomColumnWidth(element);
Integer cutColumnCustomWidth = (Integer)cut.getProperty(JRXlsAbstractExporter.PROPERTY_COLUMN_WIDTH);
if (columnCustomWidth != null && (cutColumnCustomWidth == null || cutColumnCustomWidth < columnCustomWidth))
{
cut.setProperty(JRXlsAbstractExporter.PROPERTY_COLUMN_WIDTH, columnCustomWidth);
}
setXProperties(xCutsProperties, element);
}
@Override
public void setXProperties(Map xCutsProperties, JRPrintElement element)
{
}
private void setMargin(Integer marginValue, Cut cut, String marginName)
{
if(marginValue != null)
{
// a margin value cannot be negative
cut.setProperty(marginName, max(marginValue,0));
}
}
private void setHeaderFooter(String headerFooterValue, Cut cut, String headerFooterName)
{
if(headerFooterValue != null && headerFooterValue.trim().length() > 0)
{
cut.setProperty(headerFooterName, headerFooterValue);
}
}
@Override
public void setYProperties(CutsInfo yCuts, JRPrintElement element, int row1, int col1, int row2, int col2)
{
Map yCutsProperties = yCuts.getPropertiesMap();
Cut cut = yCuts.getCut(row1);
Boolean rowAutoFit = getRowAutoFit(element);
if (rowAutoFit != null)
{
if(!cut.hasProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_ROW))
{
cut.setProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_ROW, rowAutoFit);
}
else
{
cut.setProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_ROW, (Boolean)cut.getProperty(JRXlsAbstractExporter.PROPERTY_AUTO_FIT_ROW) && rowAutoFit);
}
}
List rowLevelSuffixes = getRowLevelSuffixes(element);
if(rowLevelSuffixes != null && !rowLevelSuffixes.isEmpty())
{
SortedMap levelMap = new TreeMap();
for(PropertySuffix suffix : rowLevelSuffixes)
{
String level = suffix.getSuffix();
String marker = suffix.getValue();
levelMap.put(level, "end".equalsIgnoreCase(marker));
}
// FIXMEXLS we should preserve existing outline level information in the current y cut
// SortedMap oldLevelMap = (SortedMap)cut.getProperty(JRXlsAbstractExporter.PROPERTY_ROW_OUTLINE_LEVEL_PREFIX);
// if (oldLevelMap != null)
// {
// oldLevelMap.putAll(levelMap);
// levelMap = oldLevelMap;
// }
cut.setProperty(JRXlsAbstractExporter.PROPERTY_ROW_OUTLINE_LEVEL_PREFIX, levelMap);
}
String sheetName = getSheetName(element);
if(sheetName != null)
{
cut.setProperty(JRXlsAbstractExporter.PROPERTY_SHEET_NAME, sheetName);
}
String tabColor = getSheetTabColor(element);
if(tabColor != null)
{
cut.setProperty(PROPERTY_SHEET_TAB_COLOR, tabColor);
}
Integer pageScale = getPageScale(element);
if(pageScale != null && pageScale > 9 && pageScale < 401)
{
cut.setProperty(PROPERTY_PAGE_SCALE, pageScale);
}
Integer firstPageNumber = getFirstPageNumber(element);
if(firstPageNumber != null)
{
cut.setProperty(PROPERTY_FIRST_PAGE_NUMBER, firstPageNumber);
}
Boolean showGridlines = getShowGridlines(element);
if(showGridlines != null)
{
cut.setProperty(PROPERTY_SHOW_GRIDLINES, showGridlines);
}
Boolean ignoreCellBackground = getIgnoreCellBackground(element);
if(ignoreCellBackground != null)
{
cut.setProperty(PROPERTY_IGNORE_CELL_BACKGROUND, ignoreCellBackground);
}
Boolean ignoreCellBorder = getIgnoreCellBorder(element);
if(ignoreCellBorder != null)
{
cut.setProperty(PROPERTY_IGNORE_CELL_BORDER, ignoreCellBorder);
}
Boolean whitePageBackground = getWhitePageBackground(element);
if(whitePageBackground != null)
{
cut.setProperty(PROPERTY_WHITE_PAGE_BACKGROUND, whitePageBackground);
}
EdgeEnum freezeColumnEdge = getFreezeColumnEdge(element);
int columnFreezeIndex = freezeColumnEdge == null
? 0
: (EdgeEnum.RIGHT.equals(freezeColumnEdge)
? col2
: col1
);
if(columnFreezeIndex > 0)
{
cut.setProperty(JRXlsAbstractExporter.PROPERTY_FREEZE_COLUMN_EDGE, columnFreezeIndex);
}
EdgeEnum freezeRowEdge = getFreezeRowEdge(element);
int rowFreezeIndex = freezeRowEdge == null
? 0
: (EdgeEnum.BOTTOM.equals(freezeRowEdge)
? row2
: row1
);
if(rowFreezeIndex > 0)
{
cut.setProperty(JRXlsAbstractExporter.PROPERTY_FREEZE_ROW_EDGE, rowFreezeIndex);
}
Float columnWidthRatio = getColumnWidthRatio(element);
// only positive values are allowed
if(columnWidthRatio != null && columnWidthRatio > 0f)
{
cut.setProperty(PROPERTY_COLUMN_WIDTH_RATIO, columnWidthRatio);
}
setMargin(getPrintPageTopMargin(element), cut, PROPERTY_PRINT_PAGE_TOP_MARGIN);
setMargin(getPrintPageLeftMargin(element), cut, PROPERTY_PRINT_PAGE_LEFT_MARGIN);
setMargin(getPrintPageBottomMargin(element), cut, PROPERTY_PRINT_PAGE_BOTTOM_MARGIN);
setMargin(getPrintPageRightMargin(element), cut, PROPERTY_PRINT_PAGE_RIGHT_MARGIN);
setMargin(getPrintHeaderMargin(element), cut, PROPERTY_PRINT_HEADER_MARGIN);
setMargin(getPrintFooterMargin(element), cut, PROPERTY_PRINT_FOOTER_MARGIN);
setHeaderFooter(getSheetHeaderLeft(element), cut, PROPERTY_SHEET_HEADER_LEFT);
setHeaderFooter(getSheetHeaderCenter(element), cut, PROPERTY_SHEET_HEADER_CENTER);
setHeaderFooter(getSheetHeaderRight(element), cut, PROPERTY_SHEET_HEADER_RIGHT);
setHeaderFooter(getSheetFooterLeft(element), cut, PROPERTY_SHEET_FOOTER_LEFT);
setHeaderFooter(getSheetFooterCenter(element), cut, PROPERTY_SHEET_FOOTER_CENTER);
setHeaderFooter(getSheetFooterRight(element), cut, PROPERTY_SHEET_FOOTER_RIGHT);
setYProperties(yCutsProperties, element);
}
@Override
public void setYProperties(Map yCutsProperties, JRPrintElement element)
{
// nothing to do here
}
public Integer getPrintPageTopMargin(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_PRINT_PAGE_TOP_MARGIN)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getIntegerProperty(element, PROPERTY_PRINT_PAGE_TOP_MARGIN, 0);
}
return null;
}
public Integer getPrintPageLeftMargin(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_PRINT_PAGE_LEFT_MARGIN)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getIntegerProperty(element, PROPERTY_PRINT_PAGE_LEFT_MARGIN, 0);
}
return null;
}
public Integer getPrintPageBottomMargin(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_PRINT_PAGE_BOTTOM_MARGIN)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getIntegerProperty(element, PROPERTY_PRINT_PAGE_BOTTOM_MARGIN, 0);
}
return null;
}
public Integer getPrintPageRightMargin(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_PRINT_PAGE_RIGHT_MARGIN)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getIntegerProperty(element, PROPERTY_PRINT_PAGE_RIGHT_MARGIN, 0);
}
return null;
}
public Integer getPrintHeaderMargin(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_PRINT_HEADER_MARGIN)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getIntegerProperty(element, PROPERTY_PRINT_HEADER_MARGIN, 0);
}
return null;
}
public Integer getPrintFooterMargin(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_PRINT_FOOTER_MARGIN)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getIntegerProperty(element, PROPERTY_PRINT_FOOTER_MARGIN, 0);
}
return null;
}
public String getSheetHeaderLeft(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_SHEET_HEADER_LEFT)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getProperty(element, PROPERTY_SHEET_HEADER_LEFT);
}
return null;
}
public String getSheetHeaderCenter(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_SHEET_HEADER_CENTER)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getProperty(element, PROPERTY_SHEET_HEADER_CENTER);
}
return null;
}
public String getSheetHeaderRight(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_SHEET_HEADER_RIGHT)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getProperty(element, PROPERTY_SHEET_HEADER_RIGHT);
}
return null;
}
public String getSheetFooterLeft(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_SHEET_FOOTER_LEFT)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getProperty(element, PROPERTY_SHEET_FOOTER_LEFT);
}
return null;
}
public String getSheetFooterCenter(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_SHEET_FOOTER_CENTER)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getProperty(element, PROPERTY_SHEET_FOOTER_CENTER);
}
return null;
}
public String getSheetFooterRight(JRPrintElement element) {
if (element.hasProperties()
&& element.getPropertiesMap().containsProperty(PROPERTY_SHEET_FOOTER_RIGHT)
)
{
// we make this test to avoid reaching the global default value of the property directly
// and thus skipping the report level one, if present
return getPropertiesUtil().getProperty(element, PROPERTY_SHEET_FOOTER_RIGHT);
}
return null;
}
}