Minor Update
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-table-widget@95693 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
924d659745
commit
85be5cfce1
|
@ -1,12 +1,11 @@
|
||||||
package org.gcube.portlets.user.td.tablewidget.client.rows;
|
package org.gcube.portlets.user.td.tablewidget.client.rows;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
|
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.tr.rows.DeleteRowsSession;
|
import org.gcube.portlets.user.td.gwtservice.shared.tr.rows.DeleteRowsSession;
|
||||||
import org.gcube.portlets.user.td.tablewidget.client.progress.DeleteRowsProgressDialog;
|
import org.gcube.portlets.user.td.tablewidget.client.progress.DeleteRowsProgressDialog;
|
||||||
import org.gcube.portlets.user.td.tablewidget.client.resources.ResourceBundle;
|
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.tablewidget.client.util.UtilsGXT3;
|
||||||
import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId;
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId;
|
||||||
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.grid.model.RowRaw;
|
||||||
|
|
||||||
import com.google.web.bindery.event.shared.EventBus;
|
import com.google.web.bindery.event.shared.EventBus;
|
||||||
import com.sencha.gxt.widget.core.client.Window;
|
import com.sencha.gxt.widget.core.client.Window;
|
||||||
|
@ -24,20 +23,20 @@ public class EditRowDialog extends Window {
|
||||||
protected String HEIGHT = "486px";
|
protected String HEIGHT = "486px";
|
||||||
protected TRId trId;
|
protected TRId trId;
|
||||||
protected EventBus eventBus;
|
protected EventBus eventBus;
|
||||||
protected ArrayList<String> rows;
|
protected RowRaw row;
|
||||||
protected DeleteRowsSession deleteRowsSession;
|
protected DeleteRowsSession deleteRowsSession;
|
||||||
protected DeleteRowsProgressDialog deleteRowsProgressDialog;
|
protected DeleteRowsProgressDialog deleteRowsProgressDialog;
|
||||||
|
|
||||||
public EditRowDialog(TRId trId, ArrayList<String> rows, EventBus eventBus) {
|
public EditRowDialog(TRId trId, RowRaw row, EventBus eventBus) {
|
||||||
this.trId = trId;
|
this.trId = trId;
|
||||||
this.rows = rows;
|
this.row = row;
|
||||||
this.eventBus = eventBus;
|
this.eventBus = eventBus;
|
||||||
if (rows == null || rows.size() <= 0) {
|
if (row == null) {
|
||||||
UtilsGXT3.alert("Attentions",
|
UtilsGXT3.alert("Attentions",
|
||||||
"No row selected");
|
"No row selected");
|
||||||
} else {
|
} else {
|
||||||
initWindow();
|
initWindow();
|
||||||
EditRowPanel editRowPanel = new EditRowPanel(this, trId, rows,
|
EditRowPanel editRowPanel = new EditRowPanel(this, trId, row,
|
||||||
eventBus);
|
eventBus);
|
||||||
add(editRowPanel);
|
add(editRowPanel);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package org.gcube.portlets.user.td.tablewidget.client.rows;
|
package org.gcube.portlets.user.td.tablewidget.client.rows;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
import org.gcube.portlets.user.td.columnwidget.client.dimension.DimensionRowSelectionDialog;
|
import org.gcube.portlets.user.td.columnwidget.client.dimension.DimensionRowSelectionDialog;
|
||||||
import org.gcube.portlets.user.td.columnwidget.client.dimension.DimensionRowSelectionListener;
|
import org.gcube.portlets.user.td.columnwidget.client.dimension.DimensionRowSelectionListener;
|
||||||
|
@ -12,6 +13,7 @@ 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.tablewidget.client.util.UtilsGXT3;
|
||||||
import org.gcube.portlets.user.td.widgetcommonevent.shared.CellData;
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.CellData;
|
||||||
import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId;
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId;
|
||||||
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.grid.model.RowRaw;
|
||||||
import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnDataType;
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnDataType;
|
||||||
import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnTypeCode;
|
import org.gcube.portlets.user.td.widgetcommonevent.shared.tr.column.ColumnTypeCode;
|
||||||
|
|
||||||
|
@ -19,12 +21,14 @@ 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.ValueChangeEvent;
|
import com.google.gwt.event.logical.shared.ValueChangeEvent;
|
||||||
import com.google.gwt.event.logical.shared.ValueChangeHandler;
|
import com.google.gwt.event.logical.shared.ValueChangeHandler;
|
||||||
|
import com.google.gwt.i18n.client.DateTimeFormat;
|
||||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
import com.google.gwt.user.client.ui.HorizontalPanel;
|
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.util.Margins;
|
import com.sencha.gxt.core.client.util.Margins;
|
||||||
|
import com.sencha.gxt.core.client.util.ToggleGroup;
|
||||||
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;
|
||||||
import com.sencha.gxt.widget.core.client.button.TextButton;
|
import com.sencha.gxt.widget.core.client.button.TextButton;
|
||||||
|
@ -58,24 +62,24 @@ public class EditRowPanel extends FramedPanel {
|
||||||
protected EditRowDialog parent;
|
protected EditRowDialog parent;
|
||||||
protected TRId trId;
|
protected TRId trId;
|
||||||
protected EventBus eventBus;
|
protected EventBus eventBus;
|
||||||
protected ArrayList<String> rows;
|
|
||||||
protected ArrayList<ColumnData> columns;
|
protected ArrayList<ColumnData> columns;
|
||||||
protected String currentRow;
|
protected RowRaw rowRaw;
|
||||||
|
|
||||||
private TextButton btnSave;
|
private TextButton btnSave;
|
||||||
private TextButton btnClose;
|
private TextButton btnClose;
|
||||||
|
|
||||||
public EditRowPanel(EditRowDialog parent, TRId trId,
|
private DateTimeFormat sdf= DateTimeFormat.getFormat("yyyy-MM-dd");
|
||||||
ArrayList<String> rows, EventBus eventBus) {
|
|
||||||
|
public EditRowPanel(EditRowDialog parent, TRId trId, RowRaw row,
|
||||||
|
EventBus eventBus) {
|
||||||
super();
|
super();
|
||||||
this.parent = parent;
|
this.parent = parent;
|
||||||
this.trId = trId;
|
this.trId = trId;
|
||||||
this.rows = rows;
|
this.rowRaw = row;
|
||||||
this.eventBus = eventBus;
|
this.eventBus = eventBus;
|
||||||
Log.debug("Create EditRowPanel(): [" + trId.toString() + " , rows:"
|
Log.debug("Create EditRowPanel(): [" + trId.toString() + " , RowRaw:"
|
||||||
+ rows + "]");
|
+ row + "]");
|
||||||
if (rows == null || rows.size() <= 0) {
|
if (rowRaw == null) {
|
||||||
currentRow = rows.get(0);
|
|
||||||
UtilsGXT3.alert("Attentions", "No row selected");
|
UtilsGXT3.alert("Attentions", "No row selected");
|
||||||
} else {
|
} else {
|
||||||
init();
|
init();
|
||||||
|
@ -180,8 +184,8 @@ public class EditRowPanel extends FramedPanel {
|
||||||
ColumnTypeCode.DIMENSION.toString()) == 0
|
ColumnTypeCode.DIMENSION.toString()) == 0
|
||||||
|| col.getTypeCode().compareTo(
|
|| col.getTypeCode().compareTo(
|
||||||
ColumnTypeCode.TIMEDIMENSION.toString()) == 0) {
|
ColumnTypeCode.TIMEDIMENSION.toString()) == 0) {
|
||||||
|
|
||||||
FieldLabel dimensionLabel=retrieveDimensionLabel(col);
|
FieldLabel dimensionLabel = retrieveDimensionLabel(col);
|
||||||
fields.add(dimensionLabel);
|
fields.add(dimensionLabel);
|
||||||
} else {
|
} else {
|
||||||
if (col.getDataTypeName().compareTo(
|
if (col.getDataTypeName().compareTo(
|
||||||
|
@ -190,9 +194,21 @@ public class EditRowPanel extends FramedPanel {
|
||||||
radioTrue.setBoxLabel("true");
|
radioTrue.setBoxLabel("true");
|
||||||
Radio radioFalse = new Radio();
|
Radio radioFalse = new Radio();
|
||||||
radioFalse.setBoxLabel("false");
|
radioFalse.setBoxLabel("false");
|
||||||
|
|
||||||
|
String value=rowRaw.getMap().get(col.getColumnId());
|
||||||
|
if(new Boolean(value)){
|
||||||
|
radioTrue.setValue(true);
|
||||||
|
} else {
|
||||||
|
radioFalse.setValue(true);
|
||||||
|
}
|
||||||
|
ToggleGroup toggleGroup = new ToggleGroup();
|
||||||
|
toggleGroup.add(radioTrue);
|
||||||
|
toggleGroup.add(radioFalse);
|
||||||
|
|
||||||
HorizontalPanel hp = new HorizontalPanel();
|
HorizontalPanel hp = new HorizontalPanel();
|
||||||
hp.add(radioTrue);
|
hp.add(radioTrue);
|
||||||
hp.add(radioFalse);
|
hp.add(radioFalse);
|
||||||
|
|
||||||
FieldLabel booleanLabel = new FieldLabel(hp,
|
FieldLabel booleanLabel = new FieldLabel(hp,
|
||||||
col.getLabel());
|
col.getLabel());
|
||||||
booleanLabel.setId(col.getColumnId());
|
booleanLabel.setId(col.getColumnId());
|
||||||
|
@ -201,6 +217,16 @@ public class EditRowPanel extends FramedPanel {
|
||||||
if (col.getDataTypeName().compareTo(
|
if (col.getDataTypeName().compareTo(
|
||||||
ColumnDataType.Date.toString()) == 0) {
|
ColumnDataType.Date.toString()) == 0) {
|
||||||
DateField date = new DateField();
|
DateField date = new DateField();
|
||||||
|
String value=rowRaw.getMap().get(col.getColumnId());
|
||||||
|
Date d=null;
|
||||||
|
try{
|
||||||
|
d=sdf.parse(value);
|
||||||
|
} catch(Throwable e){
|
||||||
|
Log.error("Error parsing date string: "+e.getLocalizedMessage());
|
||||||
|
}
|
||||||
|
if(d!=null){
|
||||||
|
date.setValue(d);
|
||||||
|
}
|
||||||
FieldLabel dateLabel = new FieldLabel(date,
|
FieldLabel dateLabel = new FieldLabel(date,
|
||||||
col.getLabel());
|
col.getLabel());
|
||||||
dateLabel.setId(col.getColumnId());
|
dateLabel.setId(col.getColumnId());
|
||||||
|
@ -209,6 +235,8 @@ public class EditRowPanel extends FramedPanel {
|
||||||
if (col.getDataTypeName().compareTo(
|
if (col.getDataTypeName().compareTo(
|
||||||
ColumnDataType.Text.toString()) == 0) {
|
ColumnDataType.Text.toString()) == 0) {
|
||||||
TextField text = new TextField();
|
TextField text = new TextField();
|
||||||
|
String value=rowRaw.getMap().get(col.getColumnId());
|
||||||
|
text.setValue(value);
|
||||||
text.addValueChangeHandler(new ValueChangeHandler<String>() {
|
text.addValueChangeHandler(new ValueChangeHandler<String>() {
|
||||||
@Override
|
@Override
|
||||||
public void onValueChange(
|
public void onValueChange(
|
||||||
|
@ -224,6 +252,8 @@ public class EditRowPanel extends FramedPanel {
|
||||||
if (col.getDataTypeName().compareTo(
|
if (col.getDataTypeName().compareTo(
|
||||||
ColumnDataType.Geometry.toString()) == 0) {
|
ColumnDataType.Geometry.toString()) == 0) {
|
||||||
TextField geometry = new TextField();
|
TextField geometry = new TextField();
|
||||||
|
String value=rowRaw.getMap().get(col.getColumnId());
|
||||||
|
geometry.setValue(value);
|
||||||
geometry.addValueChangeHandler(new ValueChangeHandler<String>() {
|
geometry.addValueChangeHandler(new ValueChangeHandler<String>() {
|
||||||
@Override
|
@Override
|
||||||
public void onValueChange(
|
public void onValueChange(
|
||||||
|
@ -239,7 +269,8 @@ public class EditRowPanel extends FramedPanel {
|
||||||
if (col.getDataTypeName().compareTo(
|
if (col.getDataTypeName().compareTo(
|
||||||
ColumnDataType.Integer.toString()) == 0) {
|
ColumnDataType.Integer.toString()) == 0) {
|
||||||
TextField integ = new TextField();
|
TextField integ = new TextField();
|
||||||
|
String value=rowRaw.getMap().get(col.getColumnId());
|
||||||
|
integ.setValue(value);
|
||||||
integ.addValueChangeHandler(new ValueChangeHandler<String>() {
|
integ.addValueChangeHandler(new ValueChangeHandler<String>() {
|
||||||
@Override
|
@Override
|
||||||
public void onValueChange(
|
public void onValueChange(
|
||||||
|
@ -256,6 +287,8 @@ public class EditRowPanel extends FramedPanel {
|
||||||
ColumnDataType.Numeric
|
ColumnDataType.Numeric
|
||||||
.toString()) == 0) {
|
.toString()) == 0) {
|
||||||
TextField numeric = new TextField();
|
TextField numeric = new TextField();
|
||||||
|
String value=rowRaw.getMap().get(col.getColumnId());
|
||||||
|
numeric.setValue(value);
|
||||||
numeric.setId(col.getColumnId());
|
numeric.setId(col.getColumnId());
|
||||||
numeric.addValueChangeHandler(new ValueChangeHandler<String>() {
|
numeric.addValueChangeHandler(new ValueChangeHandler<String>() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -284,54 +317,50 @@ public class EditRowPanel extends FramedPanel {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected FieldLabel retrieveDimensionLabel(final ColumnData col) {
|
||||||
protected FieldLabel retrieveDimensionLabel(final ColumnData col){
|
|
||||||
// comboDimension
|
// comboDimension
|
||||||
DimensionRowsProperties propsDimension = GWT
|
DimensionRowsProperties propsDimension = GWT
|
||||||
.create(DimensionRowsProperties.class);
|
.create(DimensionRowsProperties.class);
|
||||||
ListStore<DimensionRow> storeComboDimensionType = new ListStore<DimensionRow>(
|
ListStore<DimensionRow> storeComboDimensionType = new ListStore<DimensionRow>(
|
||||||
propsDimension.rowId());
|
propsDimension.rowId());
|
||||||
|
|
||||||
|
|
||||||
final ComboBox<DimensionRow> comboDimension = new ComboBox<DimensionRow>(
|
final ComboBox<DimensionRow> comboDimension = new ComboBox<DimensionRow>(
|
||||||
storeComboDimensionType, propsDimension.value());
|
storeComboDimensionType, propsDimension.value());
|
||||||
|
|
||||||
Log.debug("ComboDimensionType created");
|
Log.debug("ComboDimensionType created");
|
||||||
|
|
||||||
|
final DimensionRowSelectionListener listener = new DimensionRowSelectionListener() {
|
||||||
|
|
||||||
final DimensionRowSelectionListener listener=new DimensionRowSelectionListener() {
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void selectedDimensionRow(DimensionRow dimensionRow) {
|
public void selectedDimensionRow(DimensionRow dimensionRow) {
|
||||||
comboDimension.setValue(dimensionRow);
|
comboDimension.setValue(dimensionRow);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void failedDimensionRowSelection(String reason, String detail) {
|
public void failedDimensionRowSelection(String reason, String detail) {
|
||||||
Log.error("Change Value Failed:" + reason + " " + detail);
|
Log.error("Change Value Failed:" + reason + " " + detail);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void abortedDimensionRowSelection() {
|
public void abortedDimensionRowSelection() {
|
||||||
Log.debug("Change Value Aborted");
|
Log.debug("Change Value Aborted");
|
||||||
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
final CellData cellData = new CellData(currentRow,
|
final CellData cellData = new CellData(rowRaw.getMap().get(
|
||||||
col.getName(), col.getColumnId(), col.getLabel(),
|
col.getColumnId()), col.getName(), col.getColumnId(),
|
||||||
currentRow, 0, 0);
|
col.getLabel(), rowRaw.getRowId(), 0, 0);
|
||||||
|
|
||||||
comboDimension.addTriggerClickHandler(new TriggerClickHandler() {
|
comboDimension.addTriggerClickHandler(new TriggerClickHandler() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onTriggerClick(TriggerClickEvent event) {
|
public void onTriggerClick(TriggerClickEvent event) {
|
||||||
Log.debug("ComboDimensionRows TriggerClickEvent");
|
Log.debug("ComboDimensionRows TriggerClickEvent");
|
||||||
comboDimension.collapse();
|
comboDimension.collapse();
|
||||||
|
|
||||||
DimensionRowSelectionDialog dialogDimensionRowSelection = new DimensionRowSelectionDialog(
|
DimensionRowSelectionDialog dialogDimensionRowSelection = new DimensionRowSelectionDialog(
|
||||||
col, cellData, eventBus);
|
col, cellData, eventBus);
|
||||||
dialogDimensionRowSelection.addListener(listener);
|
dialogDimensionRowSelection.addListener(listener);
|
||||||
|
@ -346,12 +375,10 @@ public class EditRowPanel extends FramedPanel {
|
||||||
comboDimension.setEditable(false);
|
comboDimension.setEditable(false);
|
||||||
comboDimension.setTriggerAction(TriggerAction.ALL);
|
comboDimension.setTriggerAction(TriggerAction.ALL);
|
||||||
|
|
||||||
|
|
||||||
FieldLabel dimensionLabel = new FieldLabel(comboDimension,
|
FieldLabel dimensionLabel = new FieldLabel(comboDimension,
|
||||||
col.getLabel());
|
col.getLabel());
|
||||||
dimensionLabel.setId(col.getColumnId());
|
dimensionLabel.setId(col.getColumnId());
|
||||||
return dimensionLabel;
|
return dimensionLabel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue