aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--gwtquery-core/src/main/java/com/google/gwt/query/client/EventsListener.java43
-rw-r--r--gwtquery-core/src/test/java/com/google/gwt/query/client/GwtEventsTest.java23
2 files changed, 49 insertions, 17 deletions
diff --git a/gwtquery-core/src/main/java/com/google/gwt/query/client/EventsListener.java b/gwtquery-core/src/main/java/com/google/gwt/query/client/EventsListener.java
index 43c50f3b..5de960e4 100644
--- a/gwtquery-core/src/main/java/com/google/gwt/query/client/EventsListener.java
+++ b/gwtquery-core/src/main/java/com/google/gwt/query/client/EventsListener.java
@@ -34,14 +34,14 @@ class EventsListener implements EventListener {
private static class BindFunction {
- int type;
+ Object data;
Function function;
- Object data;
-
int times = -1;
+ int type;
+
BindFunction(int t, Function f, Object d) {
type = t;
function = f;
@@ -67,32 +67,44 @@ class EventsListener implements EventListener {
}
public static EventsListener getInstance(Element e) {
- EventsListener ret = getWidgetElementImpl(e);
+ EventsListener ret = getGQueryEventLinstener(e);
return ret != null ? ret : new EventsListener(e);
}
- private static native EventsListener getWidgetElementImpl(Element elem) /*-{
+ private static native EventsListener getGQueryEventLinstener(Element elem) /*-{
return elem.__gqueryevent;
}-*/;
+ private static native EventListener getOriginalEventListener(Element elem) /*-{
+ return elem.__listener;
+ }-*/;
+
private static native void setFocusable(Element elem) /*-{
elem.tabIndex = 0;
}-*/;
- private static native void setWidgetElementImpl(Element elem,
+ private static native void setGQueryEventListener(Element elem,
EventsListener gqevent) /*-{
elem.__gqueryevent = gqevent;
}-*/;
+ private Element element;
+
private JsObjectArray<EventsListener.BindFunction> elementEvents = JsObjectArray
.createArray().cast();
+ private EventListener originalEventListener;
- private Element element;
+ private EventsListener(Element element) {
+ this.element = element;
+ originalEventListener = getOriginalEventListener(element);
+ setGQueryEventListener(element, this);
+ DOM.setEventListener((com.google.gwt.user.client.Element) element, this);
+ }
- private EventsListener(Element e) {
- element = e;
- setWidgetElementImpl(element, this);
- DOM.setEventListener((com.google.gwt.user.client.Element) e, this);
+ public void bind(int eventbits, final Object data, Function...funcs) {
+ for (Function function: funcs) {
+ bind(eventbits, data, function, -1);
+ }
}
public void bind(int eventbits, final Object data, final Function function,
@@ -112,13 +124,10 @@ class EventsListener implements EventListener {
}
}
- public void bind(int eventbits, final Object data, Function...funcs) {
- for (Function function: funcs) {
- bind(eventbits, data, function, -1);
- }
- }
-
public void onBrowserEvent(Event event) {
+ if (originalEventListener != null) {
+ originalEventListener.onBrowserEvent(event);
+ }
int etype = DOM.eventGetType(event);
for (int i = 0; i < elementEvents.length(); i++) {
EventsListener.BindFunction listener = elementEvents.get(i);
diff --git a/gwtquery-core/src/test/java/com/google/gwt/query/client/GwtEventsTest.java b/gwtquery-core/src/test/java/com/google/gwt/query/client/GwtEventsTest.java
index fe8793e1..ca28b0f7 100644
--- a/gwtquery-core/src/test/java/com/google/gwt/query/client/GwtEventsTest.java
+++ b/gwtquery-core/src/test/java/com/google/gwt/query/client/GwtEventsTest.java
@@ -18,10 +18,13 @@ package com.google.gwt.query.client;
import static com.google.gwt.query.client.GQuery.$;
import com.google.gwt.dom.client.Element;
+import com.google.gwt.event.dom.client.ClickEvent;
+import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.junit.DoNotRunWith;
import com.google.gwt.junit.Platform;
import com.google.gwt.junit.client.GWTTestCase;
import com.google.gwt.user.client.Event;
+import com.google.gwt.user.client.ui.Button;
import com.google.gwt.user.client.ui.HTML;
import com.google.gwt.user.client.ui.RootPanel;
@@ -170,4 +173,24 @@ public class GwtEventsTest extends GWTTestCase {
$("p", e).dblclick();
assertEquals("yellow", $("p", e).css("color"));
}
+
+ public void testWidgetEvents() {
+ final Button b = new Button("click-me");
+ b.addClickHandler(new ClickHandler() {
+ public void onClick(ClickEvent event) {
+ b.getElement().getStyle().setBackgroundColor("black");
+ }
+ });
+ RootPanel.get().add(b);
+ $("button").click(new Function(){
+ public boolean f(Event e) {
+ $(e).css("color", "red");
+ return true;
+ }
+ });
+ $("button").click();
+ assertEquals("red", $("button").css("color"));
+ assertEquals("black", $("button").css("background-color"));
+ RootPanel.get().remove(b);
+ }
}