package com.smartgwt.sample.showcase.client.effects.dragdrop; import java.util.HashMap; import java.util.Map; import com.smartgwt.client.types.Alignment; import com.smartgwt.client.types.Cursor; import com.smartgwt.client.types.DragAppearance; import com.smartgwt.client.types.Overflow; import com.smartgwt.client.util.EventHandler; import com.smartgwt.client.util.FileLoader; import com.smartgwt.client.widgets.Canvas; import com.smartgwt.client.widgets.Img; import com.smartgwt.client.widgets.events.DragStartEvent; import com.smartgwt.client.widgets.events.DragStartHandler; import com.smartgwt.client.widgets.events.DropEvent; import com.smartgwt.client.widgets.events.DropHandler; import com.smartgwt.client.widgets.events.DropOutEvent; import com.smartgwt.client.widgets.events.DropOutHandler; import com.smartgwt.client.widgets.events.DropOverEvent; import com.smartgwt.client.widgets.events.DropOverHandler; import com.smartgwt.client.widgets.events.ShowContextMenuEvent; import com.smartgwt.client.widgets.events.ShowContextMenuHandler; import com.smartgwt.client.widgets.layout.HStack; import com.smartgwt.client.widgets.layout.VStack; import com.smartgwt.sample.showcase.client.PanelFactory; import com.smartgwt.sample.showcase.client.ShowcasePanel; public class NativeDragCreateSample extends ShowcasePanel { private static final String DESCRIPTION = "Drag the large cubes into the boxes to create new small cubes. " + "The blue, yellow, and green boxes accept cubes with the same color only. The gray box accepts any color." + "<p>" + "Try opening this sample in two different tabs or browser windows and dragging a cube from one window to the drop boxes of the other."; public static class Factory implements PanelFactory { private String id; public ShowcasePanel create() { final NativeDragCreateSample panel = new NativeDragCreateSample(); id = panel.getID(); return panel; } public String getID() { return id; } public String getDescription() { return DESCRIPTION; } } public static final Map<String, String> DRAG_TRACKER_IMAGE_URLS = new HashMap<String, String>(); static { DRAG_TRACKER_IMAGE_URLS.put("b", ""); DRAG_TRACKER_IMAGE_URLS.put("y", ""); DRAG_TRACKER_IMAGE_URLS.put("g", ""); } private static final class DragPiece extends Img { public DragPiece(String src, String dragType) { setWidth(48); setHeight(48); setCursor(Cursor.MOVE); setAppImgDir("pieces/48/"); setSrc(src); setCanDrag(true); setUseNativeDrag(true); setDragType(dragType); setCanDrop(true); setDragAppearance(DragAppearance.TRACKER); addDragStartHandler(new DragStartHandler() { @Override public void onDragStart(DragStartEvent event) { final String src = getSrc(); EventHandler.setNativeDragData(src, src); final double pageTop = getPageTop(), pageLeft = getPageLeft(), x = EventHandler.getX(), y = EventHandler.getY(); EventHandler.setDragTrackerImage(DRAG_TRACKER_IMAGE_URLS.get(getDragType()), (int)(5.0 + (x - pageLeft) / getWidth() * 38.0), (int)(5.0 + (y - pageTop) / getHeight() * 38.0)); } }); } @Override protected boolean setDragTracker() { EventHandler.setDragTracker(Canvas.imgHTML("pieces/24/" + getSrc(), 24, 24), 24, 24, 15, 15); return false; } } private static final class DroppedPiece extends Img { public DroppedPiece(String src, int left, int top) { setWidth(24); setHeight(24); setLeft(left); setTop(top); setAppImgDir("pieces/24/"); setSrc(src); setCanDragReposition(true); setKeepInParentRect(true); setDragAppearance(DragAppearance.TARGET); addShowContextMenuHandler(new ShowContextMenuHandler() { public void onShowContextMenu(ShowContextMenuEvent event) { DroppedPiece.this.destroy(); event.cancel(); } }); } } private static final class PieceBin extends Canvas { public PieceBin(String edgeImage, String... dropTypes) { setWidth(100); setHeight(100); setBackgroundColor("White"); setOverflow(Overflow.HIDDEN); setShowEdges(true); setEdgeSize(6); setEdgeImage(edgeImage); setCanAcceptDrop(true); setDropTypes(dropTypes); addShowContextMenuHandler(new ShowContextMenuHandler() { public void onShowContextMenu(ShowContextMenuEvent event) { event.cancel(); } }); addDropOverHandler(new DropOverHandler() { @Override public void onDropOver(DropOverEvent event) { if (PieceBin.this.willAcceptDrop()) { PieceBin.this.setBackgroundColor("LightGray"); } } }); addDropOutHandler(new DropOutHandler() { @Override public void onDropOut(DropOutEvent event) { PieceBin.this.setBackgroundColor("White"); } }); addDropHandler(new DropHandler() { @Override public void onDrop(DropEvent event) { String src = (String)EventHandler.getNativeDragData(); if (src == null) { // The native drag data might be null because the browser does not support // HTML5 drag and drop. final Canvas dragTarget = EventHandler.getDragTarget(); if (!(dragTarget instanceof Img)) { event.cancel(); return; } src = ((Img)dragTarget).getSrc(); } final int edgeSize = PieceBin.this.getEdgeSize(); PieceBin.this.addChild(new DroppedPiece(src, PieceBin.this.getOffsetX() - 15 - edgeSize, PieceBin.this.getOffsetY() - 15 - edgeSize)); } }); } } @Override public Canvas getViewPanel() { FileLoader.cacheImgs(getSkinImgDir(), DRAG_TRACKER_IMAGE_URLS.values()); final HStack piecesLayout = new HStack(40); piecesLayout.setLayoutMargin(20); piecesLayout.setLayoutAlign(Alignment.CENTER); piecesLayout.setMembers(new DragPiece("cube_blue.png", "b"), new DragPiece("cube_yellow.png", "y"), new DragPiece("cube_green.png", "g")); final HStack binsLayout = new HStack(20); binsLayout.setMembers(new PieceBin("edges/blue/6.png", "b"), new PieceBin("edges/yellow/6.png", "y"), new PieceBin("edges/green/6.png", "g"), new PieceBin("edges/gray/6.png", "b","y","g")); final VStack mainLayout = new VStack(); mainLayout.setMembers(piecesLayout, binsLayout); return mainLayout; } public String getIntro() { return DESCRIPTION; } protected boolean isTopIntro() { return true; } }