Announcement

Collapse
No announcement yet.
X
  • Filter
  • Time
Clear All
new posts

    Drag And Drop Contents To Non GWT IFrame from TreeGrid

    Hi,

    I am trying to find a solution to enable drag and drop from a GWT TreeGrid to a non GWT pure HTML and JS IFrame. As a short test I made a HTML Portlet showing a simple HTML Dropzone (https://www.sitepoint.com/html5-file-drag-and-drop/). When I drag a record from the TreeGrid to the DropZone no event is triggered on the IFRAME side.

    Is there a way to support such a behaviour? What configurations do I have to make to my TreeGrid to Enable such kind of Drag and Drop? If it can work, how does the Object look like, which will be dropped on the IFrame side?

    Thank you
    Martin
    Last edited by Martin00001; 13 Apr 2017, 06:22.

    #2
    You need to use a native (HTML5) drag to get drop events in another frame or window. See canvas.useNativeDrag and the linked sample.

    Comment


      #3
      Hi,

      Thanks for your response.

      I tried to adop the Native Drag and Drop Create Example to Drag a canvas to a non GWT Div. In my test window I copied the DragPiece Code from the sample and added a HtmlPane with a test iframe. In order to test the iframe functionality I added a sample image. When I drop the sample w3c image to the div the JavaScript drop function gets triggered and everythin works. When I drop the cubes to the div nothing happens. Do you have any idea why this is not working?

      I tried setting the z-index of the dropzone div to a higher value then the the z-index of the cubes, but it had no effect.

      My GWT and html code look as follows.

      Test Window
      Code:
      /**
       * 
       */
      package at.invaris.ta.client.gwt.panel.dragdrop;
      
      import java.util.HashMap;
      import java.util.Map;
      
      import at.invaris.commons.gwt.window.GwtWindow;
      
      import com.smartgwt.client.types.Alignment;
      import com.smartgwt.client.types.ContentsType;
      import com.smartgwt.client.types.Cursor;
      import com.smartgwt.client.types.DragAppearance;
      import com.smartgwt.client.util.EventHandler;
      import com.smartgwt.client.widgets.Canvas;
      import com.smartgwt.client.widgets.HTMLPane;
      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.layout.HStack;
      import com.smartgwt.client.widgets.layout.VLayout;
      
      public class TADragDropTestPanel extends GwtWindow {
      
          private final VLayout vLayout = new VLayout();
      
          private final HTMLPane html5Pane;
      
          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",
                              "");
          }
      
          public TADragDropTestPanel() {
              this.setShowHeader(false);
      
              setWidth100();
              setHeight100();
      
              vLayout.setWidth100();
      
              html5Pane = new HTMLPane();
              html5Pane.setContentsURL("http://localhost:8087/html5fileupload/");
              html5Pane.setContentsType(ContentsType.PAGE);
              html5Pane.setCanAcceptDrop(true);
      
              html5Pane.setHeight100();
              html5Pane.setWidth100();
      
              // html5Pane.setZIndex(900000);
      
              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"));
      
              vLayout.addMember(piecesLayout);
      
              vLayout.addMember(html5Pane);
              addItem(vLayout);
          }
      
          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(
                              @SuppressWarnings("unused") 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;
              }
          }
      
      }
      Test html
      Code:
      <!DOCTYPE html>
      <html lang="en">
          <head>
              <meta charset="UTF-8" />
              <title>HTML5 File Drag &amp; Drop API</title>
              <!-- <link rel="stylesheet" type="text/css" media="all" href="styles.css" /> -->
              <style>
                  #div1 {
                      width: 350px;
                      height: 70px;
                      padding: 10px;
                      border: 1px solid #aaaaaa;
                  }
              </style>
              <script>
                  function allowDrop(ev) {
                      ev.preventDefault();
                  }
      
                  function drag(ev) {
                      ev.dataTransfer.setData("text", ev.target.id);
                  }
      
                  function drop(ev) {
                      ev.preventDefault();
                      var data = ev.dataTransfer.getData("text");
                      ev.target.appendChild(document.getElementById(data));
                  }
              </script>
          </head>
          <body>        
              <p>Drag the W3Schools image into the rectangle:</p>
              
              <div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)"></div>
              <br>
              <img id="drag1" src="https://www.w3schools.com/html/img_logo.gif" draggable="true" ondragstart="drag(event)" width="336" height="69">
          </body>
      </html>

      Comment


        #4
        What browser are you testing in? As the docs tell you, cross-frame drags can't be done in IE due to browser limitations. (always post this).

        What are the contents of the Developer Console (this also is always required when posting).

        You've also forgotten to say what product and version you're using (again always required).

        Finally, are you getting any events or nothing at all?

        Comment


          #5
          I mainly test in Chrome ([FONT=Segoe UI, Tahoma, sans-serif][COLOR=#303942]Version [/COLOR][/FONT]57.0.2987.133), I also tried with Firefox (Version 50.1.0).

          In both browsers no event is fired on the test html side. The onDragStart event is fired on the GWT side and looks good.

          I activated Drag and Drop Debug Logging in the developer console and got following log messages.

          08:24:23.489:MDN3:INFO:dragDrop:target is draggable with dragOperation: drag, dragTarget is : [Img ID:isc_TADragDropTestPanel_DragPiece_1]
          08:24:23.527:dragstart9:INFO:dragDrop:Started dragOperation: drag with dragTarget: [Img ID:isc_TADragDropTestPanel_DragPiece_1] dragAppearance: none
          08:24:23.615:dragover2:DEBUG:dragDrop:New drop target: [HTMLPane ID:isc_HTMLPane_0]
          08:24:24.118:drop8:INFO:dragDrop:end of drag interaction

          Our SmartGWT version is 6.0p (Tue Feb 28 12:52:00 GMT+100 2017) and GWT Version 2.6

          Thank your for your help

          Comment


            #6
            So what's happening here is that an HTMLPane that contains an iframe will automatically be masked during dragging, in order to prevent the iframe from swallowing events and ruining the drag (which is a concern with a normal drag).

            The simplest way to get around this would be to switch to using a Canvas, and write your own getInnerHTML() override to return an <iframe> element. Then automatic masking will not kick in.

            Comment


              #7
              We've fixed SGWT 6.0p and newer releases so that you can call Canvas.setUseDragMask(false) on the HTMLPane to resolve this issue. The change will be in the nightly builds dated 2017-05-02 and beyond.

              Comment


                #8
                Thank you, iIwill try it.

                Comment

                Working...
                X