aboutsummaryrefslogtreecommitdiff
path: root/js/lib
diff options
context:
space:
mode:
authorewinslow <ewinslow@36083f99-b078-4883-b0ff-0f9b5a30f544>2010-11-14 08:28:22 +0000
committerewinslow <ewinslow@36083f99-b078-4883-b0ff-0f9b5a30f544>2010-11-14 08:28:22 +0000
commit72a4b251503eeb2ae4cc8efdea1f522817652406 (patch)
treedd611bd8cce5fbcbf1c398da5619287a7487ee9a /js/lib
parentaa5bb3f0bc17d858831412da82eef805ecafac89 (diff)
downloadelgg-72a4b251503eeb2ae4cc8efdea1f522817652406.tar.gz
elgg-72a4b251503eeb2ae4cc8efdea1f522817652406.tar.bz2
Refs #2538: Refactored and cleaned up ElggPriorityList and events
git-svn-id: http://code.elgg.org/elgg/trunk@7312 36083f99-b078-4883-b0ff-0f9b5a30f544
Diffstat (limited to 'js/lib')
-rw-r--r--js/lib/events.js87
1 files changed, 37 insertions, 50 deletions
diff --git a/js/lib/events.js b/js/lib/events.js
index 358dd6280..ad05a9888 100644
--- a/js/lib/events.js
+++ b/js/lib/events.js
@@ -1,65 +1,52 @@
elgg.provide('elgg.config.events');
-elgg.provide('elgg.config.events.all');
-elgg.provide('elgg.config.events.all.all');
-elgg.register_event_handler = function(event, type, callback, priority) {
- elgg.assertTypeOf('string', event);
- elgg.assertTypeOf('string', event);
- elgg.assertTypeOf('function', callback);
-
- if (!event || !type) {
+/**
+ *
+ */
+elgg.register_event_handler = function(event_name, event_type, handler, priority) {
+ elgg.assertTypeOf('string', event_name);
+ elgg.assertTypeOf('string', event_type);
+ elgg.assertTypeOf('function', handler);
+
+ if (!event_name || !event_type) {
return false;
}
- elgg.provide('elgg.config.events.' + event + '.' + type);
-
var events = elgg.config.events;
- if (!(events[event][type] instanceof elgg.ElggPriorityList)) {
- events[event][type] = new elgg.ElggPriorityList();
+ elgg.provide(event_name + '.' + event_type, events);
+
+
+ if (!(events[event_name][event_type] instanceof elgg.ElggPriorityList)) {
+ events[event_name][event_type] = new elgg.ElggPriorityList();
}
- return events[event][type].insert(callback, priority);
+ return events[event_name][event_type].insert(handler, priority);
};
-elgg.trigger_event = function(event, type, object) {
- elgg.assertTypeOf('string', event);
- elgg.assertTypeOf('string', event);
+/**
+ *
+ */
+elgg.trigger_event = function(event_name, event_type, opt_object) {
+ elgg.assertTypeOf('string', event_name);
+ elgg.assertTypeOf('string', event_type);
- elgg.provide('elgg.config.events.' + event + '.' + type);
- elgg.provide('elgg.config.events.all.' + type);
- elgg.provide('elgg.config.events.' + event + '.all');
- elgg.provide('elgg.config.events.all.all');
-
- var events = elgg.config.events;
-
- var callEventHandler = function(handler) {
- return handler(event, type, object) !== false;
- };
-
- if (events[event][type] instanceof elgg.ElggPriorityList) {
- if (!events[event][type].every(callEventHandler)) {
- return false;
+ var events = elgg.config.events,
+ callEventHandler = function(handler) {
+ return handler(event_name, event_type, opt_object) !== false;
}
- }
- if (events['all'][type] instanceof elgg.ElggPriorityList) {
- if (!events['all'][type].every(callEventHandler)) {
- return false;
- }
- }
-
- if (events[event]['all'] instanceof elgg.ElggPriorityList) {
- if (!events[event]['all'].every(callEventHandler)) {
- return false;
- }
- }
-
- if (events['all']['all'] instanceof elgg.ElggPriorityList) {
- if (!events['all']['all'].every(callEventHandler)) {
- return false;
- }
- }
-
- return true;
+ elgg.provide(event_name + '.' + event_type, events);
+ elgg.provide('all.' + event_type, events);
+ elgg.provide(event_name + '.all', events);
+ elgg.provide('all.all', events);
+
+ return [
+ events[event_name][event_type],
+ events['all'][event_type],
+ events[event_name]['all'],
+ events['all']['all']
+ ].every(function(handlers) {
+ return !(handlers instanceof elgg.ElggPriorityList) || handlers.every(callEventHandler);
+ });
}; \ No newline at end of file