Pass on the browser tree events by generating node specific 'browser-node' events.

Added a test event in test.js
This commit is contained in:
Ashesh Vashi 2015-12-16 13:27:08 +05:30
parent c3b517cb91
commit 8611e29c60
2 changed files with 31 additions and 15 deletions

View File

@ -434,19 +434,8 @@ OWNER TO helpdesk;\n';
// Treeview event handler // Treeview event handler
$('#tree').on('acitree', function(event, api, item, eventName, options) { $('#tree').on('acitree', function(event, api, item, eventName, options) {
var d = null; var d = item ? obj.tree.itemData(item) : null;
if (item) {
d = obj.tree.itemData(item);
if (d && obj.Nodes[d._type] &&
_.isObject(obj.Nodes[d._type].callbacks) &&
eventName in obj.Nodes[d._type].callbacks &&
typeof obj.Nodes[d._type].callbacks[eventName] ==
'function') {
return obj.Nodes[d._type].callbacks[eventName].apply(
obj.Nodes[d._type], [item, d, obj, options, eventName]
);
}
}
switch (eventName) { switch (eventName) {
// When a node is added in the browser tree, we need to // When a node is added in the browser tree, we need to
// load the registered scripts // load the registered scripts
@ -477,6 +466,29 @@ OWNER TO helpdesk;\n';
} }
break; break;
} }
if (d && obj.Nodes[d._type]) {
var node = obj.Nodes[d._type];
/* If the node specific callback returns false, we will also return
* false for further processing.
*/
if (_.isObject(node.callbacks) &&
eventName in node.callbacks &&
typeof node.callbacks[eventName] == 'function' &&
!node.callbacks[eventName].apply(
node, [item, d, obj, options, eventName])) {
return false;
}
/* Raise tree events for the nodes */
try {
node.trigger(
'browser-node.' + eventName, node, item, d
);
} catch (e) {
console.log(e);
}
}
return true; return true;
}); });

View File

@ -1,6 +1,6 @@
define( define(
['jquery', 'alertify', 'pgadmin', 'pgadmin.node.server'], ['jquery', 'alertify', 'pgadmin', 'pgadmin.node.server', 'pgadmin.node.server-group'],
function($, alertify, pgAdmin, pgServer) { function($, alertify, pgAdmin, pgServer, ServerGroup) {
pgAdmin = pgAdmin || window.pgAdmin || {}; pgAdmin = pgAdmin || window.pgAdmin || {};
pgAdmin.Test = { pgAdmin.Test = {
@ -76,5 +76,9 @@ define(
}, },
{'a': 'test'}); {'a': 'test'});
ServerGroup.on('browser-node.loaded', function() {
console.log('I know that the server-group has been expanded!');
}, pgAdmin.Test);
return pgAdmin.Test; return pgAdmin.Test;
}); });