summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHenrik Paul <henrik@vaadin.com>2015-02-23 12:07:13 +0200
committerVaadin Code Review <review@vaadin.com>2015-02-23 11:01:14 +0000
commit04b87d89360fa9b62dc10f9d399eef07d2491d50 (patch)
tree03b3498deca6dece20a5fd98c7c3ddf5c017ae73
parentbe86d0238efcab3fd36ef44b2c1db4b46589fa82 (diff)
downloadvaadin-framework-04b87d89360fa9b62dc10f9d399eef07d2491d50.tar.gz
vaadin-framework-04b87d89360fa9b62dc10f9d399eef07d2491d50.zip
Fixes a graphical scrollbar glitch in Grid + some OSX configurations + Valo (#16565)
Change-Id: I8eb8bb2d941fc88b9f896c8d351ada6286e8322d
-rw-r--r--client/src/com/vaadin/client/widget/escalator/ScrollbarBundle.java7
1 files changed, 6 insertions, 1 deletions
diff --git a/client/src/com/vaadin/client/widget/escalator/ScrollbarBundle.java b/client/src/com/vaadin/client/widget/escalator/ScrollbarBundle.java
index ef8713b82f..e4924e9509 100644
--- a/client/src/com/vaadin/client/widget/escalator/ScrollbarBundle.java
+++ b/client/src/com/vaadin/client/widget/escalator/ScrollbarBundle.java
@@ -22,6 +22,7 @@ import com.google.gwt.dom.client.Element;
import com.google.gwt.dom.client.Style.Display;
import com.google.gwt.dom.client.Style.Overflow;
import com.google.gwt.dom.client.Style.Unit;
+import com.google.gwt.dom.client.Style.Visibility;
import com.google.gwt.event.shared.EventHandler;
import com.google.gwt.event.shared.GwtEvent;
import com.google.gwt.event.shared.HandlerManager;
@@ -103,18 +104,20 @@ public abstract class ScrollbarBundle implements DeferredWorker {
VERTICAL, HORIZONTAL;
}
- private class TemporaryResizer extends Object {
+ private class TemporaryResizer {
private static final int TEMPORARY_RESIZE_DELAY = 1000;
private final Timer timer = new Timer() {
@Override
public void run() {
internalSetScrollbarThickness(1);
+ root.getStyle().setVisibility(Visibility.HIDDEN);
}
};
public void show() {
internalSetScrollbarThickness(OSX_INVISIBLE_SCROLLBAR_FAKE_SIZE_PX);
+ root.getStyle().setVisibility(Visibility.VISIBLE);
timer.schedule(TEMPORARY_RESIZE_DELAY);
}
}
@@ -666,9 +669,11 @@ public abstract class ScrollbarBundle implements DeferredWorker {
invisibleScrollbarTemporaryResizer.show();
}
});
+ root.getStyle().setVisibility(Visibility.HIDDEN);
} else {
Event.sinkEvents(root, 0);
Event.setEventListener(root, null);
+ root.getStyle().clearVisibility();
}
internalSetScrollbarThickness(Math.max(1d, px));