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

xdev.tableexport.cmd.ExportCreation Maven / Gradle / Ivy

package xdev.tableexport.cmd;

/*-
 * #%L
 * XDEV BI Suite
 * %%
 * Copyright (C) 2011 - 2020 XDEV Software
 * %%
 * This program 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.
 * 
 * This program 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 General Lesser Public License for more details.
 * 
 * You should have received a copy of the GNU General Lesser Public
 * License along with this program.  If not, see
 * .
 * #L%
 */


import java.awt.Color;
import java.awt.Font;
import java.io.File;
import java.io.OutputStream;
import java.util.HashMap;

import javax.swing.JTable;

import net.sf.jasperreports.engine.JRRewindableDataSource;
import net.sf.jasperreports.engine.JasperReport;
import xdev.io.XdevFile;
import xdev.lang.cmd.CommandException;
import xdev.lang.cmd.XdevCommandObject;
import xdev.tableexport.JRVirtualTableDataSource;
import xdev.tableexport.config.ColumnAlignment;
import xdev.tableexport.config.ColumnBorder;
import xdev.tableexport.config.ColumnStyle;
import xdev.tableexport.config.ContentColumn;
import xdev.tableexport.config.HeaderColumn;
import xdev.tableexport.config.TemplateColumn;
import xdev.tableexport.config.TemplateConfig;
import xdev.tableexport.config.builder.ExportConfigBuilder;
import xdev.tableexport.config.builder.JTableViewConfigBuilder;
import xdev.tableexport.config.builder.VTConfigBuilder;
import xdev.tableexport.config.builder.XdevTableConfigBuilder;
import xdev.tableexport.datasource.XdevJTableRendererDataSource;
import xdev.tableexport.datasource.XdevTableDataSource;
import xdev.tableexport.export.ExportException;
import xdev.tableexport.export.ReportBuilder;
import xdev.tableexport.export.ReportExporter;
import xdev.tableexport.export.writer.CSVToFileWriter;
import xdev.tableexport.export.writer.CSVToOutputStreamWriter;
import xdev.tableexport.export.writer.ExportWriter;
import xdev.tableexport.export.writer.HtmlToFileWriter;
import xdev.tableexport.export.writer.HtmlToOutputStreamWriter;
import xdev.tableexport.export.writer.PdfToFileWriter;
import xdev.tableexport.export.writer.PdfToOutputStreamWriter;
import xdev.tableexport.export.writer.PrintWriter;
import xdev.tableexport.export.writer.ReportToPreviewWriter;
import xdev.tableexport.export.writer.RtfToFileWriter;
import xdev.tableexport.export.writer.RtfToOutputStreamWriter;
import xdev.tableexport.export.writer.XMLToFileWriter;
import xdev.tableexport.export.writer.XMLToOutputStreamWriter;
import xdev.tableexport.export.writer.XlsToFileWriter;
import xdev.tableexport.export.writer.XlsToOutputStreamWriter;
import xdev.tableexport.export.writer.XlsxToFileWriter;
import xdev.tableexport.export.writer.XlsxToOutputStreamWriter;
import xdev.ui.DesktopUtils;
import xdev.ui.VirtualTableEditor;
import xdev.ui.XdevFileChooser;
import xdev.ui.XdevFileChooserFactory;
import xdev.ui.XdevFileFilter;
import xdev.vt.VirtualTable;


public abstract class ExportCreation extends XdevCommandObject
{
	
	private DataSourceType		dataSourceType;
	
	/**
	 * Source types
	 */
	private VirtualTable		virtualTable;
	private VirtualTableEditor	xdevTable;
	private JTable				jTable;
	// //////////////////////////////////////////////////////////////
	// //////// COLUMN ELEMENTE ///////////////////////////
	// ////////////////////////////////////////////////////////////
	private TemplateConfig		templateConfig		= new TemplateConfig();
	
