Updated EditRow to manage to more than one row

git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-table-widget@111328 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
Giancarlo Panichi 2015-01-09 17:16:50 +00:00 committed by Giancarlo Panichi
parent 9243ec04e3
commit c8e081d048
2 changed files with 204 additions and 140 deletions

View File

@ -1,5 +1,7 @@
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.tablewidget.client.resources.ResourceBundle;
import org.gcube.portlets.user.td.tablewidget.client.util.UtilsGXT3;
@ -22,29 +24,29 @@ public class EditRowDialog extends Window {
protected String HEIGHT = "456px";
protected TRId trId;
protected EventBus eventBus;
protected RowRaw row;
protected ArrayList<RowRaw> rows;
protected DeleteRowsSession deleteRowsSession;
private boolean addRow;
/**
* Edit selected row
* Edit selected rows
*
* @param trId
* @param row
* @param rows
* @param eventBus
*/
public EditRowDialog(TRId trId, RowRaw row, EventBus eventBus) {
public EditRowDialog(TRId trId, ArrayList<RowRaw> rows, EventBus eventBus) {
this.trId = trId;
this.row = row;
//this.rows = rows;
this.eventBus = eventBus;
addRow = false;
if (row == null) {
if (rows == null) {
UtilsGXT3.alert("Attentions", "No row selected");
} else {
initWindow();
EditRowPanel editRowPanel = new EditRowPanel(this, trId, row,
EditRowPanel editRowPanel = new EditRowPanel(this, trId, rows,
eventBus);
add(editRowPanel);
}

View File

@ -61,6 +61,7 @@ import com.sencha.gxt.widget.core.client.event.TriggerClickEvent.TriggerClickHan
import com.sencha.gxt.widget.core.client.form.ComboBox;
import com.sencha.gxt.widget.core.client.form.DateField;
import com.sencha.gxt.widget.core.client.form.FieldLabel;
import com.sencha.gxt.widget.core.client.form.FieldSet;
import com.sencha.gxt.widget.core.client.form.Radio;
import com.sencha.gxt.widget.core.client.form.TextField;
import com.sencha.gxt.widget.core.client.form.validator.RegExValidator;
@ -71,22 +72,27 @@ import com.sencha.gxt.widget.core.client.form.validator.RegExValidator;
*
*/
public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
private static final String ITEM_CREATE_ROW = "NewRow";
private static final String GEOMETRY_REGEXPR = "(\\s*POINT\\s*\\(\\s*(-)?\\d+(\\.\\d+)?\\s+(-)?\\d+(\\.\\d+)?\\s*\\)\\s*$)"
+ "|(\\s*LINESTRING\\s*\\((\\s*(-)?\\d+(\\.\\d+)?\\s+(-)?\\d+(\\.\\d+)?\\s*,)+\\s*((-)?\\d+(\\.\\d+)?\\s+(-)?\\d+(\\.\\d+)?\\s*)\\)\\s*$)";
protected String WIDTH = "510px";
protected String HEIGHT = "370px";
protected String FIELDSHEIGHT = "370px";
protected int LABELSIZE = 120;
private static final String WIDTH = "510px";
private static final String HEIGHT = "370px";
private static final String FIELDSHEIGHT = "370px";
private static final int LABELSIZE = 120;
protected EditRowDialog parent;
protected TRId trId;
protected EventBus eventBus;
protected ArrayList<ColumnData> columns;
protected RowRaw rowRaw;
protected boolean editRow;
private EditRowDialog parent;
private TRId trId;
private EventBus eventBus;
private ArrayList<ColumnData> columns;
private ArrayList<RowRaw> rowsRaw;
private boolean editRow;
private VerticalLayoutContainer v;
private ArrayList<String> rowsId;
protected VerticalLayoutContainer v;
private TextButton btnSave;
private TextButton btnClose;
@ -97,20 +103,20 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
*
* @param parent
* @param trId
* @param rowRaw
* @param rowsRaw
* @param eventBus
*/
public EditRowPanel(EditRowDialog parent, TRId trId, RowRaw rowRaw,
EventBus eventBus) {
public EditRowPanel(EditRowDialog parent, TRId trId,
ArrayList<RowRaw> rowsRaw, EventBus eventBus) {
super();
this.parent = parent;
this.trId = trId;
this.rowRaw = rowRaw;
this.rowsRaw = rowsRaw;
this.eventBus = eventBus;
this.editRow = true;
Log.debug("Create EditRowPanel(): [" + trId.toString() + " , RowRaw:"
+ rowRaw + "]");
if (rowRaw == null) {
Log.debug("Create EditRowPanel(): [" + trId.toString() + " , RowsRaw:"
+ rowsRaw + "]");
if (rowsRaw == null || rowsRaw.isEmpty()) {
UtilsGXT3.alert("Attentions", "No row selected");
} else {
init();
@ -190,10 +196,45 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
flowButton.add(btnSave, new BoxLayoutData(new Margins(2, 4, 2, 4)));
flowButton.add(btnClose, new BoxLayoutData(new Margins(2, 4, 2, 4)));
ArrayList<FieldLabel> fields = generateFields();
for (FieldLabel fl : fields) {
v.add(fl, new VerticalLayoutData(1, -1, new Margins(1)));
rowsId=new ArrayList<String>();
if (editRow) {
for (RowRaw rowRaw : rowsRaw) {
FieldSet fieldSet = new FieldSet();
fieldSet.setCollapsible(false);
fieldSet.setItemId(rowRaw.getRowId());
rowsId.add(rowRaw.getRowId());
VerticalLayoutContainer fieldSetLayout = new VerticalLayoutContainer();
fieldSetLayout.setScrollMode(ScrollMode.AUTO);
fieldSet.add(fieldSetLayout);
ArrayList<FieldLabel> fields = generateFields(rowRaw);
for (FieldLabel fl : fields) {
fieldSetLayout.add(fl, new VerticalLayoutData(1, -1,
new Margins(1)));
}
v.add(fieldSet, new VerticalLayoutData(1, -1, new Margins(1)));
}
} else {
FieldSet fieldSet = new FieldSet();
fieldSet.setCollapsible(false);
fieldSet.setItemId(ITEM_CREATE_ROW);
rowsId.add(ITEM_CREATE_ROW);
VerticalLayoutContainer fieldSetLayout = new VerticalLayoutContainer();
fieldSetLayout.setScrollMode(ScrollMode.AUTO);
fieldSet.add(fieldSetLayout);
ArrayList<FieldLabel> fields = generateFields(null);
for (FieldLabel fl : fields) {
fieldSetLayout.add(fl, new VerticalLayoutData(1, -1,
new Margins(1)));
}
v.add(fieldSet, new VerticalLayoutData(1, -1, new Margins(1)));
}
container.forceLayout();
@ -236,7 +277,7 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
}
protected ArrayList<FieldLabel> generateFields() {
protected ArrayList<FieldLabel> generateFields(RowRaw rowRaw) {
ArrayList<FieldLabel> fields = new ArrayList<FieldLabel>();
for (ColumnData col : columns) {
@ -254,8 +295,8 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
|| col.getTypeCode().compareTo(
ColumnTypeCode.TIMEDIMENSION.toString()) == 0) {
FieldLabel dimensionLabel = retrieveDimensionLabel(col,
label);
FieldLabel dimensionLabel = retrieveDimensionLabel(rowRaw,
col, label);
dimensionLabel.setLabelWidth(LABELSIZE);
fields.add(dimensionLabel);
} else {
@ -424,8 +465,8 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
}
protected FieldLabel retrieveDimensionLabel(final ColumnData col,
String label) {
protected FieldLabel retrieveDimensionLabel(RowRaw rowRaw,
final ColumnData col, String label) {
Log.debug("retriveDimensionLabel on:" + col);
// comboDimension
DimensionRowsProperties propsDimension = GWT
@ -503,10 +544,19 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
protected void save() {
int i = 0;
int lenght = v.getWidgetCount();
HashMap<String, String> maps = new HashMap<String, String>();
HashMap<String, HashMap<String, String>> rowsMaps = new HashMap<String, HashMap<String, String>>();
for (; i < lenght; i++) {
FieldLabel fieldLabel = (FieldLabel) v.getWidget(i);
FieldSet fieldSet = (FieldSet) v.getWidget(i);
VerticalLayoutContainer fieldSetLayout = (VerticalLayoutContainer) fieldSet
.getWidget();
int j = 0;
int fieldSetLayoutLenght = fieldSetLayout.getWidgetCount();
HashMap<String, String> maps = new HashMap<String, String>();
for (; j < fieldSetLayoutLenght; j++) {
FieldLabel fieldLabel = (FieldLabel) fieldSetLayout
.getWidget(j);
String columnId = fieldLabel.getId();
ColumnData colCurrent = null;
for (ColumnData col : columns) {
@ -531,7 +581,9 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
if (dimRow == null
|| (dimRow != null && (dimRow.getRowId() == null || dimRow
.getRowId().isEmpty()))) {
UtilsGXT3.alert("Attentions", "Select a valid value for "
UtilsGXT3.alert(
"Attentions",
"Select a valid value for "
+ colCurrent.getLabel());
btnSave.enable();
return;
@ -558,7 +610,8 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
} else {
if (colCurrent.getDataTypeName().compareTo(
ColumnDataType.Text.toString()) == 0) {
TextField text = (TextField) fieldLabel.getWidget();
TextField text = (TextField) fieldLabel
.getWidget();
String val = text.getCurrentValue();
if (val == null) {
val = "";
@ -598,21 +651,26 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
} catch (NumberFormatException e) {
UtilsGXT3
.alert("Attentions",
colCurrent.getLabel()
colCurrent
.getLabel()
+ " is no a valid Integer type");
btnSave.enable();
return;
}
maps.put(columnId, integ.getCurrentValue());
maps.put(columnId,
integ.getCurrentValue());
} else {
if (colCurrent.getDataTypeName().compareTo(
ColumnDataType.Numeric.toString()) == 0) {
if (colCurrent.getDataTypeName()
.compareTo(
ColumnDataType.Numeric
.toString()) == 0) {
TextField numeric = (TextField) fieldLabel
.getWidget();
@SuppressWarnings("unused")
Double d;
String val = numeric.getCurrentValue();
String val = numeric
.getCurrentValue();
if (val == null) {
Log.debug("Attentions"
+ colCurrent.getLabel()
@ -652,12 +710,16 @@ public class EditRowPanel extends FramedPanel implements MonitorDialogListener {
}
}
rowsMaps.put(fieldSet.getItemId(), maps);
}
EditRowSession editRowSession;
if (editRow) {
editRowSession = new EditRowSession(trId, columns, maps,
rowRaw.getRowId());
editRowSession = new EditRowSession(trId, columns, rowsMaps,
rowsId);
} else {
editRowSession = new EditRowSession(trId, columns, maps);
editRowSession = new EditRowSession(trId, columns, rowsMaps);
}
callEditRow(editRowSession);