aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--themes/src/main/themes/VAADIN/themes/valo/components/_tabsheet.scss8
-rw-r--r--uitest/src/main/java/com/vaadin/tests/components/tabsheet/TabNotVisibleInTheMiddleOfTabsheet.java43
-rw-r--r--uitest/src/test/java/com/vaadin/tests/components/tabsheet/TabNotVisibleInTheMiddleOfTabsheetTest.java46
3 files changed, 97 insertions, 0 deletions
diff --git a/themes/src/main/themes/VAADIN/themes/valo/components/_tabsheet.scss b/themes/src/main/themes/VAADIN/themes/valo/components/_tabsheet.scss
index e0fa665020..2b98bcbbaf 100644
--- a/themes/src/main/themes/VAADIN/themes/valo/components/_tabsheet.scss
+++ b/themes/src/main/themes/VAADIN/themes/valo/components/_tabsheet.scss
@@ -246,6 +246,10 @@ $v-tabsheet-content-animation-enabled: $v-animations-enabled !default;
margin-left: 0;
}
+ &:not([aria-hidden="true"]) ~ td .v-caption {
+ margin-left: round($v-unit-size/2);
+ }
+
&:focus {
outline: none;
@@ -443,6 +447,10 @@ $v-tabsheet-content-animation-enabled: $v-animations-enabled !default;
margin-left: 0;
}
+ :not([aria-hidden="true"]) ~ td .v-caption {
+ margin-left: $tab-spacing or first-number($v-border) * -1;
+ }
+
@if $frame-inactive-tabs {
.#{$primary-stylename}-tabitem .v-caption {
border-color: first-color(valo-border($color: $v-app-background-color, $strength: 0.5));
diff --git a/uitest/src/main/java/com/vaadin/tests/components/tabsheet/TabNotVisibleInTheMiddleOfTabsheet.java b/uitest/src/main/java/com/vaadin/tests/components/tabsheet/TabNotVisibleInTheMiddleOfTabsheet.java
new file mode 100644
index 0000000000..cb65e4cd21
--- /dev/null
+++ b/uitest/src/main/java/com/vaadin/tests/components/tabsheet/TabNotVisibleInTheMiddleOfTabsheet.java
@@ -0,0 +1,43 @@
+package com.vaadin.tests.components.tabsheet;
+
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.tests.components.AbstractTestUI;
+import com.vaadin.ui.Button;
+import com.vaadin.ui.Label;
+import com.vaadin.ui.TabSheet;
+import com.vaadin.ui.VerticalLayout;
+
+public class TabNotVisibleInTheMiddleOfTabsheet extends AbstractTestUI {
+
+ private TabSheet.Tab secondTab;
+
+ @Override
+ protected void setup(VaadinRequest request) {
+ TabSheet tabSheet = new TabSheet();
+ tabSheet.setWidth("600px");
+
+ tabSheet.addTab(new Label("first visible tab"), "first visible tab");
+
+ secondTab = tabSheet.addTab(new Label("second visible tab"),
+ "second visible tab");
+
+ for (int i = 3; i < 10; i++) {
+ tabSheet.addTab(new Label("visible tab " + i), "visible tab " + i);
+ }
+
+ addComponent(new VerticalLayout(tabSheet, new Button(
+ "Toggle second tab",
+ event -> secondTab.setVisible(!secondTab.isVisible()))));
+ }
+
+ @Override
+ protected Integer getTicketNumber() {
+ return 10437;
+ }
+
+ @Override
+ protected String getTestDescription() {
+ return "First and third tab should have the usual gap "
+ + "between them when second tab gets hidden.";
+ }
+}
diff --git a/uitest/src/test/java/com/vaadin/tests/components/tabsheet/TabNotVisibleInTheMiddleOfTabsheetTest.java b/uitest/src/test/java/com/vaadin/tests/components/tabsheet/TabNotVisibleInTheMiddleOfTabsheetTest.java
new file mode 100644
index 0000000000..cfbb0adb84
--- /dev/null
+++ b/uitest/src/test/java/com/vaadin/tests/components/tabsheet/TabNotVisibleInTheMiddleOfTabsheetTest.java
@@ -0,0 +1,46 @@
+package com.vaadin.tests.components.tabsheet;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertFalse;
+
+import java.util.List;
+
+import org.junit.Test;
+import org.openqa.selenium.WebElement;
+
+import com.vaadin.testbench.By;
+import com.vaadin.testbench.elements.ButtonElement;
+import com.vaadin.testbench.elements.TabSheetElement;
+import com.vaadin.tests.tb3.MultiBrowserTest;
+
+public class TabNotVisibleInTheMiddleOfTabsheetTest extends MultiBrowserTest {
+ @Test
+ public void testFirstTabIsVisibleAfterBeingInvisible() {
+ openTestURL();
+
+ TabSheetElement tabSheet = $(TabSheetElement.class).first();
+ List<WebElement> captionElements = tabSheet
+ .findElements(By.className("v-caption"));
+ int secondPosition = captionElements.get(1).getLocation().getX();
+ int thirdPosition = captionElements.get(2).getLocation().getX();
+
+ assertGreater(
+ "Third tab should be further than the second tab: "
+ + thirdPosition + " vs. " + secondPosition,
+ thirdPosition, secondPosition);
+
+ toggleSecondTabVisibility();
+
+ assertFalse("TabSheet should not have second tab visible",
+ captionElements.get(1).isDisplayed());
+
+ thirdPosition = captionElements.get(2).getLocation().getX();
+
+ assertEquals("Third tab should be where second tab was:",
+ secondPosition, thirdPosition);
+ }
+
+ private void toggleSecondTabVisibility() {
+ $(ButtonElement.class).caption("Toggle second tab").first().click();
+ }
+}