summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorArtur Signell <artur.signell@itmill.com>2009-10-06 05:49:55 +0000
committerArtur Signell <artur.signell@itmill.com>2009-10-06 05:49:55 +0000
commitd660c18b68dd9006c455ccece593b453772d4361 (patch)
treecb783eced8f9f4648e8e7c8bf575fa1afa15fa13 /src
parentbd9de82daa80a57e6de21dc55e01d42891faf733 (diff)
downloadvaadin-framework-d660c18b68dd9006c455ccece593b453772d4361.tar.gz
vaadin-framework-d660c18b68dd9006c455ccece593b453772d4361.zip
Fix for #3377 - VButton clicklistener should be overridable
svn changeset:9089/svn branch:6.1
Diffstat (limited to 'src')
-rw-r--r--src/com/vaadin/terminal/gwt/client/ui/VButton.java41
1 files changed, 26 insertions, 15 deletions
diff --git a/src/com/vaadin/terminal/gwt/client/ui/VButton.java b/src/com/vaadin/terminal/gwt/client/ui/VButton.java
index 93f06f9954..decf262a17 100644
--- a/src/com/vaadin/terminal/gwt/client/ui/VButton.java
+++ b/src/com/vaadin/terminal/gwt/client/ui/VButton.java
@@ -20,7 +20,7 @@ import com.vaadin.terminal.gwt.client.UIDL;
import com.vaadin.terminal.gwt.client.Util;
import com.vaadin.terminal.gwt.client.VTooltip;
-public class VButton extends FocusWidget implements Paintable {
+public class VButton extends FocusWidget implements Paintable, ClickHandler {
public static final String CLASSNAME = "v-button";
private static final String CLASSNAME_PRESSED = "v-pressed";
@@ -86,18 +86,7 @@ public class VButton extends FocusWidget implements Paintable {
captionElement.setClassName(CLASSNAME + "-caption");
wrapper.appendChild(captionElement);
- addClickHandler(new ClickHandler() {
- public void onClick(ClickEvent event) {
- if (id == null || client == null) {
- return;
- }
- if (BrowserInfo.get().isSafari()) {
- VButton.this.setFocus(true);
- }
- client.updateVariable(id, "state", true, true);
- clickPending = false;
- }
- });
+ addClickHandler(this);
}
public void updateFromUIDL(UIDL uidl, ApplicationConnection client) {
@@ -301,14 +290,36 @@ public class VButton extends FocusWidget implements Paintable {
}
/*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.google.gwt.event.dom.client.ClickHandler#onClick(com.google.gwt.event
+ * .dom.client.ClickEvent)
+ */
+ public void onClick(ClickEvent event) {
+ if (id == null || client == null) {
+ return;
+ }
+ if (BrowserInfo.get().isSafari()) {
+ VButton.this.setFocus(true);
+ }
+ client.updateVariable(id, "state", true, true);
+
+ clickPending = false;
+ }
+
+ /*
* ALL BELOW COPY-PASTED FROM GWT CustomButton
*/
/**
- * Called when the user finishes clicking on this button. The default
- * behavior is to fire the click event to listeners. Subclasses that
+ * Called internally when the user finishes clicking on this button. The
+ * default behavior is to fire the click event to listeners. Subclasses that
* override {@link #onClickStart()} should override this method to restore
* the normal widget display.
+ * <p>
+ * To add custom code for a click event, override
+ * {@link #onClick(ClickEvent)} instead of this.
*/
protected void onClick() {
// Allow the click we're about to synthesize to pass through to the