summaryrefslogtreecommitdiffstats
path: root/src/com/vaadin/ui/DragAndDropWrapper.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/vaadin/ui/DragAndDropWrapper.java')
-rw-r--r--src/com/vaadin/ui/DragAndDropWrapper.java84
1 files changed, 67 insertions, 17 deletions
diff --git a/src/com/vaadin/ui/DragAndDropWrapper.java b/src/com/vaadin/ui/DragAndDropWrapper.java
index 3274b60b47..a848d7af40 100644
--- a/src/com/vaadin/ui/DragAndDropWrapper.java
+++ b/src/com/vaadin/ui/DragAndDropWrapper.java
@@ -3,8 +3,11 @@
*/
package com.vaadin.ui;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.OutputStream;
+import java.util.HashMap;
import java.util.Map;
-import java.util.Set;
import com.vaadin.event.Transferable;
import com.vaadin.event.TransferableImpl;
@@ -15,10 +18,13 @@ import com.vaadin.event.dd.DropTargetDetails;
import com.vaadin.event.dd.DropTargetDetailsImpl;
import com.vaadin.terminal.PaintException;
import com.vaadin.terminal.PaintTarget;
+import com.vaadin.terminal.UploadStream;
import com.vaadin.terminal.gwt.client.MouseEventDetails;
import com.vaadin.terminal.gwt.client.ui.VDragAndDropWrapper;
import com.vaadin.terminal.gwt.client.ui.dd.HorizontalDropLocation;
import com.vaadin.terminal.gwt.client.ui.dd.VerticalDropLocation;
+import com.vaadin.terminal.gwt.server.AbstractApplicationServlet;
+import com.vaadin.ui.DragAndDropWrapper.WrapperTransferable.Html5File;
import com.vaadin.ui.Upload.Receiver;
@ClientWidget(VDragAndDropWrapper.class)
@@ -27,9 +33,24 @@ public class DragAndDropWrapper extends CustomComponent implements DropTarget,
public class WrapperTransferable extends TransferableImpl {
+ private Html5File[] files;
+
public WrapperTransferable(Component sourceComponent,
Map<String, Object> rawVariables) {
super(sourceComponent, rawVariables);
+ Integer fc = (Integer) rawVariables.get("filecount");
+ if (fc != null) {
+ files = new Html5File[fc];
+ for (int i = 0; i < fc; i++) {
+ Html5File file = new Html5File();
+ String id = (String) rawVariables.get("fi" + i);
+ file.name = (String) rawVariables.get("fn" + i);
+ file.size = (Integer) rawVariables.get("fs" + i);
+ file.type = (String) rawVariables.get("ft" + i);
+ files[i] = file;
+ receivers.put(id, file);
+ }
+ }
}
/**
@@ -51,21 +72,28 @@ public class DragAndDropWrapper extends CustomComponent implements DropTarget,
}
public Html5File[] getFiles() {
- // TODO Auto-generated method stub
- return null;
+ return files;
}
public class Html5File {
+ public String name;
+ private String id;
+ private int size;
+ private Receiver receiver;
+ private String type;
+
public String getFileName() {
- // TODO Auto-generated method stub
- return null;
+ return name;
+ }
+
+ public int getFileSize() {
+ return size;
}
- // public int getFileSize() {
- // // TODO Auto-generated method stub
- // return 0;
- // }
+ public String getType() {
+ return type;
+ }
/**
* HTML5 drags are read from client disk with a callback. This and
@@ -77,14 +105,15 @@ public class DragAndDropWrapper extends CustomComponent implements DropTarget,
* implementation writes the file contents as it arrives.
*/
public void receive(Receiver receiver) {
- // TODO Auto-generated method stub
-
+ this.receiver = receiver;
}
}
}
+ private Map<String, Html5File> receivers = new HashMap<String, Html5File>();
+
public class WrapperDropDetails extends DropTargetDetailsImpl {
/**
@@ -195,13 +224,34 @@ public class DragAndDropWrapper extends CustomComponent implements DropTarget,
return dragStartMode;
}
- @Override
- public void changeVariables(Object source, Map<String, Object> variables) {
- super.changeVariables(source, variables);
+ /**
+ * This method should only be used by Vaadin terminal implementation. This
+ * is not end user api.
+ *
+ * TODO should fire progress events + end/succes events like upload
+ *
+ * @param upstream
+ * @param fileId
+ */
+ public void receiveFile(UploadStream upstream, String fileId) {
+ Html5File file = receivers.get(fileId);
+ if (file != null && file.receiver != null) {
+ OutputStream receiveUpload = file.receiver.receiveUpload(file
+ .getFileName(), "TODO");
+
+ InputStream stream = upstream.getStream();
+ byte[] buf = new byte[AbstractApplicationServlet.MAX_BUFFER_SIZE];
+ int bytesRead;
+ try {
+ while ((bytesRead = stream.read(buf)) != -1) {
+ receiveUpload.write(buf, 0, bytesRead);
+ }
+ } catch (IOException e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ }
- Set<String> keySet = variables.keySet();
- for (String string : keySet) {
- // TODO get files
}
+
}
}