summaryrefslogtreecommitdiffstats
path: root/client
diff options
context:
space:
mode:
Diffstat (limited to 'client')
-rw-r--r--client/src/com/vaadin/client/ui/Icon.java11
-rw-r--r--client/src/com/vaadin/client/ui/button/ButtonConnector.java13
2 files changed, 19 insertions, 5 deletions
diff --git a/client/src/com/vaadin/client/ui/Icon.java b/client/src/com/vaadin/client/ui/Icon.java
index 5ba3cc6eeb..9d5829c079 100644
--- a/client/src/com/vaadin/client/ui/Icon.java
+++ b/client/src/com/vaadin/client/ui/Icon.java
@@ -53,4 +53,15 @@ public class Icon extends UIObject {
}
}
+ /**
+ * Sets the alternate text for the icon.
+ *
+ * @param alternateText
+ * with the alternate text.
+ */
+ public void setAlternateText(String alternateText) {
+ getElement().setAttribute("alt",
+ alternateText == null ? "" : alternateText);
+ }
+
}
diff --git a/client/src/com/vaadin/client/ui/button/ButtonConnector.java b/client/src/com/vaadin/client/ui/button/ButtonConnector.java
index fff983c168..a6630f28b9 100644
--- a/client/src/com/vaadin/client/ui/button/ButtonConnector.java
+++ b/client/src/com/vaadin/client/ui/button/ButtonConnector.java
@@ -24,7 +24,6 @@ import com.google.gwt.event.dom.client.FocusEvent;
import com.google.gwt.event.dom.client.FocusHandler;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.user.client.DOM;
-import com.google.gwt.user.client.Element;
import com.vaadin.client.EventHelper;
import com.vaadin.client.MouseEventDetailsBuilder;
import com.vaadin.client.communication.StateChangeEvent;
@@ -84,13 +83,12 @@ public class ButtonConnector extends AbstractComponentConnector implements
if (getIcon() != null) {
if (getWidget().icon == null) {
getWidget().icon = new Icon(getConnection());
- Element iconElement = getWidget().icon.getElement();
- iconElement.setAttribute("alt", getState().iconAltText);
-
- getWidget().wrapper.insertBefore(iconElement,
+ getWidget().wrapper.insertBefore(
+ getWidget().icon.getElement(),
getWidget().captionElement);
}
getWidget().icon.setUri(getIcon());
+ getWidget().icon.setAlternateText(getState().iconAltText);
} else {
if (getWidget().icon != null) {
getWidget().wrapper.removeChild(getWidget().icon
@@ -120,6 +118,11 @@ public class ButtonConnector extends AbstractComponentConnector implements
}
}
+ if (getWidget().icon != null
+ && stateChangeEvent.hasPropertyChanged("iconAltText")) {
+ getWidget().icon.setAlternateText(getState().iconAltText);
+ }
+
getWidget().clickShortcut = getState().clickShortcutKeyCode;
}