summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPekka Hyvönen <pekka@vaadin.com>2017-05-15 11:56:10 +0300
committerGitHub <noreply@github.com>2017-05-15 11:56:10 +0300
commit88b84533e099ae9b3cbc75c449675934482026a6 (patch)
treebfbe090b0437d0c29420887c4a97c0a3024a2df5
parent6cfd4ed55a1f8e5defa6ef42e6c666966aca584b (diff)
downloadvaadin-framework-88b84533e099ae9b3cbc75c449675934482026a6.tar.gz
vaadin-framework-88b84533e099ae9b3cbc75c449675934482026a6.zip
Distinguish between touch scroll and drag start on Grid (#9315)
* Set touch scroll timeout for Grid on GridDragSource
-rw-r--r--client/src/main/java/com/vaadin/client/connectors/grid/GridDragSourceConnector.java43
1 files changed, 40 insertions, 3 deletions
diff --git a/client/src/main/java/com/vaadin/client/connectors/grid/GridDragSourceConnector.java b/client/src/main/java/com/vaadin/client/connectors/grid/GridDragSourceConnector.java
index 39af55515b..175383af87 100644
--- a/client/src/main/java/com/vaadin/client/connectors/grid/GridDragSourceConnector.java
+++ b/client/src/main/java/com/vaadin/client/connectors/grid/GridDragSourceConnector.java
@@ -60,6 +60,18 @@ import elemental.json.JsonObject;
@Connect(GridDragSource.class)
public class GridDragSourceConnector extends DragSourceExtensionConnector {
+ /**
+ * Delay used to distinct between scroll and drag start in grid: if the user
+ * doens't move the finger before this "timeout", it should be considered as
+ * a drag start.
+ * <p>
+ * This default value originates from VScrollTable which uses it to
+ * distinguish between scroll and context click (long tap).
+ *
+ * @see Escalator#setDelayToCancelTouchScroll(double)
+ */
+ private static final int TOUCH_SCROLL_TIMEOUT_DELAY = 500;
+
private static final String STYLE_SUFFIX_DRAG_BADGE = "-drag-badge";
private GridConnector gridConnector;
@@ -69,14 +81,23 @@ public class GridDragSourceConnector extends DragSourceExtensionConnector {
*/
private List<String> draggedItemKeys;
+ private boolean touchScrollDelayUsed;
+
@Override
protected void extend(ServerConnector target) {
gridConnector = (GridConnector) target;
// HTML5 DnD is by default not enabled for mobile devices
- if (BrowserInfo.get().isTouchDevice() && !getConnection()
- .getUIConnector().isMobileHTML5DndEnabled()) {
- return;
+ if (BrowserInfo.get().isTouchDevice()) {
+ if (getConnection().getUIConnector().isMobileHTML5DndEnabled()) {
+ // distinct between scroll and drag start
+ gridConnector.getWidget().getEscalator()
+ .setDelayToCancelTouchScroll(
+ TOUCH_SCROLL_TIMEOUT_DELAY);
+ touchScrollDelayUsed = true;
+ } else {
+ return;
+ }
}
// Set newly added rows draggable
@@ -85,12 +106,22 @@ public class GridDragSourceConnector extends DragSourceExtensionConnector {
// Add drag listeners to body element
addDragListeners(getGridBody().getElement());
+
+ gridConnector.onDragSourceAttached();
}
@Override
protected void onDragStart(Event event) {
NativeEvent nativeEvent = (NativeEvent) event;
+ // Make sure user is not actually scrolling
+ if (touchScrollDelayUsed && gridConnector.getWidget().getEscalator()
+ .isTouchScrolling()) {
+ event.preventDefault();
+ event.stopPropagation();
+ return;
+ }
+
// Do not allow drag starts from native Android Chrome, since it doesn't
// work properly (doesn't fire dragend reliably)
if (isAndoidChrome() && isNativeDragEvent(nativeEvent)) {
@@ -320,6 +351,12 @@ public class GridDragSourceConnector extends DragSourceExtensionConnector {
// Remove callback for newly added rows
getGridBody().setNewEscalatorRowCallback(null);
+
+ if (touchScrollDelayUsed) {
+ gridConnector.getWidget().getEscalator()
+ .setDelayToCancelTouchScroll(-1);
+ touchScrollDelayUsed = false;
+ }
}
private Grid<JsonObject> getGrid() {