On 08/11/2011 08:38 AM, e-lena-s wrote: > The issue is that the JS function is written by some other library. > The custom event will be fired not by my module but by other code on > the page . I however need to listen to that event, and get the > customData out of that event for further processing within the > module. > I have tried to use DOM.sinkBitlessEvent (and seeing if I can catch > this event in onBrowserEvent() ), but that didn't work. Not sure what > other way I can get that event , or why does the custom event looses > its customData when within JSNI method
Interesting problem. Are you sure the event data is kept for the case of js --> js? I'd eliminate that possibility first. I'm sure it works, but nothing you've said so far positively eliminates that (admittedly small) possibility. If it /is/ kept, then: 0) write an event hander in js (i.e. outside gwt) that calls addLookupResultHandler 1) load the event handler from step 0 as part of your external library's load phase 2) hook your addLookupResultHandler to GWT's $wnd object before step 3) 3) fire the event in the library. That will call the event handler written in step 0 > > > On Aug 11, 8:17 am, Jeffrey Chimene <jchim...@gmail.com> wrote: >> On 8/10/2011 4:50 PM, e-lena-s wrote: >> >> >> >> >> >> >> >>> I am trying to listen to a custom JS event that is created outside my >>> GWT module. In my JS file I create the event, and then fire it as >>> such : >> >>> var evt = document.createEvent("Event"); >>> evt.initEvent('customEvent', true, true); >>> evt.customData = "someData"; >> >>> window.addEventListener('customEvent', function(evt) >>> { console.log("test: " + evt.customData)}, false); >>> window.dispatchEvent(evt); >> >>> Now, in my GWT code, I have a JSNI method that adds a listener to >>> listen to my customEvent and act on it. Code as follows: >> >>> public native void addLookupResultHandler()/*-{ >>> $wnd.addEventListener('lookupEntitySelected', >>> $entry(function(evt){ >> >>> console.log("gwt: " + evt.customData); >> >>> console.log("gwt: " + evt.type); >> >>> @myClassName::handleEvent(LmyCustomEventEvent;)(evt) >>> }), false); >>> }-*/; >> >>> The problem I have is that the customData is being dropped when the >>> event gets to JSNI code. I can see that the event listner written in >>> JS does get the correct event with the correct customData, but logging >>> the event properties in JSNI shows that customData is undefined (event >>> type looks correct though) >> >>> Am I doing something wrong here ? >> >>> Is there may be a better way to create custom events (it has to be >>> created in JavaScript, since the code firing it won't be in GWT >>> module) >> >> My earlier answer was not correct. I don't see why >> addLookupResultHandler is a JSNI routine. I think you want to write it >> in GWT, via handling a NativeEvent. However, I've never tried this, so >> it may not work as you intend. >> >> OTOH, maybe you should be using the GWT event bus. From an architectural >> perspective, I think that's a better choice. Instead of using >> window.dispatch(), fire the event via a JSNI method. So, your first JS >> sample should become a JSNI routine that calls a Java routine that calls >> eventBus.fire(), and your second example should become Java. It's >> possible to call eventBus.fire() entirely within JSNI, but getting that >> eventBus argument to your JSNI method may be problematic. > -- You received this message because you are subscribed to the Google Groups "Google Web Toolkit" group. To post to this group, send email to google-web-toolkit@googlegroups.com. To unsubscribe from this group, send email to google-web-toolkit+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/google-web-toolkit?hl=en.