	// //////////////////////////////////////////////////////////////
	// //////// PRINT ELEMENTE ///////////////////////////
	// ////////////////////////////////////////////////////////////
	private boolean				displayPageDialog;
	private boolean				displayPageDialogOnlyOnce;
	private boolean				displayPrintDialog;
	private boolean				displayPrintDialogOnlyOnce;
	
	private ColumnStyle			defaultHeaderStyle	= null;
	private ColumnStyle			defaultContentStyle	= null;
	
	// //////////////////////////////////////////////////////////////
	// //////// OUTPUT ELEMENTE ///////////////////////////
	// ////////////////////////////////////////////////////////////
	private Target				target;
	private OutputFormat		outputFormat;
	/**
	 * Flag to open file after export
	 */
	private boolean				openFileAfterExport;
	private File				file;
	private OutputStream		outputStream;
	
	/** 
	 *	excel specific flag
	 *
	 */
	private boolean				freezeHeadline = false;
	
	private TableExportDebugger exportDebugger = new TableExportDebugger.DefaultTableExportDebuggerImpl();
	
	
	public static enum DataSourceType
	{
		// VTModelConfigBuilder
//		STATIC_VT_SOURCE,
//		// VTModelConfigBuilder
//		STATIC_XDEVTABLE_SOURCE,
		// VTConfigBuilder
		VT_SOURCE,
		// XdevTableConfigBuilder
		XDEVTABLE_SOURCE,
		// JTableViewConfigBuilder
		JTABLE_VIEW_SOURCE
	}
	
	
	
	/**
	 * Specifies an output format to control the table export.
	 */
	public static enum OutputFormat
	{
		PDF("pdf"), HTML("html"), XLS("xls"), XLSX("xlsx"), RTF("rtf"), CSV("csv"), XML("xml");
		
		private String suffix;
		private OutputFormat(final String suffix)
		{
			this.suffix = suffix;
		}
		
		public String getSuffix()
		{
			return suffix;
		}
		
	}
	
	public  XdevFile showFileChooser()
	{
		final String suffix = outputFormat.getSuffix();
		XdevFileChooser chooser = XdevFileChooserFactory.getFileChooser("exportCreationFileChooser",suffix!=null ? new XdevFileFilter(suffix,suffix) : null);
		return chooser.showSaveDialog();	
	}
	
	public XdevFile showFileChooser(final String suffix)
	{
		XdevFileChooser chooser = XdevFileChooserFactory.getFileChooser("exportCreationFileChooser",suffix!=null ? new XdevFileFilter(suffix,suffix) : null);
		return chooser.showSaveDialog();	
	}
	
	public static enum Target
	{
		PREVIEW, PRINT, FILE, STREAM
	}
	
	
	/**
	 * 
	 * @param args
	 */
	public ExportCreation(Object... args)
	{
		super(args);
	}
	
	
	public void setDataSourceType(DataSourceType dataSourceType)
	{
		this.dataSourceType = dataSourceType;
	}
	
	
	public DataSourceType getDataSourceType()
	{
		return dataSourceType;
	}
	
	
	public void setVirtualTable(VirtualTable virtualTable)
	{
		this.virtualTable = virtualTable;
	}
	
	
	public VirtualTable getVirtualTable()
	{
		return virtualTable;
	}
	
	
	public void setJTable(JTable jTable)
	{
		this.jTable = jTable;
	}
	
	
	public JTable getJTable()
	{
		return jTable;
	}
	
	
	public void setXdevTable(VirtualTableEditor xdevTable)
	{
		this.xdevTable = xdevTable;
	}
	
	
	public VirtualTableEditor getXdevTable()
	{
		return xdevTable;
	}
	
	
	public void addColumn(final String columnName)
	{
		final TemplateColumn newColumn = new TemplateColumn(columnName);
		decorateColumn(newColumn);
		this.templateConfig.addColumn(newColumn);
	}
	
	private void decorateColumn(final TemplateColumn newColumn)
	{
		
		if(this.defaultHeaderStyle != null)
		{
			newColumn.getHeaderColumn().setStyle(this.defaultHeaderStyle.clone());
		}
		if(this.defaultContentStyle != null)
		{
			newColumn.getContentColumn().setStyle(this.defaultContentStyle.clone());
		}
	}
	
	
	public void setDefaultHeaderStyle(ColumnStyle defaultHeaderStyle)
	{
		this.defaultHeaderStyle = defaultHeaderStyle;
	}
	public void setDefaultContentStyle(ColumnStyle defaultContentStyle)
	{
		this.defaultContentStyle = defaultContentStyle;
	}
	
	
	public void setColumnWidth(final String columnName, final int width)
	{
		this.templateConfig.getTemplateColumn(columnName).setWidth(width);
	}
	
	
	// //////////////////////////////////////////////////////////////
	// //////// HEADER STYLE METHOD ///////////////////////////
	// ////////////////////////////////////////////////////////////
	
	public void setHeaderStyleForColumn(final String columnName, final ColumnStyle style)
	{
		this.getHeaderColumn(columnName).setStyle(style);
	}
	
	
	public void setHeaderCaptionForColumn(final String columnName, final String columnCaption)
	{
		this.getHeaderColumn(columnName).setProperty(columnCaption);
	}
	
	
	/**
	 * Sets the font of the specified {@link HeaderColumn}.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param font
	 *            the new {@link Font}
	 * 
	 */
	public void setHeaderStyleFontProperty(final String columnName, final Font font)
	{
		final ColumnStyle style = this.getHeaderColumn(columnName).getStyle();
		style.setFont(font);
	}
	
	
	/**
	 * Sets the foreground color of the specified {@link HeaderColumn}.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param foreground
	 *            the {@link Color} of the foreground
	 * 
	 */
	public void setHeaderStyleForegroundProperty(final String columnName, final Color foreground)
	{
		final ColumnStyle style = this.getHeaderColumn(columnName).getStyle();
		style.setForeground(foreground);
	}
	
	
	/**
	 * Sets the background color of the specified {@link HeaderColumn}.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param background
	 *            the {@link Color} of the background
	 * 
	 */
	public void setHeaderStyleBackgroundProperty(final String columnName, final Color background)
	{
		final ColumnStyle style = this.getHeaderColumn(columnName).getStyle();
		style.setBackground(background);
	}
	
	
	/**
	 * Sets the alignment of the specified {@link HeaderColumn} content.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param horizontalAlignment
	 *            the {@link ColumnAlignment} of the content
	 * 
	 */
	public void setHeaderStyleAlignmentProperty(final String columnName,
			final ColumnAlignment horizontalAlignment)
	{
		final ColumnStyle style = this.getHeaderColumn(columnName).getStyle();
		style.setHorizontalAlignment(horizontalAlignment);
	}
	
	
	/**
	 * Sets the border of the specified {@link HeaderColumn}.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param colBorder
	 *            the {@link ColumnBorder}
	 * 
	 */
	public void setHeaderStyleBorderProperty(final String columnName, final ColumnBorder colBorder)
	{
		final ColumnStyle style = this.getHeaderColumn(columnName).getStyle();
		style.setColBorder(colBorder);
	}
	
	
	// //////////////////////////////////////////////////////////////
	// //////// CONTENT STYLE METHOD ///////////////////////////
	// ////////////////////////////////////////////////////////////
	
