changeset 249:6c7133eb8c4c

Implemented handler for WQ value selection. flys-client/trunk@1837 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author Raimund Renkert <raimund.renkert@intevation.de>
date Thu, 05 May 2011 13:32:36 +0000 (2011-05-05)
parents ed90309ec608
children 27f12703937e
files flys-client/ChangeLog flys-client/src/main/java/de/intevation/flys/client/client/ui/WQInputPanel.java
diffstat 2 files changed, 113 insertions(+), 31 deletions(-) [+]
line wrap: on
line diff
--- a/flys-client/ChangeLog	Thu May 05 09:51:51 2011 +0000
+++ b/flys-client/ChangeLog	Thu May 05 13:32:36 2011 +0000
@@ -1,3 +1,8 @@
+2011-05-05  Raimund Renkert <rrenkert@intevation.de>
+
+	* src/main/java/de/intevation/flys/client/client/ui/WQInputPanel.java:
+	  Implemented handler for the value selection.
+
 2011-05-05  Raimund Renkert <rrenkert@intevation.de>
 
 	* src/main/java/de/intevation/flys/client/client/ui/WQInputPanel.java:
--- a/flys-client/src/main/java/de/intevation/flys/client/client/ui/WQInputPanel.java	Thu May 05 09:51:51 2011 +0000
+++ b/flys-client/src/main/java/de/intevation/flys/client/client/ui/WQInputPanel.java	Thu May 05 13:32:36 2011 +0000
@@ -33,6 +33,7 @@
 import de.intevation.flys.client.shared.model.WQInfoRecord;
 import de.intevation.flys.client.shared.model.ArtifactDescription;
 import com.smartgwt.client.types.ListGridFieldType;
+import com.smartgwt.client.types.SelectionStyle;
 
 import de.intevation.flys.client.client.services.WQInfoService;
 import de.intevation.flys.client.client.services.WQInfoServiceAsync;
@@ -124,6 +125,18 @@
     /** The values entered in the single Q mode.*/
     protected double[] valuesQ;
 
+    /** The input panel for W values*/
+    protected DoubleArrayPanel wArrayPanel;
+
+    /** The input panel for q values*/
+    protected DoubleArrayPanel qArrayPanel;
+
+    /** The input panel for w range*/
+    protected DoubleRangePanel wRangePanel;
+
+    /** The input panel for q range*/
+    protected DoubleRangePanel qRangePanel;
+
     /** The WQ Data*/
     protected WQInfoObject[] tableData;
 
@@ -241,15 +254,92 @@
         ListGridField addWQ = new ListGridField("", "");
         addWQ.setType(ListGridFieldType.ICON);
         addWQ.setWidth(30);
-        wqTable.addCellClickHandler(new CellClickHandler() {
+
+        CellClickHandler cch = new CellClickHandler() {
             public void onCellClick(CellClickEvent e) {
-                if (e.getColNum() == 0 && e.getRecord().getEnabled ()) {
+                if (e.getColNum() == 0 && !e.getRecord().getEnabled ()) {
                     Record r = e.getRecord ();
                     double val = r.getAttributeAsDouble("value");
-//                    setValue(val);
+                    if(isWMode() && !isRangeMode()) {
+                        double[] in = wArrayPanel.getInputValues();
+                        int size = 0;
+                        if (in == null) {
+                            double[] vals = new double[1];
+                            vals[0] = val;
+                            wArrayPanel.setValues(vals);
+                            setSingleW(vals);
+                        }
+                        else {
+                            double[] vals = new double[in.length+1];
+                            for(int i = 0; i < in.length; i++) {
+                                vals[i] = in[i];
+                            }
+                            vals[in.length] = val;
+                            wArrayPanel.setValues(vals);
+                            setSingleW(vals);
+                        }
+                    }
+                    else if (!isWMode() && !isRangeMode()) {
+                        double[] in = qArrayPanel.getInputValues();
+                        int size = 0;
+                        if (in == null) {
+                            double[] vals = new double[1];
+                            vals[0] = val;
+                            qArrayPanel.setValues(vals);
+                            setSingleQ(vals);
+                        }
+                        else {
+                            double[] vals = new double[in.length+1];
+                            for(int i = 0; i < in.length; i++) {
+                                vals[i] = in[i];
+                            }
+                            vals[in.length] = val;
+                            qArrayPanel.setValues(vals);
+                            setSingleQ(vals);
+                        }
+                    }
                 }
             }
-        });
+        };
+
+        CellClickHandler cchRange = new CellClickHandler() {
+            public void onCellClick(CellClickEvent e) {
+                if (e.getColNum() == 0 && !e.getRecord().getEnabled ()) {
+                    Record r = e.getRecord ();
+                    double val = r.getAttributeAsDouble("value");
+                    if(isWMode() && isRangeMode()) {
+                        wRangePanel.setValues(
+                            val,
+                            wRangePanel.getTo(),
+                            wRangePanel. getStep());
+                    }
+                    else if (!isWMode() && isRangeMode()) {
+                        qRangePanel.setValues(
+                            val,
+                            qRangePanel.getTo(),
+                            qRangePanel.getStep());
+                    }
+                }
+                if (e.getColNum() == 1 && !e.getRecord().getEnabled()) {
+                    Record r = e.getRecord ();
+                    double val = r.getAttributeAsDouble("value");
+                    if (isWMode() && isRangeMode()) {
+                         wRangePanel.setValues(
+                             wRangePanel.getFrom(),
+                             val,
+                             wRangePanel.getStep());
+                    }
+                    else if(!isWMode() && isRangeMode()) {
+                        qRangePanel.setValues(
+                            qRangePanel.getFrom(),
+                            val,
+                            qRangePanel.getStep());
+                    }
+                }
+            }
+        };
+        wqTable.addCellClickHandler(cch);
+        wqRangeTable.addCellClickHandler(cchRange);
         addWQ.setCellIcon (IMAGES.markerGreen().getURL());
 
         ListGridField addWQMin = new ListGridField("", "");
@@ -259,18 +349,7 @@
         addWQMax.setType(ListGridFieldType.ICON);
         addWQMax.setWidth(30);
 
-        wqRangeTable.addCellClickHandler(new CellClickHandler() {
-            public void onCellClick(CellClickEvent e) {
-                if (e.getColNum() == 0 && e.getRecord().getEnabled ()) {
-                    Record r = e.getRecord ();
-                    double val = r.getAttributeAsDouble("value");
-//                    setValue(val);
-                }
-                else if (e.getColNum() == 1 && e.getRecord().getEnabled()) {
-
-                }
-            }
-        });
+        wqRangeTable.addCellClickHandler(cch);
         addWQMin.setCellIcon(IMAGES.markerGreen().getURL());
         addWQMax.setCellIcon(IMAGES.markerRed().getURL());
 
@@ -294,7 +373,8 @@
         value_r.setType(ListGridFieldType.TEXT);
         type_r.setWidth("50");
 
-
+        wqTable.setSelectionType(SelectionStyle.SINGLE);
+        wqRangeTable.setSelectionType(SelectionStyle.SINGLE);
         wqTable.setFields(addWQ, name, type, value);
         wqRangeTable.setFields(addWQMin, addWQMax, name_r, type_r, value_r);
     }
@@ -390,9 +470,9 @@
         createWQInputPanel();
         // the initial panel is the Single-W panel.
         double[] values = getSingleW();
-        container.addMember(new DoubleArrayPanel(
-            MESSAGE.unitWSingle(), values, this));
-
+        wArrayPanel = new DoubleArrayPanel(
+            MESSAGE.unitWSingle(), values, this);
+        container.addMember(wArrayPanel);
         container.addMember(wqTable);
         layout.addMember(modeForm);
         layout.addMember(container);
@@ -718,10 +798,10 @@
                 // Single W mode
                 double[] values = getSingleW();
 
-                newPanel = new DoubleArrayPanel(
+                wArrayPanel = new DoubleArrayPanel(
                     MESSAGE.unitWSingle(), values, this);
 
-                container.addMember(newPanel);
+                container.addMember(wArrayPanel);
                 container.addMember(wqTable);
             }
             else {
@@ -730,12 +810,12 @@
                 double to   = getToW();
                 double step = getStepW();
 
-                newPanel = new DoubleRangePanel(
+                wRangePanel = new DoubleRangePanel(
                     MESSAGE.unitWFrom(), MESSAGE.unitWTo(), MESSAGE.unitWStep(),
                     from, to, step,
                     250,
                     this);
-                container.addMember(newPanel);
+                container.addMember(wRangePanel);
                 container.addMember(wqRangeTable);
             }
         }
@@ -744,9 +824,9 @@
                 // Single Q mode
                 double[] values = getSingleQ();
 
-                newPanel = new DoubleArrayPanel(
+                qArrayPanel = new DoubleArrayPanel(
                     MESSAGE.unitQSingle(), values, this);
-                container.addMember(newPanel);
+                container.addMember(qArrayPanel);
                 container.addMember(wqTable);
             }
             else {
@@ -755,12 +835,12 @@
                 double to   = getToQ();
                 double step = getStepQ();
 
-                newPanel = new DoubleRangePanel(
+                qRangePanel = new DoubleRangePanel(
                     MESSAGE.unitQFrom(), MESSAGE.unitQTo(), MESSAGE.unitQStep(),
                     from, to, step,
                     250,
                     this);
-                container.addMember(newPanel);
+                container.addMember(qRangePanel);
                 container.addMember(wqRangeTable);
             }
         }
@@ -1031,7 +1111,4 @@
         return;
     }
 }
-
-
-
 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org