Updated OperationMonitor
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-monitor-widget@99337 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
e4fe8efe0e
commit
7ea82a3f6a
|
@ -0,0 +1,16 @@
|
|||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<launchConfiguration type="com.google.gdt.eclipse.suite.webapp">
|
||||
<stringAttribute key="com.google.gdt.eclipse.suiteMainTypeProcessor.PREVIOUSLY_SET_MAIN_TYPE_NAME" value="com.google.gwt.dev.DevMode"/>
|
||||
<stringAttribute key="com.google.gwt.eclipse.core.URL" value="MonitorWidgetTD.html"/>
|
||||
<listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_PATHS">
|
||||
<listEntry value="/tabular-data-monitor-widget"/>
|
||||
</listAttribute>
|
||||
<listAttribute key="org.eclipse.debug.core.MAPPED_RESOURCE_TYPES">
|
||||
<listEntry value="4"/>
|
||||
</listAttribute>
|
||||
<stringAttribute key="org.eclipse.jdt.launching.CLASSPATH_PROVIDER" value="com.google.gdt.eclipse.maven.mavenClasspathProvider"/>
|
||||
<stringAttribute key="org.eclipse.jdt.launching.MAIN_TYPE" value="com.google.gwt.dev.DevMode"/>
|
||||
<stringAttribute key="org.eclipse.jdt.launching.PROGRAM_ARGUMENTS" value="-remoteUI "${gwt_remote_ui_server_port}:${unique_id}" -startupUrl MonitorWidgetTD.html -logLevel INFO -codeServerPort 9997 -port 8888"/>
|
||||
<stringAttribute key="org.eclipse.jdt.launching.PROJECT_ATTR" value="tabular-data-monitor-widget"/>
|
||||
<stringAttribute key="org.eclipse.jdt.launching.VM_ARGUMENTS" value="-Xmx512m -Dgwt.nowarn.legacy.tools"/>
|
||||
</launchConfiguration>
|
1
pom.xml
1
pom.xml
|
@ -289,4 +289,5 @@
|
|||
</dependency>
|
||||
</dependencies>
|
||||
</dependencyManagement>
|
||||
<packaging>war</packaging>
|
||||
</project>
|
||||
|
|
|
@ -6,23 +6,31 @@ import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTSessionExpire
|
|||
import org.gcube.portlets.user.td.gwtservice.shared.monitor.OperationMonitor;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.monitor.OperationMonitorSession;
|
||||
import org.gcube.portlets.user.td.monitorwidget.client.details.MonitorDetailPanel;
|
||||
import org.gcube.portlets.user.td.monitorwidget.client.resources.ResourceBundle;
|
||||
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.shared.TRId;
|
||||
|
||||
import com.allen_sauer.gwt.log.client.Log;
|
||||
import com.google.web.bindery.event.shared.EventBus;
|
||||
import com.sencha.gxt.cell.core.client.ButtonCell.IconAlign;
|
||||
import com.sencha.gxt.core.client.dom.ScrollSupport.ScrollMode;
|
||||
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.button.TextButton;
|
||||
import com.sencha.gxt.widget.core.client.button.ToolButton;
|
||||
import com.sencha.gxt.widget.core.client.container.FlowLayoutContainer;
|
||||
import com.sencha.gxt.widget.core.client.container.HBoxLayoutContainer;
|
||||
import com.sencha.gxt.widget.core.client.container.MarginData;
|
||||
import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer;
|
||||
import com.sencha.gxt.widget.core.client.container.BoxLayoutContainer.BoxLayoutData;
|
||||
import com.sencha.gxt.widget.core.client.container.BoxLayoutContainer.BoxLayoutPack;
|
||||
import com.sencha.gxt.widget.core.client.container.HBoxLayoutContainer.HBoxLayoutAlign;
|
||||
import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer.VerticalLayoutData;
|
||||
import com.sencha.gxt.widget.core.client.event.SelectEvent;
|
||||
import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler;
|
||||
import com.sencha.gxt.widget.core.client.form.FieldSet;
|
||||
|
||||
/**
|
||||
* AddColumnProgressDialog is a Dialog that show progress of AddColumn
|
||||
|
@ -34,12 +42,16 @@ import com.sencha.gxt.widget.core.client.form.FieldSet;
|
|||
public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
||||
|
||||
public static final int STATUS_POLLING_DELAY = 1000;
|
||||
private static final String WIDTH = "400px";
|
||||
private static final String HEIGHT = "120px";
|
||||
private static final String WIDTH = "520px";
|
||||
private static final String HEIGHT = "378px";
|
||||
private static final String PANELWIDTH = "500px";
|
||||
private static final String PANELHEIGHT = "308px";
|
||||
private EventBus eventBus;
|
||||
private String taskId;
|
||||
private MonitorUpdater progressUpdater;
|
||||
private TextButton ok;
|
||||
private TextButton btnOk;
|
||||
private TextButton btnBackground;
|
||||
private TextButton btnAbort;
|
||||
private TRId trId;
|
||||
private String reason;
|
||||
private String details;
|
||||
|
@ -69,24 +81,32 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
setBodyBorder(false);
|
||||
setResizable(true);
|
||||
setModal(true);
|
||||
setClosable(false);
|
||||
setHeadingText("Progress");
|
||||
}
|
||||
|
||||
protected void create(){
|
||||
FramedPanel panel = new FramedPanel();
|
||||
panel.setWidth(PANELWIDTH);
|
||||
panel.setHeight(PANELHEIGHT);
|
||||
panel.setHeaderVisible(false);
|
||||
panel.setBodyBorder(false);
|
||||
|
||||
VerticalLayoutContainer v = new VerticalLayoutContainer();
|
||||
/*FlowLayoutContainer progressDetailContainer = new FlowLayoutContainer();
|
||||
progressDetailContainer.setScrollMode(ScrollMode.AUTO);
|
||||
MarginData layoutData = new MarginData(new Margins(5, 5, 5, 5));*/
|
||||
|
||||
|
||||
ProgressBar progressBar = new ProgressBar();
|
||||
progressBar.setWidth("498px");
|
||||
|
||||
FieldSet detailsSet = new FieldSet();
|
||||
/*FieldSet detailsSet = new FieldSet();
|
||||
detailsSet.setHeadingText("Details");
|
||||
detailsSet.setCollapsible(true);
|
||||
detailsSet.setCollapsible(true);*/
|
||||
|
||||
monitorDetailPanel=new MonitorDetailPanel(eventBus);
|
||||
detailsSet.add(monitorDetailPanel);
|
||||
//detailsSet.add(monitorDetailPanel);
|
||||
|
||||
/*TextField
|
||||
|
||||
|
@ -101,8 +121,14 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
RootPanel.get().add(v);
|
||||
*/
|
||||
|
||||
ok = new TextButton("OK");
|
||||
ok.addSelectHandler(new SelectHandler() {
|
||||
btnOk = new TextButton("Ok");
|
||||
btnOk.setWidth("70px");
|
||||
//btnOk.setIcon(ResourceBundle.INSTANCE.ok());
|
||||
//btnOk.setIconAlign(IconAlign.RIGHT);
|
||||
btnOk.setTitle("Ok");
|
||||
|
||||
|
||||
btnOk.addSelectHandler(new SelectHandler() {
|
||||
|
||||
public void onSelect(SelectEvent event) {
|
||||
updateInvocation();
|
||||
|
@ -110,24 +136,92 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
}
|
||||
});
|
||||
|
||||
v.add(progressBar,
|
||||
new VerticalLayoutData(1, 1, new Margins(5, 5, 5, 5)));
|
||||
btnBackground = new TextButton("Background");
|
||||
btnBackground.setWidth("70px");
|
||||
//btnOk.setIcon(ResourceBundle.INSTANCE.ok());
|
||||
//btnOk.setIconAlign(IconAlign.RIGHT);
|
||||
btnBackground.setTitle("Background");
|
||||
|
||||
v.add(detailsSet,new VerticalLayoutData(1, 1, new Margins(5, 5, 5, 5)));
|
||||
|
||||
btnBackground.addSelectHandler(new SelectHandler() {
|
||||
|
||||
public void onSelect(SelectEvent event) {
|
||||
startBackground();
|
||||
|
||||
}
|
||||
|
||||
|
||||
});
|
||||
|
||||
|
||||
btnAbort = new TextButton("Abort");
|
||||
btnAbort.setWidth("70px");
|
||||
//btnOk.setIcon(ResourceBundle.INSTANCE.ok());
|
||||
//btnOk.setIconAlign(IconAlign.RIGHT);
|
||||
btnAbort.setTitle("Abort");
|
||||
|
||||
|
||||
btnAbort.addSelectHandler(new SelectHandler() {
|
||||
|
||||
public void onSelect(SelectEvent event) {
|
||||
startAbort();
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
HBoxLayoutContainer flowButton = new HBoxLayoutContainer();
|
||||
flowButton.setHBoxLayoutAlign(HBoxLayoutAlign.MIDDLE);
|
||||
flowButton.setPack(BoxLayoutPack.CENTER);
|
||||
|
||||
flowButton.add(btnOk, new BoxLayoutData(new Margins(0, 4, 0, 4)));
|
||||
flowButton.add(btnBackground, new BoxLayoutData(new Margins(0, 4, 0, 4)));
|
||||
flowButton.add(btnAbort, new BoxLayoutData(new Margins(0, 4, 0, 4)));
|
||||
|
||||
|
||||
v.add(progressBar,
|
||||
new VerticalLayoutData(1, -1, new Margins(5, 5, 5, 5)));
|
||||
|
||||
v.add(monitorDetailPanel,new VerticalLayoutData(1, -1, new Margins(5, 5, 5, 5)));
|
||||
|
||||
v.add(flowButton, new VerticalLayoutData(1, 36,
|
||||
new Margins(5, 5, 5, 5)));
|
||||
|
||||
/*progressDetailContainer.add(progressBar, layoutData);
|
||||
progressDetailContainer.add(monitorDetailPanel, layoutData);*/
|
||||
|
||||
panel.add(v);
|
||||
panel.addButton(ok);
|
||||
add(panel);
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
//panel.addButton(btnOk);
|
||||
|
||||
|
||||
/*
|
||||
OperationMonitorSession operationMonitorSession = new OperationMonitorSession(
|
||||
taskId);
|
||||
progressUpdater = new MonitorUpdater(operationMonitorSession);
|
||||
progressUpdater.addListener(new MonitorBarUpdater(progressBar));
|
||||
|
||||
progressUpdater.addListener(this);
|
||||
progressUpdater.scheduleRepeating(STATUS_POLLING_DELAY);
|
||||
progressUpdater.scheduleRepeating(STATUS_POLLING_DELAY);*/
|
||||
show();
|
||||
ok.setVisible(false);
|
||||
//ok.setVisible(false);
|
||||
}
|
||||
|
||||
protected void startAbort() {
|
||||
// TODO Auto-generated method stub
|
||||
close();
|
||||
|
||||
}
|
||||
|
||||
protected void startBackground() {
|
||||
// TODO Auto-generated method stub
|
||||
close();
|
||||
|
||||
}
|
||||
|
||||
public void addProgressDialogListener(MonitorDialogListener listener) {
|
||||
|
@ -143,6 +237,7 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
if(monitorDetailPanel!=null){
|
||||
monitorDetailPanel.update(operationMonitor);
|
||||
}
|
||||
forceLayout();
|
||||
|
||||
}
|
||||
|
||||
|
@ -151,7 +246,7 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
if(monitorDetailPanel!=null){
|
||||
monitorDetailPanel.update(operationMonitor);
|
||||
}
|
||||
|
||||
forceLayout();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -169,15 +264,17 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
public void monitorFailed(Throwable caught, String reason, String details, OperationMonitor operationMonitor) {
|
||||
if(monitorDetailPanel!=null){
|
||||
monitorDetailPanel.update(operationMonitor);
|
||||
|
||||
}
|
||||
forceLayout();
|
||||
if (caught instanceof TDGWTSessionExpiredException) {
|
||||
eventBus.fireEvent(new SessionExpiredEvent(
|
||||
SessionExpiredType.EXPIREDONSERVER));
|
||||
} else {
|
||||
fireOperationFailed(caught,reason,details);
|
||||
hide();
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public void updateInvocation() {
|
||||
|
@ -198,8 +295,8 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
this.trId = trId;
|
||||
this.reason = reason;
|
||||
this.details = details;
|
||||
ok.setVisible(true);
|
||||
|
||||
btnOk.setVisible(true);
|
||||
forceLayout();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -207,6 +304,7 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
if(monitorDetailPanel!=null){
|
||||
monitorDetailPanel.update(operationMonitor);
|
||||
}
|
||||
forceLayout();
|
||||
|
||||
}
|
||||
|
||||
|
@ -215,7 +313,7 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
if(monitorDetailPanel!=null){
|
||||
monitorDetailPanel.update(operationMonitor);
|
||||
}
|
||||
|
||||
forceLayout();
|
||||
}
|
||||
|
||||
|
||||
|
@ -263,7 +361,7 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
*/
|
||||
@Override
|
||||
protected void initTools() {
|
||||
if (backgroundBtnEnabled) {
|
||||
/*if (backgroundBtnEnabled) {
|
||||
backgroundBtn = new ToolButton(ToolButton.CLOSE);
|
||||
backgroundBtn.setToolTip("Put in the background");
|
||||
backgroundBtn.addSelectHandler(new SelectHandler() {
|
||||
|
@ -275,16 +373,17 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
});
|
||||
|
||||
header.addTool(backgroundBtn);
|
||||
}
|
||||
}*/
|
||||
|
||||
super.initTools();
|
||||
|
||||
/*
|
||||
closeBtn.addSelectHandler(new SelectHandler() {
|
||||
|
||||
public void onSelect(SelectEvent event) {
|
||||
close();
|
||||
}
|
||||
});
|
||||
});*/
|
||||
|
||||
}
|
||||
|
||||
|
@ -293,6 +392,11 @@ public class MonitorDialog extends Window implements MonitorUpdaterListener {
|
|||
|
||||
}
|
||||
|
||||
|
||||
public void updateOperationMonitor(OperationMonitor operationMonitor){
|
||||
if(monitorDetailPanel!=null){
|
||||
monitorDetailPanel.update(operationMonitor);
|
||||
}
|
||||
forceLayout();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -1,19 +1,64 @@
|
|||
package org.gcube.portlets.user.td.monitorwidget.client;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Date;
|
||||
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.UIOperationsId;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.monitor.OperationMonitor;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.task.JobS;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.task.State;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.task.TaskS;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.task.ValidationsJobS;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.task.WorkerState;
|
||||
|
||||
import com.allen_sauer.gwt.log.client.Log;
|
||||
import com.google.gwt.core.client.EntryPoint;
|
||||
import com.google.web.bindery.event.shared.SimpleEventBus;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author "Giancarlo Panichi"
|
||||
* email: <a href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
|
||||
* @author "Giancarlo Panichi" email: <a
|
||||
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
|
||||
*
|
||||
*/
|
||||
public class MonitorWidgetEntry implements EntryPoint {
|
||||
|
||||
public void onModuleLoad() {
|
||||
Log.debug("Test MonitorWidget");
|
||||
SimpleEventBus eventBus = new SimpleEventBus();
|
||||
MonitorDialog monitorWidget= new MonitorDialog("taskId",eventBus);
|
||||
MonitorDialog monitorWidget = new MonitorDialog("1", eventBus);
|
||||
monitorWidget.show();
|
||||
OperationMonitor operationMonitor = new OperationMonitor("1",
|
||||
UIOperationsId.EditRow);
|
||||
operationMonitor.setTask(createTaskForTest());
|
||||
monitorWidget.updateOperationMonitor(operationMonitor);
|
||||
|
||||
}
|
||||
|
||||
private TaskS createTaskForTest() {
|
||||
ArrayList<ValidationsJobS> validationsJobs = new ArrayList<ValidationsJobS>();
|
||||
ValidationsJobS validationJobS = new ValidationsJobS("1",
|
||||
WorkerState.IN_PROGRESS, 0.5f, "Row Validate", null,
|
||||
"Validation in progress");
|
||||
validationsJobs.add(validationJobS);
|
||||
|
||||
ArrayList<JobS> jobs = new ArrayList<JobS>();
|
||||
JobS job1 = new JobS("1", 0.8f, "Edit Row Job for Human",
|
||||
"Edit Row Job", WorkerState.IN_PROGRESS, null, validationsJobs);
|
||||
jobs.add(job1);
|
||||
|
||||
JobS job2 = new JobS("2", 0.3f, "Add Row Job for Human",
|
||||
"Add Row Job", WorkerState.IN_PROGRESS, null, validationsJobs);
|
||||
jobs.add(job2);
|
||||
|
||||
JobS job3 = new JobS("3", 0.72f, "Delete Job for Human",
|
||||
"Delete Row Job", WorkerState.IN_PROGRESS, null, validationsJobs);
|
||||
jobs.add(job3);
|
||||
|
||||
TaskS task = new TaskS("1", 0.3f, State.IN_PROGRESS, null, "default",
|
||||
new Date(), null, jobs);
|
||||
|
||||
return task;
|
||||
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,6 +5,8 @@ import java.util.List;
|
|||
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.monitor.OperationMonitor;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.task.ValidationsTasksMetadata;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.task.WorkerState;
|
||||
import org.gcube.portlets.user.td.gwtservice.shared.task.WorkerStateParser;
|
||||
import org.gcube.portlets.user.td.monitorwidget.client.details.tree.MonitorBaseDto;
|
||||
import org.gcube.portlets.user.td.monitorwidget.client.details.tree.MonitorFolderDto;
|
||||
import org.gcube.portlets.user.td.monitorwidget.client.details.tree.MonitorTreeDataGenerator;
|
||||
|
@ -22,7 +24,7 @@ import com.google.web.bindery.event.shared.EventBus;
|
|||
import com.sencha.gxt.cell.core.client.ProgressBarCell;
|
||||
import com.sencha.gxt.core.client.ToStringValueProvider;
|
||||
import com.sencha.gxt.core.client.ValueProvider;
|
||||
import com.sencha.gxt.core.client.dom.ScrollSupport.ScrollMode;
|
||||
import com.sencha.gxt.core.client.util.Margins;
|
||||
import com.sencha.gxt.data.shared.IconProvider;
|
||||
import com.sencha.gxt.data.shared.ModelKeyProvider;
|
||||
import com.sencha.gxt.data.shared.TreeStore;
|
||||
|
@ -45,8 +47,10 @@ import com.sencha.gxt.widget.core.client.toolbar.ToolBar;
|
|||
import com.sencha.gxt.widget.core.client.treegrid.TreeGrid;
|
||||
|
||||
public class MonitorDetailPanel extends FramedPanel {
|
||||
protected String WIDTH = "380px";
|
||||
protected String HEIGHT = "200px";
|
||||
protected static final String WIDTH = "498px";
|
||||
protected static final String HEIGHT = "256px";
|
||||
protected static final String GRIDHEIGHT = "212px";
|
||||
|
||||
protected MonitorDetailPanel thisPanel;
|
||||
|
||||
protected Menu contextMenu;
|
||||
|
@ -90,9 +94,9 @@ public class MonitorDetailPanel extends FramedPanel {
|
|||
if (tree != null) {
|
||||
remove(tree);
|
||||
}
|
||||
if(operationMonitor!=null){
|
||||
|
||||
createTreeData();
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
protected void init() {
|
||||
|
@ -110,7 +114,7 @@ public class MonitorDetailPanel extends FramedPanel {
|
|||
|
||||
protected void create() {
|
||||
con = new VerticalLayoutContainer();
|
||||
con.setScrollMode(ScrollMode.AUTO);
|
||||
//con.setScrollMode(ScrollMode.AUTO);
|
||||
|
||||
store = new TreeStore<MonitorBaseDto>(new KeyProvider());
|
||||
|
||||
|
@ -136,34 +140,42 @@ public class MonitorDetailPanel extends FramedPanel {
|
|||
}
|
||||
});
|
||||
|
||||
ColumnConfig<MonitorBaseDto, Double> cc2 = new ColumnConfig<MonitorBaseDto, Double>(
|
||||
new ValueProvider<MonitorBaseDto, Double>() {
|
||||
ColumnConfig<MonitorBaseDto, String> cc2 = new ColumnConfig<MonitorBaseDto, String>(
|
||||
new ValueProvider<MonitorBaseDto, String>() {
|
||||
|
||||
@Override
|
||||
public Double getValue(MonitorBaseDto object) {
|
||||
Double d = null;
|
||||
public String getValue(MonitorBaseDto object) {
|
||||
String state = null;
|
||||
if (object instanceof MonitorValidationJobSDto) {
|
||||
Float f = ((MonitorValidationJobSDto) object).getProgress();
|
||||
d = new Double(f);
|
||||
state = ((MonitorValidationJobSDto) object).getWorkerState().toString();
|
||||
}
|
||||
return d;
|
||||
if (object instanceof MonitorFolderDto) {
|
||||
state = ((MonitorFolderDto) object).getState();
|
||||
}
|
||||
return state;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setValue(MonitorBaseDto object, Double value) {
|
||||
public void setValue(MonitorBaseDto object, String value) {
|
||||
if (object instanceof MonitorValidationJobSDto) {
|
||||
WorkerState workerState=WorkerStateParser.parse(value);
|
||||
((MonitorValidationJobSDto) object)
|
||||
.setProgress(value.floatValue());
|
||||
.setWorkerState(workerState);
|
||||
|
||||
}
|
||||
if (object instanceof MonitorFolderDto) {
|
||||
((MonitorFolderDto) object)
|
||||
.setState(value);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getPath() {
|
||||
return "progress";
|
||||
return "status";
|
||||
}
|
||||
}, 140, "Progress");
|
||||
cc2.setHeader("Progress");
|
||||
|
||||
}, 100, "Status");
|
||||
cc2.setHeader("Status");
|
||||
/*
|
||||
ProgressBarCell progress = new ProgressBarCell() {
|
||||
@Override
|
||||
public boolean handlesSelection() {
|
||||
|
@ -173,10 +185,60 @@ public class MonitorDetailPanel extends FramedPanel {
|
|||
progress.setProgressText("{0}% Complete");
|
||||
progress.setWidth(140);
|
||||
cc2.setCell(progress);
|
||||
*/
|
||||
ColumnConfig<MonitorBaseDto, Double> cc3 = new ColumnConfig<MonitorBaseDto, Double>(
|
||||
new ValueProvider<MonitorBaseDto, Double>() {
|
||||
|
||||
@Override
|
||||
public Double getValue(MonitorBaseDto object) {
|
||||
Double d = null;
|
||||
if (object instanceof MonitorValidationJobSDto) {
|
||||
Float f = ((MonitorValidationJobSDto) object).getProgress();
|
||||
d = new Double(f);
|
||||
}
|
||||
if (object instanceof MonitorFolderDto) {
|
||||
Float f = ((MonitorFolderDto) object).getProgress();
|
||||
d = new Double(f);
|
||||
}
|
||||
|
||||
return d;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setValue(MonitorBaseDto object, Double value) {
|
||||
if (object instanceof MonitorValidationJobSDto) {
|
||||
((MonitorValidationJobSDto) object)
|
||||
.setProgress(value.floatValue());
|
||||
}
|
||||
if (object instanceof MonitorFolderDto) {
|
||||
((MonitorFolderDto) object)
|
||||
.setProgress(value.floatValue());
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getPath() {
|
||||
return "progress";
|
||||
}
|
||||
}, 100, "Progress");
|
||||
cc3.setHeader("Progress");
|
||||
|
||||
ProgressBarCell progress = new ProgressBarCell() {
|
||||
@Override
|
||||
public boolean handlesSelection() {
|
||||
return true;
|
||||
}
|
||||
};
|
||||
progress.setProgressText("{0}% Complete");
|
||||
progress.setWidth(110);
|
||||
cc3.setCell(progress);
|
||||
|
||||
|
||||
|
||||
List<ColumnConfig<MonitorBaseDto, ?>> l = new ArrayList<ColumnConfig<MonitorBaseDto, ?>>();
|
||||
l.add(cc1);
|
||||
l.add(cc2);
|
||||
l.add(cc3);
|
||||
ColumnModel<MonitorBaseDto> cm = new ColumnModel<MonitorBaseDto>(l);
|
||||
|
||||
tree = new TreeGrid<MonitorBaseDto>(store, cm, cc1);
|
||||
|
@ -185,6 +247,8 @@ public class MonitorDetailPanel extends FramedPanel {
|
|||
tree.setLoadMask(true);
|
||||
tree.setColumnResize(true);
|
||||
tree.getView().setAutoExpandColumn(cc1);
|
||||
tree.setHeight(GRIDHEIGHT);
|
||||
|
||||
|
||||
IconProvider<MonitorBaseDto> iconProvider = new IconProvider<MonitorBaseDto>() {
|
||||
|
||||
|
@ -258,8 +322,8 @@ public class MonitorDetailPanel extends FramedPanel {
|
|||
});
|
||||
toolBar.add(btnCollapseAll);
|
||||
|
||||
con.add(toolBar, new VerticalLayoutData(1, -1));
|
||||
con.add(tree, new VerticalLayoutData(1, -1));
|
||||
con.add(toolBar, new VerticalLayoutData(1, -1,new Margins(0)));
|
||||
con.add(tree, new VerticalLayoutData(1, -1, new Margins(0)));
|
||||
|
||||
add(con, new MarginData(0));
|
||||
|
||||
|
@ -280,6 +344,7 @@ public class MonitorDetailPanel extends FramedPanel {
|
|||
this.operationMonitor = operationMonitor;
|
||||
draw();
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -14,16 +14,21 @@ public class MonitorFolderDto extends MonitorBaseDto {
|
|||
protected String description;
|
||||
protected ArrayList<MonitorBaseDto> childrens;
|
||||
protected String type;
|
||||
protected String state;
|
||||
protected float progress;
|
||||
|
||||
public MonitorFolderDto(){
|
||||
|
||||
}
|
||||
|
||||
public MonitorFolderDto(String type,String id,String description, ArrayList<MonitorBaseDto> childrens){
|
||||
public MonitorFolderDto(String type,String id,String description, String state, float progress, ArrayList<MonitorBaseDto> childrens){
|
||||
super(id);
|
||||
this.type=type;
|
||||
this.description=description;
|
||||
this.state=state;
|
||||
this.progress=progress;
|
||||
this.childrens=childrens;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
@ -52,6 +57,22 @@ public class MonitorFolderDto extends MonitorBaseDto {
|
|||
this.description = description;
|
||||
}
|
||||
|
||||
public float getProgress() {
|
||||
return progress;
|
||||
}
|
||||
|
||||
public void setProgress(float progress) {
|
||||
this.progress = progress;
|
||||
}
|
||||
|
||||
|
||||
public String getState() {
|
||||
return state;
|
||||
}
|
||||
|
||||
public void setState(String state) {
|
||||
this.state = state;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
|
|
|
@ -25,7 +25,7 @@ public class MonitorTreeDataGenerator {
|
|||
public MonitorTreeDataGenerator(OperationMonitor operationMonitor) {
|
||||
Log.debug("MonitorTreeDataGenerator");
|
||||
ArrayList<MonitorBaseDto> childrens = new ArrayList<MonitorBaseDto>();
|
||||
if (operationMonitor.getTask() != null) {
|
||||
if (operationMonitor!=null && operationMonitor.getTask() != null) {
|
||||
TaskS task = operationMonitor.getTask();
|
||||
ArrayList<MonitorBaseDto> jobs = new ArrayList<MonitorBaseDto>();
|
||||
for (JobS job : task.getJobs()) {
|
||||
|
@ -42,19 +42,23 @@ public class MonitorTreeDataGenerator {
|
|||
}
|
||||
MonitorFolderDto foldJob = new MonitorFolderDto("job",
|
||||
task.getId() + "-" + job.getId(), job.getDescription(),
|
||||
job.getWorkerState().toString(), job.getProgress(),
|
||||
validations);
|
||||
jobs.add(foldJob);
|
||||
}
|
||||
MonitorFolderDto foldTask = new MonitorFolderDto("task",
|
||||
task.getId(), sdf.format(task.getStartTime()), jobs);
|
||||
task.getId(), sdf.format(task.getStartTime()), task
|
||||
.getState().toString(), task.getProgress(), jobs);
|
||||
childrens.add(foldTask);
|
||||
|
||||
root = new MonitorFolderDto("root", "-1", "root", childrens);
|
||||
root = new MonitorFolderDto("root", "-1", "root", "root", 0,
|
||||
childrens);
|
||||
Log.debug("Generated root");
|
||||
// printRecorsive(root);
|
||||
printRecorsive(root);
|
||||
|
||||
} else {
|
||||
root = new MonitorFolderDto("root", "-1", "root", childrens);
|
||||
root = new MonitorFolderDto("root", "-1", "root", "root", 0,
|
||||
childrens);
|
||||
Log.debug("Generated root without childrens");
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1,3 @@
|
|||
@CHARSET "UTF-8";
|
||||
|
||||
|
|
@ -17,15 +17,28 @@
|
|||
<!-- Other module inherits -->
|
||||
<inherits name='com.sencha.gxt.ui.GXT' />
|
||||
<inherits name="com.allen_sauer.gwt.log.gwt-log-TRACE" />
|
||||
<inherits name="com.google.gwt.resources.Resources" />
|
||||
|
||||
<inherits name='org.gcube.portlets.user.td.gwtservice.TDGWTService' />
|
||||
|
||||
|
||||
<!-- Specify the app entry point class. -->
|
||||
<!-- <entry-point class='org.gcube.portlets.user.monitorwidget.client.MonitorWidgetEntry' /> -->
|
||||
<entry-point
|
||||
class='org.gcube.portlets.user.td.monitorwidget.client.MonitorWidgetEntry' />
|
||||
|
||||
<!-- Logger -->
|
||||
<set-property name="log_DivLogger" value="ENABLED" />
|
||||
<set-property name="log_ConsoleLogger" value="ENABLED" />
|
||||
<set-property name="log_FirebugLogger" value="ENABLED" />
|
||||
<set-property name="log_GWTLogger" value="ENABLED" />
|
||||
<set-property name="log_SystemLogger" value="ENABLED" />
|
||||
<!-- <set-property name="log_DivLogger" value="DISABLED" /> <set-property
|
||||
name="log_ConsoleLogger" value="DISABLED" /> <set-property name="log_FirebugLogger"
|
||||
value="DISABLED" /> <set-property name="log_GWTLogger" value="DISABLED" />
|
||||
<set-property name="log_SystemLogger" value="DISABLED" /> -->
|
||||
|
||||
<!-- Specify the paths for translatable code -->
|
||||
<source path='client' />
|
||||
<source path='shared' />
|
||||
<!-- <source path='org.gcube.data.analysis.tabulardata.operation.worker'/> -->
|
||||
|
||||
</module>
|
||||
|
|
|
@ -26,7 +26,7 @@
|
|||
</servlet-mapping>
|
||||
<servlet-mapping>
|
||||
<servlet-name>jUnitHostImpl</servlet-name>
|
||||
<url-pattern>UnionWizardWidgets/junithost/*</url-pattern>
|
||||
<url-pattern>/MonitorWidgetTD/junithost/*</url-pattern>
|
||||
</servlet-mapping>
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue