diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/properties/ValidationsProperties.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/properties/ValidationsProperties.java
new file mode 100644
index 0000000..d61f28b
--- /dev/null
+++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/properties/ValidationsProperties.java
@@ -0,0 +1,25 @@
+package org.gcube.portlets.user.td.tablewidget.client.properties;
+
+import org.gcube.portlets.user.td.gwtservice.shared.tr.table.Validations;
+
+import com.google.gwt.editor.client.Editor.Path;
+import com.sencha.gxt.core.client.ValueProvider;
+import com.sencha.gxt.data.shared.ModelKeyProvider;
+import com.sencha.gxt.data.shared.PropertyAccess;
+
+/**
+ *
+ * @author "Giancarlo Panichi"
+ * g.panichi@isti.cnr.it
+ *
+ */
+public interface ValidationsProperties extends
+ PropertyAccess {
+
+ @Path("id")
+ ModelKeyProvider id();
+
+ ValueProvider description();
+ ValueProvider valid();
+
+}
diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ResourceBundle.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ResourceBundle.java
index 228c54a..3558ae4 100644
--- a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ResourceBundle.java
+++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ResourceBundle.java
@@ -40,4 +40,16 @@ public interface ResourceBundle extends ClientBundle {
@Source("arrow-refresh_32.png")
ImageResource refresh32();
+ @Source("exit.png")
+ ImageResource exit();
+
+ @Source("exit_32.png")
+ ImageResource exit32();
+
+ @Source("ok.png")
+ ImageResource ok();
+
+ @Source("ok_32.png")
+ ImageResource ok32();
+
}
\ No newline at end of file
diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/exit.png b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/exit.png
new file mode 100644
index 0000000..74f4826
Binary files /dev/null and b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/exit.png differ
diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/exit_32.png b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/exit_32.png
new file mode 100644
index 0000000..89b102d
Binary files /dev/null and b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/exit_32.png differ
diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ok.png b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ok.png
new file mode 100644
index 0000000..3d93f52
Binary files /dev/null and b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ok.png differ
diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ok_32.png b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ok_32.png
new file mode 100644
index 0000000..dae05cd
Binary files /dev/null and b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/resources/ok_32.png differ
diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/rows/DuplicatesRowsPanel.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/rows/DuplicatesRowsPanel.java
index 13fea3f..820c0d5 100644
--- a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/rows/DuplicatesRowsPanel.java
+++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/rows/DuplicatesRowsPanel.java
@@ -149,6 +149,7 @@ public class DuplicatesRowsPanel extends FramedPanel {
FieldLabel columnsLabel = new FieldLabel(null, "Columns");
+ columnsLabel.getElement().applyStyles("font-weight:bold");
HBoxLayoutContainer hBox=new HBoxLayoutContainer();
hBox.add(validatesButton, new BoxLayoutData(new Margins(2,5,2,5)));
hBox.add(deleteButton,new BoxLayoutData(new Margins(2,5,2,5)));
@@ -156,8 +157,8 @@ public class DuplicatesRowsPanel extends FramedPanel {
VerticalLayoutContainer v = new VerticalLayoutContainer();
v.setScrollMode(ScrollMode.AUTO);
- v.add(columnsLabel, new VerticalLayoutData(-1, -1, new Margins(0)));
- v.add(grid, new VerticalLayoutData(-1, -1, new Margins(0)));
+ v.add(columnsLabel, new VerticalLayoutData(-1, -1, new Margins(2,1,5,1)));
+ v.add(grid, new VerticalLayoutData(1, -1, new Margins(0)));
v.add(hBox, new VerticalLayoutData(-1, -1, new Margins(10, 0,
10, 0)));
add(v, new VerticalLayoutData(-1, -1, new Margins(0)));
diff --git a/src/main/java/org/gcube/portlets/user/td/tablewidget/client/validation/ValidationsTablePanel.java b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/validation/ValidationsTablePanel.java
new file mode 100644
index 0000000..34954b1
--- /dev/null
+++ b/src/main/java/org/gcube/portlets/user/td/tablewidget/client/validation/ValidationsTablePanel.java
@@ -0,0 +1,215 @@
+package org.gcube.portlets.user.td.tablewidget.client.validation;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import org.gcube.portlets.user.td.gwtservice.client.rpc.TDGWTServiceAsync;
+import org.gcube.portlets.user.td.gwtservice.shared.tr.TableData;
+import org.gcube.portlets.user.td.gwtservice.shared.tr.table.Validations;
+import org.gcube.portlets.user.td.gwtservice.shared.tr.table.metadata.TabValidationsMetadata;
+import org.gcube.portlets.user.td.tablewidget.client.properties.ValidationsProperties;
+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.shared.TRId;
+
+import com.allen_sauer.gwt.log.client.Log;
+import com.google.gwt.cell.client.AbstractCell;
+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.safehtml.shared.SafeHtmlBuilder;
+import com.google.gwt.user.client.rpc.AsyncCallback;
+import com.google.web.bindery.event.shared.EventBus;
+import com.sencha.gxt.core.client.dom.ScrollSupport.ScrollMode;
+import com.sencha.gxt.core.client.util.Margins;
+import com.sencha.gxt.data.client.loader.RpcProxy;
+import com.sencha.gxt.data.shared.ListStore;
+import com.sencha.gxt.data.shared.loader.ListLoadConfig;
+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.container.VerticalLayoutContainer;
+import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer.VerticalLayoutData;
+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.grid.ColumnConfig;
+import com.sencha.gxt.widget.core.client.grid.ColumnModel;
+import com.sencha.gxt.widget.core.client.grid.Grid;
+
+/**
+ *
+ * @author "Giancarlo Panichi" g.panichi@isti.cnr.it
+ *
+ */
+public class ValidationsTablePanel extends FramedPanel {
+ protected String WIDTH = "640px";
+ protected String HEIGHT = "520px";
+
+ protected TRId trId;
+ protected TableData table;
+ protected String headingTitle;
+ protected VerticalLayoutContainer vl;
+ protected EventBus eventBus;
+
+ protected ComboBox comboValidations;
+ protected ListStore storeValidations;
+ protected ListLoader> loader;
+ protected Grid grid;
+
+ public ValidationsTablePanel(TRId trId, EventBus eventBus) {
+ super();
+ this.trId = trId;
+ this.eventBus = eventBus;
+ forceLayoutOnResize = true;
+ init();
+ create();
+ }
+
+ protected void init() {
+ setWidth(WIDTH);
+ setHeight(HEIGHT);
+ setHeaderVisible(false);
+ setBodyBorder(false);
+ }
+
+ protected void create(){
+ ValidationsProperties props = GWT
+ .create(ValidationsProperties.class);
+
+
+ ColumnConfig descriptionCol = new ColumnConfig(
+ props.description(), 168, "Description");
+ ColumnConfig validCol = new ColumnConfig(
+ props.valid(), 32, "Valid");
+ validCol.setCell(new AbstractCell(){
+
+ @Override
+ public void render(Context context, Boolean value,
+ SafeHtmlBuilder sb) {
+
+ if(value){
+ sb.appendHtmlConstant("");
+
+ } else {
+ sb.appendHtmlConstant("");
+
+ }
+
+ }
+ });
+
+
+
+ List> l = new ArrayList>();
+ l.add(descriptionCol);
+ l.add(validCol);
+
+ ColumnModel cm = new ColumnModel(l);
+
+ storeValidations = new ListStore(props.id());
+
+
+
+ RpcProxy> proxy = new RpcProxy>() {
+
+ public void load(ListLoadConfig loadConfig,
+ final AsyncCallback> callback) {
+ loadData(loadConfig, callback);
+ }
+
+
+ };
+
+ loader = new ListLoader>(
+ proxy);
+
+ loader.setRemoteSort(false);
+ loader.addLoadHandler(new LoadResultListStoreBinding>(
+ storeValidations) {
+ });
+
+
+
+
+ grid = new Grid(storeValidations, cm) {
+ @Override
+ protected void onAfterFirstAttach() {
+ super.onAfterFirstAttach();
+ Scheduler.get().scheduleDeferred(new ScheduledCommand() {
+
+ public void execute() {
+ loader.load();
+ }
+ });
+ }
+ };
+
+ grid.setLoader(loader);
+ grid.setHeight(360);
+ grid.getView().setStripeRows(true);
+ grid.getView().setColumnLines(true);
+ grid.getView().setAutoFill(true);
+ grid.setBorders(false);
+ grid.setLoadMask(true);
+ grid.setColumnReordering(true);
+ grid.setColumnResize(true);
+ grid.getView().setAutoExpandColumn(descriptionCol);
+
+ FieldLabel validationsLabel = new FieldLabel(null, "Validations");
+ validationsLabel.getElement().applyStyles("font-weight:bold");
+
+ VerticalLayoutContainer v = new VerticalLayoutContainer();
+ v.setScrollMode(ScrollMode.AUTO);
+ v.add(validationsLabel, new VerticalLayoutData(-1, -1, new Margins(2,1,5,1)));
+ v.add(grid, new VerticalLayoutData(1, -1, new Margins(0)));
+ add(v);
+
+ }
+
+
+ protected void loadData(ListLoadConfig loadConfig,
+ final AsyncCallback> callback) {
+
+ TDGWTServiceAsync.INSTANCE.getTableValidationsMetadata(trId,
+ new AsyncCallback() {
+
+ public void onFailure(Throwable caught) {
+ Log.error("load validations metadata failure:"
+ + caught.getLocalizedMessage());
+ UtilsGXT3.alert("Error retrieving validations metadata",
+ "Error retrieving validations metadata");
+ callback.onFailure(caught);
+ }
+
+ public void onSuccess(TabValidationsMetadata result) {
+ Log.trace("loaded " + result.getId());
+ if(result.getValidations()!=null){
+ callback.onSuccess(new ListLoadResultBean(
+ result.getValidations()));
+ } else {
+ Log.error("load validations metadata failure: null");
+ UtilsGXT3.alert("Error retrieving validations metadata",
+ "Error retrieving validations metadata");
+ callback.onFailure(new Exception("Error retrieving validations metadata"));
+ }
+
+
+ }
+
+ });
+
+ }
+
+
+
+
+
+ public void update(TRId trId) {
+ this.trId = trId;
+ loader.load();
+ }
+
+}
diff --git a/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/exit.png b/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/exit.png
new file mode 100644
index 0000000..74f4826
Binary files /dev/null and b/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/exit.png differ
diff --git a/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/exit_32.png b/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/exit_32.png
new file mode 100644
index 0000000..89b102d
Binary files /dev/null and b/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/exit_32.png differ
diff --git a/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/ok.png b/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/ok.png
new file mode 100644
index 0000000..3d93f52
Binary files /dev/null and b/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/ok.png differ
diff --git a/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/ok_32.png b/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/ok_32.png
new file mode 100644
index 0000000..dae05cd
Binary files /dev/null and b/src/main/resources/org/gcube/portlets/user/td/tablewidget/client/resources/ok_32.png differ