public void dataRemoved(int firstRowIndex, int numberOfRows) {
if (awaitingRowsState == AwaitingRowsState.COLLAPSE) {
awaitingRowsState = AwaitingRowsState.NONE;
- // make sure the cache stays up to date with the collapsing
- Range visibleRowRange = getWidget().getEscalator()
- .getVisibleRowRange();
- getDataSource().ensureAvailability(
- visibleRowRange.getStart(),
- visibleRowRange.length());
}
+ // make sure the cache stays up to date
+ Range visibleRowRange = getWidget().getEscalator()
+ .getVisibleRowRange();
+ getDataSource().ensureAvailability(visibleRowRange.getStart(),
+ visibleRowRange.length());
checkExpand();
}
public void dataAdded(int firstRowIndex, int numberOfRows) {
if (awaitingRowsState == AwaitingRowsState.EXPAND) {
awaitingRowsState = AwaitingRowsState.NONE;
- // make sure the cache stays up to date with the expanding
- Range visibleRowRange = getWidget().getEscalator()
- .getVisibleRowRange();
- getDataSource().ensureAvailability(
- visibleRowRange.getStart(),
- visibleRowRange.length());
}
+ // make sure the cache stays up to date
+ Range visibleRowRange = getWidget().getEscalator()
+ .getVisibleRowRange();
+ getDataSource().ensureAvailability(visibleRowRange.getStart(),
+ visibleRowRange.length());
checkExpand();
}
GridEventHandler<?> eventHandler)
/*-{
var browserEventHandlers = grid.@com.vaadin.client.widgets.Grid::browserEventHandlers;
-
+
// FocusEventHandler is initially 5th in the list of browser event handlers
browserEventHandlers.@java.util.List::set(*)(5, eventHandler);
}-*/;
--- /dev/null
+package com.vaadin.tests.components.treegrid;
+
+import com.vaadin.data.TreeData;
+import com.vaadin.data.provider.TreeDataProvider;
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.tests.components.AbstractTestUI;
+import com.vaadin.ui.Button;
+import com.vaadin.ui.TreeGrid;
+
+public class TreeGridProgrammaticExpand extends AbstractTestUI {
+
+ @Override
+ protected void setup(VaadinRequest request) {
+ TreeData<String> data = new TreeData<>();
+ String root = "Root";
+ data.addItem(null, root);
+ for (int i = 0; i < 15; i++) {
+ String leaf = "Leaf " + i;
+ data.addItem(root, leaf);
+ }
+
+ TreeDataProvider<String> treeDataProvider = new TreeDataProvider<>(
+ data);
+ TreeGrid<String> treeGrid = new TreeGrid<>();
+ treeGrid.setDataProvider(treeDataProvider);
+ treeGrid.addColumn(String::toString).setCaption("String")
+ .setId("string");
+ treeGrid.addColumn(i -> "--").setCaption("Nothing");
+
+ Button button = new Button("Expand", e -> treeGrid.expand(root));
+
+ addComponents(button, treeGrid);
+ }
+
+ @Override
+ protected String getTestDescription() {
+ return "There should be no client-side exception when clicking Leaf 4 "
+ + "or lower before scrolling.";
+ }
+
+ @Override
+ protected Integer getTicketNumber() {
+ return 12372;
+ }
+}
--- /dev/null
+package com.vaadin.tests.components.treegrid;
+
+import org.junit.Test;
+import org.openqa.selenium.By;
+
+import com.vaadin.testbench.elements.ButtonElement;
+import com.vaadin.testbench.elements.TreeGridElement;
+import com.vaadin.tests.tb3.MultiBrowserTest;
+
+public class TreeGridProgrammaticExpandTest extends MultiBrowserTest {
+
+ @Test
+ public void expandAndClick() {
+ openTestURL("debug");
+ TreeGridElement treeGrid = $(TreeGridElement.class).first();
+ $(ButtonElement.class).first().click();
+ waitUntilLoadingIndicatorNotVisible();
+ treeGrid.getCell(5, 0).click();
+ waitUntilLoadingIndicatorNotVisible();
+ assertElementNotPresent(By.className("v-Notification-error"));
+ }
+}