diff options
3 files changed, 28 insertions, 13 deletions
diff --git a/client/src/main/java/com/vaadin/client/extensions/FileDropTargetConnector.java b/client/src/main/java/com/vaadin/client/extensions/FileDropTargetConnector.java index f496e90d7f..df236b6072 100644 --- a/client/src/main/java/com/vaadin/client/extensions/FileDropTargetConnector.java +++ b/client/src/main/java/com/vaadin/client/extensions/FileDropTargetConnector.java @@ -90,6 +90,8 @@ public class FileDropTargetConnector extends DropTargetExtensionConnector { FileUploadXHR xhr = (FileUploadXHR) FileUploadXHR.create(); xhr.setOnReadyStateChange(xmlHttpRequest -> { if (xmlHttpRequest.getReadyState() == XMLHttpRequest.DONE) { + // Poll server for changes + getRpcProxy(FileDropTargetRpc.class).poll(); uploading = false; uploadNextFile(); xmlHttpRequest.clearOnReadyStateChange(); diff --git a/server/src/main/java/com/vaadin/ui/FileDropTarget.java b/server/src/main/java/com/vaadin/ui/FileDropTarget.java index 654563dbd0..831d6723d9 100644 --- a/server/src/main/java/com/vaadin/ui/FileDropTarget.java +++ b/server/src/main/java/com/vaadin/ui/FileDropTarget.java @@ -30,6 +30,7 @@ import com.vaadin.shared.ApplicationConstants; import com.vaadin.shared.ui.dnd.FileDropTargetClientRpc; import com.vaadin.shared.ui.dnd.FileDropTargetRpc; import com.vaadin.shared.ui.dnd.FileDropTargetState; +import com.vaadin.shared.ui.dnd.FileParameters; /** * Extension to add drop target functionality to a widget for accepting and @@ -68,24 +69,31 @@ public class FileDropTarget<T extends AbstractComponent> extends protected void registerDropTargetRpc(T target) { super.registerDropTargetRpc(target); - registerRpc((FileDropTargetRpc) fileParams -> { + registerRpc(new FileDropTargetRpc() { + @Override + public void drop(Map<String, FileParameters> fileParams) { + List<Html5File> files = new ArrayList<>(); + Map<String, String> urls = new HashMap<>(); - List<Html5File> files = new ArrayList<>(); - Map<String, String> urls = new HashMap<>(); + fileParams.forEach((id, fileParameters) -> { + Html5File html5File = new Html5File(fileParameters.getName(), + fileParameters.getSize(), fileParameters.getMime()); + String url = createUrl(html5File, id); - fileParams.forEach((id, fileParameters) -> { - Html5File html5File = new Html5File(fileParameters.getName(), - fileParameters.getSize(), fileParameters.getMime()); - String url = createUrl(html5File, id); + files.add(html5File); + urls.put(id, url); + }); - files.add(html5File); - urls.put(id, url); - }); + getRpcProxy(FileDropTargetClientRpc.class).sendUploadUrl(urls); - getRpcProxy(FileDropTargetClientRpc.class).sendUploadUrl(urls); + FileDropEvent<T> event = new FileDropEvent<>(target, files); + fileDropHandler.drop(event); + } - FileDropEvent<T> event = new FileDropEvent<>(target, files); - fileDropHandler.drop(event); + @Override + public void poll() { + // Polling server for changes after upload finished + } }); } diff --git a/shared/src/main/java/com/vaadin/shared/ui/dnd/FileDropTargetRpc.java b/shared/src/main/java/com/vaadin/shared/ui/dnd/FileDropTargetRpc.java index fd290a41f5..521f3ec7e6 100644 --- a/shared/src/main/java/com/vaadin/shared/ui/dnd/FileDropTargetRpc.java +++ b/shared/src/main/java/com/vaadin/shared/ui/dnd/FileDropTargetRpc.java @@ -34,4 +34,9 @@ public interface FileDropTargetRpc extends ServerRpc { * Generated file IDs and file parameters of dropped files. */ public void drop(Map<String, FileParameters> fileParams); + + /** + * Called to poll the server for changes when the upload is complete. + */ + public void poll(); } |