comparison artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/collision/CollisionCalcDetailResult.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
children f9bb5d0a6ff3
comparison
equal deleted inserted replaced
9149:5be112fba832 9150:23945061daec
1 /* Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
2 * Software engineering by
3 * Björnsen Beratende Ingenieure GmbH
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
5 *
6 * This file is Free Software under the GNU AGPL (>=v3)
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
8 * documentation coming with Dive4Elements River for details.
9 */
10 package org.dive4elements.river.artifacts.sinfo.collision;
11
12 import java.util.ArrayList;
13 import java.util.Collection;
14
15 import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult;
16 import org.dive4elements.river.artifacts.common.ExportContextCSV;
17 import org.dive4elements.river.artifacts.common.GeneralResultType;
18 import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource;
19 import org.dive4elements.river.artifacts.common.ResultRow;
20 import org.dive4elements.river.artifacts.sinfo.util.RiverInfo;
21
22 /**
23 * Contains the results of a {@link FloodDurationCalculation}.
24 *
25 * @author Gernot Belger
26 */
27 final class CollisionCalcDetailResult extends AbstractCalculationExportableResult<CollisionCalculationResults> {
28
29 private static final long serialVersionUID = 1L;
30 private static final String JASPER_FILE = "/jasper/templates/sinfo.collision.detail.jrxml";
31
32 public CollisionCalcDetailResult(final String label, final Collection<ResultRow> rows) {
33 super(label, rows);
34 }
35
36 @Override
37 protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results) {
38 // TODO Auto-generated method stub
39 // final WstInfo wst = result.getWst();
40 // exportContext.writeCSVWaterlevelMetadata(writer, wst);
41 // if hasMetadata...
42 exportContextCSV.writeBlankLine();
43 }
44
45 @Override
46 public void writeCSVHeader(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results, final RiverInfo river) {
47
48 // FIXME wrong columns:
49 final Collection<String> header = new ArrayList<>(99);
50
51 header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station));
52 //
53 // header.add(exportContext.formatCsvHeader(SInfoResultType.riverside));
54 // header.add(exportContext.formatCsvHeader(SInfoResultType.inundationduration));
55 // header.add(exportContext.formatCsvHeader(SInfoResultType.inundationdurationq));
56 // header.add(exportContext.formatCsvHeader(SInfoResultType.infrastructureHeight));
57 // header.add(exportContext.formatCsvHeader(SInfoResultType.infrastructuretype));
58 // header.add(exportContext.formatCsvHeader(SInfoResultType.gaugeLabel));
59 // header.add(exportContext.formatCsvHeader(SInfoResultType.location));
60
61 exportContextCSV.writeCSVLine(header.toArray(new String[header.size()]));
62 }
63
64 @Override
65 protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results, final ResultRow row) {
66 return formatRow(exportContextCSV, results, row);
67 }
68
69 @Override
70 protected String[] formatPDFRow(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results, final ResultRow row) {
71 return formatRow(exportContextCSV, results, row);
72 }
73
74 private String[] formatRow(final ExportContextCSV exportContextCSV, final CollisionCalculationResults results, final ResultRow row) {
75
76 final Collection<String> lines = new ArrayList<>(11);
77
78 // FIXME wrong columns:
79 lines.add(exportContextCSV.formatRowValue(row, GeneralResultType.station));
80 // lines.add(exportContext.formatRowValue(row, SInfoResultType.tkh));
81 // lines.add(exportContext.formatRowValue(row, SInfoResultType.soilkind));
82 // lines.add(exportContext.formatRowValue(row, SInfoResultType.meanBedHeight));
83 // lines.add(exportContext.formatRowValue(row, SInfoResultType.waterlevel));
84 // lines.add(exportContext.formatRowValue(row, SInfoResultType.discharge));
85 // lines.add(exportContext.formatRowValue(row, SInfoResultType.gaugeLabel));
86 // lines.add(exportContext.formatRowValue(row, SInfoResultType.location));
87
88 return lines.toArray(new String[lines.size()]);
89 }
90
91 @Override
92 protected String getJasperFile() {
93 return JASPER_FILE;
94 }
95
96 @Override
97 protected void addJRTableHeader(final ExportContextCSV exportContextCSV, final MetaAndTableJRDataSource source, final CollisionCalculationResults results) {
98
99 /* column headings */
100 // FIXME wrong columns:
101 exportContextCSV.addJRMetadata(source, "station_header", GeneralResultType.station);
102 // exportContext.addJRMetadata(source, "station_header", GeneralResultType.station);
103 // exportContext.addJRMetadata(source, "tkh_header", SInfoResultType.tkh);
104 // exportContext.addJRMetadata(source, "tkhkind_header", SInfoResultType.soilkind);
105 // exportContext.addJRMetadata(source, "bedheight_header", SInfoResultType.meanBedHeight);
106 // exportContext.addJRMetadata(source, "waterlevel_header", SInfoResultType.waterlevel);
107 // exportContext.addJRMetadata(source, "discharge_header", SInfoResultType.discharge);
108 }
109 }

http://dive4elements.wald.intevation.org