X-Git-Url: https://code.grnet.gr/git/pithos/blobdiff_plain/023f6f1e5465d565189031ead1aaef7351476f73..9d937b3fca5a7e5e52f0d9a5d1fea2d2b8d345e3:/src/gr/ebs/gss/client/FileUploadGearsIEDialog.java diff --git a/src/gr/ebs/gss/client/FileUploadGearsIEDialog.java b/src/gr/ebs/gss/client/FileUploadGearsIEDialog.java index f0e98d9..9efc402 100644 --- a/src/gr/ebs/gss/client/FileUploadGearsIEDialog.java +++ b/src/gr/ebs/gss/client/FileUploadGearsIEDialog.java @@ -18,6 +18,8 @@ */ package gr.ebs.gss.client; +import java.util.List; + import gr.ebs.gss.client.rest.RestCommand; import com.google.gwt.gears.client.desktop.File; @@ -34,16 +36,16 @@ public class FileUploadGearsIEDialog extends FileUploadGearsDialog implements Up /** * Perform the HTTP request to upload the specified file. - */ + */ @Override - protected void doSend(final File file, final int index) { + protected void doSend(final List filesRemaining) { final GSS app = GSS.get(); HttpRequest request = factory.createHttpRequest(); requests.add(request); String method = "POST"; String path; - final String filename = getFilename(file.getName()); + final String filename = getFilename(filesRemaining.get(0).getName()); path = folder.getUri(); if (!path.endsWith("/")) path = path + "/"; @@ -62,18 +64,23 @@ public class FileUploadGearsIEDialog extends FileUploadGearsDialog implements Up public void onResponseReceived(HttpRequest req) { // XXX: No error checking, since IE throws an Internal Error // when accessing req.getStatus(). - selectedFiles.remove(file); - finish(); + filesRemaining.remove(0); + if(filesRemaining.isEmpty()){ + finish(); + } + doSend(filesRemaining); } }); request.getUpload().setProgressHandler(new ProgressHandler() { @Override public void onProgress(ProgressEvent event) { double pcnt = (double) event.getLoaded() / event.getTotal(); - progressBars.get(index).setProgress((int) Math.floor(pcnt * 100)); + progressBars.get(0).setProgress((int) Math.floor(pcnt * 100)); + if(pcnt*100 == 100) + progressBars.remove(0); } }); - request.send(file.getBlob()); + request.send(filesRemaining.get(0).getBlob()); } }