Mercurial > dive4elements > river
diff artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/tkhstate/TkhExporter.java @ 9195:a4121ec450d6
'ca.'-issue
ExportContextCSV+PDF separated
uinfo.inundationduration url export
author | gernotbelger |
---|---|
date | Fri, 29 Jun 2018 14:52:54 +0200 |
parents | 23945061daec |
children | a49fe0ebb297 |
line wrap: on
line diff
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/tkhstate/TkhExporter.java Thu Jun 28 15:57:40 2018 +0200 +++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/tkhstate/TkhExporter.java Fri Jun 29 14:52:54 2018 +0200 @@ -8,17 +8,10 @@ package org.dive4elements.river.artifacts.sinfo.tkhstate; -import java.io.OutputStream; - -import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult; import org.dive4elements.river.artifacts.common.AbstractCommonExporter; import org.dive4elements.river.artifacts.common.ExportContextCSV; -import org.dive4elements.river.artifacts.common.JasperReporter; +import org.dive4elements.river.artifacts.common.ExportContextPDF; import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource; -import org.dive4elements.river.artifacts.sinfo.util.RiverInfo; - -import au.com.bytecode.opencsv.CSVWriter; -import net.sf.jasperreports.engine.JRException; /** * Generates different output formats (csv, pdf) of data that resulted from a tkh computation. @@ -26,67 +19,25 @@ * @author Gernot Belger */ // REMARK: must be public because its registered in generators.xml -public class TkhExporter extends AbstractCommonExporter<TkhCalculationResults> { +public class TkhExporter extends AbstractCommonExporter<TkhCalculationResult, TkhCalculationResults> { private static final String CSV_META_CALCULATION_FORMULA = "sinfo.export.tkh.calculation.formula"; @Override - protected void doWritePdf(final OutputStream out, final TkhCalculationResults results) { - // TODO: Move to super - try { - final ExportContextCSV exportContextCSV = new ExportContextCSV(this.context, null); - - final JasperReporter reporter = new JasperReporter(); - - for (final AbstractCalculationExportableResult<TkhCalculationResults> result : results.getResults()) { - final MetaAndTableJRDataSource source = new MetaAndTableJRDataSource(); - getHelper().addJRMetaDataUSINFO(source, results); + protected void writeCSVGlobalMetadata(final ExportContextCSV exportContext, final TkhCalculationResults results) { - source.addMetaData("calculation_label", msg("sinfo.export.flow_depth.pdf.meta.calculation.label")); - source.addMetaData("calculation_name", msg("sinfo.export.flow_depth.pdf.meta.calculation.name")); + /* write as csv */ + exportContext.writeCSVGlobalMetadataDefaults(); // ggf auslagern innerhalb dieser Klasse - result.addReport(exportContextCSV, results, reporter, source); - } - - reporter.exportPDF(out); - } - catch (final JRException je) { - getLog().warn("Error generating PDF Report!", je); - } + // "# Berechnungsgrundlage: Gleichung nach GILL (1971)" + exportContext.writeCSVMetaEntry(CSV_META_CALCULATION_FORMULA); } @Override - protected void doWriteCSVData(final CSVWriter writer, final TkhCalculationResults results) { - // TODO: Diesen Ablauf in super? _WINZIGE ABWEICHUNG vom Standard... - - // TODO: move results into context? - final ExportContextCSV exportContextCSV = new ExportContextCSV(this.context, writer); - - getLog().info("writeCSVData"); - - /* write as csv */ - exportContextCSV.writeCSVGlobalMetadataDefaults(results); // ggf auslagern innerhalb dieser Klasse - - // "# Berechnungsgrundlage: Gleichung nach GILL (1971)" - exportContextCSV.writeCSVMetaEntry(CSV_META_CALCULATION_FORMULA); - - // writer.writeNext(new String[] { "" }); // break line HERE to avoid redundance + protected final void writePDFGlobalMetadata(final ExportContextPDF exportContext, final MetaAndTableJRDataSource source) { + exportContext.addJRMetaDataUSINFO(source); - final RiverInfo river = results.getRiver(); - - final Class<?> lastResultType = null; - - for (final AbstractCalculationExportableResult<TkhCalculationResults> result : results.getResults()) { - - final Class<?> resultType = result.getClass(); - if (lastResultType == null || lastResultType != resultType) { - exportContextCSV.writeBlankLine(); - result.writeCSVHeader(exportContextCSV, results, river); - exportContextCSV.writeBlankLine(); - } else - exportContextCSV.writeCSVLine(new String[] { "#" }); - - result.writeCsv(exportContextCSV, results); - } + source.addMetaData("calculation_label", msg("sinfo.export.flow_depth.pdf.meta.calculation.label")); + source.addMetaData("calculation_name", msg("sinfo.export.flow_depth.pdf.meta.calculation.name")); } } \ No newline at end of file