diff options
author | Olli Tietäväinen <ollit@vaadin.com> | 2018-11-13 15:00:48 +0200 |
---|---|---|
committer | Sun Zhe <31067185+ZheSun88@users.noreply.github.com> | 2018-12-04 10:34:50 +0200 |
commit | 8313623dd318c92aa49e9cf96268f5fff6ad6456 (patch) | |
tree | 2516ca0e151f491cc0204077f3320a2110e1d6dd | |
parent | 89f5052510560f278179c23af38f8abb73721625 (diff) | |
download | vaadin-framework-8313623dd318c92aa49e9cf96268f5fff6ad6456.tar.gz vaadin-framework-8313623dd318c92aa49e9cf96268f5fff6ad6456.zip |
v7 Grid performance improvements picked to compatibility package
-rwxr-xr-x[-rw-r--r--] | compatibility-client/src/main/java/com/vaadin/v7/client/connectors/GridConnector.java | 96 | ||||
-rwxr-xr-x[-rw-r--r--] | compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java | 375 |
2 files changed, 296 insertions, 175 deletions
diff --git a/compatibility-client/src/main/java/com/vaadin/v7/client/connectors/GridConnector.java b/compatibility-client/src/main/java/com/vaadin/v7/client/connectors/GridConnector.java index 067d74389e..46f63fd6f8 100644..100755 --- a/compatibility-client/src/main/java/com/vaadin/v7/client/connectors/GridConnector.java +++ b/compatibility-client/src/main/java/com/vaadin/v7/client/connectors/GridConnector.java @@ -177,6 +177,28 @@ public class GridConnector extends AbstractHasComponentsConnector } /** + * Creates and initializes a custom grid column with attributes of given state. + * + * @param state with attributes to initialize the column. + */ + @SuppressWarnings("unchecked") + private CustomGridColumn(GridColumnState state) { + this(state.id, (AbstractGridRendererConnector<Object>) state.rendererConnector); + this.hidingToggleCaption = state.hidingToggleCaption; + this.hidden = state.hidden; + this.hidable = state.hidable; + this.resizable = state.resizable; + this.sortable = state.sortable; + this.headerCaption = state.headerCaption == null ? "" : state.headerCaption; + this.widthUser = state.width; + this.minimumWidthPx = state.minWidth; + this.maximumWidthPx = state.maxWidth; + this.expandRatio = state.expandRatio; + this.editable = state.editable; + setEditorConnector((AbstractComponentConnector) state.editorConnector); + } + + /** * Sets a new renderer for this column object * * @param rendererConnector @@ -472,7 +494,8 @@ public class GridConnector extends AbstractHasComponentsConnector } else { getLogger().warning( "Visibility changed for a unknown column type in Grid: " - + column + ", type " + column.getClass()); + + column.toString() + ", type " + + column.getClass()); } } } @@ -544,9 +567,13 @@ public class GridConnector extends AbstractHasComponentsConnector if (spacerCellBorderHeights != null && !getLayoutManager().isLayoutRunning() && hasDetailsOpen(rowIndex)) { - double height = getLayoutManager().getOuterHeightDouble( - element) + spacerCellBorderHeights; - getWidget().setDetailsHeight(rowIndex, height); + // Measure and set details height if element is visible + if (WidgetUtil.isDisplayed(element)) { + double height = + getLayoutManager().getOuterHeightDouble( + element) + spacerCellBorderHeights; + getWidget().setDetailsHeight(rowIndex, height); + } } } }; @@ -890,13 +917,8 @@ public class GridConnector extends AbstractHasComponentsConnector // Remove old columns purgeRemovedColumns(); - // Add new columns - for (GridColumnState state : getState().columns) { - if (!columnIdToColumn.containsKey(state.id)) { - addColumnFromStateChangeEvent(state); - } - updateColumnFromStateChangeEvent(state); - } + // Update all columns + updateColumnsFromState(); } if (stateChangeEvent.hasPropertyChanged("columnOrder")) { @@ -1099,37 +1121,33 @@ public class GridConnector extends AbstractHasComponentsConnector cell.setStyleName(cellState.styleName); } - /** - * Updates a column from a state change event. - * - * @param columnIndex - * The index of the column to update - */ - private void updateColumnFromStateChangeEvent(GridColumnState columnState) { - CustomGridColumn column = columnIdToColumn.get(columnState.id); - - columnsUpdatedFromState = true; - updateColumnFromState(column, columnState); - columnsUpdatedFromState = false; - } /** - * Adds a new column to the grid widget from a state change event + * Update columns from the current state. * - * @param columnIndex - * The index of the column, according to how it */ - private void addColumnFromStateChangeEvent(GridColumnState state) { + private void updateColumnsFromState() { + this.columnsUpdatedFromState = true; + final List<Column<?, JsonObject>> columns = new ArrayList<Column<?, JsonObject>>(getState().columns.size()); + for (String columnId : getState().columnOrder) { + for (GridColumnState state : getState().columns) { + if (state.id.equals(columnId)) { + CustomGridColumn column = this.columnIdToColumn.get(state.id); + if (column == null) { + column = new CustomGridColumn(state); + this.columnIdToColumn.put(state.id, column); + this.columnOrder.add(state.id); + columns.add(column); + } else { + updateColumnFromState(column, state); + } + } + } + } @SuppressWarnings("unchecked") - CustomGridColumn column = new CustomGridColumn(state.id, - ((AbstractGridRendererConnector<Object>) state.rendererConnector)); - columnIdToColumn.put(state.id, column); - - /* - * Add column to grid. Reordering is handled as a separate problem. - */ - getWidget().addColumn(column); - columnOrder.add(state.id); + final Column<?, JsonObject>[] columnArray = columns.toArray(new Column[0]); + getWidget().addColumns(columnArray); + this.columnsUpdatedFromState = false; } /** @@ -1148,7 +1166,8 @@ public class GridConnector extends AbstractHasComponentsConnector column.setMaximumWidth(state.maxWidth); column.setExpandRatio(state.expandRatio); - assert state.rendererConnector instanceof AbstractGridRendererConnector : "GridColumnState.rendererConnector is invalid (not subclass of AbstractGridRendererConnector)"; + assert state.rendererConnector instanceof AbstractGridRendererConnector : "GridColumnState.rendererConnector is invalid (not subclass of " + + "AbstractRendererConnector)"; column.setRenderer( (AbstractGridRendererConnector<Object>) state.rendererConnector); @@ -1322,6 +1341,7 @@ public class GridConnector extends AbstractHasComponentsConnector info.setContentMode(contentMode); return info; } + @Override protected void sendContextClickEvent(MouseEventDetails details, EventTarget eventTarget) { diff --git a/compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java b/compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java index 8af5818eb1..2d0774f3ec 100644..100755 --- a/compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java +++ b/compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java @@ -114,6 +114,8 @@ import com.vaadin.v7.client.widget.escalator.Spacer; import com.vaadin.v7.client.widget.escalator.SpacerUpdater; import com.vaadin.v7.client.widget.escalator.events.RowHeightChangedEvent; import com.vaadin.v7.client.widget.escalator.events.RowHeightChangedHandler; +import com.vaadin.v7.client.widget.escalator.events.SpacerVisibilityChangedEvent; +import com.vaadin.v7.client.widget.escalator.events.SpacerVisibilityChangedHandler; import com.vaadin.v7.client.widget.grid.AutoScroller; import com.vaadin.v7.client.widget.grid.AutoScroller.AutoScrollerCallback; import com.vaadin.v7.client.widget.grid.AutoScroller.ScrollAxis; @@ -1316,6 +1318,23 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, private static final String ERROR_CLASS_NAME = "error"; private static final String NOT_EDITABLE_CLASS_NAME = "not-editable"; + ScheduledCommand fieldFocusCommand = new ScheduledCommand() { + private int count = 0; + + @Override + public void execute() { + Element focusedElement = WidgetUtil.getFocusedElement(); + if (focusedElement == grid.getElement() + || focusedElement == Document.get().getBody() + || count > 2) { + focusColumn(focusedColumnIndexDOM); + } else { + ++count; + Scheduler.get().scheduleDeferred(this); + } + } + }; + /** * A handler for events related to the Grid editor. Responsible for * opening, moving or closing the editor based on the received event. @@ -1751,10 +1770,10 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, * if the editor handler is not set */ public void setEnabled(boolean enabled) { - if (!enabled && state != State.INACTIVE) { + if (enabled == false && state != State.INACTIVE) { throw new IllegalStateException( "Cannot disable: editor is in edit mode"); - } else if (enabled && getHandler() == null) { + } else if (enabled == true && getHandler() == null) { throw new IllegalStateException( "Cannot enable: EditorHandler not set"); } @@ -1875,7 +1894,11 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, } if (i == focusedColumnIndexDOM) { - focusColumn(focusedColumnIndexDOM); + if (BrowserInfo.get().isIE8()) { + Scheduler.get().scheduleDeferred(fieldFocusCommand); + } else { + focusColumn(focusedColumnIndexDOM); + } } } else { cell.addClassName(NOT_EDITABLE_CLASS_NAME); @@ -2116,8 +2139,20 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, private void updateHorizontalScrollPosition() { double scrollLeft = grid.getScrollLeft(); - cellWrapper.getStyle().setLeft( - frozenCellWrapper.getOffsetWidth() - scrollLeft, Unit.PX); + int frozenWidth = frozenCellWrapper.getOffsetWidth(); + double newLeft = frozenWidth - scrollLeft; + cellWrapper.getStyle().setLeft(newLeft, Unit.PX); + + // sometimes focus handling twists the editor row out of alignment + // with the grid itself and the position needs to be compensated for + TableRowElement rowElement = grid.getEscalator().getBody() + .getRowElement(grid.getEditor().getRow()); + int rowLeft = rowElement.getAbsoluteLeft(); + int editorLeft = cellWrapper.getAbsoluteLeft(); + if (editorLeft != rowLeft + frozenWidth) { + cellWrapper.getStyle().setLeft(newLeft + rowLeft - editorLeft, + Unit.PX); + } } /** @@ -2326,7 +2361,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, if (!Element.is(target)) { return null; } - return WidgetUtil.findWidget(Element.as(target), Grid.class); + return WidgetUtil.findWidget(Element.as(target), Grid.class, false); } /** @@ -2354,6 +2389,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, } else if (container == getGrid().escalator.getBody()) { section = Section.BODY; } + doDispatch(handler, section); } } @@ -2392,7 +2428,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, if (!Element.is(target)) { return null; } - return WidgetUtil.findWidget(Element.as(target), Grid.class); + return WidgetUtil.findWidget(Element.as(target), Grid.class, false); } /** @@ -3148,7 +3184,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, if (!columns.contains(column)) { throw new IllegalArgumentException( - "Given column is not a column in this grid. " + column); + "Given column is not a column in this grid. " + + column.toString()); } if (!column.isSortable()) { @@ -3475,7 +3512,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, */ final double widthPerRatio; int leftOver = 0; - if (BrowserInfo.getBrowserString().contains("PhantomJS")) { + if (BrowserInfo.get().isIE8() || BrowserInfo.get().isIE9() + || BrowserInfo.getBrowserString().contains("PhantomJS")) { // These browsers report subpixels as integers. this usually // results into issues.. widthPerRatio = (int) (pixelsToDistribute / totalRatios); @@ -3936,7 +3974,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, private void setHeightToHeaderCellHeight() { RowContainer header = grid.escalator.getHeader(); - if (header.getDomRowCount() == 0 + if (header.getRowCount() == 0 || !header.getRowElement(0).hasChildNodes()) { getLogger().info( "No header cell available when calculating sidebar button height"); @@ -4008,7 +4046,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, private final class ColumnHider { /** Map from columns to their hiding toggles, component might change */ - private Map<Column<?, T>, MenuItem> columnToHidingToggleMap = new HashMap<Column<?, T>, MenuItem>(); + private HashMap<Column<?, T>, MenuItem> columnToHidingToggleMap = new HashMap<Column<?, T>, MenuItem>(); /** * When column is being hidden with a toggle, do not refresh toggles for @@ -4047,7 +4085,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, } private String createHTML(Column<?, T> column) { - final StringBuilder buf = new StringBuilder(); + final StringBuffer buf = new StringBuffer(); buf.append("<span class=\""); if (column.isHidden()) { buf.append("v-off"); @@ -4114,7 +4152,6 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, * on initialization, but not after that. */ private DataSource<T> dataSource; - private Registration changeHandler; /** * Currently available row range in DataSource. @@ -4330,10 +4367,12 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, && rightBoundaryForDrag < dropMarkerLeft && dropMarkerLeft <= escalator.getInnerWidth()) { dropMarkerLeft = rightBoundaryForDrag - dropMarkerWidthOffset; - } else if ( + } + // Check if the drop marker shouldn't be shown at all - dropMarkerLeft < frozenColumnsWidth || dropMarkerLeft > Math - .min(rightBoundaryForDrag, escalator.getInnerWidth()) + else if (dropMarkerLeft < frozenColumnsWidth + || dropMarkerLeft > Math.min(rightBoundaryForDrag, + escalator.getInnerWidth()) || dropMarkerLeft < 0) { dropMarkerLeft = -10000000; } @@ -4452,8 +4491,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, reordered.addAll(columns.subList( draggedColumnIndex + colspan, columns.size())); } - // since setColumnOrder will add it anyway! - reordered.remove(selectionColumn); + reordered.remove(selectionColumn); // since setColumnOrder will + // add it anyway! // capture focused cell column before reorder Cell focusedCell = cellFocusHandler.getFocusedCell(); @@ -4482,8 +4521,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, if (focusedColumnIndex == draggedColumnIndex) { // move with the dragged column int adjustedDropIndex = latestColumnDropIndex > draggedColumnIndex - ? latestColumnDropIndex - 1 - : latestColumnDropIndex; + ? latestColumnDropIndex - 1 : latestColumnDropIndex; // remove hidden columns from indexing adjustedDropIndex = getVisibleColumns() .indexOf(getColumn(adjustedDropIndex)); @@ -4608,8 +4646,9 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, rightBound = cellColumnRightIndex; } cellColumnIndex = cellColumnRightIndex - 1; - } else { - // can't drop inside a spanned cell, or this is the + } + + else { // can't drop inside a spanned cell, or this is the // dragged cell while (colspan > 1) { cellColumnIndex++; @@ -4714,8 +4753,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, @Override public void render(RendererCellReference cell, Object data) { if (!warned && !(data instanceof String)) { - getLogger().warning( - Column.this + ": " + DEFAULT_RENDERER_WARNING); + getLogger().warning(Column.this.toString() + ": " + + DEFAULT_RENDERER_WARNING); warned = true; } @@ -4736,33 +4775,65 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, private Grid<T> grid; /** - * Width of column in pixels as {@link #setWidth(double)} has been - * called + * Width of column in pixels as {@link #setWidth(double)} has been called. */ - private double widthUser = GridConstants.DEFAULT_COLUMN_WIDTH_PX; + protected double widthUser = GridConstants.DEFAULT_COLUMN_WIDTH_PX; /** * Renderer for rendering a value into the cell */ private Renderer<? super C> bodyRenderer; - private boolean sortable = false; + /** + * The sortable state of this column. + */ + protected boolean sortable = false; - private boolean editable = true; + /** + * The editable state of this column. + */ + protected boolean editable = true; - private boolean resizable = true; + /** + * The resizable state of this column. + */ + protected boolean resizable = true; + + /** + * The hidden state of this column. + */ + protected boolean hidden = false; + + /** + * The hidable state of this column. + */ + protected boolean hidable = false; + + /** + * The header-caption of this column. + */ + protected String headerCaption = ""; - private boolean hidden = false; + /** + * The hiding-toggle-caption of this column. + */ + protected String hidingToggleCaption = null; - private boolean hidable = false; + /** + * The minimum width in pixels of this column. + */ + protected double minimumWidthPx = GridConstants.DEFAULT_MIN_WIDTH; - private String headerCaption = ""; + /** + * The maximum width in pixels of this column. + */ + protected double maximumWidthPx = GridConstants.DEFAULT_MAX_WIDTH; - private String hidingToggleCaption = null; + /** + * The expand ratio of this column. + */ + protected int expandRatio = GridConstants.DEFAULT_EXPAND_RATIO; - private double minimumWidthPx = GridConstants.DEFAULT_MIN_WIDTH; - private double maximumWidthPx = GridConstants.DEFAULT_MAX_WIDTH; - private int expandRatio = GridConstants.DEFAULT_EXPAND_RATIO; /** * Constructs a new column with a simple TextRenderer. @@ -5644,7 +5715,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, if (renderer instanceof WidgetRenderer) { try { Widget w = WidgetUtil.findWidget( - cell.getElement().getFirstChildElement(), null); + cell.getElement().getFirstChildElement()); if (w != null) { // Logical detach @@ -5863,7 +5934,16 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, dragEnded(); col.setWidth(width); - fireEvent(new ColumnResizeEvent<T>(col)); + + // Need to wait for column width recalculation + // scheduled by setWidth() before firing the event + Scheduler.get().scheduleDeferred( + new ScheduledCommand() { + @Override + public void execute() { + fireEvent(new ColumnResizeEvent<T>(col)); + } + }); } }; @@ -6201,29 +6281,6 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, fireEvent(new GridEnabledEvent(enabled)); } - @Override - public void setStylePrimaryName(String style) { - super.setStylePrimaryName(style); - escalator.setStylePrimaryName(style); - editor.setStylePrimaryName(style); - sidebar.setStylePrimaryName(style + "-sidebar"); - sidebar.addStyleName("v-contextmenu"); - - String rowStyle = getStylePrimaryName() + "-row"; - rowHasDataStyleName = rowStyle + "-has-data"; - rowSelectedStyleName = rowStyle + "-selected"; - rowStripeStyleName = rowStyle + "-stripe"; - - cellFocusStyleName = getStylePrimaryName() + "-cell-focused"; - rowFocusStyleName = getStylePrimaryName() + "-row-focused"; - - if (isAttached()) { - refreshHeader(); - refreshBody(); - refreshFooter(); - } - } - /** * Sets the column resize mode to use. The default mode is * {@link ColumnResizeMode.ANIMATED}. @@ -6241,12 +6298,36 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, * {@link ColumnResizeMode.ANIMATED}. * * @return a ColumnResizeMode value + * * @since 7.7.5 */ public ColumnResizeMode getColumnResizeMode() { return columnResizeMode; } + @Override + public void setStylePrimaryName(String style) { + super.setStylePrimaryName(style); + escalator.setStylePrimaryName(style); + editor.setStylePrimaryName(style); + sidebar.setStylePrimaryName(style + "-sidebar"); + sidebar.addStyleName("v-contextmenu"); + + String rowStyle = getStylePrimaryName() + "-row"; + rowHasDataStyleName = rowStyle + "-has-data"; + rowSelectedStyleName = rowStyle + "-selected"; + rowStripeStyleName = rowStyle + "-stripe"; + + cellFocusStyleName = getStylePrimaryName() + "-cell-focused"; + rowFocusStyleName = getStylePrimaryName() + "-row-focused"; + + if (isAttached()) { + refreshHeader(); + refreshBody(); + refreshFooter(); + } + } + /** * Creates the escalator updater used to update the header rows in this * grid. The updater is invoked when header rows or columns are added or @@ -6369,9 +6450,24 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, * the columns to add */ public void addColumns(Column<?, T>... columns) { - int count = getColumnCount(); + final int count = getColumnCount(); for (Column<?, T> column : columns) { - addColumn(column, count++); + checkColumnIsValidToAdd(column, count); + } + addColumnsSkipSelectionColumnCheck(Arrays.asList(columns), count); + } + + + /** + * Checks the given column is valid to add at the given index. + */ + private void checkColumnIsValidToAdd(Column<?, T> column, int index) { + if (column == this.selectionColumn) { + throw new IllegalArgumentException( + "The selection column many " + "not be added manually"); + } else if (this.selectionColumn != null && index == 0) { + throw new IllegalStateException("A column cannot be inserted " + + "before the selection column"); } } @@ -6401,53 +6497,56 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, * and {@code index} is 0. */ public <C extends Column<?, T>> C addColumn(C column, int index) { - if (column == selectionColumn) { - throw new IllegalArgumentException( - "The selection column many " + "not be added manually"); - } else if (selectionColumn != null && index == 0) { - throw new IllegalStateException("A column cannot be inserted " - + "before the selection column"); - } - - addColumnSkipSelectionColumnCheck(column, index); + checkColumnIsValidToAdd(column, index); + addColumnsSkipSelectionColumnCheck(Collections.singleton(column), index); return column; } - private void addColumnSkipSelectionColumnCheck(Column<?, T> column, - int index) { - // Register column with grid - columns.add(index, column); - header.addColumn(column); - footer.addColumn(column); + private <C extends Column<?, T>> void addColumnsSkipSelectionColumnCheck(Collection<C> columnCollection, int index) { + int visibleNewColumns = 0; + int currentIndex = index; - // Register this grid instance with the column - ((Column<?, T>) column).setGrid(this); + //prevent updates of hiding toggles. + //it will be updated finally all at once. + this.columnHider.hidingColumn = true; - // Grid knows about hidden columns, Escalator only knows about what is - // visible so column indexes do not match - if (!column.isHidden()) { - int escalatorIndex = index; - for (int existingColumn = 0; existingColumn < index; existingColumn++) { - if (getColumn(existingColumn).isHidden()) { - escalatorIndex--; - } + for (final Column<?, T> column : columnCollection) { + // Register column with grid + this.columns.add(currentIndex++, column); + this.footer.addColumn(column); + this.header.addColumn(column); + + // Register this grid instance with the column + column.setGrid(this); + + if (!column.isHidden()) { + visibleNewColumns++; } - escalator.getColumnConfiguration().insertColumns(escalatorIndex, 1); + } + if (visibleNewColumns > 0) { + final ColumnConfiguration columnConfiguration = this.escalator.getColumnConfiguration(); + columnConfiguration.insertColumns(index, visibleNewColumns); } - // Reapply column width - column.reapplyWidth(); - - // Sink all renderer events - Set<String> events = new HashSet<String>(); - events.addAll(getConsumedEventsForRenderer(column.getRenderer())); + for (final Column<?, T> column : columnCollection) { + // Reapply column width + column.reapplyWidth(); + // Sink all renderer events + final Set<String> events = new HashSet<String>(); + events.addAll(getConsumedEventsForRenderer(column.getRenderer())); - if (column.isHidable()) { - columnHider.updateColumnHidable(column); + if (column.isHidable()) { + this.columnHider.updateColumnHidable(column); + } + sinkEvents(events); } - - sinkEvents(events); + //now we do the update of the hiding toggles. + this.columnHider.hidingColumn = false; + this.columnHider.updateTogglesOrder(); + refreshHeader(); + this.header.updateColSpans(); + this.footer.updateColSpans(); } private void sinkEvents(Collection<String> events) { @@ -6551,7 +6650,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, * @return A unmodifiable list of the currently visible columns in the grid */ public List<Column<?, T>> getVisibleColumns() { - List<Column<?, T>> visible = new ArrayList<Column<?, T>>(); + ArrayList<Column<?, T>> visible = new ArrayList<Column<?, T>>(); for (Column<?, T> c : columns) { if (!c.isHidden()) { visible.add(c); @@ -6925,41 +7024,33 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, selectionModel.reset(); - if (changeHandler != null) { - changeHandler.remove(); - changeHandler = null; + if (this.dataSource != null) { + this.dataSource.addDataChangeHandler((DataChangeHandler) null); } this.dataSource = dataSource; - changeHandler = dataSource - .addDataChangeHandler(new DataChangeHandler() { + dataSource.addDataChangeHandler(new DataChangeHandler() { @Override public void dataUpdated(int firstIndex, int numberOfItems) { - escalator.getBody().refreshRows(firstIndex, - numberOfItems); + escalator.getBody().refreshRows(firstIndex, numberOfItems); } @Override public void dataRemoved(int firstIndex, int numberOfItems) { - escalator.getBody().removeRows(firstIndex, - numberOfItems); - Range removed = Range.withLength(firstIndex, - numberOfItems); + escalator.getBody().removeRows(firstIndex, numberOfItems); + Range removed = Range.withLength(firstIndex, numberOfItems); cellFocusHandler.rowsRemovedFromBody(removed); } @Override public void dataAdded(int firstIndex, int numberOfItems) { - escalator.getBody().insertRows(firstIndex, - numberOfItems); - Range added = Range.withLength(firstIndex, - numberOfItems); + escalator.getBody().insertRows(firstIndex, numberOfItems); + Range added = Range.withLength(firstIndex, numberOfItems); cellFocusHandler.rowsAddedToBody(added); } @Override - public void dataAvailable(int firstIndex, - int numberOfItems) { + public void dataAvailable(int firstIndex, int numberOfItems) { currentDataAvailable = Range.withLength(firstIndex, numberOfItems); fireEvent(new DataAvailableEvent(currentDataAvailable)); @@ -6971,31 +7062,27 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, int oldSize = body.getRowCount(); // Hide all details. - Set<Integer> oldDetails = new HashSet<Integer>( - visibleDetails); + Set<Integer> oldDetails = new HashSet<Integer>(visibleDetails); for (int i : oldDetails) { setDetailsVisible(i, false); } if (newSize > oldSize) { body.insertRows(oldSize, newSize - oldSize); - cellFocusHandler.rowsAddedToBody(Range - .withLength(oldSize, newSize - oldSize)); + cellFocusHandler.rowsAddedToBody( + Range.withLength(oldSize, newSize - oldSize)); } else if (newSize < oldSize) { body.removeRows(newSize, oldSize - newSize); - cellFocusHandler.rowsRemovedFromBody(Range - .withLength(newSize, oldSize - newSize)); + cellFocusHandler.rowsRemovedFromBody( + Range.withLength(newSize, oldSize - newSize)); } if (newSize > 0) { - Range visibleRowRange = escalator - .getVisibleRowRange(); - dataSource.ensureAvailability( - visibleRowRange.getStart(), + Range visibleRowRange = escalator.getVisibleRowRange(); + dataSource.ensureAvailability(visibleRowRange.getStart(), visibleRowRange.length()); } else { - // We won't expect any data more data updates, so - // just make + // We won't expect any data more data updates, so just make // the bookkeeping happy dataAvailable(0, 0); } @@ -7466,7 +7553,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, } private boolean isElementInChildWidget(Element e) { - Widget w = WidgetUtil.findWidget(e, null); + Widget w = WidgetUtil.findWidget(e); if (w == this) { return false; @@ -7853,7 +7940,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, cellFocusHandler.offsetRangeBy(1); selectionColumn = new SelectionColumn(selectColumnRenderer); - addColumnSkipSelectionColumnCheck(selectionColumn, 0); + addColumnsSkipSelectionColumnCheck(Collections.singleton(selectionColumn), 0); selectionColumn.setEnabled(isEnabled()); selectionColumn.initDone(); @@ -8440,6 +8527,19 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, } /** + * Adds a spacer visibility changed handler to the underlying escalator. + * + * @param handler + * the handler to be called when a spacer's visibility changes + * @return the registration object with which the handler can be removed + * @since 7.7.13 + */ + public HandlerRegistration addSpacerVisibilityChangedHandler( + SpacerVisibilityChangedHandler handler) { + return escalator.addHandler(handler, SpacerVisibilityChangedEvent.TYPE); + } + + /** * Adds a low-level DOM event handler to this Grid. The handler is inserted * into the given position in the list of handlers. The handlers are invoked * in order. If the @@ -8830,7 +8930,6 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, for (int row : details) { setDetailsVisible(row, false); } - super.onDetach(); } @@ -8948,17 +9047,17 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, * @param parent * The parent to set */ - private static final native void setParent(Widget widget, Grid<?> parent) + private static native final void setParent(Widget widget, Grid<?> parent) /*-{ widget.@com.google.gwt.user.client.ui.Widget::setParent(Lcom/google/gwt/user/client/ui/Widget;)(parent); }-*/; - private static final native void onAttach(Widget widget) + private static native final void onAttach(Widget widget) /*-{ widget.@Widget::onAttach()(); }-*/; - private static final native void onDetach(Widget widget) + private static native final void onDetach(Widget widget) /*-{ widget.@Widget::onDetach()(); }-*/; @@ -9081,7 +9180,9 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>, if (visible && !isVisible) { escalator.getBody().setSpacer(rowIndex, DETAILS_ROW_INITIAL_HEIGHT); visibleDetails.add(rowIndexInteger); - } else if (!visible && isVisible) { + } + + else if (!visible && isVisible) { escalator.getBody().setSpacer(rowIndex, -1); visibleDetails.remove(rowIndexInteger); } |