aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOlli Tietäväinen <ollit@vaadin.com>2018-11-13 15:00:48 +0200
committerSun Zhe <31067185+ZheSun88@users.noreply.github.com>2018-12-04 10:34:50 +0200
commit8313623dd318c92aa49e9cf96268f5fff6ad6456 (patch)
tree2516ca0e151f491cc0204077f3320a2110e1d6dd
parent89f5052510560f278179c23af38f8abb73721625 (diff)
downloadvaadin-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.java96
-rwxr-xr-x[-rw-r--r--]compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java375
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);
}