annotate gwt-client/src/main/java/org/dive4elements/river/client/client/ui/bundu/BunduWstWQPanel.java @ 9276:3141f0e7314e

clone for bundu.ws.wq
author gernotbelger
date Thu, 19 Jul 2018 17:54:10 +0200
parents
children 2323d005f9a5
rev   line source
9276
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
2 * Software engineering by Intevation GmbH
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
3 *
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
6 * documentation coming with Dive4Elements River for details.
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
7 */
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
8
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
9 package org.dive4elements.river.client.client.ui.bundu;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
10
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
11 import java.util.ArrayList;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
12 import java.util.List;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
13 import java.util.Map;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
14
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
15 import org.dive4elements.river.client.client.ui.DoubleArrayPanel;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
16 import org.dive4elements.river.client.client.ui.WQAdaptedInputPanel;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
17
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
18 import com.google.gwt.i18n.client.NumberFormat;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
19
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
20 /**
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
21 * This UIProvider creates a widget to enter W or Q data for
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
22 * Fixation analysis
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
23 *
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
24 * @author <a href="mailto:aheinecke@intevation.de">Andre Heinecke</a>
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
25 */
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
26 public class BunduWstWQPanel extends WQAdaptedInputPanel {
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
27 private static final long serialVersionUID = -3218827566805476423L;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
28
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
29 @Override
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
30 protected List<String> validateRange(final Map<String, double[]> ranges) {
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
31 final List<String> errors = new ArrayList<String>();
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
32 final NumberFormat nf = NumberFormat.getDecimalFormat();
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
33
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
34 for (final DoubleArrayPanel dap : this.wqranges.values()) {
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
35
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
36 if (!dap.validateForm()) {
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
37 errors.add(this.MSG.error_invalid_double_value());
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
38 return errors;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
39 }
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
40
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
41 int idx = 0;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
42
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
43 final double[] values = dap.getInputValues();
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
44
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
45 final double[] good = new double[values.length];
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
46
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
47 for (final double value : values) {
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
48 if (value <= 0) {
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
49 String tmp = this.MSG.error_validate_positive();
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
50 tmp = tmp.replace("$1", nf.format(value));
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
51 errors.add(tmp);
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
52 } else {
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
53 good[idx++] = value;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
54 }
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
55 }
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
56
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
57 final double[] justGood = new double[idx];
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
58 for (int i = 0; i < justGood.length; i++) {
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
59 justGood[i] = good[i];
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
60 }
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
61
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
62 if (!errors.isEmpty()) {
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
63 dap.setValues(justGood);
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
64 }
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
65 }
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
66 return errors;
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
67 }
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
68 }
3141f0e7314e clone for bundu.ws.wq
gernotbelger
parents:
diff changeset
69 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org