Skip to content

Commit

Permalink
Make it possible to set a Resource as drag image (#9088)
Browse files Browse the repository at this point in the history
Fixes #8892

Note that IE and Edge are not covered by this change - see #8977
  • Loading branch information
wbadam authored and hesara committed Apr 25, 2017
1 parent bb46fff commit d0a8608
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,11 @@
import com.google.gwt.dom.client.DataTransfer;
import com.google.gwt.dom.client.Element;
import com.google.gwt.dom.client.NativeEvent;
import com.google.gwt.user.client.ui.Image;
import com.google.gwt.user.client.ui.Widget;
import com.vaadin.client.ComponentConnector;
import com.vaadin.client.ServerConnector;
import com.vaadin.client.annotations.OnStateChange;
import com.vaadin.event.dnd.DragSourceExtension;
import com.vaadin.shared.ui.Connect;
import com.vaadin.shared.ui.dnd.DragSourceRpc;
Expand Down Expand Up @@ -118,6 +120,15 @@ public void onUnregister() {
removeDragListeners(dragSource);
}

@OnStateChange("resources")
private void prefetchDragImage() {
String dragImageUrl = getResourceUrl(
DragSourceState.RESOURCE_DRAG_IMAGE);
if (dragImageUrl != null && !dragImageUrl.isEmpty()) {
Image.prefetch(getConnection().translateVaadinUri(dragImageUrl));
}
}

/**
* Event handler for the {@code dragstart} event. Called when {@code
* dragstart} event occurs.
Expand All @@ -135,6 +146,9 @@ protected void onDragStart(Event event) {
getState().effectAllowed.getValue());
}

// Set drag image
setDragImage(event);

// Set text data parameter
nativeEvent.getDataTransfer().setData(DragSourceState.DATA_TYPE_TEXT,
createDataTransferText(event));
Expand Down Expand Up @@ -174,6 +188,22 @@ protected void sendDragStartEventToServer(Event dragStartEvent) {
getRpcProxy(DragSourceRpc.class).dragStart();
}

/**
* Sets the drag image to be displayed.
*
* @param dragStartEvent
* The drag start event.
*/
protected void setDragImage(Event dragStartEvent) {
String imageUrl = getResourceUrl(DragSourceState.RESOURCE_DRAG_IMAGE);
if (imageUrl != null && !imageUrl.isEmpty()) {
Image dragImage = new Image(
getConnection().translateVaadinUri(imageUrl));
((NativeEvent) dragStartEvent).getDataTransfer()
.setDragImage(dragImage.getElement(), 0, 0);
}
}

/**
* Event handler for the {@code dragend} event. Called when {@code dragend}
* event occurs.
Expand Down
11 changes: 11 additions & 0 deletions server/src/main/java/com/vaadin/event/dnd/DragSourceExtension.java
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
import java.util.Objects;

import com.vaadin.server.AbstractExtension;
import com.vaadin.server.Resource;
import com.vaadin.shared.Registration;
import com.vaadin.shared.ui.dnd.DragSourceRpc;
import com.vaadin.shared.ui.dnd.DragSourceState;
Expand Down Expand Up @@ -220,6 +221,16 @@ public Registration addDragEndListener(DragEndListener<T> listener) {
listener, DragEndListener.DRAGEND_METHOD);
}

/**
* Set a custom drag image for the current drag source.
*
* @param imageResource
* Resource of the image to be displayed as drag image.
*/
public void setDragImage(Resource imageResource) {
setResource(DragSourceState.RESOURCE_DRAG_IMAGE, imageResource);
}

@Override
protected DragSourceState getState() {
return (DragSourceState) super.getState();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,8 @@ public class DragSourceState extends SharedState {
*/
public static final String DATA_TYPE_TEXT = "text";

public static final String RESOURCE_DRAG_IMAGE = "drag-image";

/**
* {@code DataTransfer.effectAllowed} parameter for the drag event.
*/
Expand Down

0 comments on commit d0a8608

Please sign in to comment.