Updated OperationMonitor
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-csv-import-widget@99352 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
973b19dae1
commit
5b5e688fa1
|
@ -6,30 +6,29 @@ package org.gcube.portlets.user.td.csvimportwidget.client;
|
||||||
import org.gcube.portlets.user.td.gwtservice.client.rpc.TDGWTServiceAsync;
|
import org.gcube.portlets.user.td.gwtservice.client.rpc.TDGWTServiceAsync;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportSession;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportSession;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTSessionExpiredException;
|
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTSessionExpiredException;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.monitor.OperationMonitor;
|
import org.gcube.portlets.user.td.monitorwidget.client.MonitorDialog;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.monitor.OperationMonitorSession;
|
import org.gcube.portlets.user.td.monitorwidget.client.MonitorDialogListener;
|
||||||
import org.gcube.portlets.user.td.monitorwidget.client.MonitorBarUpdater;
|
|
||||||
import org.gcube.portlets.user.td.monitorwidget.client.MonitorUpdater;
|
|
||||||
import org.gcube.portlets.user.td.monitorwidget.client.MonitorUpdaterListener;
|
|
||||||
import org.gcube.portlets.user.td.widgetcommonevent.client.event.SessionExpiredEvent;
|
import org.gcube.portlets.user.td.widgetcommonevent.client.event.SessionExpiredEvent;
|
||||||
import org.gcube.portlets.user.td.widgetcommonevent.client.type.SessionExpiredType;
|
import org.gcube.portlets.user.td.widgetcommonevent.client.type.SessionExpiredType;
|
||||||
import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId;
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId;
|
||||||
import org.gcube.portlets.user.td.wizardwidget.client.WizardCard;
|
import org.gcube.portlets.user.td.wizardwidget.client.WizardCard;
|
||||||
|
|
||||||
import com.allen_sauer.gwt.log.client.Log;
|
import com.allen_sauer.gwt.log.client.Log;
|
||||||
|
import com.google.gwt.safehtml.shared.SafeHtmlBuilder;
|
||||||
import com.google.gwt.user.client.Command;
|
import com.google.gwt.user.client.Command;
|
||||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
import com.google.gwt.user.client.ui.FlexTable;
|
import com.google.gwt.user.client.ui.FlexTable;
|
||||||
import com.sencha.gxt.core.client.util.Margins;
|
import com.sencha.gxt.core.client.util.Margins;
|
||||||
import com.sencha.gxt.widget.core.client.FramedPanel;
|
import com.sencha.gxt.widget.core.client.FramedPanel;
|
||||||
import com.sencha.gxt.widget.core.client.ProgressBar;
|
|
||||||
import com.sencha.gxt.widget.core.client.box.AlertMessageBox;
|
import com.sencha.gxt.widget.core.client.box.AlertMessageBox;
|
||||||
import com.sencha.gxt.widget.core.client.container.BoxLayoutContainer.BoxLayoutData;
|
import com.sencha.gxt.widget.core.client.container.BoxLayoutContainer.BoxLayoutData;
|
||||||
|
import com.sencha.gxt.widget.core.client.container.HtmlLayoutContainer;
|
||||||
import com.sencha.gxt.widget.core.client.container.VBoxLayoutContainer;
|
import com.sencha.gxt.widget.core.client.container.VBoxLayoutContainer;
|
||||||
import com.sencha.gxt.widget.core.client.container.VBoxLayoutContainer.VBoxLayoutAlign;
|
import com.sencha.gxt.widget.core.client.container.VBoxLayoutContainer.VBoxLayoutAlign;
|
||||||
import com.sencha.gxt.widget.core.client.event.HideEvent;
|
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.HideEvent.HideHandler;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author "Giancarlo Panichi" <a
|
* @author "Giancarlo Panichi" <a
|
||||||
|
@ -37,13 +36,12 @@ import com.sencha.gxt.widget.core.client.event.HideEvent.HideHandler;
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class CSVOperationInProgressCard extends WizardCard implements
|
public class CSVOperationInProgressCard extends WizardCard implements
|
||||||
MonitorUpdaterListener {
|
MonitorDialogListener {
|
||||||
|
|
||||||
public static final int STATUS_POLLING_DELAY = 1000;
|
|
||||||
protected CSVOperationInProgressCard thisCard;
|
protected CSVOperationInProgressCard thisCard;
|
||||||
protected CSVImportSession importSession;
|
protected CSVImportSession importSession;
|
||||||
protected MonitorUpdater progressUpdater;
|
protected TRId newTrId;
|
||||||
protected ProgressBar progressBar;
|
protected HtmlLayoutContainer resultField;
|
||||||
|
|
||||||
public CSVOperationInProgressCard(final CSVImportSession importSession) {
|
public CSVOperationInProgressCard(final CSVImportSession importSession) {
|
||||||
super("Operation In Progress", "");
|
super("Operation In Progress", "");
|
||||||
|
@ -79,30 +77,26 @@ public class CSVOperationInProgressCard extends WizardCard implements
|
||||||
operationInProgressPanel.add(summary, new BoxLayoutData(new Margins(20,
|
operationInProgressPanel.add(summary, new BoxLayoutData(new Margins(20,
|
||||||
5, 10, 5)));
|
5, 10, 5)));
|
||||||
|
|
||||||
progressBar = new ProgressBar();
|
|
||||||
operationInProgressPanel.add(progressBar, new BoxLayoutData(
|
resultField= new HtmlLayoutContainer("<div></div>");
|
||||||
new Margins(10, 5, 10, 5)));
|
|
||||||
|
operationInProgressPanel.add(resultField, new BoxLayoutData( new
|
||||||
|
Margins(10, 5, 10, 5)));
|
||||||
|
|
||||||
|
|
||||||
setContent(operationInProgressPanel);
|
setContent(operationInProgressPanel);
|
||||||
|
resultField.setVisible(false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// columnToImportMask
|
|
||||||
|
|
||||||
public void importCSV() {
|
public void importCSV() {
|
||||||
TDGWTServiceAsync.INSTANCE.startCSVImport(importSession,
|
TDGWTServiceAsync.INSTANCE.startCSVImport(importSession,
|
||||||
new AsyncCallback<String>() {
|
new AsyncCallback<String>() {
|
||||||
|
|
||||||
public void onSuccess(String taskId) {
|
public void onSuccess(String taskId) {
|
||||||
OperationMonitorSession operationMonitorSession = new OperationMonitorSession(
|
openMonitorDialog(taskId);
|
||||||
taskId);
|
|
||||||
progressUpdater = new MonitorUpdater(
|
|
||||||
operationMonitorSession);
|
|
||||||
progressUpdater.addListener(new MonitorBarUpdater(
|
|
||||||
progressBar));
|
|
||||||
|
|
||||||
progressUpdater.addListener(thisCard);
|
|
||||||
progressUpdater.scheduleRepeating(STATUS_POLLING_DELAY);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -133,26 +127,27 @@ public class CSVOperationInProgressCard extends WizardCard implements
|
||||||
importCSV();
|
importCSV();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
//
|
||||||
public void monitorInitializing(OperationMonitor operationMonitor) {
|
protected void openMonitorDialog(String taskId) {
|
||||||
|
MonitorDialog monitorDialog = new MonitorDialog(taskId, getEventBus());
|
||||||
|
monitorDialog.addProgressDialogListener(this);
|
||||||
|
monitorDialog.show();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void monitorUpdate(OperationMonitor operationMonitor) {
|
public void operationComplete(TRId trId) {
|
||||||
|
newTrId = trId;
|
||||||
}
|
SafeHtmlBuilder safeHtmlBuilder=new SafeHtmlBuilder();
|
||||||
|
safeHtmlBuilder.appendHtmlConstant("<div style='text-align:center;font-size:large;font-weight:bold; color:#009900;'>Operation Completed</div>");
|
||||||
@Override
|
resultField.setHTML(safeHtmlBuilder.toSafeHtml());
|
||||||
public void monitorComplete(final TRId trId, OperationMonitor operationMonitor) {
|
resultField.setVisible(true);
|
||||||
|
|
||||||
Command sayComplete = new Command() {
|
Command sayComplete = new Command() {
|
||||||
public void execute() {
|
public void execute() {
|
||||||
try {
|
try {
|
||||||
getWizardWindow().close(false);
|
getWizardWindow().close(false);
|
||||||
Log.info("fire Complete: " + trId);
|
Log.info("fire Complete: " + newTrId);
|
||||||
|
|
||||||
getWizardWindow().fireCompleted(trId);
|
getWizardWindow().fireCompleted(newTrId);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Log.error("fire Complete :" + e.getLocalizedMessage());
|
Log.error("fire Complete :" + e.getLocalizedMessage());
|
||||||
|
@ -164,38 +159,50 @@ public class CSVOperationInProgressCard extends WizardCard implements
|
||||||
|
|
||||||
setNextButtonVisible(true);
|
setNextButtonVisible(true);
|
||||||
getWizardWindow().setEnableNextButton(true);
|
getWizardWindow().setEnableNextButton(true);
|
||||||
|
forceLayout();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void monitorFailed(Throwable caught, String reason,
|
public void operationFailed(Throwable caught, String reason, String details) {
|
||||||
String failureDetails, OperationMonitor operationMonitor) {
|
SafeHtmlBuilder safeHtmlBuilder=new SafeHtmlBuilder();
|
||||||
|
safeHtmlBuilder.appendHtmlConstant("<div style='text-align:center;font-size:large;font-weight:bold;color:red;'>Operation Failed</div>");
|
||||||
|
resultField.setHTML(safeHtmlBuilder.toSafeHtml());
|
||||||
|
resultField.setVisible(true);
|
||||||
if (caught instanceof TDGWTSessionExpiredException) {
|
if (caught instanceof TDGWTSessionExpiredException) {
|
||||||
getEventBus()
|
getEventBus()
|
||||||
.fireEvent(
|
.fireEvent(
|
||||||
new SessionExpiredEvent(
|
new SessionExpiredEvent(
|
||||||
SessionExpiredType.EXPIREDONSERVER));
|
SessionExpiredType.EXPIREDONSERVER));
|
||||||
} else {
|
} else {
|
||||||
AlertMessageBox d = new AlertMessageBox(
|
AlertMessageBox d = new AlertMessageBox("Error in CSV Import",
|
||||||
"Error in CSV Import", reason);
|
reason);
|
||||||
d.addHideHandler(new HideHandler() {
|
d.addHideHandler(new HideHandler() {
|
||||||
public void onHide(HideEvent event) {
|
public void onHide(HideEvent event) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
d.show();
|
d.show();
|
||||||
}
|
}
|
||||||
|
forceLayout();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void monitorStopped(final TRId trId, String reason, String details, OperationMonitor operationMonitor) {
|
public void operationStopped(TRId trId, String reason, String details) {
|
||||||
|
newTrId = trId;
|
||||||
|
SafeHtmlBuilder safeHtmlBuilder=new SafeHtmlBuilder();
|
||||||
|
safeHtmlBuilder.appendHtmlConstant("<div style='text-align:center;font-size:large;font-weight:bold;color: #FF9900;'>Problems in the Operation</div>");
|
||||||
|
resultField.setHTML(safeHtmlBuilder.toSafeHtml());
|
||||||
|
resultField.setVisible(true);
|
||||||
|
|
||||||
Command sayComplete = new Command() {
|
Command sayComplete = new Command() {
|
||||||
public void execute() {
|
public void execute() {
|
||||||
try {
|
try {
|
||||||
getWizardWindow().close(false);
|
getWizardWindow().close(false);
|
||||||
Log.info("fire Complete: tabular resource " + trId.getId());
|
Log.info("fire Complete: tabular resource "
|
||||||
Log.info("fire Complete: tableId " + trId.getTableId());
|
+ newTrId.getId());
|
||||||
|
Log.info("fire Complete: tableId " + newTrId.getTableId());
|
||||||
|
|
||||||
getWizardWindow().fireCompleted(trId);
|
getWizardWindow().fireCompleted(newTrId);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Log.error("fire Complete :" + e.getLocalizedMessage());
|
Log.error("fire Complete :" + e.getLocalizedMessage());
|
||||||
|
@ -207,32 +214,64 @@ public class CSVOperationInProgressCard extends WizardCard implements
|
||||||
|
|
||||||
setNextButtonVisible(true);
|
setNextButtonVisible(true);
|
||||||
getWizardWindow().setEnableNextButton(true);
|
getWizardWindow().setEnableNextButton(true);
|
||||||
|
forceLayout();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void operationAborted() {
|
||||||
|
SafeHtmlBuilder safeHtmlBuilder=new SafeHtmlBuilder();
|
||||||
|
safeHtmlBuilder.appendHtmlConstant("<div style='text-align:center;font-size:large;font-weight:bold;color: #AA00AA;'>Operation Aborted</div>");
|
||||||
|
resultField.setHTML(safeHtmlBuilder.toSafeHtml());
|
||||||
|
resultField.setVisible(true);
|
||||||
|
|
||||||
|
Command sayComplete = new Command() {
|
||||||
|
public void execute() {
|
||||||
|
try {
|
||||||
|
getWizardWindow().close(false);
|
||||||
|
Log.info("fire Aborted");
|
||||||
|
|
||||||
|
getWizardWindow().fireAborted();
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
Log.error("fire Aborted :" + e.getLocalizedMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
getWizardWindow().setNextButtonCommand(sayComplete);
|
||||||
|
|
||||||
|
setNextButtonVisible(true);
|
||||||
|
getWizardWindow().setEnableNextButton(true);
|
||||||
|
forceLayout();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void monitorGeneratingView(OperationMonitor operationMonitor) {
|
public void operationPutInBackground() {
|
||||||
// TODO Auto-generated method stub
|
SafeHtmlBuilder safeHtmlBuilder=new SafeHtmlBuilder();
|
||||||
|
safeHtmlBuilder.appendHtmlConstant("<div style='text-align:center;font-size:large;font-weight:bold;color: #00AAAA;'>Operation in Background</div>");
|
||||||
|
resultField.setHTML(safeHtmlBuilder.toSafeHtml());
|
||||||
|
resultField.setVisible(true);
|
||||||
|
|
||||||
}
|
Command sayComplete = new Command() {
|
||||||
|
public void execute() {
|
||||||
|
try {
|
||||||
|
getWizardWindow().close(false);
|
||||||
|
Log.info("fire Operation In Background");
|
||||||
|
|
||||||
@Override
|
getWizardWindow().fireAborted();
|
||||||
public void monitorValidate(OperationMonitor operationMonitor) {
|
|
||||||
// TODO Auto-generated method stub
|
|
||||||
|
|
||||||
}
|
} catch (Exception e) {
|
||||||
|
Log.error("fire Operation In Background :" + e.getLocalizedMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
getWizardWindow().setNextButtonCommand(sayComplete);
|
||||||
|
|
||||||
|
setNextButtonVisible(true);
|
||||||
@Override
|
getWizardWindow().setEnableNextButton(true);
|
||||||
public void monitorAborted() {
|
forceLayout();
|
||||||
// TODO Auto-generated method stub
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void monitorPutInBackground() {
|
|
||||||
// TODO Auto-generated method stub
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue