# HG changeset patch
# User Ingo Weinzierl <ingo.weinzierl@intevation.de>
# Date 1308907222 0
# Node ID 854312c0528c67f7743a92ebdf30389e800aabb8
# Parent  ea2191b1299d9fa2de637f35de7ce51d121879fa
#21 Newly created projects cannot be opened twice.

flys-client/trunk@2225 c6561f87-3c4e-4783-a992-168aeb5c3f6f

diff -r ea2191b1299d -r 854312c0528c flys-client/ChangeLog
--- a/flys-client/ChangeLog	Thu Jun 23 17:46:08 2011 +0000
+++ b/flys-client/ChangeLog	Fri Jun 24 09:20:22 2011 +0000
@@ -1,3 +1,17 @@
+2011-06-24  Ingo Weinzierl <ingo@intevation.de>
+
+	  flys/issue21 (Gleiches Projekt kann mehr als einmal gleichzeitig geƶffnet werden)
+
+	* src/main/java/de/intevation/flys/client/client/FLYS.java: Implements
+	  CollectionChangeHandler to lock new projects. In addition, there is a
+	  new method to close projects.
+
+	* src/main/java/de/intevation/flys/client/client/ui/CollectionView.java:
+	  If this view contains a Collection, FLYS is used to close this window.
+	  FLYS needs to unlock the project before the view is destroyed.
+	  Otherwise - if no Collection has been created yet - this view destroys
+	  itself.
+
 2011-06-23  Ingo Weinzierl <ingo@intevation.de>
 
 	  flys/issue170 (Diagramm: Initiales Zoomen zeigt verschobenen Bereich)
diff -r ea2191b1299d -r 854312c0528c flys-client/src/main/java/de/intevation/flys/client/client/FLYS.java
--- a/flys-client/src/main/java/de/intevation/flys/client/client/FLYS.java	Thu Jun 23 17:46:08 2011 +0000
+++ b/flys-client/src/main/java/de/intevation/flys/client/client/FLYS.java	Fri Jun 24 09:20:22 2011 +0000
@@ -25,6 +25,8 @@
 import de.intevation.flys.client.shared.model.River;
 import de.intevation.flys.client.shared.model.User;
 
+import de.intevation.flys.client.client.event.CollectionChangeEvent;
+import de.intevation.flys.client.client.event.CollectionChangeHandler;
 import de.intevation.flys.client.client.services.ArtifactService;
 import de.intevation.flys.client.client.services.ArtifactServiceAsync;
 import de.intevation.flys.client.client.services.DescribeCollectionService;
@@ -49,7 +51,7 @@
  *
  * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a>
  */
-public class FLYS implements EntryPoint {
+public class FLYS implements EntryPoint, CollectionChangeHandler {
 
     /** The message class that provides i18n strings.*/
     protected FLYSConstants MSG = GWT.create(FLYSConstants.class);
@@ -382,6 +384,12 @@
     }
 
 
+    public void closeProject(String uuid) {
+        unlockProject(uuid);
+        workspace.destroyProject(uuid);
+    }
+
+
     /**
      * Create a new Artifact.
      */
@@ -404,12 +412,22 @@
     }
 
 
+    public void onCollectionChange(CollectionChangeEvent event) {
+        Collection oldC = event.getOldValue();
+
+        if (oldC == null) {
+            Collection newC = event.getNewValue();
+            lockProject(newC.identifier());
+        }
+    }
+
+
 
     /**
      * This CloseClickHandler is used to remove lock on a specific Collection so
      * that is might be opened again.
      */
-    private class CloseCollectionViewHandler implements CloseClickHandler {
+    public class CloseCollectionViewHandler implements CloseClickHandler {
         protected FLYS   flys;
         protected String uuid;
 
@@ -419,8 +437,7 @@
         }
 
         public void onCloseClick(CloseClientEvent event) {
-            flys.unlockProject(uuid);
-            workspace.removeProject(uuid);
+            flys.closeProject(uuid);
         }
     }
 }
diff -r ea2191b1299d -r 854312c0528c flys-client/src/main/java/de/intevation/flys/client/client/ui/CollectionView.java
--- a/flys-client/src/main/java/de/intevation/flys/client/client/ui/CollectionView.java	Thu Jun 23 17:46:08 2011 +0000
+++ b/flys-client/src/main/java/de/intevation/flys/client/client/ui/CollectionView.java	Fri Jun 24 09:20:22 2011 +0000
@@ -114,6 +114,7 @@
 
         addCollectionChangeHandler(this);
         addCollectionChangeHandler(parameterList);
+        addCollectionChangeHandler(flys);
         addOutputModesChangeHandler(this);
         addOutputModesChangeHandler(parameterList);
         addCloseClickHandler(this);
@@ -139,6 +140,7 @@
 
         addCollectionChangeHandler(this);
         addCollectionChangeHandler(parameterList);
+        addCollectionChangeHandler(flys);
         addOutputModesChangeHandler(this);
         addOutputModesChangeHandler(parameterList);
         addCloseClickHandler(this);
@@ -493,8 +495,13 @@
 
 
     public void onCloseClick(CloseClientEvent event) {
-        hide();
-        destroy();
+        if (collection != null) {
+            flys.closeProject(collection.identifier());
+        }
+        else {
+            hide();
+            destroy();
+        }
     }
 }
 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :
diff -r ea2191b1299d -r 854312c0528c flys-client/src/main/java/de/intevation/flys/client/client/ui/chart/ChartOutputTab.java
--- a/flys-client/src/main/java/de/intevation/flys/client/client/ui/chart/ChartOutputTab.java	Thu Jun 23 17:46:08 2011 +0000
+++ b/flys-client/src/main/java/de/intevation/flys/client/client/ui/chart/ChartOutputTab.java	Fri Jun 24 09:20:22 2011 +0000
@@ -307,7 +307,10 @@
         Axis xAxis = chartInfo.getXAxis(0);
         Axis yAxis = chartInfo.getYAxis(0);
 
+        GWT.log("ZOOM X");
         double[] x = zoomAxis(xAxis, factor);
+
+        GWT.log("ZOOM Y");
         double[] y = zoomAxis(yAxis, factor);
 
         zoom[0] = x[0];
@@ -324,12 +327,16 @@
         double min  = axis.getFrom();
         double max  = axis.getTo();
 
+        GWT.log("ZOOM CURRENT: " + min + " - " + max);
+
         double add = (max - min) / 100 * factor;
         add = add < 0 ? (-1) * add : add;
 
         min -= add;
         max += add;
 
+        GWT.log("ZOOM TO: " + min + " - " + max);
+
         return computeZoom(axis, min, max);
     }