From d660c18b68dd9006c455ccece593b453772d4361 Mon Sep 17 00:00:00 2001 From: Artur Signell Date: Tue, 6 Oct 2009 05:49:55 +0000 Subject: [PATCH] Fix for #3377 - VButton clicklistener should be overridable svn changeset:9089/svn branch:6.1 --- .../terminal/gwt/client/ui/VButton.java | 41 ++++++++++++------- 1 file 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) { @@ -300,15 +289,37 @@ public class VButton extends FocusWidget implements Paintable { return isHovering; } + /* + * (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. + *

+ * 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 -- 2.39.5