2014-07-03 18:12:39 +02:00
|
|
|
package org.gcube.portlets.user.td.tablewidget.client.normalize;
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
|
|
|
|
import org.gcube.portlets.user.td.gwtservice.client.rpc.TDGWTServiceAsync;
|
2014-09-30 13:07:04 +02:00
|
|
|
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTIsFinalException;
|
|
|
|
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTIsLockedException;
|
2014-07-03 18:12:39 +02:00
|
|
|
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTSessionExpiredException;
|
|
|
|
import org.gcube.portlets.user.td.gwtservice.shared.tr.normalization.DenormalizationSession;
|
2014-08-27 12:08:40 +02:00
|
|
|
import org.gcube.portlets.user.td.monitorwidget.client.MonitorDialog;
|
|
|
|
import org.gcube.portlets.user.td.monitorwidget.client.MonitorDialogListener;
|
2015-04-01 16:53:25 +02:00
|
|
|
import org.gcube.portlets.user.td.columnwidget.client.properties.ColumnDataPropertiesCombo;
|
2014-07-03 18:12:39 +02:00
|
|
|
import org.gcube.portlets.user.td.tablewidget.client.resources.ResourceBundle;
|
|
|
|
import org.gcube.portlets.user.td.tablewidget.client.util.UtilsGXT3;
|
|
|
|
import org.gcube.portlets.user.td.widgetcommonevent.client.event.ChangeTableRequestEvent;
|
|
|
|
import org.gcube.portlets.user.td.widgetcommonevent.client.event.SessionExpiredEvent;
|
|
|
|
import org.gcube.portlets.user.td.widgetcommonevent.client.type.ChangeTableRequestType;
|
|
|
|
import org.gcube.portlets.user.td.widgetcommonevent.client.type.ChangeTableWhy;
|
|
|
|
import org.gcube.portlets.user.td.widgetcommonevent.client.type.SessionExpiredType;
|
2015-01-29 18:33:19 +01:00
|
|
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.OperationResult;
|
2014-07-03 18:12:39 +02:00
|
|
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId;
|
2015-04-13 13:00:05 +02:00
|
|
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnData;
|
2014-07-03 18:52:05 +02:00
|
|
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnDataType;
|
2014-07-03 18:12:39 +02:00
|
|
|
|
|
|
|
import com.allen_sauer.gwt.log.client.Log;
|
|
|
|
import com.google.gwt.core.client.GWT;
|
|
|
|
import com.google.gwt.core.client.Scheduler;
|
|
|
|
import com.google.gwt.core.client.Scheduler.ScheduledCommand;
|
|
|
|
import com.google.gwt.event.logical.shared.SelectionEvent;
|
|
|
|
import com.google.gwt.event.logical.shared.SelectionHandler;
|
|
|
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
|
|
|
import com.google.web.bindery.event.shared.EventBus;
|
|
|
|
import com.sencha.gxt.cell.core.client.ButtonCell.IconAlign;
|
|
|
|
import com.sencha.gxt.cell.core.client.form.ComboBoxCell.TriggerAction;
|
|
|
|
import com.sencha.gxt.core.client.util.Margins;
|
|
|
|
import com.sencha.gxt.data.client.loader.RpcProxy;
|
|
|
|
import com.sencha.gxt.data.shared.LabelProvider;
|
|
|
|
import com.sencha.gxt.data.shared.ListStore;
|
|
|
|
import com.sencha.gxt.data.shared.loader.ListLoadConfig;
|
|
|
|
import com.sencha.gxt.data.shared.loader.ListLoadConfigBean;
|
|
|
|
import com.sencha.gxt.data.shared.loader.ListLoadResult;
|
|
|
|
import com.sencha.gxt.data.shared.loader.ListLoadResultBean;
|
|
|
|
import com.sencha.gxt.data.shared.loader.ListLoader;
|
|
|
|
import com.sencha.gxt.data.shared.loader.LoadResultListStoreBinding;
|
|
|
|
import com.sencha.gxt.widget.core.client.FramedPanel;
|
|
|
|
import com.sencha.gxt.widget.core.client.button.TextButton;
|
|
|
|
import com.sencha.gxt.widget.core.client.container.BoxLayoutContainer.BoxLayoutData;
|
|
|
|
import com.sencha.gxt.widget.core.client.container.HBoxLayoutContainer;
|
|
|
|
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.SelectEvent;
|
|
|
|
import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler;
|
|
|
|
import com.sencha.gxt.widget.core.client.form.ComboBox;
|
|
|
|
import com.sencha.gxt.widget.core.client.form.FieldLabel;
|
|
|
|
import com.sencha.gxt.widget.core.client.info.Info;
|
|
|
|
|
|
|
|
public class DenormalizePanel extends FramedPanel implements
|
2014-08-27 12:08:40 +02:00
|
|
|
MonitorDialogListener {
|
2014-07-03 18:12:39 +02:00
|
|
|
protected String WIDTH = "640px";
|
|
|
|
protected String HEIGHT = "520px";
|
|
|
|
|
|
|
|
protected TRId trId;
|
|
|
|
protected EventBus eventBus;
|
|
|
|
protected ArrayList<String> rows;
|
|
|
|
|
|
|
|
protected DenormalizationSession denormalizationSession;
|
|
|
|
|
|
|
|
protected ComboBox<ColumnData> comboValueColumn = null;
|
|
|
|
protected ComboBox<ColumnData> comboAttributeColumn = null;
|
|
|
|
protected ListStore<ColumnData> storeComboAttributeColumn;
|
|
|
|
|
|
|
|
protected ListLoader<ListLoadConfig, ListLoadResult<ColumnData>> loader;
|
|
|
|
|
|
|
|
protected FieldLabel comboAttributeColumnLabel;
|
|
|
|
|
|
|
|
protected TextButton denormalizeButton;
|
|
|
|
|
|
|
|
protected DenormalizeDialog parent;
|
2014-08-27 12:08:40 +02:00
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
protected ArrayList<ColumnData> columnsRetrieved;
|
|
|
|
|
|
|
|
public DenormalizePanel(DenormalizeDialog parent, TRId trId,
|
|
|
|
EventBus eventBus) {
|
|
|
|
this.parent = parent;
|
|
|
|
this.trId = trId;
|
|
|
|
this.eventBus = eventBus;
|
|
|
|
create();
|
|
|
|
}
|
|
|
|
|
|
|
|
public DenormalizePanel(TRId trId, EventBus eventBus) {
|
|
|
|
this.trId = trId;
|
|
|
|
this.eventBus = eventBus;
|
|
|
|
this.parent = null;
|
|
|
|
create();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void create() {
|
|
|
|
|
|
|
|
setWidth(WIDTH);
|
|
|
|
setHeight(HEIGHT);
|
|
|
|
setHeaderVisible(false);
|
|
|
|
setBodyBorder(false);
|
|
|
|
Log.debug("Create DenormalizationPanel(): [" + trId.toString() + "]");
|
|
|
|
|
|
|
|
ColumnDataPropertiesCombo propsColumnData = GWT
|
|
|
|
.create(ColumnDataPropertiesCombo.class);
|
|
|
|
|
|
|
|
// Combo Value Column
|
|
|
|
ListStore<ColumnData> storeComboValueColumn = new ListStore<ColumnData>(
|
|
|
|
propsColumnData.id());
|
|
|
|
|
|
|
|
Log.trace("StoreComboValueColumn created");
|
|
|
|
|
|
|
|
RpcProxy<ListLoadConfig, ListLoadResult<ColumnData>> proxy = new RpcProxy<ListLoadConfig, ListLoadResult<ColumnData>>() {
|
|
|
|
|
|
|
|
public void load(ListLoadConfig loadConfig,
|
|
|
|
final AsyncCallback<ListLoadResult<ColumnData>> callback) {
|
|
|
|
loadData(loadConfig, callback);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
loader = new ListLoader<ListLoadConfig, ListLoadResult<ColumnData>>(
|
|
|
|
proxy) {
|
|
|
|
@Override
|
|
|
|
protected ListLoadConfig newLoadConfig() {
|
|
|
|
return (ListLoadConfig) new ListLoadConfigBean();
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
loader.addLoadHandler(new LoadResultListStoreBinding<ListLoadConfig, ColumnData, ListLoadResult<ColumnData>>(
|
|
|
|
storeComboValueColumn));
|
|
|
|
Log.trace("LoaderCombo created");
|
|
|
|
|
|
|
|
comboValueColumn = new ComboBox<ColumnData>(storeComboValueColumn,
|
|
|
|
propsColumnData.label()) {
|
|
|
|
|
|
|
|
protected void onAfterFirstAttach() {
|
|
|
|
super.onAfterFirstAttach();
|
|
|
|
Scheduler.get().scheduleDeferred(new ScheduledCommand() {
|
|
|
|
public void execute() {
|
|
|
|
loader.load();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Log.trace("Combo Value Column created");
|
|
|
|
|
|
|
|
addHandlersForComboColumn(propsColumnData.label());
|
|
|
|
|
|
|
|
comboValueColumn.setLoader(loader);
|
|
|
|
comboValueColumn.setEmptyText("Select a column...");
|
|
|
|
comboValueColumn.setWidth(191);
|
|
|
|
comboValueColumn.setTypeAhead(false);
|
|
|
|
comboValueColumn.setEditable(false);
|
|
|
|
comboValueColumn.setTriggerAction(TriggerAction.ALL);
|
|
|
|
|
|
|
|
// Combo Attribute Column
|
|
|
|
storeComboAttributeColumn = new ListStore<ColumnData>(
|
|
|
|
propsColumnData.id());
|
|
|
|
Log.trace("StoreComboAttributeColumn created");
|
|
|
|
|
|
|
|
// storeComboAttributeColumn.addAll(ColumnDataTypeStore.getAttributeType());
|
|
|
|
|
|
|
|
comboAttributeColumn = new ComboBox<ColumnData>(
|
|
|
|
storeComboAttributeColumn, propsColumnData.label());
|
|
|
|
Log.trace("ComboAttributeColumn created");
|
|
|
|
|
|
|
|
addHandlersForComboAttributeColumn(propsColumnData.label());
|
|
|
|
|
|
|
|
comboAttributeColumn.setEmptyText("Select a column...");
|
|
|
|
comboAttributeColumn.setWidth(191);
|
|
|
|
comboAttributeColumn.setTypeAhead(true);
|
|
|
|
comboAttributeColumn.setTriggerAction(TriggerAction.ALL);
|
|
|
|
|
|
|
|
comboAttributeColumnLabel = new FieldLabel(comboAttributeColumn,
|
|
|
|
"Attribute Column");
|
|
|
|
|
|
|
|
// Normalize Button
|
|
|
|
denormalizeButton = new TextButton("Denormalize");
|
|
|
|
denormalizeButton.setIcon(ResourceBundle.INSTANCE.tableDenormalize());
|
|
|
|
denormalizeButton.setIconAlign(IconAlign.RIGHT);
|
|
|
|
denormalizeButton.setTitle("Denormalize");
|
2014-08-27 12:08:40 +02:00
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
SelectHandler deleteHandler = new SelectHandler() {
|
|
|
|
|
|
|
|
public void onSelect(SelectEvent event) {
|
|
|
|
onDenormalize();
|
|
|
|
|
|
|
|
}
|
|
|
|
};
|
|
|
|
denormalizeButton.addSelectHandler(deleteHandler);
|
|
|
|
|
|
|
|
HBoxLayoutContainer hBox = new HBoxLayoutContainer();
|
|
|
|
hBox.add(denormalizeButton, new BoxLayoutData(new Margins(2, 5, 2, 5)));
|
|
|
|
|
|
|
|
VerticalLayoutContainer v = new VerticalLayoutContainer();
|
2014-12-05 12:05:19 +01:00
|
|
|
//v.setScrollMode(ScrollMode.AUTO); Set in GXT 3.0.1
|
2014-07-03 18:12:39 +02:00
|
|
|
v.add(new FieldLabel(comboValueColumn, "Value Column"),
|
|
|
|
new VerticalLayoutData(1, -1, new Margins(1)));
|
|
|
|
|
|
|
|
v.add(comboAttributeColumnLabel, new VerticalLayoutData(1, -1,
|
|
|
|
new Margins(1)));
|
|
|
|
|
|
|
|
v.add(hBox, new VerticalLayoutData(-1, -1, new Margins(10, 0, 10, 0)));
|
|
|
|
add(v, new VerticalLayoutData(-1, -1, new Margins(0)));
|
|
|
|
|
|
|
|
comboAttributeColumnLabel.setVisible(false);
|
|
|
|
denormalizeButton.disable();
|
2014-08-27 12:08:40 +02:00
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
protected void addHandlersForComboColumn(
|
|
|
|
final LabelProvider<ColumnData> labelProvider) {
|
|
|
|
comboValueColumn
|
|
|
|
.addSelectionHandler(new SelectionHandler<ColumnData>() {
|
|
|
|
public void onSelection(SelectionEvent<ColumnData> event) {
|
|
|
|
Info.display(
|
|
|
|
"Value Column Selected",
|
|
|
|
"You selected "
|
|
|
|
+ (event.getSelectedItem() == null ? "nothing"
|
|
|
|
: labelProvider.getLabel(event
|
|
|
|
.getSelectedItem())
|
|
|
|
+ "!"));
|
|
|
|
Log.debug("ComboValueColumn selected: "
|
|
|
|
+ event.getSelectedItem());
|
|
|
|
ColumnData valueColumn = event.getSelectedItem();
|
|
|
|
updateComboValueColumn(valueColumn);
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void addHandlersForComboAttributeColumn(
|
|
|
|
final LabelProvider<ColumnData> labelProvider) {
|
|
|
|
comboAttributeColumn
|
|
|
|
.addSelectionHandler(new SelectionHandler<ColumnData>() {
|
|
|
|
public void onSelection(SelectionEvent<ColumnData> event) {
|
|
|
|
Info.display(
|
|
|
|
"Attribute Column Selected",
|
|
|
|
"You selected "
|
|
|
|
+ (event.getSelectedItem() == null ? "nothing"
|
|
|
|
: labelProvider.getLabel(event
|
|
|
|
.getSelectedItem())
|
|
|
|
+ "!"));
|
|
|
|
Log.debug("ComboAttributeColumn selected: "
|
|
|
|
+ event.getSelectedItem());
|
|
|
|
ColumnData attributeColumn = event.getSelectedItem();
|
|
|
|
updateComboAttributeColumn(attributeColumn);
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
protected void updateComboValueColumn(ColumnData columnData) {
|
|
|
|
comboAttributeColumn.clear();
|
|
|
|
storeComboAttributeColumn.clear();
|
2014-08-27 12:08:40 +02:00
|
|
|
for (ColumnData c : columnsRetrieved) {
|
|
|
|
if (c.getColumnId().compareTo(columnData.getColumnId()) != 0) {
|
2014-07-03 18:12:39 +02:00
|
|
|
storeComboAttributeColumn.add(c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
storeComboAttributeColumn.commitChanges();
|
|
|
|
comboAttributeColumnLabel.setVisible(true);
|
|
|
|
denormalizeButton.disable();
|
2015-01-14 15:17:54 +01:00
|
|
|
forceLayout();
|
2014-08-27 12:08:40 +02:00
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
protected void updateComboAttributeColumn(ColumnData columnData) {
|
|
|
|
denormalizeButton.enable();
|
2015-01-14 15:17:54 +01:00
|
|
|
forceLayout();
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
protected void resetComboStatus() {
|
|
|
|
comboAttributeColumn.clear();
|
|
|
|
storeComboAttributeColumn.clear();
|
|
|
|
storeComboAttributeColumn.commitChanges();
|
|
|
|
comboAttributeColumnLabel.setVisible(false);
|
|
|
|
denormalizeButton.disable();
|
2015-01-14 15:17:54 +01:00
|
|
|
forceLayout();
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
protected void loadData(ListLoadConfig loadConfig,
|
|
|
|
final AsyncCallback<ListLoadResult<ColumnData>> callback) {
|
|
|
|
TDGWTServiceAsync.INSTANCE.getColumns(trId,
|
|
|
|
new AsyncCallback<ArrayList<ColumnData>>() {
|
|
|
|
|
|
|
|
public void onFailure(Throwable caught) {
|
|
|
|
if (caught instanceof TDGWTSessionExpiredException) {
|
|
|
|
eventBus.fireEvent(new SessionExpiredEvent(
|
|
|
|
SessionExpiredType.EXPIREDONSERVER));
|
|
|
|
} else {
|
2014-09-30 13:07:04 +02:00
|
|
|
if (caught instanceof TDGWTIsLockedException) {
|
|
|
|
Log.error(caught.getLocalizedMessage());
|
|
|
|
UtilsGXT3.alert("Error Locked",
|
|
|
|
caught.getLocalizedMessage());
|
|
|
|
} else {
|
|
|
|
Log.error("load combo failure:"
|
|
|
|
+ caught.getLocalizedMessage());
|
|
|
|
UtilsGXT3.alert("Error",
|
|
|
|
"Error retrieving columns of tabular resource:"
|
|
|
|
+ trId.getId());
|
|
|
|
}
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
callback.onFailure(caught);
|
|
|
|
}
|
|
|
|
|
|
|
|
public void onSuccess(ArrayList<ColumnData> result) {
|
|
|
|
Log.trace("loaded " + result.size() + " ColumnData");
|
2014-08-27 12:08:40 +02:00
|
|
|
columnsRetrieved = result;
|
2014-07-03 18:12:39 +02:00
|
|
|
resetComboStatus();
|
2014-08-27 12:08:40 +02:00
|
|
|
ArrayList<ColumnData> columnsIntegerNumeric = new ArrayList<ColumnData>();
|
|
|
|
for (ColumnData c : result) {
|
|
|
|
if (c.getDataTypeName().compareTo(
|
|
|
|
ColumnDataType.Numeric.toString()) == 0
|
|
|
|
|| c.getDataTypeName().compareTo(
|
|
|
|
ColumnDataType.Integer.toString()) == 0) {
|
2014-07-03 18:52:05 +02:00
|
|
|
columnsIntegerNumeric.add(c);
|
|
|
|
}
|
|
|
|
}
|
2014-08-27 12:08:40 +02:00
|
|
|
if (columnsIntegerNumeric.size() < 1) {
|
|
|
|
UtilsGXT3
|
|
|
|
.alert("Attention",
|
|
|
|
"No Column with data type Integer or Numeric");
|
2014-07-03 18:52:05 +02:00
|
|
|
return;
|
|
|
|
}
|
2014-08-27 12:08:40 +02:00
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
callback.onSuccess(new ListLoadResultBean<ColumnData>(
|
2014-07-03 18:52:05 +02:00
|
|
|
columnsIntegerNumeric));
|
2014-07-03 18:12:39 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public void update(TRId trId) {
|
|
|
|
this.trId = trId;
|
|
|
|
loader.load();
|
2014-08-27 12:08:40 +02:00
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
protected void onDenormalize() {
|
|
|
|
|
|
|
|
ColumnData valueColumn = comboValueColumn.getCurrentValue();
|
2014-08-27 12:08:40 +02:00
|
|
|
if (valueColumn == null) {
|
|
|
|
UtilsGXT3.alert("Attention", "Attention no value column selected!");
|
|
|
|
return;
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
2014-08-27 12:08:40 +02:00
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
ColumnData attributeColumn = comboAttributeColumn.getCurrentValue();
|
2014-08-27 12:08:40 +02:00
|
|
|
if (attributeColumn == null) {
|
|
|
|
UtilsGXT3.alert("Attention",
|
|
|
|
"Attention no attribute column selected!");
|
|
|
|
return;
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
2014-08-27 12:08:40 +02:00
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
denormalizationSession = new DenormalizationSession(trId, valueColumn,
|
|
|
|
attributeColumn);
|
|
|
|
|
|
|
|
TDGWTServiceAsync.INSTANCE.startDenormalization(denormalizationSession,
|
2014-08-27 12:08:40 +02:00
|
|
|
new AsyncCallback<String>() {
|
2014-07-03 18:12:39 +02:00
|
|
|
|
|
|
|
public void onFailure(Throwable caught) {
|
|
|
|
if (caught instanceof TDGWTSessionExpiredException) {
|
|
|
|
eventBus.fireEvent(new SessionExpiredEvent(
|
|
|
|
SessionExpiredType.EXPIREDONSERVER));
|
|
|
|
} else {
|
2014-09-30 13:07:04 +02:00
|
|
|
if (caught instanceof TDGWTIsLockedException) {
|
|
|
|
Log.error(caught.getLocalizedMessage());
|
|
|
|
UtilsGXT3.alert("Error Locked",
|
|
|
|
caught.getLocalizedMessage());
|
|
|
|
} else {
|
|
|
|
if (caught instanceof TDGWTIsFinalException) {
|
|
|
|
Log.error(caught.getLocalizedMessage());
|
|
|
|
UtilsGXT3.alert("Error Final",
|
|
|
|
caught.getLocalizedMessage());
|
|
|
|
} else {
|
|
|
|
Log.debug("Denormalize Error: "
|
|
|
|
+ caught.getLocalizedMessage());
|
|
|
|
UtilsGXT3.alert("Error on Denormalize",
|
|
|
|
caught.getLocalizedMessage());
|
|
|
|
}
|
|
|
|
}
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-27 12:08:40 +02:00
|
|
|
public void onSuccess(String taskId) {
|
|
|
|
openMonitorDialog(taskId);
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public void close() {
|
|
|
|
if (parent != null) {
|
|
|
|
parent.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-27 12:08:40 +02:00
|
|
|
// /
|
|
|
|
protected void openMonitorDialog(String taskId) {
|
|
|
|
MonitorDialog monitorDialog = new MonitorDialog(taskId, eventBus);
|
|
|
|
monitorDialog.addProgressDialogListener(this);
|
|
|
|
monitorDialog.show();
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2015-01-29 18:33:19 +01:00
|
|
|
public void operationComplete(OperationResult operationResult) {
|
2014-07-03 18:12:39 +02:00
|
|
|
ChangeTableWhy why = ChangeTableWhy.TABLEUPDATED;
|
|
|
|
ChangeTableRequestEvent changeTableRequestEvent = new ChangeTableRequestEvent(
|
2015-01-29 18:33:19 +01:00
|
|
|
ChangeTableRequestType.DENORMALIZE, operationResult.getTrId(), why);
|
2014-07-03 18:12:39 +02:00
|
|
|
eventBus.fireEvent(changeTableRequestEvent);
|
|
|
|
close();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-08-27 12:08:40 +02:00
|
|
|
public void operationFailed(Throwable caught, String reason, String details) {
|
|
|
|
UtilsGXT3.alert(reason, details);
|
2014-07-03 18:12:39 +02:00
|
|
|
close();
|
2014-08-27 12:08:40 +02:00
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2015-01-29 18:33:19 +01:00
|
|
|
public void operationStopped(OperationResult operationResult, String reason, String details) {
|
2014-07-03 18:12:39 +02:00
|
|
|
ChangeTableWhy why = ChangeTableWhy.TABLECURATION;
|
|
|
|
ChangeTableRequestEvent changeTableRequestEvent = new ChangeTableRequestEvent(
|
2015-01-29 18:33:19 +01:00
|
|
|
ChangeTableRequestType.DENORMALIZE, operationResult.getTrId(), why);
|
2014-07-03 18:12:39 +02:00
|
|
|
eventBus.fireEvent(changeTableRequestEvent);
|
|
|
|
close();
|
2014-08-27 12:08:40 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void operationAborted() {
|
|
|
|
close();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void operationPutInBackground() {
|
|
|
|
close();
|
|
|
|
|
2014-07-03 18:12:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|