summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--client/src/com/vaadin/client/ui/VRichTextArea.java33
-rw-r--r--uitest/src/com/vaadin/tests/components/richtextarea/RichTextAreaEmptyString.java42
2 files changed, 74 insertions, 1 deletions
diff --git a/client/src/com/vaadin/client/ui/VRichTextArea.java b/client/src/com/vaadin/client/ui/VRichTextArea.java
index 7cb7f9ec59..1498c096ed 100644
--- a/client/src/com/vaadin/client/ui/VRichTextArea.java
+++ b/client/src/com/vaadin/client/ui/VRichTextArea.java
@@ -191,7 +191,7 @@ public class VRichTextArea extends Composite implements Field, ChangeHandler,
*/
public void synchronizeContentToServer() {
if (client != null && id != null) {
- final String html = rta.getHTML();
+ final String html = sanitizeRichTextAreaValue(rta.getHTML());
if (!html.equals(currentValue)) {
client.updateVariable(id, "text", html, immediate);
currentValue = html;
@@ -199,6 +199,37 @@ public class VRichTextArea extends Composite implements Field, ChangeHandler,
}
}
+ /**
+ * Browsers differ in what they return as the content of a visually empty
+ * rich text area. This method is used to normalize these to an empty
+ * string. See #8004.
+ *
+ * @param html
+ * @return cleaned html string
+ */
+ private String sanitizeRichTextAreaValue(String html) {
+ BrowserInfo browser = BrowserInfo.get();
+ String result = html;
+ if (browser.isFirefox()) {
+ if ("<br>".equals(html)) {
+ result = "";
+ }
+ } else if (browser.isWebkit()) {
+ if ("<div><br></div>".equals(html)) {
+ result = "";
+ }
+ } else if (browser.isIE()) {
+ if ("<P>&nbsp;</P>".equals(html)) {
+ result = "";
+ }
+ } else if (browser.isOpera()) {
+ if ("<br>".equals(html) || "<p><br></p>".equals(html)) {
+ result = "";
+ }
+ }
+ return result;
+ }
+
@Override
public void onBlur(BlurEvent event) {
synchronizeContentToServer();
diff --git a/uitest/src/com/vaadin/tests/components/richtextarea/RichTextAreaEmptyString.java b/uitest/src/com/vaadin/tests/components/richtextarea/RichTextAreaEmptyString.java
new file mode 100644
index 0000000000..5eddf9dc6d
--- /dev/null
+++ b/uitest/src/com/vaadin/tests/components/richtextarea/RichTextAreaEmptyString.java
@@ -0,0 +1,42 @@
+package com.vaadin.tests.components.richtextarea;
+
+import com.vaadin.shared.ui.label.ContentMode;
+import com.vaadin.tests.components.TestBase;
+import com.vaadin.ui.Button;
+import com.vaadin.ui.Button.ClickEvent;
+import com.vaadin.ui.Button.ClickListener;
+import com.vaadin.ui.Label;
+import com.vaadin.ui.RichTextArea;
+
+public class RichTextAreaEmptyString extends TestBase {
+
+ @Override
+ protected String getDescription() {
+ return "Test the value of a rich text area. Visually empty area should return \"\"";
+ }
+
+ @Override
+ protected Integer getTicketNumber() {
+ return 8004;
+ }
+
+ @Override
+ protected void setup() {
+ final RichTextArea area = new RichTextArea();
+
+ final Label l = new Label(area.getValue(), ContentMode.PREFORMATTED);
+ l.setCaption("Value recieved from RichTextArea:");
+
+ final Button b = new Button("get area value", new ClickListener() {
+
+ public void buttonClick(ClickEvent event) {
+ l.setValue(area.getValue());
+ }
+ });
+
+ addComponent(area);
+ addComponent(b);
+ addComponent(l);
+ }
+
+}