comparison flys-artifacts/src/main/java/de/intevation/flys/artifacts/ChartArtifact.java @ 3468:f37e7e8907cb

merged flys-artifacts/2.8.1
author Thomas Arendsen Hein <thomas@intevation.de>
date Fri, 28 Sep 2012 12:14:39 +0200
parents 2f922be407ea
children b1912514e0f5
comparison
equal deleted inserted replaced
3387:5ffad8bde8ad 3468:f37e7e8907cb
1 package de.intevation.flys.artifacts;
2
3 import org.apache.log4j.Logger;
4
5 import java.util.List;
6
7 import org.w3c.dom.Document;
8 import org.w3c.dom.Element;
9
10 import de.intevation.artifacts.Artifact;
11
12 import de.intevation.artifacts.ArtifactFactory;
13 import de.intevation.artifacts.CallMeta;
14 import de.intevation.artifacts.CallContext;
15
16 import de.intevation.artifacts.common.utils.XMLUtils;
17 import de.intevation.artifacts.common.utils.XMLUtils.ElementCreator;
18 import de.intevation.artifacts.common.ArtifactNamespaceContext;
19
20 import de.intevation.artifactdatabase.ProtocolUtils;
21 import de.intevation.artifactdatabase.state.Facet;
22 import de.intevation.artifactdatabase.state.State;
23 import de.intevation.artifactdatabase.state.StateEngine;
24 import de.intevation.artifactdatabase.state.Output;
25
26 import de.intevation.flys.utils.FLYSUtils;
27
28 import de.intevation.flys.artifacts.states.DefaultState;
29 import de.intevation.flys.artifacts.context.FLYSContext;
30 import de.intevation.flys.artifacts.resources.Resources;
31
32
33 public class ChartArtifact extends FLYSArtifact {
34
35 private static final Logger logger =
36 Logger.getLogger(ChartArtifact.class);
37
38 @Override
39 public void setup(
40 String identifier,
41 ArtifactFactory factory,
42 Object context,
43 CallMeta callmeta,
44 Document data)
45 {
46 logger.debug("ChartArtifact.setup");
47 this.identifier = identifier;
48 name = "new_chart";
49
50 List<State> states = getStates(context);
51
52 setCurrentState(states.get(0));
53 }
54
55 @Override
56 protected void appendBackgroundActivity(
57 ElementCreator cr,
58 Element root,
59 CallContext context
60 ) {
61 Element inBackground = cr.create("background-processing");
62 root.appendChild(inBackground);
63
64 cr.addAttr(
65 inBackground,
66 "value",
67 String.valueOf(context.isInBackground()),
68 true);
69 }
70
71
72 /**
73 * Append output mode nodes to a document.
74 */
75 @Override
76 protected void appendOutputModes(
77 Document doc,
78 Element outs,
79 CallContext context,
80 String uuid)
81 {
82 List<String> stateIds = getPreviousStateIds();
83
84 XMLUtils.ElementCreator creator = new XMLUtils.ElementCreator(
85 doc,
86 ArtifactNamespaceContext.NAMESPACE_URI,
87 ArtifactNamespaceContext.NAMESPACE_PREFIX);
88
89 FLYSContext flysContext = FLYSUtils.getFlysContext(context);
90 StateEngine engine = (StateEngine) flysContext.get(
91 FLYSContext.STATE_ENGINE_KEY);
92
93 for (String stateId: stateIds) {
94 logger.debug("Append output modes for state: " + stateId);
95 DefaultState state = (DefaultState) engine.getState(stateId);
96
97 List<Output> list = state.getOutputs();
98 if (list == null || list.size() == 0) {
99 logger.debug("-> No output modes for this state.");
100 continue;
101 }
102
103 List<Facet> fs = facets.get(stateId);
104
105 if (fs == null || fs.size() == 0) {
106 logger.debug("No facets for previous state found.");
107 continue;
108 }
109
110 logger.debug("Found " + fs.size() + " facets in previous states.");
111
112 List<Output> generated = generateOutputs(list, fs);
113
114 ProtocolUtils.appendOutputModes(doc, outs, generated);
115 }
116
117 try {
118 DefaultState cur = (DefaultState) getCurrentState(context);
119 List<Output> list = cur.getOutputs();
120 if (list != null && list.size() > 0) {
121 logger.debug(
122 "Append output modes for current state: " + cur.getID());
123
124 List<Facet> fs = facets.get(cur.getID());
125
126 if (fs != null && fs.size() > 0) {
127 List<Output> generated = generateOutputs(list, fs);
128
129 logger.debug("Found " + fs.size() + " current facets.");
130 if (!generated.isEmpty()) {
131 ProtocolUtils.appendOutputModes(
132 doc, outs, generated);
133 }
134 }
135 else {
136 logger.debug("No facets found for the current state.");
137 }
138 }
139 }
140 catch (IllegalArgumentException iae) {
141 // state is not valid, so we do not append its outputs.
142 }
143 }
144
145 public static class ChartState extends DefaultState {
146
147 public static final String FIELD_MODE = "chart_type";
148
149 public static final String DURATION_CURVE =
150 "chart.new.durationcurve";
151
152 public static final String COMPUTED_DISCHARGE_CURVE =
153 "chart.new.computeddischargecurve";
154
155 public static final String DISCHARGE_LONGITUDINAL_CURVE =
156 "chart.new.longitudinal_section";
157
158 public static final String W_DIFFERENCES =
159 "chart.new.w_differences";
160
161 public static final String WATERLEVEL =
162 "chart.new.crosssection";
163
164 public static final String[] CHARTS = {
165 COMPUTED_DISCHARGE_CURVE,
166 DURATION_CURVE,
167 DISCHARGE_LONGITUDINAL_CURVE,
168 W_DIFFERENCES,
169 WATERLEVEL };
170
171
172
173 @Override
174 public Object computeAdvance(
175 FLYSArtifact artifact,
176 String hash,
177 CallContext context,
178 List<Facet> facets,
179 Object old)
180 {
181 logger.debug("ChartState.computeAdvance");
182
183
184 return null;
185 }
186
187
188 @Override
189 protected Element[] createItems(
190 XMLUtils.ElementCreator cr,
191 Artifact artifact,
192 String name,
193 CallContext context)
194 {
195 CallMeta meta = context.getMeta();
196 Element[] charts = new Element[CHARTS.length];
197
198 int i = 0;
199
200 for (String chart: CHARTS) {
201 charts[i++] = createItem(
202 cr, new String[] {
203 Resources.getMsg(meta, chart, chart),
204 chart
205 });
206 }
207
208 return charts;
209 }
210 }
211 }
212 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org