1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
/*
* Javascript hook interface
*/
elgg.provide('elgg.config.hooks');
/**
* Registers an hook handler with the event system.
*
* The special keyword "all" can be used for either the name or the type or both
* and means to call that handler for all of those hooks.
*
* @param {String} name Name of the plugin hook to register for
* @param {String} type Type of the event to register for
* @param {Function} handler Handle to call
* @param {Number} priority Priority to call the event handler
* @return {Bool}
*/
elgg.register_hook_handler = function(name, type, handler, priority) {
elgg.assertTypeOf('string', name);
elgg.assertTypeOf('string', type);
elgg.assertTypeOf('function', handler);
if (!name || !type) {
return false;
}
var priorities = elgg.config.hooks;
elgg.provide(name + '.' + type, priorities);
if (!(priorities[name][type] instanceof elgg.ElggPriorityList)) {
priorities[name][type] = new elgg.ElggPriorityList();
}
return priorities[name][type].insert(handler, priority);
};
/**
* Emits a hook.
*
* Loops through all registered hooks and calls the handler functions in order.
* Every handler function will always be called, regardless of the return value.
*
* @warning Handlers take the same 4 arguments in the same order as when calling this function.
* This is different to the PHP version!
*
* Hooks are called in this order:
* specifically registered (event_name and event_type match)
* all names, specific type
* specific name, all types
* all names, all types
*
* @param {String} name Name of the hook to emit
* @param {String} type Type of the hook to emit
* @param {Object} params Optional parameters to pass to the handlers
* @param {Object} value Initial value of the return. Can be mangled by handlers
*
* @return {Bool}
*/
elgg.trigger_hook = function(name, type, params, value) {
elgg.assertTypeOf('string', name);
elgg.assertTypeOf('string', type);
// default to true if unpassed
value = value || true;
var hooks = elgg.config.hooks,
tempReturnValue = null,
returnValue = value,
callHookHandler = function(handler) {
tempReturnValue = handler(name, type, params, value);
};
elgg.provide(name + '.' + type, hooks);
elgg.provide('all.' + type, hooks);
elgg.provide(name + '.all', hooks);
elgg.provide('all.all', hooks);
var hooksList = [];
if (name != 'all' && type != 'all') {
hooksList.push(hooks[name][type]);
}
if (type != 'all') {
hooksList.push(hooks['all'][type]);
}
if (name != 'all') {
hooksList.push(hooks[name]['all']);
}
hooksList.push(hooks['all']['all']);
hooksList.every(function(handlers) {
if (handlers instanceof elgg.ElggPriorityList) {
handlers.forEach(callHookHandler);
}
return true;
});
return (tempReturnValue !== null) ? tempReturnValue : returnValue;
};
|