	public void setFieldNameForColumn(final String columnName, final String fieldName)
	{
		this.getContentColumn(columnName).setFieldName(fieldName);
	}
	
	
	public void setFieldClassForColumn(final String columnName, final DataType dataType)
	{
		this.getContentColumn(columnName).setColumnValueClass(dataType.getJavaClass());
	}
	
	
	public void setPatternForColumn(final String columnName, final String pattern)
	{
		this.getContentColumn(columnName).setProperty(pattern);
	}
	
	
	/**
	 * Sets the font of the specified {@link ContentColumn}.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param font
	 *            the new {@link Font}
	 * 
	 */
	public void setContentStyleFontProperty(final String columnName, final Font font)
	{
		final ColumnStyle style = this.getContentColumn(columnName).getStyle();
		style.setFont(font);
	}
	
	
	/**
	 * Sets the foreground color of the specified {@link ContentColumn}.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param foreground
	 *            the {@link Color} of the foreground
	 * 
	 */
	public void setContentStyleForegroundProperty(final String columnName, final Color foreground)
	{
		final ColumnStyle style = this.getContentColumn(columnName).getStyle();
		style.setForeground(foreground);
	}
	
	
	/**
	 * Sets the background color of the specified {@link ContentColumn}.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param background
	 *            the {@link Color} of the background
	 * 
	 */
	public void setContentStyleBackgroundProperty(final String columnName, final Color background)
	{
		final ColumnStyle style = this.getContentColumn(columnName).getStyle();
		style.setBackground(background);
	}
	
	
	/**
	 * Sets the alignment of the specified {@link ContentColumn} content.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param horizontalAlignment
	 *            the {@link ColumnAlignment} of the content
	 * 
	 */
	public void setContentStyleAlignmentProperty(final String columnName,
			final ColumnAlignment horizontalAlignment)
	{
		final ColumnStyle style = this.getContentColumn(columnName).getStyle();
		style.setHorizontalAlignment(horizontalAlignment);
	}
	
	
	/**
	 * Sets the border of the specified {@link ContentColumn}.
	 * 
	 * 
	 * @param columnName
	 *            the column name
	 * @param colBorder
	 *            the {@link ColumnBorder}
	 * 
	 */
	public void setContentStyleBorderProperty(final String columnName, final ColumnBorder colBorder)
	{
		final ColumnStyle style = this.getContentColumn(columnName).getStyle();
		style.setColBorder(colBorder);
	}
	
	
	public void setContentStyleForColumn(final String columnName, final ColumnStyle style)
	{
		this.getContentColumn(columnName).setStyle(style);
	}
	
	public ColumnStyle getDefaultContentStyle()
	{
		return defaultContentStyle;
	}
	public ColumnStyle getDefaultHeaderStyle()
	{
		return defaultHeaderStyle;
	}
	
	private HeaderColumn getHeaderColumn(final String columnName)
	{
		return this.templateConfig.getTemplateColumn(columnName).getHeaderColumn();
	}
	
	
	private ContentColumn getContentColumn(final String columnName)
	{
		return this.templateConfig.getTemplateColumn(columnName).getContentColumn();
	}
	
	
	// //////////////////////////////////////////////////////////////
	// //////// PRINT METHOD ///////////////////////////
	// ////////////////////////////////////////////////////////////
	
	public void setDisplayPageDialogOnlyOnce(boolean displayPageDialogOnlyOnce)
	{
		this.displayPageDialogOnlyOnce = displayPageDialogOnlyOnce;
	}
	
	
	public void setDisplayPrintDialogOnlyOnce(boolean displayPrintDialogOnlyOnce)
	{
		this.displayPrintDialogOnlyOnce = displayPrintDialogOnlyOnce;
	}
	
	
	public void setDisplayPageDialog(boolean displayPageDialog)
	{
		this.displayPageDialog = displayPageDialog;
	}
	
	
	public void setDisplayPrintDialog(boolean displayPrintDialog)
	{
		this.displayPrintDialog = displayPrintDialog;
	}
	
	
	public boolean getDisplayPageDialogOnlyOnce()
	{
		return displayPageDialogOnlyOnce;
	}
	
	
	public boolean getDisplayPageDialog()
	{
		return displayPageDialog;
	}
	
	
	public boolean getDisplayPrintDialog()
	{
		return displayPrintDialog;
	}
	
	
	public boolean getDisplayPrintDialogOnlyOnce()
	{
		return displayPrintDialogOnlyOnce;
	}
	
	
	
	
	// //////////////////////////////////////////////////////////////
	// //////// OUTPUT METHOD ///////////////////////////
	// ////////////////////////////////////////////////////////////
	
	public void setOutputFormat(OutputFormat outputFormat)
	{
		this.outputFormat = outputFormat;
	}
	

	
	
