aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--gwtquery-core/src/main/java/com/google/gwt/query/client/plugins/events/EventsListener.java112
1 files changed, 62 insertions, 50 deletions
diff --git a/gwtquery-core/src/main/java/com/google/gwt/query/client/plugins/events/EventsListener.java b/gwtquery-core/src/main/java/com/google/gwt/query/client/plugins/events/EventsListener.java
index 07dc9c8f..fe71a9e9 100644
--- a/gwtquery-core/src/main/java/com/google/gwt/query/client/plugins/events/EventsListener.java
+++ b/gwtquery-core/src/main/java/com/google/gwt/query/client/plugins/events/EventsListener.java
@@ -17,6 +17,11 @@ package com.google.gwt.query.client.plugins.events;
import static com.google.gwt.query.client.GQuery.$;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
import com.google.gwt.core.client.Duration;
import com.google.gwt.dom.client.Element;
import com.google.gwt.dom.client.EventTarget;
@@ -26,11 +31,6 @@ import com.google.gwt.user.client.DOM;
import com.google.gwt.user.client.Event;
import com.google.gwt.user.client.EventListener;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
/**
* This class implements an event queue instance for one Element. The queue
* instance is configured as the default event listener in GWT.
@@ -108,7 +108,7 @@ public class EventsListener implements EventListener {
bindFunctions = new ArrayList<BindFunction>();
bindFunctionBySelector.put(cssSelector, bindFunctions);
}
-
+
bindFunctions.add(f);
}
@@ -145,14 +145,13 @@ public class EventsListener implements EventListener {
for (String cssSelector : realCurrentTargetBySelector.keySet()) {
List<BindFunction> bindFunctions = bindFunctionBySelector.get(cssSelector);
-
+
if (bindFunctions == null){
continue;
}
for (BindFunction f : bindFunctions) {
for (Element element : realCurrentTargetBySelector.get(cssSelector)) {
- gqEvent.setCurrentElementTarget(element);
boolean subResult = f.fire(gqEvent);
result &= subResult;
if (!subResult) {
@@ -174,7 +173,7 @@ public class EventsListener implements EventListener {
* Remove the BindFunction associated to this cssSelector
*/
public void removeBindFunctionForSelector(String cssSelector) {
- bindFunctionBySelector.remove(cssSelector);
+ bindFunctionBySelector.remove(cssSelector);
}
/**
@@ -222,8 +221,8 @@ public class EventsListener implements EventListener {
}
- // Gwt Events class has not this event defined
- public static int ONSUBMIT = 0x08000;
+ // Gwt Events class has not this event defined, so we have to select ane available power of 2
+ public static int ONSUBMIT = 0x800000;
public static void clean(Element e) {
EventsListener ret = getGQueryEventListener(e);
@@ -330,23 +329,17 @@ public class EventsListener implements EventListener {
}
public void bind(String event, final Object data, Function... funcs) {
+ // TODO: nameSpaces in event lists
String nameSpace = event.replaceFirst("^[^\\.]+\\.*(.*)$", "$1");
String eventName = event.replaceFirst("^([^\\.]+).*$", "$1");
- int b = 0;
- if ("submit".equals(eventName)) {
- b = ONSUBMIT;
- } else {
- b = Event.getTypeInt(eventName);
- }
+ int b = getEventBits(eventName);
for (Function function : funcs) {
bind(b, nameSpace, data, function, -1);
}
}
-
- public void die(String eventName, String cssSelector) {
- int eventType = "submit".equals(eventName) ? eventType = ONSUBMIT
- : Event.getTypeInt(eventName);
- die(eventType, cssSelector);
+
+ public void die(String eventNames, String cssSelector) {
+ die(getEventBits(eventNames), cssSelector);
}
public void die(int eventbits, String cssSelector) {
@@ -363,8 +356,7 @@ public class EventsListener implements EventListener {
}
public void dispatchEvent(Event event) {
- int etype = "submit".equalsIgnoreCase(event.getType()) ? ONSUBMIT
- : DOM.eventGetType(event);
+ int etype = getTypeInt(event.getType());
for (int i = 0; i < elementEvents.length(); i++) {
BindFunction listener = elementEvents.get(i);
if (listener.hasEventType(etype)) {
@@ -384,31 +376,33 @@ public class EventsListener implements EventListener {
return getGwtEventListener(element);
}
- public void live(String eventName, String cssSelector, Object data,
+ public void live(String eventNames, String cssSelector, Object data,
Function... f) {
- int eventType = "submit".equals(eventName) ? eventType = ONSUBMIT
- : Event.getTypeInt(eventName);
- live(eventType, cssSelector, data, f);
+ live(getEventBits(eventNames), cssSelector, data, f);
}
-
- public void live(int eventbits, String cssSelector, Object data,
+
+ public void live(int eventbits, String cssSelector, Object data,
Function... funcs) {
+ for (int i = 0; i < 28; i++) {
+ int event = (int)Math.pow(2,i);
+ if ((eventbits & event) == event) {
+
+ // is a LiveBindFunction already attached for this kind of event
+ LiveBindFunction liveBindFunction = liveBindFunctionByEventType.get(event);
+ if (liveBindFunction == null) {
+ liveBindFunction = new LiveBindFunction(event, "live");
+ eventBits |= event;
+ sink();
+ elementEvents.add(liveBindFunction);
+ liveBindFunctionByEventType.put(event, liveBindFunction);
+ }
- // is a LiveBindFunction already attached for this kind of event
- LiveBindFunction liveBindFunction = liveBindFunctionByEventType.get(eventbits);
- if (liveBindFunction == null) {
- liveBindFunction = new LiveBindFunction(eventbits, "live");
- eventBits |= eventbits;
- sink();
- elementEvents.add(liveBindFunction);
- liveBindFunctionByEventType.put(eventbits, liveBindFunction);
- }
-
- for (Function f : funcs) {
- liveBindFunction.addBindFunctionForSelector(cssSelector,
- new BindFunction(eventbits, "live", f, data));
+ for (Function f: funcs) {
+ liveBindFunction.addBindFunctionForSelector(cssSelector,
+ new BindFunction(event, "live", f, data));
+ }
+ }
}
-
}
public void onBrowserEvent(Event event) {
@@ -449,14 +443,10 @@ public class EventsListener implements EventListener {
}
public void unbind(String event) {
+ // TODO: nameSpaces in event lists
String nameSpace = event.replaceFirst("^[^\\.]+\\.*(.*)$", "$1");
String eventName = event.replaceFirst("^([^\\.]+).*$", "$1");
- int b = 0;
- if ("submit".equals(eventName)) {
- b = ONSUBMIT;
- } else {
- b = Event.getTypeInt(eventName);
- }
+ int b = getEventBits(eventName);
unbind(b, nameSpace);
}
@@ -481,4 +471,26 @@ public class EventsListener implements EventListener {
}
}
+
+ private int getEventBits(String... events) {
+ int ret = 0;
+ for (String e: events) {
+ String[] parts = e.split("[\\s,]+");
+ for (String s : parts) {
+ if ("submit".equals(s)) {
+ ret |= ONSUBMIT;
+ } else {
+ int event = Event.getTypeInt(s);
+ if (event > 0) {
+ ret |= event;
+ }
+ }
+ }
+ }
+ return ret;
+ }
+
+ private int getTypeInt(String eventName) {
+ return "submit".equals(eventName) ? ONSUBMIT : Event.getTypeInt(eventName);
+ }
}