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

ar.com.fdvs.dj.domain.ExpressionHelper Maven / Gradle / Ivy

Go to download

DynamicJasper (DJ) is an API that hides the complexity of Jasper Reports, it helps developers to save time when designing simple/medium complexity reports generating the layout of the report elements automatically. It creates reports dynamically, defining at runtime the columns, column width (auto width), groups, variables, fonts, charts, crosstabs, sub reports (that can also be dynamic), page size and everything else that you can define at design time. DJ keeps full compatibility with Jasper Reports since it's a tool that helps create reports programmatically in a easy way (it only interferes with the creation of the report design doing the layout of the elements). You can use the classic .jrxml files as templates while the content and layout of the report elements are handled by the DJ API. http://dynamicjasper.com

There is a newer version: 5.3.9
Show newest version
package ar.com.fdvs.dj.domain;

import ar.com.fdvs.dj.domain.entities.Entity;
import ar.com.fdvs.dj.util.customexpression.PageNumberCustomExpression;
import ar.com.fdvs.dj.util.customexpression.RecordsInPageCustomExpression;
import ar.com.fdvs.dj.util.customexpression.RecordsInReportCustomExpression;

import java.util.Map;

public class ExpressionHelper {
	private static final BooleanExpression printInFirstPage = new PrintInFirstPage();
	private static final BooleanExpression printNotInFirstPage = new PrintNotInFirstPage();
	private static final CustomExpression pageNumber = new PageNumberCustomExpression();
	private static final CustomExpression recordsInPage = new RecordsInPageCustomExpression();
	private static final CustomExpression recordsInReport = new RecordsInReportCustomExpression();
	
	public static BooleanExpression printInFirstPage() {
		return printInFirstPage;
	}
	
	public static BooleanExpression printNotInFirstPage() {
		return printNotInFirstPage;
	}

	/**
	 * Convenient CustomExpression that returns page number
	 */
	public static CustomExpression getPageNumber() {
		return pageNumber;
	}
	
	/**
	 * Convenient CustomExpression that returns the record number for the current page
	 */
	public static CustomExpression getRecordsInPage() {
		return recordsInPage;
	}
	
	/**
	 * Convenient CustomExpression that returns the record number for whole report
	 */
	public static CustomExpression getRecordsInReport() {
		return recordsInReport;
	}
	
	public static BooleanExpression printWhenGroupHasMoreThanOneRecord(final String groupName) {		
		return new BooleanExpression() {
			private static final long serialVersionUID = Entity.SERIAL_VERSION_UID;
			
			public Object evaluate(Map fields, Map variables, Map parameters) {
				return new Boolean(getGroupCount(groupName, variables) > 1);
			}
		};
	}
	
	public static int getPageNumber(Map variables) {
		return ((Integer) variables.get("PAGE_NUMBER")).intValue(); 
	}

	public static int getGroupCount(String groupName, Map variables) {
		return ((Integer) variables.get(groupName + "_COUNT")).intValue(); 
	}
	
	private static class PrintInFirstPage extends BooleanExpression {
		private static final long serialVersionUID = Entity.SERIAL_VERSION_UID;
		
		public Object evaluate(Map fields, Map variables, Map parameters) {
			return new Boolean(getPageNumber(variables) == 1);
		}
	}
	
	private static class PrintNotInFirstPage extends BooleanExpression {
		private static final long serialVersionUID = Entity.SERIAL_VERSION_UID;
		
		public Object evaluate(Map fields, Map variables, Map parameters) {
			return new Boolean(getPageNumber(variables) > 1);
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy