Added Quadrant
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-table-widget@111908 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
1ba26b4071
commit
68a1c4724e
|
@ -0,0 +1,428 @@
|
||||||
|
package org.gcube.portlets.user.td.tablewidget.client.geometry;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
import org.gcube.portlets.user.td.columnwidget.client.properties.ColumnDataPropertiesCombo;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.client.rpc.TDGWTServiceAsync;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTIsFinalException;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTIsLockedException;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTSessionExpiredException;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.geospatial.GeospatialCreateCoordinatesSession;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.tr.ColumnData;
|
||||||
|
import org.gcube.portlets.user.td.monitorwidget.client.MonitorDialog;
|
||||||
|
import org.gcube.portlets.user.td.monitorwidget.client.MonitorDialogListener;
|
||||||
|
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;
|
||||||
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.OperationResult;
|
||||||
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId;
|
||||||
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnDataType;
|
||||||
|
|
||||||
|
import com.allen_sauer.gwt.log.client.Log;
|
||||||
|
import com.google.gwt.core.client.GWT;
|
||||||
|
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.dom.ScrollSupport.ScrollMode;
|
||||||
|
import com.sencha.gxt.core.client.util.Margins;
|
||||||
|
import com.sencha.gxt.data.shared.LabelProvider;
|
||||||
|
import com.sencha.gxt.data.shared.ListStore;
|
||||||
|
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.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;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author "Giancarlo Panichi" <a
|
||||||
|
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class GeometryCreatePointPanel extends FramedPanel implements
|
||||||
|
MonitorDialogListener {
|
||||||
|
private static final String WIDTH = "640px";
|
||||||
|
private static final String HEIGHT = "520px";
|
||||||
|
|
||||||
|
private TRId trId;
|
||||||
|
private EventBus eventBus;
|
||||||
|
private boolean created;
|
||||||
|
|
||||||
|
private ArrayList<ColumnData> columns;
|
||||||
|
private VerticalLayoutContainer vl;
|
||||||
|
|
||||||
|
private TextButton createPointButton;
|
||||||
|
private ComboBox<ColumnData> comboLatitude;
|
||||||
|
private ComboBox<ColumnData> comboLongitude;
|
||||||
|
private ListStore<ColumnData> storeComboLatitude;
|
||||||
|
private ListStore<ColumnData> storeComboLongitude;
|
||||||
|
|
||||||
|
public GeometryCreatePointPanel(TRId trId, EventBus eventBus) {
|
||||||
|
super();
|
||||||
|
this.trId = trId;
|
||||||
|
|
||||||
|
this.eventBus = eventBus;
|
||||||
|
this.created = false;
|
||||||
|
forceLayoutOnResize = true;
|
||||||
|
retrieveColumns();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void testCreated() {
|
||||||
|
if (created) {
|
||||||
|
updateCombo();
|
||||||
|
} else {
|
||||||
|
created = true;
|
||||||
|
create();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void updateCombo() {
|
||||||
|
storeComboLatitude.clear();
|
||||||
|
storeComboLatitude.addAll(columns);
|
||||||
|
storeComboLatitude.commitChanges();
|
||||||
|
comboLatitude.reset();
|
||||||
|
comboLatitude.clear();
|
||||||
|
|
||||||
|
storeComboLongitude.clear();
|
||||||
|
storeComboLongitude.addAll(columns);
|
||||||
|
storeComboLongitude.commitChanges();
|
||||||
|
comboLongitude.reset();
|
||||||
|
comboLongitude.clear();
|
||||||
|
|
||||||
|
onResize();
|
||||||
|
forceLayout();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void create() {
|
||||||
|
|
||||||
|
setWidth(WIDTH);
|
||||||
|
setHeight(HEIGHT);
|
||||||
|
setHeaderVisible(false);
|
||||||
|
setBodyBorder(false);
|
||||||
|
|
||||||
|
Log.debug("Create GeometryPointPanel(): ["
|
||||||
|
+ trId.toString() + "]");
|
||||||
|
|
||||||
|
// Column Propierties
|
||||||
|
ColumnDataPropertiesCombo propsColumnData = GWT
|
||||||
|
.create(ColumnDataPropertiesCombo.class);
|
||||||
|
|
||||||
|
// Latitude
|
||||||
|
storeComboLatitude = new ListStore<ColumnData>(propsColumnData.id());
|
||||||
|
storeComboLatitude.addAll(columns);
|
||||||
|
|
||||||
|
comboLatitude = new ComboBox<ColumnData>(storeComboLatitude,
|
||||||
|
propsColumnData.label());
|
||||||
|
Log.trace("Combo ColumnData created");
|
||||||
|
|
||||||
|
addHandlersForComboColumnLatitude(propsColumnData.label());
|
||||||
|
|
||||||
|
comboLatitude.setEmptyText("Select a column...");
|
||||||
|
comboLatitude.setWidth(191);
|
||||||
|
comboLatitude.setTypeAhead(false);
|
||||||
|
comboLatitude.setEditable(false);
|
||||||
|
comboLatitude.setTriggerAction(TriggerAction.ALL);
|
||||||
|
|
||||||
|
// Longitude
|
||||||
|
storeComboLongitude = new ListStore<ColumnData>(propsColumnData.id());
|
||||||
|
storeComboLongitude.addAll(columns);
|
||||||
|
|
||||||
|
comboLongitude = new ComboBox<ColumnData>(storeComboLongitude,
|
||||||
|
propsColumnData.label());
|
||||||
|
Log.trace("Combo ColumnData created");
|
||||||
|
|
||||||
|
addHandlersForComboColumnLongitude(propsColumnData.label());
|
||||||
|
|
||||||
|
comboLongitude.setEmptyText("Select a column...");
|
||||||
|
comboLongitude.setWidth(191);
|
||||||
|
comboLongitude.setTypeAhead(false);
|
||||||
|
comboLongitude.setEditable(false);
|
||||||
|
comboLongitude.setTriggerAction(TriggerAction.ALL);
|
||||||
|
|
||||||
|
|
||||||
|
// Create
|
||||||
|
createPointButton = new TextButton("Create");
|
||||||
|
createPointButton.setIcon(ResourceBundle.INSTANCE
|
||||||
|
.geospatialCoordinates());
|
||||||
|
createPointButton.setIconAlign(IconAlign.RIGHT);
|
||||||
|
createPointButton.setTitle("Create Point");
|
||||||
|
|
||||||
|
createPointButton.addSelectHandler(new SelectHandler() {
|
||||||
|
|
||||||
|
public void onSelect(SelectEvent event) {
|
||||||
|
onGeometryCreatePoint();
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
vl = new VerticalLayoutContainer();
|
||||||
|
vl.setScrollMode(ScrollMode.AUTO);
|
||||||
|
vl.setAdjustForScroll(true);
|
||||||
|
|
||||||
|
vl.add(new FieldLabel(comboLatitude, "Latitude"),
|
||||||
|
new VerticalLayoutData(1, -1));
|
||||||
|
|
||||||
|
vl.add(new FieldLabel(comboLongitude, "Longitude"),
|
||||||
|
new VerticalLayoutData(1, -1));
|
||||||
|
|
||||||
|
|
||||||
|
vl.add(createPointButton, new VerticalLayoutData(-1, -1,
|
||||||
|
new Margins(10, 0, 10, 0)));
|
||||||
|
|
||||||
|
add(vl);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
onResize();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addHandlersForComboColumnLatitude(
|
||||||
|
final LabelProvider<ColumnData> labelProvider) {
|
||||||
|
comboLatitude.addSelectionHandler(new SelectionHandler<ColumnData>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSelection(SelectionEvent<ColumnData> event) {
|
||||||
|
Info.display(
|
||||||
|
"Latitude Selected",
|
||||||
|
"You selected "
|
||||||
|
+ (event.getSelectedItem() == null ? "nothing"
|
||||||
|
: labelProvider.getLabel(event
|
||||||
|
.getSelectedItem()) + "!"));
|
||||||
|
Log.debug("Latitude selected: " + event.getSelectedItem());
|
||||||
|
ColumnData latitude = event.getSelectedItem();
|
||||||
|
updatedLatitude(latitude);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void updatedLatitude(ColumnData latitude) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addHandlersForComboColumnLongitude(
|
||||||
|
final LabelProvider<ColumnData> labelProvider) {
|
||||||
|
comboLongitude.addSelectionHandler(new SelectionHandler<ColumnData>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSelection(SelectionEvent<ColumnData> event) {
|
||||||
|
Info.display(
|
||||||
|
"Longitude Selected",
|
||||||
|
"You selected "
|
||||||
|
+ (event.getSelectedItem() == null ? "nothing"
|
||||||
|
: labelProvider.getLabel(event
|
||||||
|
.getSelectedItem()) + "!"));
|
||||||
|
Log.debug("Longitude selected: " + event.getSelectedItem());
|
||||||
|
ColumnData longitude = event.getSelectedItem();
|
||||||
|
updatedLongitude(longitude);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void updatedLongitude(ColumnData longitude) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
protected void onGeometryCreatePoint() {
|
||||||
|
ColumnData latitude = comboLatitude.getCurrentValue();
|
||||||
|
if (latitude != null) {
|
||||||
|
ColumnData longitude = comboLongitude.getCurrentValue();
|
||||||
|
if (longitude != null) {
|
||||||
|
/*GeospatialCoordinatesType type=null;
|
||||||
|
GeospatialCreateCoordinatesSession gsCreateCoordinatesSession = new GeospatialCreateCoordinatesSession(
|
||||||
|
trId, latitude, longitude, type, null, null);
|
||||||
|
callGeometryCreatePoint(gsCreateCoordinatesSession);*/
|
||||||
|
|
||||||
|
} else {
|
||||||
|
UtilsGXT3.alert("Attention", "Select Longitude!");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
UtilsGXT3.alert("Attention", "Select Latitude!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void callGeometryCreatePoint(
|
||||||
|
GeospatialCreateCoordinatesSession gsCreateCoordinatesSession) {
|
||||||
|
TDGWTServiceAsync.INSTANCE.startGeospatialCreateCoordinates(
|
||||||
|
gsCreateCoordinatesSession, new AsyncCallback<String>() {
|
||||||
|
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
if (caught instanceof TDGWTSessionExpiredException) {
|
||||||
|
eventBus.fireEvent(new SessionExpiredEvent(
|
||||||
|
SessionExpiredType.EXPIREDONSERVER));
|
||||||
|
} else {
|
||||||
|
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("Create Geospatial Coordinates Error: "
|
||||||
|
+ caught.getLocalizedMessage());
|
||||||
|
UtilsGXT3
|
||||||
|
.alert("Error Creating Geospatial Coordinates",
|
||||||
|
"Error creating geospatial coordinates: "
|
||||||
|
+ caught.getLocalizedMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onSuccess(String taskId) {
|
||||||
|
openMonitorDialog(taskId);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void retrieveColumns() {
|
||||||
|
TDGWTServiceAsync.INSTANCE.getColumns(trId,
|
||||||
|
new AsyncCallback<ArrayList<ColumnData>>() {
|
||||||
|
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
if (caught instanceof TDGWTSessionExpiredException) {
|
||||||
|
eventBus.fireEvent(new SessionExpiredEvent(
|
||||||
|
SessionExpiredType.EXPIREDONSERVER));
|
||||||
|
} else {
|
||||||
|
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.error("load combo failure:"
|
||||||
|
+ caught.getLocalizedMessage());
|
||||||
|
UtilsGXT3.alert("Error",
|
||||||
|
"Error retrieving columns of tabular resource:"
|
||||||
|
+ trId.getId());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onSuccess(ArrayList<ColumnData> result) {
|
||||||
|
Log.trace("loaded " + result.size() + " ColumnData");
|
||||||
|
columns = new ArrayList<ColumnData>();
|
||||||
|
|
||||||
|
for (ColumnData column : result) {
|
||||||
|
ColumnDataType columnDataType = ColumnDataType
|
||||||
|
.getColumnDataTypeFromId(column
|
||||||
|
.getDataTypeName());
|
||||||
|
if (columnDataType
|
||||||
|
.compareTo(ColumnDataType.Integer) == 0
|
||||||
|
|| columnDataType
|
||||||
|
.compareTo(ColumnDataType.Numeric) == 0) {
|
||||||
|
columns.add(column);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
if (columns.size() < 1) {
|
||||||
|
Log.debug("Attention no Integer or Numeric column is present in the tabular resource");
|
||||||
|
UtilsGXT3
|
||||||
|
.alert("Attention",
|
||||||
|
"No Integer or Numeric column is present in the tabular resource!");
|
||||||
|
}
|
||||||
|
testCreated();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void update(TRId trId) {
|
||||||
|
this.trId = trId;
|
||||||
|
|
||||||
|
retrieveColumns();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void close() {
|
||||||
|
/*
|
||||||
|
* if (parent != null) { parent.close(); }
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
// /
|
||||||
|
protected void openMonitorDialog(String taskId) {
|
||||||
|
MonitorDialog monitorDialog = new MonitorDialog(taskId, eventBus);
|
||||||
|
monitorDialog.addProgressDialogListener(this);
|
||||||
|
monitorDialog.show();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void operationComplete(OperationResult operationResult) {
|
||||||
|
ChangeTableWhy why = ChangeTableWhy.TABLEUPDATED;
|
||||||
|
ChangeTableRequestEvent changeTableRequestEvent = new ChangeTableRequestEvent(
|
||||||
|
ChangeTableRequestType.GEOSPATIALCREATECOORDINATES,
|
||||||
|
operationResult.getTrId(), why);
|
||||||
|
eventBus.fireEvent(changeTableRequestEvent);
|
||||||
|
close();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void operationFailed(Throwable caught, String reason, String details) {
|
||||||
|
UtilsGXT3.alert(reason, details);
|
||||||
|
close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void operationStopped(OperationResult operationResult,
|
||||||
|
String reason, String details) {
|
||||||
|
ChangeTableWhy why = ChangeTableWhy.TABLECURATION;
|
||||||
|
ChangeTableRequestEvent changeTableRequestEvent = new ChangeTableRequestEvent(
|
||||||
|
ChangeTableRequestType.GEOSPATIALCREATECOORDINATES,
|
||||||
|
operationResult.getTrId(), why);
|
||||||
|
eventBus.fireEvent(changeTableRequestEvent);
|
||||||
|
close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void operationAborted() {
|
||||||
|
close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void operationPutInBackground() {
|
||||||
|
close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -30,12 +30,17 @@ import com.allen_sauer.gwt.log.client.Log;
|
||||||
import com.google.gwt.core.client.GWT;
|
import com.google.gwt.core.client.GWT;
|
||||||
import com.google.gwt.event.logical.shared.SelectionEvent;
|
import com.google.gwt.event.logical.shared.SelectionEvent;
|
||||||
import com.google.gwt.event.logical.shared.SelectionHandler;
|
import com.google.gwt.event.logical.shared.SelectionHandler;
|
||||||
|
import com.google.gwt.event.logical.shared.ValueChangeEvent;
|
||||||
|
import com.google.gwt.event.logical.shared.ValueChangeHandler;
|
||||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
|
import com.google.gwt.user.client.ui.HasValue;
|
||||||
|
import com.google.gwt.user.client.ui.HorizontalPanel;
|
||||||
import com.google.web.bindery.event.shared.EventBus;
|
import com.google.web.bindery.event.shared.EventBus;
|
||||||
import com.sencha.gxt.cell.core.client.ButtonCell.IconAlign;
|
import com.sencha.gxt.cell.core.client.ButtonCell.IconAlign;
|
||||||
import com.sencha.gxt.cell.core.client.form.ComboBoxCell.TriggerAction;
|
import com.sencha.gxt.cell.core.client.form.ComboBoxCell.TriggerAction;
|
||||||
import com.sencha.gxt.core.client.dom.ScrollSupport.ScrollMode;
|
import com.sencha.gxt.core.client.dom.ScrollSupport.ScrollMode;
|
||||||
import com.sencha.gxt.core.client.util.Margins;
|
import com.sencha.gxt.core.client.util.Margins;
|
||||||
|
import com.sencha.gxt.core.client.util.ToggleGroup;
|
||||||
import com.sencha.gxt.data.shared.LabelProvider;
|
import com.sencha.gxt.data.shared.LabelProvider;
|
||||||
import com.sencha.gxt.data.shared.ListStore;
|
import com.sencha.gxt.data.shared.ListStore;
|
||||||
import com.sencha.gxt.widget.core.client.FramedPanel;
|
import com.sencha.gxt.widget.core.client.FramedPanel;
|
||||||
|
@ -46,6 +51,7 @@ 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.event.SelectEvent.SelectHandler;
|
||||||
import com.sencha.gxt.widget.core.client.form.ComboBox;
|
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.form.FieldLabel;
|
||||||
|
import com.sencha.gxt.widget.core.client.form.Radio;
|
||||||
import com.sencha.gxt.widget.core.client.info.Info;
|
import com.sencha.gxt.widget.core.client.info.Info;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -65,6 +71,7 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
private boolean created;
|
private boolean created;
|
||||||
|
|
||||||
private ArrayList<ColumnData> columns;
|
private ArrayList<ColumnData> columns;
|
||||||
|
private ArrayList<ColumnData> quadrantColumns;
|
||||||
private VerticalLayoutContainer vl;
|
private VerticalLayoutContainer vl;
|
||||||
|
|
||||||
private TextButton createCoordinatesButton;
|
private TextButton createCoordinatesButton;
|
||||||
|
@ -73,6 +80,12 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
private ComboBox<GeospatialCoordinatesType> comboGsCoordinatesType;
|
private ComboBox<GeospatialCoordinatesType> comboGsCoordinatesType;
|
||||||
private ListStore<ColumnData> storeComboLatitude;
|
private ListStore<ColumnData> storeComboLatitude;
|
||||||
private ListStore<ColumnData> storeComboLongitude;
|
private ListStore<ColumnData> storeComboLongitude;
|
||||||
|
private ListStore<ColumnData> storeComboQuadrant;
|
||||||
|
private ComboBox<ColumnData> comboQuadrant;
|
||||||
|
private Radio hasQuadrantTrue;
|
||||||
|
private Radio hasQuadrantFalse;
|
||||||
|
private FieldLabel comboQuadrantField;
|
||||||
|
private FieldLabel hasQuadrantField;
|
||||||
|
|
||||||
public GeospatialCreateCoordinatesPanel(TRId trId,
|
public GeospatialCreateCoordinatesPanel(TRId trId,
|
||||||
RequestProperties requestProperties, EventBus eventBus) {
|
RequestProperties requestProperties, EventBus eventBus) {
|
||||||
|
@ -111,15 +124,20 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
comboLongitude.reset();
|
comboLongitude.reset();
|
||||||
comboLongitude.clear();
|
comboLongitude.clear();
|
||||||
|
|
||||||
if (gsCoordinatesType != null) {
|
storeComboQuadrant.clear();
|
||||||
comboGsCoordinatesType.setValue(gsCoordinatesType);
|
storeComboQuadrant.addAll(quadrantColumns);
|
||||||
}
|
storeComboQuadrant.commitChanges();
|
||||||
|
comboQuadrant.reset();
|
||||||
|
comboQuadrant.clear();
|
||||||
|
|
||||||
|
updateForCoordinatesType();
|
||||||
|
|
||||||
|
|
||||||
onResize();
|
|
||||||
forceLayout();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
protected void create() {
|
protected void create() {
|
||||||
|
|
||||||
setWidth(WIDTH);
|
setWidth(WIDTH);
|
||||||
|
@ -141,7 +159,7 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
|
|
||||||
comboLatitude = new ComboBox<ColumnData>(storeComboLatitude,
|
comboLatitude = new ComboBox<ColumnData>(storeComboLatitude,
|
||||||
propsColumnData.label());
|
propsColumnData.label());
|
||||||
Log.trace("Combo ColumnData created");
|
Log.trace("Combo Latide created");
|
||||||
|
|
||||||
addHandlersForComboColumnLatitude(propsColumnData.label());
|
addHandlersForComboColumnLatitude(propsColumnData.label());
|
||||||
|
|
||||||
|
@ -157,7 +175,7 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
|
|
||||||
comboLongitude = new ComboBox<ColumnData>(storeComboLongitude,
|
comboLongitude = new ComboBox<ColumnData>(storeComboLongitude,
|
||||||
propsColumnData.label());
|
propsColumnData.label());
|
||||||
Log.trace("Combo ColumnData created");
|
Log.trace("Combo Longitude created");
|
||||||
|
|
||||||
addHandlersForComboColumnLongitude(propsColumnData.label());
|
addHandlersForComboColumnLongitude(propsColumnData.label());
|
||||||
|
|
||||||
|
@ -178,7 +196,7 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
comboGsCoordinatesType = new ComboBox<GeospatialCoordinatesType>(
|
comboGsCoordinatesType = new ComboBox<GeospatialCoordinatesType>(
|
||||||
storeComboGsCoordinatesType,
|
storeComboGsCoordinatesType,
|
||||||
propsGeospatialCoordinatesType.label());
|
propsGeospatialCoordinatesType.label());
|
||||||
Log.trace("Combo ColumnData created");
|
Log.trace("Combo Geospatial Column Type created");
|
||||||
|
|
||||||
addHandlersForComboGsCoordinatesType(propsGeospatialCoordinatesType
|
addHandlersForComboGsCoordinatesType(propsGeospatialCoordinatesType
|
||||||
.label());
|
.label());
|
||||||
|
@ -189,6 +207,67 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
comboGsCoordinatesType.setEditable(false);
|
comboGsCoordinatesType.setEditable(false);
|
||||||
comboGsCoordinatesType.setTriggerAction(TriggerAction.ALL);
|
comboGsCoordinatesType.setTriggerAction(TriggerAction.ALL);
|
||||||
|
|
||||||
|
// Has Quadrant
|
||||||
|
hasQuadrantTrue = new Radio();
|
||||||
|
hasQuadrantTrue.setBoxLabel("True");
|
||||||
|
hasQuadrantTrue.setValue(true);
|
||||||
|
|
||||||
|
hasQuadrantFalse = new Radio();
|
||||||
|
hasQuadrantFalse.setBoxLabel("False");
|
||||||
|
|
||||||
|
ToggleGroup hasQuadrantGroup = new ToggleGroup();
|
||||||
|
hasQuadrantGroup.add(hasQuadrantTrue);
|
||||||
|
hasQuadrantGroup.add(hasQuadrantFalse);
|
||||||
|
|
||||||
|
hasQuadrantGroup
|
||||||
|
.addValueChangeHandler(new ValueChangeHandler<HasValue<Boolean>>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onValueChange(
|
||||||
|
ValueChangeEvent<HasValue<Boolean>> event) {
|
||||||
|
try {
|
||||||
|
if (hasQuadrantTrue.getValue()) {
|
||||||
|
comboQuadrantField.setVisible(true);
|
||||||
|
} else {
|
||||||
|
comboQuadrantField.setVisible(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
forceLayout();
|
||||||
|
|
||||||
|
} catch (Exception e) {
|
||||||
|
Log.error("ToggleGroup: onValueChange "
|
||||||
|
+ e.getLocalizedMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
HorizontalPanel hasQuadrantPanel = new HorizontalPanel();
|
||||||
|
hasQuadrantPanel.add(hasQuadrantTrue);
|
||||||
|
hasQuadrantPanel.add(hasQuadrantFalse);
|
||||||
|
|
||||||
|
hasQuadrantField = new FieldLabel(hasQuadrantPanel, "Has Quadrant");
|
||||||
|
hasQuadrantField
|
||||||
|
.setToolTip("Select true if you want select quadrant column");
|
||||||
|
|
||||||
|
// Quadrant
|
||||||
|
storeComboQuadrant = new ListStore<ColumnData>(propsColumnData.id());
|
||||||
|
storeComboQuadrant.addAll(quadrantColumns);
|
||||||
|
|
||||||
|
comboQuadrant = new ComboBox<ColumnData>(storeComboQuadrant,
|
||||||
|
propsColumnData.label());
|
||||||
|
Log.trace("Combo Quadrant created");
|
||||||
|
|
||||||
|
addHandlersForComboQuadrant(propsColumnData.label());
|
||||||
|
|
||||||
|
comboQuadrant.setEmptyText("Select a column...");
|
||||||
|
comboQuadrant.setWidth(191);
|
||||||
|
comboQuadrant.setTypeAhead(false);
|
||||||
|
comboQuadrant.setEditable(false);
|
||||||
|
comboQuadrant.setTriggerAction(TriggerAction.ALL);
|
||||||
|
|
||||||
|
comboQuadrantField = new FieldLabel(comboQuadrant, "Quadrant");
|
||||||
|
|
||||||
// Create
|
// Create
|
||||||
createCoordinatesButton = new TextButton("Create");
|
createCoordinatesButton = new TextButton("Create");
|
||||||
createCoordinatesButton.setIcon(ResourceBundle.INSTANCE
|
createCoordinatesButton.setIcon(ResourceBundle.INSTANCE
|
||||||
|
@ -217,16 +296,18 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
vl.add(new FieldLabel(comboGsCoordinatesType, "Type"),
|
vl.add(new FieldLabel(comboGsCoordinatesType, "Type"),
|
||||||
new VerticalLayoutData(1, -1));
|
new VerticalLayoutData(1, -1));
|
||||||
|
|
||||||
|
vl.add(hasQuadrantField, new VerticalLayoutData(-1, -1));
|
||||||
|
|
||||||
|
vl.add(comboQuadrantField, new VerticalLayoutData(1, -1));
|
||||||
|
|
||||||
vl.add(createCoordinatesButton, new VerticalLayoutData(-1, -1,
|
vl.add(createCoordinatesButton, new VerticalLayoutData(-1, -1,
|
||||||
new Margins(10, 0, 10, 0)));
|
new Margins(10, 0, 10, 0)));
|
||||||
|
|
||||||
add(vl);
|
add(vl);
|
||||||
|
|
||||||
if (gsCoordinatesType != null) {
|
updateForCoordinatesType();
|
||||||
comboGsCoordinatesType.setValue(gsCoordinatesType);
|
|
||||||
}
|
|
||||||
|
|
||||||
onResize();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addHandlersForComboColumnLatitude(
|
private void addHandlersForComboColumnLatitude(
|
||||||
|
@ -301,7 +382,7 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
Log.debug("Type selected: " + event.getSelectedItem());
|
Log.debug("Type selected: " + event.getSelectedItem());
|
||||||
GeospatialCoordinatesType type = event
|
GeospatialCoordinatesType type = event
|
||||||
.getSelectedItem();
|
.getSelectedItem();
|
||||||
updatedType(type);
|
updatedComboGsCoordinatesType(type);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -309,11 +390,71 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void updatedType(GeospatialCoordinatesType type) {
|
protected void updatedComboGsCoordinatesType(GeospatialCoordinatesType type) {
|
||||||
|
gsCoordinatesType=type;
|
||||||
|
updateForCoordinatesType();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void updateForCoordinatesType() {
|
||||||
|
switch (gsCoordinatesType) {
|
||||||
|
case C_SQUARE:
|
||||||
|
hasQuadrantField.setVisible(false);
|
||||||
|
comboQuadrantField.setVisible(false);
|
||||||
|
comboGsCoordinatesType.setValue(gsCoordinatesType);
|
||||||
|
break;
|
||||||
|
case OCEAN_AREA:
|
||||||
|
hasQuadrantTrue.setValue(true);
|
||||||
|
hasQuadrantField.setVisible(true);
|
||||||
|
comboQuadrantField.setVisible(true);
|
||||||
|
comboGsCoordinatesType.setValue(gsCoordinatesType);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
hasQuadrantField.setVisible(false);
|
||||||
|
comboQuadrantField.setVisible(false);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
onResize();
|
||||||
|
forceLayout();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void addHandlersForComboQuadrant(
|
||||||
|
final LabelProvider<ColumnData> labelProvider) {
|
||||||
|
comboQuadrant.addSelectionHandler(new SelectionHandler<ColumnData>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSelection(SelectionEvent<ColumnData> event) {
|
||||||
|
Info.display(
|
||||||
|
"Quadrant Selected",
|
||||||
|
"You selected "
|
||||||
|
+ (event.getSelectedItem() == null ? "nothing"
|
||||||
|
: labelProvider.getLabel(event
|
||||||
|
.getSelectedItem()) + "!"));
|
||||||
|
Log.debug("Quadrant selected: " + event.getSelectedItem());
|
||||||
|
ColumnData quadrant = event.getSelectedItem();
|
||||||
|
updatedQuadrant(quadrant);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void updatedQuadrant(ColumnData quadrant) {
|
||||||
// TODO Auto-generated method stub
|
// TODO Auto-generated method stub
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected boolean hasQuadrant() {
|
||||||
|
if (hasQuadrantTrue.getValue()) {
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
protected void onGeospatialCreateCoordinates() {
|
protected void onGeospatialCreateCoordinates() {
|
||||||
ColumnData latitude = comboLatitude.getCurrentValue();
|
ColumnData latitude = comboLatitude.getCurrentValue();
|
||||||
if (latitude != null) {
|
if (latitude != null) {
|
||||||
|
@ -322,9 +463,41 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
GeospatialCoordinatesType type = comboGsCoordinatesType
|
GeospatialCoordinatesType type = comboGsCoordinatesType
|
||||||
.getCurrentValue();
|
.getCurrentValue();
|
||||||
if (type != null) {
|
if (type != null) {
|
||||||
GeospatialCreateCoordinatesSession gsCreateCoordinatesSession = new GeospatialCreateCoordinatesSession(
|
GeospatialCreateCoordinatesSession gsCreateCoordinatesSession;
|
||||||
trId, latitude, longitude, type);
|
switch(type){
|
||||||
callGeospatialCreateCoordinates(gsCreateCoordinatesSession);
|
case C_SQUARE:
|
||||||
|
gsCreateCoordinatesSession = new GeospatialCreateCoordinatesSession(
|
||||||
|
trId, latitude, longitude, type, false, null);
|
||||||
|
callGeospatialCreateCoordinates(gsCreateCoordinatesSession);
|
||||||
|
break;
|
||||||
|
case OCEAN_AREA:
|
||||||
|
if(hasQuadrant()){
|
||||||
|
ColumnData quadrant = comboQuadrant.getCurrentValue();
|
||||||
|
if(quadrant!=null){
|
||||||
|
gsCreateCoordinatesSession = new GeospatialCreateCoordinatesSession(
|
||||||
|
trId, latitude, longitude, type, true, quadrant);
|
||||||
|
callGeospatialCreateCoordinates(gsCreateCoordinatesSession);
|
||||||
|
} else {
|
||||||
|
UtilsGXT3.alert("Attention",
|
||||||
|
"Select Quadrant column!");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
gsCreateCoordinatesSession = new GeospatialCreateCoordinatesSession(
|
||||||
|
trId, latitude, longitude, type, false, null);
|
||||||
|
callGeospatialCreateCoordinates(gsCreateCoordinatesSession);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
UtilsGXT3.alert("Attention",
|
||||||
|
"Select valid geospatial coordinates type!");
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
UtilsGXT3.alert("Attention",
|
UtilsGXT3.alert("Attention",
|
||||||
"Invalid Geospatial Coordinates Type!");
|
"Invalid Geospatial Coordinates Type!");
|
||||||
|
@ -417,10 +590,14 @@ public class GeospatialCreateCoordinatesPanel extends FramedPanel implements
|
||||||
.getColumnDataTypeFromId(column
|
.getColumnDataTypeFromId(column
|
||||||
.getDataTypeName());
|
.getDataTypeName());
|
||||||
if (columnDataType
|
if (columnDataType
|
||||||
.compareTo(ColumnDataType.Integer) == 0
|
.compareTo(ColumnDataType.Numeric) == 0) {
|
||||||
|| columnDataType
|
|
||||||
.compareTo(ColumnDataType.Numeric) == 0) {
|
|
||||||
columns.add(column);
|
columns.add(column);
|
||||||
|
} else {
|
||||||
|
if (columnDataType
|
||||||
|
.compareTo(ColumnDataType.Integer) == 0) {
|
||||||
|
columns.add(column);
|
||||||
|
quadrantColumns.add(column);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue