net.sf.jasperreports.customvisualization.fill.CVFillItemProperty Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jasperreports-custom-visualization Show documentation
Show all versions of jasperreports-custom-visualization Show documentation
JasperReports Custom Visualization Component
/*
* JasperReports - Free Java Reporting Library.
* Copyright (C) 2001 - 2023 Cloud Software Group, 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 .
*/
package net.sf.jasperreports.customvisualization.fill;
import java.io.Serializable;
import net.sf.jasperreports.components.items.ItemProperty;
import net.sf.jasperreports.engine.JRConstants;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JRExpression;
import net.sf.jasperreports.engine.fill.JRFillExpressionEvaluator;
import net.sf.jasperreports.engine.fill.JRFillObjectFactory;
/**
*
* @author Giulio Toffoli ([email protected])
*/
public class CVFillItemProperty implements Serializable
{
private static final long serialVersionUID = JRConstants.SERIAL_VERSION_UID;
protected String name;
protected JRExpression valueExpression;
protected String value;
public CVFillItemProperty(ItemProperty itemProperty, JRFillObjectFactory factory)
{
this.valueExpression = factory.getExpression(itemProperty.getValueExpression());
this.value = itemProperty.getValue();
this.name = itemProperty.getName();
}
public String getName()
{
return name;
}
public String getValue()
{
return value;
}
/**
*
*/
public void evaluate(JRFillExpressionEvaluator evaluator, byte evaluation) throws JRException
{
this.value = getEvaluatedValue(evaluator, evaluation);
}
@Override
public Object clone()
{
throw new UnsupportedOperationException();
}
public String getEvaluatedValue(JRFillExpressionEvaluator evaluator, byte evaluation) throws JRException
{
if (this.valueExpression == null || "".equals(valueExpression.getText()))
{
return getValue();
}
else
{
Object evaluatedValue = evaluator.evaluate(this.valueExpression, evaluation);
verifyValue(evaluatedValue);
return evaluatedValue == null ? null : evaluatedValue.toString();
}
}
/**
* Here we may add a validation handler to validate individual
* properties.... By default we
*
* @param value
* @throws JRException
*/
public void verifyValue(Object value) throws JRException
{
// Empty implementation. We don't do any verification.
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy