Mercurial > dive4elements > river
comparison artifacts/src/main/java/org/dive4elements/river/artifacts/states/SoundingsSelect.java @ 7919:868f55932fe6
Removed serverside path for bed height epochs.
author | Raimund Renkert <rrenkert@intevation.de> |
---|---|
date | Fri, 06 Jun 2014 16:59:16 +0200 |
parents | b320826b1183 |
children | d77f53c1e5a1 |
comparison
equal
deleted
inserted
replaced
7918:5813c206ff64 | 7919:868f55932fe6 |
---|---|
19 | 19 |
20 import org.dive4elements.artifacts.common.model.KVP; | 20 import org.dive4elements.artifacts.common.model.KVP; |
21 import org.dive4elements.artifacts.common.utils.XMLUtils; | 21 import org.dive4elements.artifacts.common.utils.XMLUtils; |
22 import org.dive4elements.artifacts.common.utils.XMLUtils.ElementCreator; | 22 import org.dive4elements.artifacts.common.utils.XMLUtils.ElementCreator; |
23 | 23 |
24 import org.dive4elements.river.model.BedHeightEpoch; | |
25 import org.dive4elements.river.model.BedHeightSingle; | 24 import org.dive4elements.river.model.BedHeightSingle; |
26 import org.dive4elements.river.model.River; | 25 import org.dive4elements.river.model.River; |
27 | 26 |
28 import org.dive4elements.river.artifacts.D4EArtifact; | 27 import org.dive4elements.river.artifacts.D4EArtifact; |
29 import org.dive4elements.river.artifacts.resources.Resources; | 28 import org.dive4elements.river.artifacts.resources.Resources; |
35 public class SoundingsSelect extends DefaultState { | 34 public class SoundingsSelect extends DefaultState { |
36 | 35 |
37 public static final String SOUNDINGS = "soundings"; | 36 public static final String SOUNDINGS = "soundings"; |
38 | 37 |
39 public static final String PREFIX_SINGLE = "single-"; | 38 public static final String PREFIX_SINGLE = "single-"; |
40 | |
41 public static final String PREFIX_EPOCH = "epoch-"; | |
42 | 39 |
43 /** Private logger. */ | 40 /** Private logger. */ |
44 private static final Logger logger = Logger.getLogger(SoundingsSelect.class); | 41 private static final Logger logger = Logger.getLogger(SoundingsSelect.class); |
45 | 42 |
46 | 43 |
91 double kmHi = Math.max(lo, hi); | 88 double kmHi = Math.max(lo, hi); |
92 | 89 |
93 List<KVP<String, String>> kvp = new ArrayList<KVP<String, String>>(); | 90 List<KVP<String, String>> kvp = new ArrayList<KVP<String, String>>(); |
94 | 91 |
95 appendSingles(river, kmLo, kmHi, creator, select, context); | 92 appendSingles(river, kmLo, kmHi, creator, select, context); |
96 appendEpochs(river, kmLo, kmHi, creator, select, context); | |
97 | 93 |
98 return kvp.toArray(new KVP[kvp.size()]); | 94 return kvp.toArray(new KVP[kvp.size()]); |
99 } | 95 } |
100 | 96 |
101 | 97 |
138 } | 134 } |
139 logger.debug("appended singles"); | 135 logger.debug("appended singles"); |
140 logger.debug(XMLUtils.toString(select)); | 136 logger.debug(XMLUtils.toString(select)); |
141 } | 137 } |
142 | 138 |
143 | |
144 protected void appendEpochs( | |
145 River river, | |
146 double kmLo, | |
147 double kmHi, | |
148 ElementCreator creator, | |
149 Element select, | |
150 CallContext context | |
151 ) { | |
152 List<BedHeightEpoch> epochs = | |
153 BedHeightEpoch.getBedHeightEpochs(river, kmLo, kmHi); | |
154 | |
155 if (epochs != null) { | |
156 int size = epochs.size(); | |
157 | |
158 logger.debug("Found " + size + " epochs."); | |
159 | |
160 NumberFormat nf = Formatter.getCalculationKm(context.getMeta()); | |
161 for (int i = 0; i < size; i++) { | |
162 BedHeightEpoch e = epochs.get(i); | |
163 | |
164 String id = PREFIX_EPOCH + e.getId(); | |
165 String value = e.getDescription(); | |
166 | |
167 Element item = creator.create("item"); | |
168 creator.addAttr(item, "label", value, true); | |
169 creator.addAttr(item, "value", id, true); | |
170 creator.addAttr(item, "analyzed_range", | |
171 nf.format(e.getRange().getA()) + | |
172 " - " + | |
173 nf.format(e.getRange().getB())); | |
174 creator.addAttr(item, "year", e.getTimeInterval().getStartTime().toString()); | |
175 select.appendChild(item); | |
176 } | |
177 } | |
178 logger.debug("appended epochs"); | |
179 } | |
180 | |
181 @Override | 139 @Override |
182 protected Element createStaticData( | 140 protected Element createStaticData( |
183 D4EArtifact flys, | 141 D4EArtifact flys, |
184 ElementCreator creator, | 142 ElementCreator creator, |
185 CallContext cc, | 143 CallContext cc, |
218 } | 176 } |
219 | 177 |
220 if (value.indexOf(PREFIX_SINGLE) >= 0) { | 178 if (value.indexOf(PREFIX_SINGLE) >= 0) { |
221 return getLabelForSingle(cc, value); | 179 return getLabelForSingle(cc, value); |
222 } | 180 } |
223 else if (value.indexOf(PREFIX_EPOCH) >= 0) { | |
224 return getLabelForEpoch(cc, value); | |
225 } | |
226 | |
227 return value; | 181 return value; |
228 } | 182 } |
229 | 183 |
230 | 184 |
231 protected String getLabelForSingle(CallContext cc, String value) { | 185 protected String getLabelForSingle(CallContext cc, String value) { |
234 BedHeightSingle s = BedHeightSingle.getBedHeightSingleById( | 188 BedHeightSingle s = BedHeightSingle.getBedHeightSingleById( |
235 Integer.parseInt(id)); | 189 Integer.parseInt(id)); |
236 | 190 |
237 if (s != null) { | 191 if (s != null) { |
238 return s.getDescription(); | 192 return s.getDescription(); |
239 } | |
240 else { | |
241 return "no value for '" + id + "'"; | |
242 } | |
243 } | |
244 catch (NumberFormatException nfe) { | |
245 logger.warn("Could not parse id from string '" + id + "'", nfe); | |
246 } | |
247 | |
248 return "n.A."; | |
249 } | |
250 | |
251 | |
252 protected String getLabelForEpoch(CallContext cc, String value) { | |
253 String id = value.replace(PREFIX_EPOCH, ""); | |
254 try { | |
255 BedHeightEpoch e = BedHeightEpoch.getBedHeightEpochById( | |
256 Integer.parseInt(id)); | |
257 | |
258 if (e != null) { | |
259 return e.getDescription(); | |
260 } | 193 } |
261 else { | 194 else { |
262 return "no value for '" + id + "'"; | 195 return "no value for '" + id + "'"; |
263 } | 196 } |
264 } | 197 } |