	public void setTarget(Target target)
	{
		this.target = target;
	}
	
	
	public File getFile()
	{
		return file;
	}
	
	
	public void setFile(File file)
	{
		this.file = file;
	}
	
	
	public void setOutputStream(OutputStream outputStream)
	{
		this.outputStream = outputStream;
	}
	
	public void setFreezeHeadline(boolean freezeHeadline)
	{
		this.freezeHeadline = freezeHeadline;
	}
	
	
	public void setOpenFileAfterExport(boolean openFile)
	{
		this.openFileAfterExport = openFile;
	}
	
	
	public Target getTarget()
	{
		return target;
	}
	
	
	public OutputFormat getOutputFormat()
	{
		return outputFormat;
	}
	
	
	public boolean isOpenFileAfterExport()
	{
		return openFileAfterExport;
	}
	
	
	public OutputStream getOutputStream()
	{
		return outputStream;
	}
	
	/**
	 * @return the freezeHeadline
	 */
	public boolean isFreezeHeadline()
	{
		return freezeHeadline;
	}
	
	
	@Override
	public void execute() throws ExportException
	{
		verifyParameter();
		try
		{
			final JasperReport jReport = createReport();
			
			if(this.exportDebugger.isDebugModeOn())
			{
				this.exportDebugger.exportJasperReportToJrxml(jReport);
			}
			final ReportExporter exporter = new ReportExporter(jReport,createDataSource(),
					createWriter());
			exporter.export();
			
			if(target == Target.FILE && isOpenFileAfterExport())
			{
				DesktopUtils.open(this.getFile());
			}
		}
		catch(Exception e)
		{
			throw new ExportException(e);
		}
	}
	
	
	
