From 7f3481b7a69d9edc31c7e70b305ece6816eee36f Mon Sep 17 00:00:00 2001 From: Sauli Tähkäpää Date: Wed, 26 Aug 2015 21:43:17 +0300 Subject: Disable multiselect checkboxes when Grid is disabled. (#18560) Change-Id: Ief0531fe90b9bc8bcf0a60132211a0633b9401d4 --- .../widget/grid/events/GridEnabledEvent.java | 46 ++++++++++++++++++++++ .../widget/grid/events/GridEnabledHandler.java | 36 +++++++++++++++++ .../grid/selection/MultiSelectionRenderer.java | 25 +++++++++--- .../main/java/com/vaadin/client/widgets/Grid.java | 40 ++++++++++++++++++- 4 files changed, 141 insertions(+), 6 deletions(-) create mode 100644 client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledEvent.java create mode 100644 client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledHandler.java (limited to 'client/src') diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledEvent.java b/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledEvent.java new file mode 100644 index 0000000000..2e4be88671 --- /dev/null +++ b/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledEvent.java @@ -0,0 +1,46 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.client.widget.grid.events; + +import com.google.gwt.event.shared.GwtEvent; + +/** + * An enabled/disabled event, fired by the Grid when it is disabled or enabled. + * + * @since + * @author Vaadin Ltd + */ +public class GridEnabledEvent extends GwtEvent { + /** + * The type of this event + */ + public static final Type TYPE = new Type(); + private final boolean enabled; + + public GridEnabledEvent(boolean enabled) { + this.enabled = enabled; + } + + @Override + public Type getAssociatedType() { + return TYPE; + } + + @Override + protected void dispatch(final GridEnabledHandler handler) { + handler.onEnabled(enabled); + } +} diff --git a/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledHandler.java b/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledHandler.java new file mode 100644 index 0000000000..26ac498bcc --- /dev/null +++ b/client/src/main/java/com/vaadin/client/widget/grid/events/GridEnabledHandler.java @@ -0,0 +1,36 @@ +/* + * Copyright 2000-2014 Vaadin Ltd. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not + * use this file except in compliance with the License. You may obtain a copy of + * the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the + * License for the specific language governing permissions and limitations under + * the License. + */ +package com.vaadin.client.widget.grid.events; + +import com.google.gwt.event.shared.EventHandler; + +/** + * Handler for a Grid enabled/disabled event, called when the Grid is enabled + * or disabled. + * + * @since + * @author Vaadin Ltd + */ +public interface GridEnabledHandler extends EventHandler { + + /** + * Called when Grid is enabled or disabled. + * + * @param enabled + * true if status changes from disabled to enabled, otherwise false. + */ + public void onEnabled(boolean enabled); +} diff --git a/client/src/main/java/com/vaadin/client/widget/grid/selection/MultiSelectionRenderer.java b/client/src/main/java/com/vaadin/client/widget/grid/selection/MultiSelectionRenderer.java index c64908f24c..f244682b49 100644 --- a/client/src/main/java/com/vaadin/client/widget/grid/selection/MultiSelectionRenderer.java +++ b/client/src/main/java/com/vaadin/client/widget/grid/selection/MultiSelectionRenderer.java @@ -42,6 +42,8 @@ import com.vaadin.client.WidgetUtil; import com.vaadin.client.renderers.ClickableRenderer; import com.vaadin.client.widget.grid.CellReference; import com.vaadin.client.widget.grid.RendererCellReference; +import com.vaadin.client.widget.grid.events.GridEnabledEvent; +import com.vaadin.client.widget.grid.events.GridEnabledHandler; import com.vaadin.client.widget.grid.selection.SelectionModel.Multi.Batched; import com.vaadin.client.widgets.Grid; @@ -76,7 +78,7 @@ public class MultiSelectionRenderer extends * @since 7.5 */ private final class CheckBoxEventHandler implements MouseDownHandler, - TouchStartHandler, ClickHandler { + TouchStartHandler, ClickHandler, GridEnabledHandler { private final CheckBox checkBox; /** @@ -89,14 +91,18 @@ public class MultiSelectionRenderer extends @Override public void onMouseDown(MouseDownEvent event) { - if (event.getNativeButton() == NativeEvent.BUTTON_LEFT) { - startDragSelect(event.getNativeEvent(), checkBox.getElement()); + if(checkBox.isEnabled()) { + if (event.getNativeButton() == NativeEvent.BUTTON_LEFT) { + startDragSelect(event.getNativeEvent(), checkBox.getElement()); + } } } @Override public void onTouchStart(TouchStartEvent event) { - startDragSelect(event.getNativeEvent(), checkBox.getElement()); + if(checkBox.isEnabled()) { + startDragSelect(event.getNativeEvent(), checkBox.getElement()); + } } @Override @@ -105,6 +111,11 @@ public class MultiSelectionRenderer extends event.preventDefault(); event.stopPropagation(); } + + @Override + public void onEnabled(boolean enabled) { + checkBox.setEnabled(enabled); + } } /** @@ -595,6 +606,7 @@ public class MultiSelectionRenderer extends final CheckBox checkBox = GWT.create(CheckBox.class); checkBox.setStylePrimaryName(grid.getStylePrimaryName() + SELECTION_CHECKBOX_CLASSNAME); + CheckBoxEventHandler handler = new CheckBoxEventHandler(checkBox); // Sink events @@ -606,6 +618,9 @@ public class MultiSelectionRenderer extends checkBox.addMouseDownHandler(handler); checkBox.addTouchStartHandler(handler); checkBox.addClickHandler(handler); + grid.addHandler(handler, GridEnabledEvent.TYPE); + + checkBox.setEnabled(grid.isEnabled()); return checkBox; } @@ -614,7 +629,7 @@ public class MultiSelectionRenderer extends public void render(final RendererCellReference cell, final Boolean data, CheckBox checkBox) { checkBox.setValue(data, false); - checkBox.setEnabled(!grid.isEditorActive()); + checkBox.setEnabled(grid.isEnabled() && !grid.isEditorActive()); checkBox.getElement().setPropertyInt(LOGICAL_ROW_PROPERTY_INT, cell.getRowIndex()); } diff --git a/client/src/main/java/com/vaadin/client/widgets/Grid.java b/client/src/main/java/com/vaadin/client/widgets/Grid.java index c388dbc951..a022db58a4 100644 --- a/client/src/main/java/com/vaadin/client/widgets/Grid.java +++ b/client/src/main/java/com/vaadin/client/widgets/Grid.java @@ -140,6 +140,8 @@ import com.vaadin.client.widget.grid.events.FooterKeyPressHandler; import com.vaadin.client.widget.grid.events.FooterKeyUpHandler; import com.vaadin.client.widget.grid.events.GridClickEvent; import com.vaadin.client.widget.grid.events.GridDoubleClickEvent; +import com.vaadin.client.widget.grid.events.GridEnabledEvent; +import com.vaadin.client.widget.grid.events.GridEnabledHandler; import com.vaadin.client.widget.grid.events.GridKeyDownEvent; import com.vaadin.client.widget.grid.events.GridKeyPressEvent; import com.vaadin.client.widget.grid.events.GridKeyUpEvent; @@ -2845,7 +2847,8 @@ public class Grid extends ResizeComposite implements } } - public final class SelectionColumn extends Column { + public final class SelectionColumn extends Column + implements GridEnabledHandler { private boolean initDone = false; private boolean selected = false; @@ -2853,6 +2856,8 @@ public class Grid extends ResizeComposite implements SelectionColumn(final Renderer selectColumnRenderer) { super(selectColumnRenderer); + + addEnabledHandler(this); } void initDone() { @@ -3002,6 +3007,24 @@ public class Grid extends ResizeComposite implements super.setEditable(editable); return this; } + + /** + * Sets whether the selection column is enabled. + * + * @since + * @param enabled true to enable the column, + * false to disable it. + */ + public void setEnabled(boolean enabled) { + if(selectAllCheckBox != null) { + selectAllCheckBox.setEnabled(enabled); + } + } + + @Override + public void onEnabled(boolean enabled) { + setEnabled(enabled); + } } /** @@ -5971,6 +5994,8 @@ public class Grid extends ResizeComposite implements getEscalator().setScrollLocked(Direction.VERTICAL, !enabled || editorOpen); getEscalator().setScrollLocked(Direction.HORIZONTAL, !enabled); + + fireEvent(new GridEnabledEvent(enabled)); } @Override @@ -7538,6 +7563,8 @@ public class Grid extends ResizeComposite implements selectionColumn = new SelectionColumn(selectColumnRenderer); addColumnSkipSelectionColumnCheck(selectionColumn, 0); + + selectionColumn.setEnabled(isEnabled()); selectionColumn.initDone(); } else { selectionColumn = null; @@ -8099,6 +8126,17 @@ public class Grid extends ResizeComposite implements return addHandler(handler, ColumnResizeEvent.getType()); } + /** + * Register a enabled status change handler to this Grid. + * The event for this handler is fired when the Grid changes from disabled + * to enabled and vice-versa. + * @param handler the handler for the event + * @return the registration for the event + */ + public HandlerRegistration addEnabledHandler(GridEnabledHandler handler) { + return addHandler(handler, GridEnabledEvent.TYPE); + } + /** * Apply sorting to data source. */ -- cgit v1.2.3