All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.jasperreports.engine.JRGenericElement Maven / Gradle / Ivy

There is a newer version: 7.0.1
Show newest version
/*
 * 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.engine;

import com.fasterxml.jackson.annotation.JsonTypeName;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.fasterxml.jackson.dataformat.xml.annotation.JacksonXmlElementWrapper;
import com.fasterxml.jackson.dataformat.xml.annotation.JacksonXmlProperty;

import net.sf.jasperreports.engine.design.JRDesignGenericElement;
import net.sf.jasperreports.engine.xml.JRXmlConstants;

/**
 * A "generic" report element that will produce a 
 * {@link JRGenericPrintElement generic print element} in the generated
 * report.
 * 

Generic Elements

* Generic report elements are like special placeholders that are put in the report template at * report design time, but are dealt with only at export time, when special content is * generated for them by the exporter. *

* A good example of a generic element use case is someone wanting to embed Javascript * visualizations in reports exported to HTML format. JasperReports has built-in support for * displaying text and images, but there is no built-in element for displaying Javascript visualizations. * This person would need to do the following to achieve it: *

    *
  • A new HTML export handler is developed, bundled into a JAR and deployed in the * application. The export handler would be registered with JasperReports for a * specific generic element type.
  • *
  • Optionally, a report custom component is implemented so that report designers * would be able to use specialized syntax in JRXMLs. The component implementation would generate * a {@link net.sf.jasperreports.engine.JRGenericPrintElement} at fill time.
  • *
  • Report designers would include either generic report elements or report * components (if implemented) in report templates.
  • *
  • At fill time, generic print elements whose type would match the type for which the * export handler was registered would be produced. Report expressions embedded in * the design report element are evaluated and the result is included in the produced * generic element as parameter values.
  • *
  • When the report will get exported to HTML, the custom HTML export handler will * output HTML snippets that embed Javascript as part of the HTML output. * Generic element parameter values would be used to parametrize the resulting Javascript code.
  • *
* But generic elements can be placeholders for any kind of special content, not necessarily * Javascript visualizations. The generic element handler implementation has the freedom to generate * any kind of output that can be embedded in the exporter report. *

* Generic report elements cannot stretch at fill time, they will always produce * a print element that has the same size as the design element. *

* They can be generated in filled reports either by a generic design element, or * by custom report components. Generic design elements can be used in simple * scenarios in which developing a specialized custom component would not benefit the * report design process. A generic design element consists of a generic element type, and a * list of element parameters. *

Generic Type

* The generic element type (see {@link #getGenericType()}) is a key that identifies a class/type * of generic elements which are to be handled uniformly. Such a type is composed of a namespace * (usually an URI associated with an organization or a product) and a name. *

* The generic type is the key used to resolve an export handler for a generic element * present in a generated report. Handlers are registered for a specific generic element * types, and when a generic element is exported the extensions registry is queried for a * generic element handler that has been registered for the element type. *

Generic Element Parameters

* A generic element can contain one or more arbitrary element parameters. The parameter * values are provided by parameter expression when using generic design elements to * generate a generic element. *

* At fill time, expressions associated with the parameters are evaluated and * the result is preserved in the print element. *

* When the generic element is generated by a custom component element, its * implementation is responsible for populating the generated element with parameter * values. *

* The parameters are queried by the export element handlers and the values are used to * produce the required output in the exported report. *

Generic Element Export Handlers

* Such a handler is an object responsible for handling generic print elements of a specific * type at export time. They usually come in bundles, which are sets generic element export * handlers that share the same type namespace. *

* Generic element handlers are specific to a report exporter. Currently only the HTML * exporter features support for generic elements. A generic element handler that would be * used for the HTML exporter would implement the * {@link net.sf.jasperreports.engine.export.GenericElementHtmlHandler} interface * (which extends the * {@link net.sf.jasperreports.engine.export.GenericElementHandler} interface that is * common to all export handlers). * Handler bundles are deployed as JasperReports extensions, using * {@link net.sf.jasperreports.engine.export.GenericElementHandlerBundle} as * extension type. JasperReports includes * {@link net.sf.jasperreports.engine.export.DefaultElementHandlerBundle}, a * convenience handler bundle implementation that wraps a map of handlers per element * type and exporter type. * * @see net.sf.jasperreports.engine.JRGenericPrintElement * @see net.sf.jasperreports.engine.export.GenericElementHandler * @see net.sf.jasperreports.engine.export.GenericElementHandlerBundle * @author Lucian Chirita ([email protected]) */ @JsonTypeName("generic") @JsonDeserialize(as = JRDesignGenericElement.class) public interface JRGenericElement extends JRElement, JREvaluation { /** * Returns the generic type of this element. * This type will be propagated to the generated print element, and used to * resolve export handler for the print element. * * @return the generic type of this element */ JRGenericElementType getGenericType(); /** * Returns the list of parameters of this element. * * @return the list of parameters */ @JacksonXmlProperty(localName = JRXmlConstants.ELEMENT_parameter) @JacksonXmlElementWrapper(useWrapping = false) JRGenericElementParameter[] getParameters(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy