diff options
author | Sauli Tähkäpää <sauli@vaadin.com> | 2014-03-28 16:41:19 +0200 |
---|---|---|
committer | Sauli Tähkäpää <sauli@vaadin.com> | 2014-03-28 16:42:30 +0200 |
commit | 6a06c3a04c9d2a7408d3b69f4863096425e90e3c (patch) | |
tree | 6c574ca779dfcbd9b4d0acc8d4417bc50edf0665 | |
parent | 2ea5ad5279af4259232082c219c0e2e14524b15f (diff) | |
parent | 5b3ae6d62e5ff49ef0b204ed27b1004399a19aac (diff) | |
download | vaadin-framework-6a06c3a04c9d2a7408d3b69f4863096425e90e3c.tar.gz vaadin-framework-6a06c3a04c9d2a7408d3b69f4863096425e90e3c.zip |
Merge remote-tracking branch 'origin/7.1'
Change-Id: I17fa1bf6982c8c7e1f9faf26b77593b170fa5fdd
3 files changed, 123 insertions, 1 deletions
diff --git a/client/src/com/vaadin/client/ui/VWindow.java b/client/src/com/vaadin/client/ui/VWindow.java index d6dd9c7b1d..6a908aaa29 100644 --- a/client/src/com/vaadin/client/ui/VWindow.java +++ b/client/src/com/vaadin/client/ui/VWindow.java @@ -679,9 +679,14 @@ public class VWindow extends VWindowOverlay implements } super.hide(); + int curIndex = windowOrder.indexOf(this); // Remove window from windowOrder to avoid references being left // hanging. - windowOrder.remove(this); + windowOrder.remove(curIndex); + // Update the z-indices of any remaining windows + while (curIndex < windowOrder.size()) { + windowOrder.get(curIndex).setWindowOrder(curIndex++); + } } private void fixIE8FocusCaptureIssue() { diff --git a/uitest/src/com/vaadin/tests/components/window/WindowZIndex.java b/uitest/src/com/vaadin/tests/components/window/WindowZIndex.java new file mode 100644 index 0000000000..5d1a2540b8 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/window/WindowZIndex.java @@ -0,0 +1,56 @@ +package com.vaadin.tests.components.window; + +import java.util.ArrayDeque; +import java.util.NoSuchElementException; +import java.util.Queue; + +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.Button.ClickListener; +import com.vaadin.ui.Label; +import com.vaadin.ui.Window; + +public class WindowZIndex extends AbstractTestUI { + + @Override + protected String getTestDescription() { + return "Windows should stack correctly when adding new windows, closing opened ones and switching focus."; + } + + @Override + protected Integer getTicketNumber() { + return 13174; + } + + int windowCount = 0; + Queue<Window> windows = new ArrayDeque<Window>(); + + @Override + protected void setup(VaadinRequest request) { + addComponent(new Button("Add window", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + Window window = new Window(); + window.setPositionX(100 + 20 * windowCount); + window.setPositionY(100 + 20 * windowCount); + window.setHeight(200, Unit.PIXELS); + window.setWidth(200, Unit.PIXELS); + window.setContent(new Label("Window " + ++windowCount)); + addWindow(window); + windows.add(window); + } + })); + addComponent(new Button("Close window", new ClickListener() { + @Override + public void buttonClick(ClickEvent event) { + try { + windows.remove().close(); + } catch (NoSuchElementException e) { + } + } + })); + } + +} diff --git a/uitest/src/com/vaadin/tests/components/window/WindowZIndexTest.java b/uitest/src/com/vaadin/tests/components/window/WindowZIndexTest.java new file mode 100644 index 0000000000..38254cf6f3 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/window/WindowZIndexTest.java @@ -0,0 +1,61 @@ +/* + * Copyright 2000-2013 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.tests.components.window; + +import java.io.IOException; + +import org.junit.Test; +import org.openqa.selenium.By; +import org.openqa.selenium.WebElement; +import org.openqa.selenium.interactions.Actions; + +import com.vaadin.tests.tb3.MultiBrowserTest; + +public class WindowZIndexTest extends MultiBrowserTest { + + @Test + public void removingUpdatesZIndices() throws IOException { + openTestURL(); + + WebElement addButton = driver.findElement(By + .xpath("//span[contains(text(),'Add window')]")); + WebElement closeButton = driver.findElement(By + .xpath("//span[contains(text(),'Close window')]")); + + addButton.click(); + addButton.click(); + addButton.click(); + addButton.click(); + addButton.click(); + + closeButton.click(); + closeButton.click(); + closeButton.click(); + + addButton.click(); + addButton.click(); + addButton.click(); + addButton.click(); + + compareScreen("stacked"); + + WebElement window4 = driver.findElement(By + .xpath("//*[contains(text(), 'Window 4')]")); + new Actions(driver).moveToElement(window4, 1, 9).click().perform(); + + compareScreen("win4-on-top"); + } +} |