summaryrefslogtreecommitdiffstats
path: root/server/src/com/vaadin/data
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2015-05-15 12:38:01 +0300
committerVaadin Code Review <review@vaadin.com>2015-06-01 06:27:36 +0000
commit90e75a20bda563f90297840f4feb5668cd524633 (patch)
tree5f53384d3f36b733066cdede9ab569f9eb92fb01 /server/src/com/vaadin/data
parent4932cecca53b25149ec18dd811c89997ee43e8d9 (diff)
downloadvaadin-framework-90e75a20bda563f90297840f4feb5668cd524633.tar.gz
vaadin-framework-90e75a20bda563f90297840f4feb5668cd524633.zip
Properly handle readonly fields when clearing FieldGroup (#17166)
Change-Id: I42b9fe5d945d23e202a252a8be12976608da19bf
Diffstat (limited to 'server/src/com/vaadin/data')
-rw-r--r--server/src/com/vaadin/data/fieldgroup/FieldGroup.java17
1 files changed, 15 insertions, 2 deletions
diff --git a/server/src/com/vaadin/data/fieldgroup/FieldGroup.java b/server/src/com/vaadin/data/fieldgroup/FieldGroup.java
index d370c3906b..aaaae9e4f7 100644
--- a/server/src/com/vaadin/data/fieldgroup/FieldGroup.java
+++ b/server/src/com/vaadin/data/fieldgroup/FieldGroup.java
@@ -258,7 +258,19 @@ public class FieldGroup implements Serializable {
if (itemDataSource == null) {
// Clear any possible existing binding to clear the field
field.setPropertyDataSource(null);
- field.clear();
+ boolean fieldReadOnly = field.isReadOnly();
+ if (!fieldReadOnly) {
+ field.clear();
+ } else {
+ // Temporarily make the field read-write so we can clear the
+ // value. Needed because setPropertyDataSource(null) does not
+ // currently clear the field
+ // (https://dev.vaadin.com/ticket/14733)
+ field.setReadOnly(false);
+ field.clear();
+ field.setReadOnly(true);
+ }
+
// Will be bound when data source is set
return;
}
@@ -1247,4 +1259,5 @@ public class FieldGroup implements Serializable {
}
}
-}
+
+} \ No newline at end of file