comparison artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/predefinedtkh/PredefinedTkhArtifact.java @ 9016:6e5ff436febe

Added datacage select and chart display for TKH series loaded from database
author mschaefer
date Mon, 23 Apr 2018 15:18:48 +0200
parents
children
comparison
equal deleted inserted replaced
9015:baef34f54ee2 9016:6e5ff436febe
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
11 package org.dive4elements.river.artifacts.sinfo.predefinedtkh;
12
13 import java.util.ArrayList;
14 import java.util.List;
15
16 import org.apache.log4j.Logger;
17 import org.dive4elements.artifactdatabase.state.DefaultOutput;
18 import org.dive4elements.artifactdatabase.state.Facet;
19 import org.dive4elements.artifactdatabase.state.FacetActivity;
20 import org.dive4elements.artifacts.Artifact;
21 import org.dive4elements.artifacts.ArtifactFactory;
22 import org.dive4elements.artifacts.CallMeta;
23 import org.dive4elements.artifacts.common.utils.XMLUtils;
24 import org.dive4elements.river.artifacts.AbstractStaticStateArtifact;
25 import org.dive4elements.river.artifacts.D4EArtifact;
26 import org.dive4elements.river.artifacts.model.FacetTypes;
27 import org.dive4elements.river.artifacts.sinfo.common.PredefinedTkhProcessor;
28 import org.dive4elements.river.artifacts.states.StaticState;
29 import org.dive4elements.river.model.sinfo.TkhColumn;
30 import org.w3c.dom.Document;
31
32 /**
33 * Display of a tkh data series loaded from database
34 *
35 * @author Matthias Schäfer
36 *
37 */
38 public class PredefinedTkhArtifact extends AbstractStaticStateArtifact implements FacetTypes {
39
40 /** The log for this class. */
41 private static Logger log = Logger.getLogger(PredefinedTkhArtifact.class);
42
43 /** Artifact name. */
44 private static final String NAME = "tkhx";
45
46 static {
47 // TODO: Move to configuration.
48 FacetActivity.Registry.getInstance().register(NAME, FacetActivity.INACTIVE);
49 }
50
51 public static final String STATIC_STATE_NAME = "state.predefined_tkh.static";
52
53 /**
54 * Trivial Constructor.
55 */
56 public PredefinedTkhArtifact() {
57 log.debug("new PredefinedTkhArtifact");
58 }
59
60 @Override
61 public String getName() {
62 return NAME;
63 }
64
65 /**
66 * Gets called from factory, to set things up.
67 */
68 @Override
69 public void setup(final String identifier, final ArtifactFactory factory, final Object context, final CallMeta callMeta, final Document data,
70 final List<Class> loadFacets) {
71
72 log.debug("PredefinedTkhArtifact.setup");
73
74 if (log.isDebugEnabled()) {
75 log.debug(XMLUtils.toString(data));
76 }
77
78 final String code = getDatacageIDValue(data);
79
80 createFacets(callMeta, code);
81
82 super.setup(identifier, factory, context, callMeta, data, loadFacets);
83 }
84
85 private void createFacets(final CallMeta callMeta, final String code) {
86 if (code == null)
87 return;
88 final String[] parts = code.split("-");
89 if (parts.length < 3) {
90 log.error("Invalid datacage ID '" + code + "'");
91 return;
92 }
93 addStringData("tkh_col_id", parts[1]);
94 addStringData("tkh_id", parts[2]);
95 final TkhColumn tkhcol = TkhColumn.getTkhColumnById(Integer.parseInt(parts[1]));
96
97 final ArrayList<Facet> facets = new ArrayList<>(1);
98 facets.add(new PredefinedTkhFacet(PredefinedTkhProcessor.FACET_PREDEFINED_TKH, tkhcol.getName() + " (" + tkhcol.getTkh().getFilename() + ")"));
99 addFacets(STATIC_STATE_NAME, facets);
100 }
101
102 @Override
103 protected void initStaticState() {
104
105 log.debug("initStaticState " + getName() + " " + identifier());
106
107 final StaticState state = new StaticState(STATIC_STATE_NAME);
108 final DefaultOutput output = new DefaultOutput("general", "general", "image/png", "chart");
109
110 final List<Facet> facets = getFacets(STATIC_STATE_NAME);
111 output.addFacets(facets);
112 state.addOutput(output);
113
114 setStaticState(state);
115 }
116
117 @Override
118 protected void initialize(final Artifact artifact, final Object context, final CallMeta meta) {
119 // do not clone facets, etc. from master artifact
120
121 log.debug("initialize");
122 importData((D4EArtifact) artifact, "river");
123 importData((D4EArtifact) artifact, "ld_from");
124 importData((D4EArtifact) artifact, "ld_to");
125
126 log.debug("ld_from " + getDataAsString("ld_from"));
127 log.debug("ld_to " + getDataAsString("ld_to"));
128 }
129 }

http://dive4elements.wald.intevation.org