summaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/src/com/vaadin/ui/Grid.java39
1 files changed, 30 insertions, 9 deletions
diff --git a/server/src/com/vaadin/ui/Grid.java b/server/src/com/vaadin/ui/Grid.java
index ef97f9b336..150f672835 100644
--- a/server/src/com/vaadin/ui/Grid.java
+++ b/server/src/com/vaadin/ui/Grid.java
@@ -90,7 +90,6 @@ import com.vaadin.shared.ui.grid.GridStaticSectionState.RowState;
import com.vaadin.shared.ui.grid.HeightMode;
import com.vaadin.shared.ui.grid.ScrollDestination;
import com.vaadin.shared.util.SharedUtil;
-import com.vaadin.ui.Notification.Type;
import com.vaadin.ui.renderer.Renderer;
import com.vaadin.ui.renderer.TextRenderer;
import com.vaadin.util.ReflectTools;
@@ -262,9 +261,12 @@ public class Grid extends AbstractComponent implements SelectionNotifier,
private Set<Column> errorColumns = new HashSet<Column>();
+ private String userErrorMessage;
+
public CommitErrorEvent(Grid grid, CommitException cause) {
super(grid);
this.cause = cause;
+ userErrorMessage = cause.getLocalizedMessage();
}
/**
@@ -310,6 +312,25 @@ public class Grid extends AbstractComponent implements SelectionNotifier,
return Collections.unmodifiableCollection(errorColumns);
}
+ /**
+ * Gets the error message to show to the user.
+ *
+ * @return error message to show
+ */
+ public String getUserErrorMessage() {
+ return userErrorMessage;
+ }
+
+ /**
+ * Sets the error message to show to the user.
+ *
+ * @param userErrorMessage
+ * the user error message to set
+ */
+ public void setUserErrorMessage(String userErrorMessage) {
+ this.userErrorMessage = userErrorMessage;
+ }
+
}
/**
@@ -349,12 +370,8 @@ public class Grid extends AbstractComponent implements SelectionNotifier,
.getHeaderCaption();
String message = invalidFields.get(firstErrorField)
.getLocalizedMessage();
- /*
- * TODO This should be shown in the editor component once there
- * is a place for that. Optionally, all errors should be shown
- */
- Notification.show(caption + ": " + message, Type.ERROR_MESSAGE);
+ event.setUserErrorMessage(caption + ": " + message);
} else {
com.vaadin.server.ErrorEvent.findErrorHandler(Grid.this).error(
new ConnectorErrorEvent(Grid.this, event.getCause()));
@@ -2536,10 +2553,10 @@ public class Grid extends AbstractComponent implements SelectionNotifier,
* {@code true} if this column should be editable,
* {@code false} otherwise
* @return this column
- *
+ *
* @throws IllegalStateException
* if the editor is currently active
- *
+ *
* @see Grid#editItem(Object)
* @see Grid#isEditorActive()
*/
@@ -3056,6 +3073,7 @@ public class Grid extends AbstractComponent implements SelectionNotifier,
@Override
public void save(int rowIndex) {
List<String> errorColumnIds = null;
+ String errorMessage = null;
boolean success = false;
try {
saveEditor();
@@ -3066,6 +3084,8 @@ public class Grid extends AbstractComponent implements SelectionNotifier,
Grid.this, e);
getEditorErrorHandler().commitError(event);
+ errorMessage = event.getUserErrorMessage();
+
errorColumnIds = new ArrayList<String>();
for (Column column : event.getErrorColumns()) {
errorColumnIds.add(column.state.id);
@@ -3078,7 +3098,8 @@ public class Grid extends AbstractComponent implements SelectionNotifier,
} catch (Exception e) {
handleError(e);
}
- getEditorRpc().confirmSave(success, errorColumnIds);
+ getEditorRpc().confirmSave(success, errorMessage,
+ errorColumnIds);
}
private void handleError(Exception e) {