diff options
5 files changed, 58 insertions, 7 deletions
diff --git a/client/src/main/java/com/vaadin/client/ui/VAccordion.java b/client/src/main/java/com/vaadin/client/ui/VAccordion.java index 9ad4ef4e96..c103f9e726 100644 --- a/client/src/main/java/com/vaadin/client/ui/VAccordion.java +++ b/client/src/main/java/com/vaadin/client/ui/VAccordion.java @@ -51,6 +51,8 @@ public class VAccordion extends VTabsheetBase { private final TouchScrollHandler touchScrollHandler; + private int tabulatorIndex; + public VAccordion() { super(CLASSNAME); @@ -110,6 +112,20 @@ public class VAccordion extends VTabsheetBase { } } + /** + * For internal use only. May be renamed or removed in a future release. + * + * @param tabIndex + * tabulator index for the open stack item + */ + public void setTabIndex(int tabIndex) { + tabulatorIndex = tabIndex; + StackItem openStackItem = getOpenStackItem(); + if (openStackItem != null) { + openStackItem.getElement().setTabIndex(tabIndex); + } + } + /** For internal use only. May be removed or replaced in the future. */ public void open(int itemIndex) { StackItem item = (StackItem) getWidget(itemIndex); @@ -308,6 +324,7 @@ public class VAccordion extends VTabsheetBase { content.getStyle().setLeft(0, Unit.PX); content.getStyle().clearVisibility(); addStyleDependentName("open"); + getElement().setTabIndex(tabulatorIndex); } public void hide() { @@ -325,6 +342,7 @@ public class VAccordion extends VTabsheetBase { setHeight(-1); setWidth(""); open = false; + getElement().setTabIndex(-1); } public boolean isOpen() { diff --git a/client/src/main/java/com/vaadin/client/ui/VTabsheet.java b/client/src/main/java/com/vaadin/client/ui/VTabsheet.java index e3e55f97ef..c9c721bbe9 100644 --- a/client/src/main/java/com/vaadin/client/ui/VTabsheet.java +++ b/client/src/main/java/com/vaadin/client/ui/VTabsheet.java @@ -787,6 +787,20 @@ public class VTabsheet extends VTabsheetBase private String currentStyle; /** + * For internal use only. May be renamed or removed in a future release. + * + * @param tabIndex + * tabulator index for the active tab of the tab sheet + */ + public void setTabIndex(int tabIndex) { + tabulatorIndex = tabIndex; + Tab activeTab = getActiveTab(); + if (activeTab != null) { + activeTab.setTabulatorIndex(tabIndex); + } + } + + /** * @return Whether the tab could be selected or not. */ private boolean canSelectTab(final int tabIndex) { diff --git a/shared/src/main/java/com/vaadin/shared/ui/tabsheet/TabsheetState.java b/shared/src/main/java/com/vaadin/shared/ui/tabsheet/TabsheetState.java index 3af0da9b42..6f8f7bfd84 100644 --- a/shared/src/main/java/com/vaadin/shared/ui/tabsheet/TabsheetState.java +++ b/shared/src/main/java/com/vaadin/shared/ui/tabsheet/TabsheetState.java @@ -34,6 +34,7 @@ public class TabsheetState extends AbstractComponentContainerState { * tabs. */ @NoLayout + @DelegateToWidget public int tabIndex; public List<TabState> tabs = new ArrayList<>(); diff --git a/uitest/src/main/java/com/vaadin/tests/fields/TabIndexes.java b/uitest/src/main/java/com/vaadin/tests/fields/TabIndexes.java index df93a43a37..179a512403 100644 --- a/uitest/src/main/java/com/vaadin/tests/fields/TabIndexes.java +++ b/uitest/src/main/java/com/vaadin/tests/fields/TabIndexes.java @@ -6,6 +6,7 @@ import java.util.List; import com.vaadin.annotations.Widgetset; import com.vaadin.server.VaadinRequest; import com.vaadin.tests.components.AbstractTestUIWithLog; +import com.vaadin.ui.Accordion; import com.vaadin.ui.Button; import com.vaadin.ui.CheckBox; import com.vaadin.ui.ComboBox; @@ -13,12 +14,14 @@ import com.vaadin.ui.Component; import com.vaadin.ui.DateField; import com.vaadin.ui.HorizontalLayout; import com.vaadin.ui.InlineDateField; +import com.vaadin.ui.Label; import com.vaadin.ui.ListSelect; import com.vaadin.ui.MenuBar; import com.vaadin.ui.NativeSelect; import com.vaadin.ui.PasswordField; import com.vaadin.ui.RichTextArea; import com.vaadin.ui.Slider; +import com.vaadin.ui.TabSheet; import com.vaadin.ui.TextArea; import com.vaadin.ui.TextField; import com.vaadin.ui.TreeGrid; @@ -54,6 +57,12 @@ public class TabIndexes extends AbstractTestUIWithLog { menubar.addItem("foo", item -> { }); fields.add(menubar); + TabSheet tabSheet = new TabSheet(); + tabSheet.addTab(new Label("Tab content"), "Tab 1"); + fields.add(tabSheet); + Accordion accordion = new Accordion(); + accordion.addTab(new Label("Tab content"), "Tab 1"); + fields.add(accordion); HorizontalLayout buttonLayout = new HorizontalLayout(); addComponent(buttonLayout); diff --git a/uitest/src/test/java/com/vaadin/tests/fields/TabIndexesTest.java b/uitest/src/test/java/com/vaadin/tests/fields/TabIndexesTest.java index db61d72d8f..67f7bea44f 100644 --- a/uitest/src/test/java/com/vaadin/tests/fields/TabIndexesTest.java +++ b/uitest/src/test/java/com/vaadin/tests/fields/TabIndexesTest.java @@ -8,7 +8,9 @@ import java.util.List; import org.junit.Test; import org.openqa.selenium.WebElement; +import com.vaadin.testbench.By; import com.vaadin.testbench.elements.AbstractComponentElement; +import com.vaadin.testbench.elements.AccordionElement; import com.vaadin.testbench.elements.ButtonElement; import com.vaadin.testbench.elements.CheckBoxElement; import com.vaadin.testbench.elements.ComboBoxElement; @@ -20,6 +22,7 @@ import com.vaadin.testbench.elements.NativeSelectElement; import com.vaadin.testbench.elements.PasswordFieldElement; import com.vaadin.testbench.elements.RichTextAreaElement; import com.vaadin.testbench.elements.SliderElement; +import com.vaadin.testbench.elements.TabSheetElement; import com.vaadin.testbench.elements.TextAreaElement; import com.vaadin.testbench.elements.TextFieldElement; import com.vaadin.testbench.elements.TreeGridElement; @@ -85,12 +88,10 @@ public class TabIndexesTest extends SingleBrowserTest { } private void assertTabIndex(String expected, WebElement element) { - if (!expected.equals(element.getAttribute("tabIndex"))) { - assertEquals( - "Unexpected tab index for element " - + element.getAttribute("outerHTML"), - expected, element.getAttribute("tabIndex")); - } + assertEquals( + "Unexpected tab index for element " + + element.getAttribute("outerHTML"), + expected, element.getAttribute("tabIndex")); } private List<WebElement> getFocusElements() { @@ -115,11 +116,19 @@ public class TabIndexesTest extends SingleBrowserTest { focusElements.add($(CheckBoxElement.class).first().getInputElement()); focusElements.add($(SliderElement.class).first()); focusElements.add($(MenuBarElement.class).first()); + TabSheetElement tabsheet = $(TabSheetElement.class).first(); + focusElements.add(tabsheet + .findElement(By.className("v-tabsheet-tabitemcell-selected"))); + AccordionElement accordion = $(AccordionElement.class).first(); + focusElements.add( + accordion.findElement(By.className("v-accordion-item-open"))); List<AbstractComponentElement> components = $( VerticalLayoutElement.class).id(TabIndexes.FIELD_CONTAINER_ID) .$(AbstractComponentElement.class).all(); - assertEquals(components.size(), focusElements.size()); + // the Labels within the TabSheet and Accordion are left out of the + // index handling + assertEquals(components.size(), focusElements.size() + 2); return focusElements; } |