Mercurial > dive4elements > river
view artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/salix/SalixLineExporter.java @ 9150:23945061daec
gigantic refactoring: exporter, result, results
to support multiple jaspers -> collisions
author | gernotbelger |
---|---|
date | Thu, 14 Jun 2018 16:56:31 +0200 |
parents | 41f4bc83aa7a |
children | a4121ec450d6 |
line wrap: on
line source
/** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde * Software engineering by * Björnsen Beratende Ingenieure GmbH * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt * * This file is Free Software under the GNU AGPL (>=v3) * and comes with ABSOLUTELY NO WARRANTY! Check out the * documentation coming with Dive4Elements River for details. */ package org.dive4elements.river.artifacts.uinfo.salix; 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.I18NStrings; import org.dive4elements.river.artifacts.common.JasperReporter; 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; /** * @author Domenico Nardi Tironi * */ public class SalixLineExporter extends AbstractCommonExporter<SalixLineCalculationResults> { @Override protected void doWritePdf(final OutputStream out, final SalixLineCalculationResults results) { // TODO: Move to super try { final ExportContextCSV exportContextCSV = new ExportContextCSV(this.context, null); final JasperReporter reporter = new JasperReporter(); for (final AbstractCalculationExportableResult<SalixLineCalculationResults> result : results.getResults()) { final MetaAndTableJRDataSource source = new MetaAndTableJRDataSource(); getHelper().addJRMetaDataUSINFO(source, results); result.addReport(exportContextCSV, results, reporter, source); } reporter.exportPDF(out); } catch (final JRException je) { getLog().warn("Error generating PDF Report!", je); } } @Override protected void doWriteCSVData(final CSVWriter writer, final SalixLineCalculationResults results) { // TODO: Diesen Ablauf in super? - ist etwas anders bei den globalen metadaten // 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 // writer.writeNext(new String[] { "" }); // break line HERE to avoid redundance // "# Höhensystem des Flusses: " exportContextCSV.writeCSVMetaEntry(I18NStrings.CSV_META_HEIGHT_UNIT_RIVER, results.getRiver().getWstUnit()); // Add Auswerter, Bezugspegel, Jahr/Zeitraum der Wasserspiegellage // "# Auswerter: " exportContextCSV.writeCSVMetaEntry("uinfo.export.salix_line.csv.meta.header.evaluator", "sounding.getEvaluationBy()"); // "# Bezugspegel: " exportContextCSV.writeCSVMetaEntry("uinfo.export.salix_line.csv.meta.header.waterlevel.gauge", "wst.getGauge()"); // "# Jahr/Zeitraum der Wasserspiegellage: " // final int year = wst.getYear(); // if (year > 0) exportContextCSV.writeCSVMetaEntry("uinfo.export.salix_line.csv.meta.header.waterlevel.year", "Integer.toString(year)"); final RiverInfo river = results.getRiver(); final Class<?> lastResultType = null; for (final AbstractCalculationExportableResult<SalixLineCalculationResults> 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); } } }