	/**
	 * Create the suitable {@link ExportConfigBuilder} and prepare the runtime
	 * config builder.
	 * 
	 * @return
	 */
	@SuppressWarnings({"rawtypes","unchecked"})
	private ExportConfigBuilder  createRuntimeConfigBuilder()
	{
		ExportConfigBuilder configBuilder = null;
		
		switch(this.getDataSourceType())
		{
			
//			case STATIC_XDEVTABLE_SOURCE:

//			break;
//			case STATIC_VT_SOURCE:
			case VT_SOURCE:
				configBuilder = new VTConfigBuilder(getVirtualTable());
			break;
			
			case XDEVTABLE_SOURCE:
				configBuilder = new XdevTableConfigBuilder((T)getXdevTable());
			break;
			
			case JTABLE_VIEW_SOURCE:
				configBuilder = new JTableViewConfigBuilder(getJTable());
			break;
			
			default:
			break;
		}
		
		return configBuilder;
	}
	
	
	/**
	 * The RuntimeConfigBuilder is prepared with the predefined header and
	 * columns.
	 * 
	 * @param runtimeBuilder
	 */
	private void prepareRuntimeConfigBuilder(final ExportConfigBuilder runtimeBuilder)
	{
		final TemplateConfig draftConfig = this.templateConfig;
		
		final HashMap predefinedTemplateColumns = new HashMap();
		
		for(TemplateColumn column : draftConfig.getColumns())
		{
			predefinedTemplateColumns.put(column.getColumnName(),column);
		}
		
		runtimeBuilder.setPredefinedColumnMap(predefinedTemplateColumns);		
	}
	
	
	private void verifyParameter()
	{
		if(dataSourceType == null)
		{
			CommandException.throwMissingParameter("dataSourceType");
		}
		if(target == null)
		{
			CommandException.throwMissingParameter("target");
		}
		switch(target)
		{
			case FILE:
			{
				if(outputFormat == null)
				{
					CommandException.throwMissingParameter("outputFormat");
				}
				if(file == null)
				{
					CommandException.throwMissingParameter("file");
				}
			}
			break;
			
			case STREAM:
			{
				if(outputFormat == null)
				{
					CommandException.throwMissingParameter("outputFormat");
				}
				if(outputStream == null)
				{
					CommandException.throwMissingParameter("outputStream");
				}
			}
			break;
			default:
			break;
		}
	}
	
	
	private JasperReport createReport() throws ExportException
	{
		final ExportConfigBuilder configBuilder = createRuntimeConfigBuilder();
		
		// builder is called when a dynamic ds is
		if(configBuilder != null)
		{
			prepareRuntimeConfigBuilder(configBuilder);
			// set header style for not mapped columns
			configBuilder.setDefaultHeaderColumnStyle(getDefaultHeaderStyle());
			configBuilder.setDefaultContentColumnStyle(getDefaultContentStyle());
			
			this.templateConfig = configBuilder.createConfig();
		}
		
		final ReportBuilder reportBuilder = new ReportBuilder(this.templateConfig);
		
		return reportBuilder.assembleReport();
	}
	
	
	@SuppressWarnings({"unchecked","rawtypes"})
	private JRRewindableDataSource createDataSource()
	{
		JRRewindableDataSource dataSource = null;
		switch(this.getDataSourceType())
		{
//			case STATIC_VT_SOURCE:
			case VT_SOURCE:
				dataSource = new JRVirtualTableDataSource(getVirtualTable());
			break;
			
//			case STATIC_XDEVTABLE_SOURCE:
			case XDEVTABLE_SOURCE:
				dataSource = new XdevTableDataSource((JTable)getXdevTable());
			break;
			
			case JTABLE_VIEW_SOURCE:
				dataSource = new XdevJTableRendererDataSource(getJTable());
			break;
			
			default:
			break;
		}
		
		return dataSource;
	}
	
	
	private ExportWriter createWriter()
	{
		ExportWriter writer = null;
		
		switch(target)
		{
			case PREVIEW:
				writer = new ReportToPreviewWriter();
			break;
			
			case PRINT:
				writer = new PrintWriter(this.displayPageDialog,this.displayPageDialogOnlyOnce,
						this.displayPrintDialog,this.displayPrintDialogOnlyOnce);
			break;
			
			case FILE:
				
				switch(this.getOutputFormat())
				{
					case XLS:
						writer = new XlsToFileWriter(this.getFile(),
								this.templateConfig.getSheetName(),isFreezeHeadline());
					break;
					case XLSX:
						writer = new XlsxToFileWriter(this.getFile(),
								this.templateConfig.getSheetName(),isFreezeHeadline());
					break;
					case PDF:
						writer = new PdfToFileWriter(this.getFile());
					break;
					case HTML:
						writer = new HtmlToFileWriter(this.getFile());
					break;					
					case CSV:
						writer = new CSVToFileWriter(this.getFile());
					break;
					
					case RTF:
						writer = new RtfToFileWriter(this.getFile());
					break;
					
					case XML:
						writer = new XMLToFileWriter(this.getFile());
					break;
					
					default:
					break;
				}
			
			break;
			case STREAM:
				switch(this.getOutputFormat())
				{
					case XLS:
						writer = new XlsToOutputStreamWriter(this.getOutputStream(),
								this.templateConfig.getSheetName(),isFreezeHeadline());
					break;
					case XLSX:
						writer = new XlsxToOutputStreamWriter(this.getOutputStream(),
								this.templateConfig.getSheetName(),isFreezeHeadline());
					break;
					case PDF:
						writer = new PdfToOutputStreamWriter(this.getOutputStream());
					break;
					case HTML:
						writer = new HtmlToOutputStreamWriter(this.getOutputStream());
					break;
					
					case CSV:
						writer = new CSVToOutputStreamWriter(this.getOutputStream());
					break;
					
					case RTF:
						writer = new RtfToOutputStreamWriter(this.getOutputStream());
					break;
					
					case XML:
						writer = new XMLToOutputStreamWriter(this.getOutputStream());
					break;
					
					default:
					break;
				}
			break;
		}
		
		return writer;
	}
	
	
	public void setExportDebugger(TableExportDebugger exportDebugger)
	{
		this.exportDebugger = exportDebugger;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy