summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/com/itmill/toolkit/terminal/gwt/client/ui/IWindow.java31
-rw-r--r--src/com/itmill/toolkit/tests/components/window/CenteredWindowWithUndefinedSize.java33
2 files changed, 49 insertions, 15 deletions
diff --git a/src/com/itmill/toolkit/terminal/gwt/client/ui/IWindow.java b/src/com/itmill/toolkit/terminal/gwt/client/ui/IWindow.java
index 7de1f81349..915f4b521e 100644
--- a/src/com/itmill/toolkit/terminal/gwt/client/ui/IWindow.java
+++ b/src/com/itmill/toolkit/terminal/gwt/client/ui/IWindow.java
@@ -341,23 +341,8 @@ public class IWindow extends IToolkitOverlay implements Container,
}
if (dynamicHeight && layoutRelativeHeight) {
- /*
- * Window height is undefined, layout is 100% high so the layout
- * should define the initial window height but on resize the layout
- * should be as high as the window. We fix the height immediately to
- * deal with this.
- */
-
- int h = contents.getOffsetHeight() + getExtraHeight();
- int w = contents.getOffsetWidth();
-
// Prevent resizing until height has been fixed
resizable = false;
-
- client.updateVariable(id, "height", h, false);
- client.updateVariable(id, "width", w, true);
- // ApplicationConnection.getConsole().log("Fixing window size to " +
- // w + "x" + h);
}
// we may have actions and notifications
@@ -429,6 +414,22 @@ public class IWindow extends IToolkitOverlay implements Container,
if (getOffsetHeight() > Window.getClientHeight()) {
setHeight(Window.getClientHeight() + "px");
}
+
+ if (dynamicHeight && layoutRelativeHeight) {
+ /*
+ * Window height is undefined, layout is 100% high so the layout
+ * should define the initial window height but on resize the layout
+ * should be as high as the window. We fix the height to deal with
+ * this.
+ */
+
+ int h = contents.getOffsetHeight() + getExtraHeight();
+ int w = contents.getOffsetWidth();
+
+ client.updateVariable(id, "height", h, false);
+ client.updateVariable(id, "width", w, true);
+ }
+
}
private void setNaturalWidth() {
diff --git a/src/com/itmill/toolkit/tests/components/window/CenteredWindowWithUndefinedSize.java b/src/com/itmill/toolkit/tests/components/window/CenteredWindowWithUndefinedSize.java
new file mode 100644
index 0000000000..3c0191ff39
--- /dev/null
+++ b/src/com/itmill/toolkit/tests/components/window/CenteredWindowWithUndefinedSize.java
@@ -0,0 +1,33 @@
+package com.itmill.toolkit.tests.components.window;
+
+import com.itmill.toolkit.tests.components.TestBase;
+import com.itmill.toolkit.ui.Label;
+import com.itmill.toolkit.ui.Window;
+
+public class CenteredWindowWithUndefinedSize extends TestBase {
+
+ @Override
+ protected String getDescription() {
+ return "The centered sub-window with undefined height and a 100% high layout should be rendered in the center of the screen and not in the top-left corner.";
+ }
+
+ @Override
+ protected Integer getTicketNumber() {
+ return 2702;
+ }
+
+ @Override
+ protected void setup() {
+ Window centered = new Window("A window");
+ centered.setSizeUndefined();
+ centered.getLayout().setSizeFull();
+ centered.center();
+
+ Label l = new Label("This window should be centered");
+ l.setSizeUndefined();
+ centered.addComponent(l);
+
+ getMainWindow().addWindow(centered);
+
+ }
+}