I’m trying to create a modular application in javascript using pusher. Different modules need to bind to the same pusher event and sometimes that event is nested in another event. Furthermore, these modules get loaded at different times depending on DOM events triggered by the user.
So, if one module has some code like
env.pusher.connection.bind('connected', function() {
env.my_channel.bind('private_message',function(data){ ... }
}
And another module comes along and wants to listen to the same private_message event. What happens if I write the same code is that the first bind gets overwritten.
What I’m looking for is a way to implement some kind of listeners, possibly with the option of removing a listener from a channel event.
I’ve thought of a solution myself. It comprises of the following steps:
every module that wants to make use of a pusher event should search the dictionary first to see if that event exists and if not, write the code that creates the bind for the first time and add it to the dictionary
when a module creates the bind for the first time, it should also trigger a custom event and pass to it the data that pusher sends at the completion of the pusher event
If that looks hard to follow, here’s some code inside a module that is a rewrite of the code in my question(I’ve used jQuery because jQuery is succint and has custom events already implemented):
Would love to get some feedback on this (drawbacks etc.)