From 737aa9f109c868f1985ab910cf6d6e6c3eb4d739 Mon Sep 17 00:00:00 2001 From: Giancarlo Panichi Date: Thu, 6 Mar 2014 14:33:52 +0000 Subject: [PATCH] Minor Updated git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-table-widget@92756 82a268e6-3cf1-43bd-a215-b396298e98cf --- .../ChangeTableTypeProgressUpdater.java | 2 +- .../DeleteRowsProgressBarUpdater.java | 75 ++++++++ .../progress/DeleteRowsProgressDialog.java | 133 +++++++++++++ .../progress/DeleteRowsProgressListener.java | 52 +++++ .../progress/DeleteRowsProgressUpdater.java | 182 ++++++++++++++++++ .../tablewidget/client/rows/DeleteRows.java | 53 ++++- 6 files changed, 495 insertions(+), 2 deletions(-) create mode 100644 src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressBarUpdater.java create mode 100644 src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressDialog.java create mode 100644 src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressListener.java create mode 100644 src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressUpdater.java diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/ChangeTableTypeProgressUpdater.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/ChangeTableTypeProgressUpdater.java index d25b48f..3c70f75 100644 --- a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/ChangeTableTypeProgressUpdater.java +++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/ChangeTableTypeProgressUpdater.java @@ -71,7 +71,7 @@ public class ChangeTableTypeProgressUpdater extends Timer { break; case SUCCEDED: cancel(); - Log.info("Import fisnish TableId :" + Log.info("Fisnish TableId :" + result.getTrId()); fireOperationComplete(result.getTrId()); break; diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressBarUpdater.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressBarUpdater.java new file mode 100644 index 0000000..d768766 --- /dev/null +++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressBarUpdater.java @@ -0,0 +1,75 @@ +/** + * + */ +package org.gcube.portlets.user.td.tablewidget.client.progress; + + + + +import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId; + +import com.allen_sauer.gwt.log.client.Log; +import com.sencha.gxt.widget.core.client.ProgressBar; + +/** + * + * @author "Giancarlo Panichi" + * g.panichi@isti.cnr.it + * + */ +public class DeleteRowsProgressBarUpdater implements ChangeTableTypeProgressListener { + + protected ProgressBar progressBar; + + /** + * Creates a new {@link ProgressBar} updater. + * @param progressBar the {@link ProgressBar} to update. + */ + public DeleteRowsProgressBarUpdater(ProgressBar progressBar) { + this.progressBar = progressBar; + } + + + /** + * {@inheritDoc} + */ + public void operationComplete(TRId trId) { + Log.info("Completed"); + progressBar.updateProgress(1, "Completed"); + + } + + /** + * {@inheritDoc} + */ + public void operationFailed(Throwable caught, String reason, String failureDetails) { + Log.info("Failed"); + progressBar.updateText("Failed"); + } + + public void operationInitializing() { + Log.info("Inizializing"); + progressBar.updateProgress(0, "Initializing..."); + } + + public void operationUpdate(float elaborated) { + Log.info("Elaborated: "+elaborated); + if (elaborated == 0) progressBar.updateProgress(0, "Initializing..."); + if (elaborated>0 && elaborated<1) { + Log.trace("progress "+elaborated); + int elab=new Float(elaborated*100).intValue(); + progressBar.updateProgress(elaborated,elab+"% Progress..."); + } + if (elaborated == 1) progressBar.updateProgress(1, "Completing..."); + + } + + + @Override + public void operationStopped(TRId trId,String reason, String details) { + Log.debug("Operation Stopped: ["+trId.toString()+", "+reason+", "+details+"]"); + progressBar.updateText("Stopped"); + + } + +} diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressDialog.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressDialog.java new file mode 100644 index 0000000..b4a834a --- /dev/null +++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressDialog.java @@ -0,0 +1,133 @@ +package org.gcube.portlets.user.td.tablewidget.client.progress; + +import org.gcube.portlets.user.td.gwtservice.shared.tr.rows.DeleteRowsSession; +import org.gcube.portlets.user.td.widgetcommonevent.client.event.ChangeTableRequestEvent; +import org.gcube.portlets.user.td.widgetcommonevent.client.type.ChangeTableRequestType; +import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId; + +import com.allen_sauer.gwt.log.client.Log; +import com.google.web.bindery.event.shared.EventBus; +import com.sencha.gxt.core.client.util.Margins; +import com.sencha.gxt.widget.core.client.FramedPanel; +import com.sencha.gxt.widget.core.client.ProgressBar; +import com.sencha.gxt.widget.core.client.Window; +import com.sencha.gxt.widget.core.client.box.AlertMessageBox; +import com.sencha.gxt.widget.core.client.button.TextButton; +import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer; +import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer.VerticalLayoutData; +import com.sencha.gxt.widget.core.client.event.HideEvent; +import com.sencha.gxt.widget.core.client.event.HideEvent.HideHandler; +import com.sencha.gxt.widget.core.client.event.SelectEvent; +import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler; + + + +/** + * LabelColumnProgressDialog is a Dialog that show progress of change the column label + * + * @author "Giancarlo Panichi" + * g.panichi@isti.cnr.it + * + */ +public class DeleteRowsProgressDialog extends Window implements ChangeTableTypeProgressListener { + public static final int STATUS_POLLING_DELAY = 1000; + protected String WIDTH = "400px"; + protected String HEIGHT = "120px"; + protected DeleteRowsSession deleteRowsSession; + protected EventBus eventBus; + protected DeleteRowsProgressUpdater progressUpdater; + protected TextButton ok; + protected TRId trId; + + public DeleteRowsProgressDialog(DeleteRowsSession deleteRowsSession, EventBus eventBus) { + this.deleteRowsSession=deleteRowsSession; + this.eventBus=eventBus; + setWidth(WIDTH); + setHeight(HEIGHT); + setBodyBorder(false); + setResizable(true); + setModal(true); + setHeadingText("Delete Rows Progress"); + + trId=null; + + FramedPanel panel=new FramedPanel(); + panel.setHeaderVisible(false); + panel.setBodyBorder(false); + + VerticalLayoutContainer v = new VerticalLayoutContainer(); + + + ProgressBar progressBar = new ProgressBar(); + + ok=new TextButton("OK"); + ok.addSelectHandler(new SelectHandler() { + + public void onSelect(SelectEvent event) { + updateInvocation(); + + } + }); + + v.add(progressBar, new VerticalLayoutData(1, + 1, new Margins(5, 5, 5, 5))); + + panel.add(v); + panel.addButton(ok); + add(panel); + + + progressUpdater = new DeleteRowsProgressUpdater(); + progressUpdater.addListener(new DeleteRowsProgressBarUpdater(progressBar)); + + progressUpdater.addListener(this); + progressUpdater.scheduleRepeating(STATUS_POLLING_DELAY); + show(); + ok.setVisible(false); + + } + + public void operationInitializing() { + // TODO Auto-generated method stub + + } + + public void operationUpdate(float elaborated) { + // TODO Auto-generated method stub + + } + + public void operationComplete(TRId trId) { + Log.debug("Operation Complete return: "+trId.toString()); + ok.setVisible(true); + this.trId=trId; + } + + public void operationFailed(Throwable caught, String reason, + String failureDetails) { + ok.setVisible(true); + this.trId=null; + AlertMessageBox d = new AlertMessageBox("Error Deleting Rows", reason); + d.addHideHandler(new HideHandler() { + public void onHide(HideEvent event) { + } + }); + d.show(); + } + + public void updateInvocation(){ + if(trId!=null){ + ChangeTableRequestEvent changeTableRequestEvent= + new ChangeTableRequestEvent(ChangeTableRequestType.DELETEROWS, trId); + eventBus.fireEvent(changeTableRequestEvent); + } + hide(); + } + + @Override + public void operationStopped(TRId trId,String reason, String details) { + Log.debug("Operation Stopped: ["+trId.toString()+", "+reason+", "+details+"]"); + ok.setVisible(true); + this.trId=trId; + } +} diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressListener.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressListener.java new file mode 100644 index 0000000..2c3eefa --- /dev/null +++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressListener.java @@ -0,0 +1,52 @@ +/** + * + */ +package org.gcube.portlets.user.td.tablewidget.client.progress; + +import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId; + + + +/** + * Defines a listener for operation progress. + * + * @author "Giancarlo Panichi" + * g.panichi@isti.cnr.it + * + */ +public interface DeleteRowsProgressListener { + + /** + * Called when the operation is starting. + */ + public void operationInitializing(); + + /** + * Called when there is a progress for the operation. + * @param elaborated the elaborated part. + */ + public void operationUpdate(float elaborated); + + + /** + * Called when the operation is complete. + */ + public void operationComplete(TRId trId); + + /** + * Called when the operation is failed. + * @param caught the failure exception. + * @param reason the failure reason. + */ + public void operationFailed(Throwable caught, String reason, String failureDetails); + + /** + * Called when the operation is stopped + * + * @param trId + * @param reason + * @param details + */ + public void operationStopped(TRId trId, String reason, String details); + +} diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressUpdater.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressUpdater.java new file mode 100644 index 0000000..3009d05 --- /dev/null +++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/progress/DeleteRowsProgressUpdater.java @@ -0,0 +1,182 @@ +/** + * + */ +package org.gcube.portlets.user.td.tablewidget.client.progress; + +import java.util.ArrayList; + +import org.gcube.portlets.user.td.gwtservice.client.rpc.TDGWTServiceAsync; +import org.gcube.portlets.user.td.gwtservice.shared.tr.rows.DeleteRowsMonitor; +import org.gcube.portlets.user.td.gwtservice.shared.tr.table.ChangeTableTypeMonitor; +import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId; + +import com.allen_sauer.gwt.log.client.Log; +import com.google.gwt.user.client.Timer; +import com.google.gwt.user.client.rpc.AsyncCallback; + + +/** + * + * @author "Giancarlo Panichi" + * g.panichi@isti.cnr.it + * + */ +public class DeleteRowsProgressUpdater extends Timer { + + protected ArrayList listeners = new ArrayList(); + + /** + * {@inheritDoc} + */ + @Override + public void run() { + Log.debug("requesting operation progress"); + TDGWTServiceAsync.INSTANCE + .getDeleteRowsMonitor(new AsyncCallback() { + + + public void onFailure(Throwable caught) { + cancel(); + Log.error("Error retrieving the operation state", + caught); + String message = getStack(caught); + fireOperationFailed(caught, + "Failed getting operation updates", message); + } + + public void onSuccess(DeleteRowsMonitor result) { + Log.info("retrieved DeleteRowsMonitor: " + + result.getStatus()); + switch (result.getStatus()) { + case INITIALIZING: + Log.info("Delete Rows Initializing..."); + fireOperationInitializing(); + break; + case ABORTED: + cancel(); + Log.info("Delete Rows Operation Aborted"); + break; + case IN_PROGRESS: + fireOperationUpdate(result.getProgress()); + break; + case VALIDATING_RULES: + fireOperationUpdate(result.getProgress()); + break; + case STOPPED: + cancel(); + stopMessage(result); + break; + case FAILED: + cancel(); + errorMessage(result); + break; + case SUCCEDED: + cancel(); + Log.info("Fisnish TableId :" + + result.getTrId()); + fireOperationComplete(result.getTrId()); + break; + default: + Log.info("Unknow State"); + break; + } + + } + + + + }); + + } + + protected void errorMessage(DeleteRowsMonitor result) { + Log.info("Delete Rows Failed"); + Throwable th = null; + String failure = null; + String details = null; + if (result.getError() != null) { + th = result.getError(); + failure = "Failed Client Library Delete Rows"; + details = result.getError().getLocalizedMessage(); + } else { + th = new Throwable("Failed"); + failure = "Failed Client Library Delete Rows"; + details = "Delete Rows failed"; + } + + fireOperationFailed(th, failure, details); + } + + protected void stopMessage(DeleteRowsMonitor result) { + Log.info("Delete Rows Stopped"); + String failure = null; + String details = null; + if (result.getError() != null) { + failure = "Stopped deleting rows"; + details = result.getError().getLocalizedMessage(); + } else { + failure = "Stopped deleting rows"; + details = "Delete Rows stopped"; + } + + fireOperationStopped(result.getTrId(),failure, details); + } + + + protected String getStack(Throwable e) { + String message = e.getLocalizedMessage() + " ->
"; + Throwable c = e.getCause(); + if (c != null) + message += getStack(c); + return message; + } + + protected void fireOperationInitializing() { + for (ChangeTableTypeProgressListener listener : listeners) + listener.operationInitializing(); + } + + protected void fireOperationUpdate(float elaborated) { + for (ChangeTableTypeProgressListener listener : listeners) + listener.operationUpdate(elaborated); + } + + protected void fireOperationComplete(TRId trId) { + for (ChangeTableTypeProgressListener listener : listeners) + listener.operationComplete(trId); + } + + protected void fireOperationFailed(Throwable caught, String failure, + String failureDetails) { + for (ChangeTableTypeProgressListener listener : listeners) + listener.operationFailed(caught, failure, failureDetails); + } + + protected void fireOperationStopped(TRId trId, String reason, String details) { + for (ChangeTableTypeProgressListener listener : listeners) + listener.operationStopped(trId,reason, details); + } + + + /** + * Add a new {@link ChangeTableTypeProgressListener} to this + * {@link DeleteRowsProgressUpdater}. + * + * @param listener + * the listener to add. + */ + public void addListener(ChangeTableTypeProgressListener listener) { + listeners.add(listener); + } + + /** + * Removes the specified {@link ChangeTableTypeProgressListener} from this + * {@link DeleteRowsProgressUpdater}. + * + * @param listener + * the listener to remove. + */ + public void removeListener(ChangeTableTypeProgressListener listener) { + listeners.remove(listener); + } +} diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/rows/DeleteRows.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/rows/DeleteRows.java index 12a678c..e227e06 100644 --- a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/rows/DeleteRows.java +++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/rows/DeleteRows.java @@ -2,18 +2,69 @@ package org.gcube.portlets.user.td.tablewidget.client.rows; import java.util.ArrayList; +import org.gcube.portlets.user.td.gwtservice.client.rpc.TDGWTServiceAsync; +import org.gcube.portlets.user.td.gwtservice.shared.tr.rows.DeleteRowsSession; +import org.gcube.portlets.user.td.tablewidget.client.progress.DeleteRowsProgressDialog; import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId; +import com.allen_sauer.gwt.log.client.Log; +import com.google.gwt.user.client.rpc.AsyncCallback; import com.google.web.bindery.event.shared.EventBus; +import com.sencha.gxt.widget.core.client.box.AlertMessageBox; +import com.sencha.gxt.widget.core.client.event.HideEvent; +import com.sencha.gxt.widget.core.client.event.HideEvent.HideHandler; public class DeleteRows { protected TRId trId; protected EventBus eventBus; protected ArrayList rows; - + protected DeleteRowsSession deleteRowsSession; + protected DeleteRowsProgressDialog deleteRowsProgressDialog; + public DeleteRows(TRId trId, ArrayList rows,EventBus eventBus) { this.trId = trId; this.rows=rows; this.eventBus = eventBus; + + delete(); } + + protected void delete(){ + deleteRowsSession =new DeleteRowsSession(trId, rows); + onDelete(); + } + + protected void onDelete(){ + TDGWTServiceAsync.INSTANCE.startDeleteRows( + deleteRowsSession, new AsyncCallback() { + + public void onFailure(Throwable caught) { + Log.debug("Delete Rows Error: " + + caught.getLocalizedMessage()); + alert("Error Deleting Rows", + "Error in invocation Delete Rows operation!"); + + } + + public void onSuccess(Void result) { + deleteRowsProgressDialog= new DeleteRowsProgressDialog(deleteRowsSession, eventBus); + } + + }); + + + } + + private void alert(String title, String message) { + final AlertMessageBox d = new AlertMessageBox(title, message); + d.addHideHandler(new HideHandler() { + + public void onHide(HideEvent event) { + + } + }); + d.show(); + + } + }