From 8ff23ad10859132e5015f6372e623ed7ce8e05cc Mon Sep 17 00:00:00 2001 From: Adam Wagner Date: Wed, 7 Jun 2017 14:50:38 +0300 Subject: Add mouse event details to the drop event (#9485) Fixes #9483 --- .../com/vaadin/ui/components/grid/GridDropEvent.java | 9 +++++++-- .../com/vaadin/ui/components/grid/GridDropTarget.java | 5 +++-- .../java/com/vaadin/ui/dnd/DropTargetExtension.java | 19 +++++++++++++------ .../main/java/com/vaadin/ui/dnd/event/DropEvent.java | 19 ++++++++++++++++++- 4 files changed, 41 insertions(+), 11 deletions(-) (limited to 'server') diff --git a/server/src/main/java/com/vaadin/ui/components/grid/GridDropEvent.java b/server/src/main/java/com/vaadin/ui/components/grid/GridDropEvent.java index aa80cdc7b8..11d56713f8 100644 --- a/server/src/main/java/com/vaadin/ui/components/grid/GridDropEvent.java +++ b/server/src/main/java/com/vaadin/ui/components/grid/GridDropEvent.java @@ -18,6 +18,7 @@ package com.vaadin.ui.components.grid; import java.util.Map; import java.util.Optional; +import com.vaadin.shared.MouseEventDetails; import com.vaadin.shared.ui.dnd.DropEffect; import com.vaadin.shared.ui.grid.DropLocation; import com.vaadin.shared.ui.grid.DropMode; @@ -59,12 +60,16 @@ public class GridDropEvent extends DropEvent> { * on empty grid * @param dropLocation * Location of the drop within the target row. + * @param mouseEventDetails + * mouse event details object containing information about the + * drop event */ public GridDropEvent(Grid target, Map data, DropEffect dropEffect, DragSourceExtension dragSourceExtension, - T dropTargetRow, DropLocation dropLocation) { - super(target, data, dropEffect, dragSourceExtension); + T dropTargetRow, DropLocation dropLocation, + MouseEventDetails mouseEventDetails) { + super(target, data, dropEffect, dragSourceExtension, mouseEventDetails); this.dropTargetRow = dropTargetRow; this.dropLocation = dropLocation; diff --git a/server/src/main/java/com/vaadin/ui/components/grid/GridDropTarget.java b/server/src/main/java/com/vaadin/ui/components/grid/GridDropTarget.java index b86ca13080..342946d5c9 100644 --- a/server/src/main/java/com/vaadin/ui/components/grid/GridDropTarget.java +++ b/server/src/main/java/com/vaadin/ui/components/grid/GridDropTarget.java @@ -145,7 +145,7 @@ public class GridDropTarget extends DropTargetExtension> { @Override protected void registerDropTargetRpc() { registerRpc((GridDropTargetRpc) (types, data, dropEffect, rowKey, - dropLocation) -> { + dropLocation, mouseEventDetails) -> { // Create a linked map that preserves the order of types Map dataPreserveOrder = new LinkedHashMap<>(); @@ -157,7 +157,8 @@ public class GridDropTarget extends DropTargetExtension> { GridDropEvent event = new GridDropEvent<>(getParent(), dataPreserveOrder, DropEffect.valueOf(dropEffect.toUpperCase()), - getUI().getActiveDragSource(), dropTargetRow, dropLocation); + getUI().getActiveDragSource(), dropTargetRow, dropLocation, + mouseEventDetails); fireEvent(event); }); diff --git a/server/src/main/java/com/vaadin/ui/dnd/DropTargetExtension.java b/server/src/main/java/com/vaadin/ui/dnd/DropTargetExtension.java index fddb636f70..1f5c675b21 100644 --- a/server/src/main/java/com/vaadin/ui/dnd/DropTargetExtension.java +++ b/server/src/main/java/com/vaadin/ui/dnd/DropTargetExtension.java @@ -21,6 +21,7 @@ import java.util.Map; import java.util.Objects; import com.vaadin.server.AbstractExtension; +import com.vaadin.shared.MouseEventDetails; import com.vaadin.shared.Registration; import com.vaadin.shared.ui.dnd.DropEffect; import com.vaadin.shared.ui.dnd.DropTargetRpc; @@ -65,12 +66,15 @@ public class DropTargetExtension * Override this method if you need to have a custom RPC interface for * transmitting the drop event with more data. If just need to do additional * things before firing the drop event, then you should override - * {@link #onDrop(List, Map, DropEffect)} instead. + * {@link #onDrop(List, Map, DropEffect, MouseEventDetails)} instead. */ protected void registerDropTargetRpc() { - registerRpc((DropTargetRpc) (types, data, dropEffect) -> { - onDrop(types, data, DropEffect.valueOf(dropEffect.toUpperCase())); - }); + registerRpc( + (DropTargetRpc) (types, data, dropEffect, mouseEventDetails) -> { + onDrop(types, data, + DropEffect.valueOf(dropEffect.toUpperCase()), + mouseEventDetails); + }); } /** @@ -84,16 +88,19 @@ public class DropTargetExtension * DataTransfer} object. * @param dropEffect * the drop effect + * @param mouseEventDetails + * mouse event details object containing information about the drop + * event */ protected void onDrop(List types, Map data, - DropEffect dropEffect) { + DropEffect dropEffect, MouseEventDetails mouseEventDetails) { // Create a linked map that preserves the order of types Map dataPreserveOrder = new LinkedHashMap<>(); types.forEach(type -> dataPreserveOrder.put(type, data.get(type))); DropEvent event = new DropEvent<>(getParent(), dataPreserveOrder, - dropEffect, getUI().getActiveDragSource()); + dropEffect, getUI().getActiveDragSource(), mouseEventDetails); fireEvent(event); } diff --git a/server/src/main/java/com/vaadin/ui/dnd/event/DropEvent.java b/server/src/main/java/com/vaadin/ui/dnd/event/DropEvent.java index ed70e8265b..275498f320 100644 --- a/server/src/main/java/com/vaadin/ui/dnd/event/DropEvent.java +++ b/server/src/main/java/com/vaadin/ui/dnd/event/DropEvent.java @@ -18,6 +18,7 @@ package com.vaadin.ui.dnd.event; import java.util.Map; import java.util.Optional; +import com.vaadin.shared.MouseEventDetails; import com.vaadin.shared.ui.dnd.DragSourceState; import com.vaadin.shared.ui.dnd.DropEffect; import com.vaadin.ui.AbstractComponent; @@ -39,6 +40,7 @@ public class DropEvent extends Component.Event { private final DragSourceExtension dragSourceExtension; private final AbstractComponent dragSource; private final DropEffect dropEffect; + private final MouseEventDetails mouseEventDetails; /** * Creates a server side drop event. @@ -53,9 +55,13 @@ public class DropEvent extends Component.Event { * @param dragSourceExtension * Drag source extension of the component that initiated the drop * event. + * @param mouseEventDetails + * Mouse event details object containing information about the drop + * event */ public DropEvent(T target, Map data, DropEffect dropEffect, - DragSourceExtension dragSourceExtension) { + DragSourceExtension dragSourceExtension, + MouseEventDetails mouseEventDetails) { super(target); this.data = data; @@ -63,6 +69,7 @@ public class DropEvent extends Component.Event { this.dragSourceExtension = dragSourceExtension; this.dragSource = Optional.ofNullable(dragSourceExtension) .map(DragSourceExtension::getParent).orElse(null); + this.mouseEventDetails = mouseEventDetails; } /** @@ -164,6 +171,16 @@ public class DropEvent extends Component.Event { return getDragSourceExtension().map(DragSourceExtension::getDragData); } + /** + * Gets the mouse event details for the drop event. + * + * @return Mouse event details object containing information about the drop + * event. + */ + public MouseEventDetails getMouseEventDetails() { + return mouseEventDetails; + } + /** * Returns the drop target component where the drop event occurred. * -- cgit v1.2.3