summaryrefslogtreecommitdiffstats
path: root/client/src
diff options
context:
space:
mode:
authormtzukanov <mtzukanov@vaadin.com>2015-10-15 13:47:23 +0300
committerJohannes Dahlström <johannesd@vaadin.com>2015-11-03 12:42:02 +0000
commitbaa8da38adeac92a3acecd9501ecbbafe5815f88 (patch)
treee1ce03fc3c1961cb7c1c3f21b2cf6daa658cd96a /client/src
parentbc78b47d1df883e71aa99082c52502efe4f48a3a (diff)
downloadvaadin-framework-baa8da38adeac92a3acecd9501ecbbafe5815f88.tar.gz
vaadin-framework-baa8da38adeac92a3acecd9501ecbbafe5815f88.zip
Changed grid sidebar to overlay (#18698)
Previously grid sidebar could be partially hidden by "overflow: hidden" of an ancestor component. Now it's in an overlay and the hierarchy doesn't affect it. Grid tests were also updated for new DOM structure. Change-Id: Ic5fb125d9c097be0f0141c121dfe74d30e650dd0
Diffstat (limited to 'client/src')
-rw-r--r--client/src/com/vaadin/client/widgets/Grid.java76
1 files changed, 42 insertions, 34 deletions
diff --git a/client/src/com/vaadin/client/widgets/Grid.java b/client/src/com/vaadin/client/widgets/Grid.java
index c25f2e5942..81d8929ecf 100644
--- a/client/src/com/vaadin/client/widgets/Grid.java
+++ b/client/src/com/vaadin/client/widgets/Grid.java
@@ -54,6 +54,8 @@ import com.google.gwt.event.dom.client.KeyDownEvent;
import com.google.gwt.event.dom.client.KeyDownHandler;
import com.google.gwt.event.dom.client.KeyEvent;
import com.google.gwt.event.dom.client.MouseEvent;
+import com.google.gwt.event.logical.shared.CloseEvent;
+import com.google.gwt.event.logical.shared.CloseHandler;
import com.google.gwt.event.logical.shared.ValueChangeEvent;
import com.google.gwt.event.logical.shared.ValueChangeHandler;
import com.google.gwt.event.shared.HandlerRegistration;
@@ -71,6 +73,7 @@ import com.google.gwt.user.client.ui.HasEnabled;
import com.google.gwt.user.client.ui.HasWidgets;
import com.google.gwt.user.client.ui.MenuBar;
import com.google.gwt.user.client.ui.MenuItem;
+import com.google.gwt.user.client.ui.PopupPanel;
import com.google.gwt.user.client.ui.ResizeComposite;
import com.google.gwt.user.client.ui.Widget;
import com.vaadin.client.BrowserInfo;
@@ -85,6 +88,7 @@ import com.vaadin.client.renderers.Renderer;
import com.vaadin.client.renderers.WidgetRenderer;
import com.vaadin.client.ui.FocusUtil;
import com.vaadin.client.ui.SubPartAware;
+import com.vaadin.client.ui.VOverlay;
import com.vaadin.client.ui.dd.DragAndDropHandler;
import com.vaadin.client.ui.dd.DragAndDropHandler.DragAndDropCallback;
import com.vaadin.client.ui.dd.DragHandle;
@@ -3579,25 +3583,7 @@ public class Grid<T> extends ResizeComposite implements
private final Grid<?> grid;
- private NativePreviewHandler clickOutsideToCloseHandler = new NativePreviewHandler() {
-
- @Override
- public void onPreviewNativeEvent(NativePreviewEvent event) {
- if (event.getTypeInt() != Event.ONMOUSEDOWN) {
- return;
- }
-
- // Click outside the panel
- EventTarget clickTarget = event.getNativeEvent()
- .getEventTarget();
- if (!rootContainer.getElement().isOrHasChild(
- Element.as(clickTarget))) {
- close();
- }
- }
- };
-
- private HandlerRegistration clickOutsideToCloseHandlerRegistration;
+ private VOverlay overlay;
private Sidebar(Grid<?> grid) {
this.grid = grid;
@@ -3624,6 +3610,8 @@ public class Grid<T> extends ResizeComposite implements
}
};
+ createOverlay();
+
menuBar = new MenuBar(true) {
@Override
@@ -3684,6 +3672,25 @@ public class Grid<T> extends ResizeComposite implements
}
/**
+ * Creates and initializes the overlay.
+ */
+ private void createOverlay() {
+ overlay = GWT.create(VOverlay.class);
+ overlay.setAutoHideEnabled(true);
+ overlay.setOwner(grid);
+ overlay.addStyleDependentName("popup");
+ overlay.add(content);
+ overlay.addAutoHidePartner(rootContainer.getElement());
+ overlay.addCloseHandler(new CloseHandler<PopupPanel>() {
+ @Override
+ public void onClose(CloseEvent<PopupPanel> event) {
+ removeStyleName("open");
+ addStyleName("closed");
+ }
+ });
+ }
+
+ /**
* Opens the sidebar if not yet opened. Opening the sidebar has no
* effect if it is empty.
*/
@@ -3691,9 +3698,7 @@ public class Grid<T> extends ResizeComposite implements
if (!isOpen() && isInDOM()) {
addStyleName("open");
removeStyleName("closed");
- rootContainer.add(content);
- clickOutsideToCloseHandlerRegistration = Event
- .addNativePreviewHandler(clickOutsideToCloseHandler);
+ overlay.showRelativeTo(rootContainer);
}
}
@@ -3701,17 +3706,7 @@ public class Grid<T> extends ResizeComposite implements
* Closes the sidebar if not yet closed.
*/
public void close() {
- if (isOpen()) {
- removeStyleName("open");
- addStyleName("closed");
- content.removeFromParent();
- // adjust open button to header height when closed
- setHeightToHeaderCellHeight();
- if (clickOutsideToCloseHandlerRegistration != null) {
- clickOutsideToCloseHandlerRegistration.removeHandler();
- clickOutsideToCloseHandlerRegistration = null;
- }
- }
+ overlay.hide();
}
/**
@@ -3720,12 +3715,13 @@ public class Grid<T> extends ResizeComposite implements
* @return <code>true</code> if open, <code>false</code> if not
*/
public boolean isOpen() {
- return content != null && content.getParent() == rootContainer;
+ return overlay != null && overlay.isShowing();
}
@Override
public void setStylePrimaryName(String styleName) {
super.setStylePrimaryName(styleName);
+ overlay.setStylePrimaryName(styleName);
content.setStylePrimaryName(styleName + "-content");
openCloseButton.setStylePrimaryName(styleName + "-button");
if (isOpen()) {
@@ -3737,6 +3733,18 @@ public class Grid<T> extends ResizeComposite implements
}
}
+ @Override
+ public void addStyleName(String style) {
+ super.addStyleName(style);
+ overlay.addStyleName(style);
+ }
+
+ @Override
+ public void removeStyleName(String style) {
+ super.removeStyleName(style);
+ overlay.removeStyleName(style);
+ }
+
private void setHeightToHeaderCellHeight() {
RowContainer header = grid.escalator.getHeader();
if (header.getRowCount() == 0