mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
-Move 'addNotification' function from list view and detail view widgets to a central location, cloudStack.ui.notifications.add, in notifications.js, to avoid redundant code. -Add helper method for triggering CloudStack-specific UI events
45 lines
1.1 KiB
JavaScript
45 lines
1.1 KiB
JavaScript
(function($, cloudStack) {
|
|
cloudStack.ui.event = {
|
|
// Attach element to specific event type
|
|
elem: function(widget, elem, $elem, extraData) {
|
|
// Setup DOM metadata
|
|
var data = { cloudStack: {} };
|
|
data.cloudStack[widget] = {
|
|
elem: elem
|
|
};
|
|
if (extraData) $.extend(data.cloudStack[widget], extraData);
|
|
|
|
return $elem
|
|
.addClass('cloudStack-elem')
|
|
.addClass(widget)
|
|
.data(data);
|
|
},
|
|
|
|
// Create widget-based event
|
|
bind: function(widget, events) {
|
|
return function(event) {
|
|
var $target = $(event.target);
|
|
var $widget, $elem;
|
|
var data, elem;
|
|
|
|
$elem = $target.closest('.cloudStack-elem.' + widget);
|
|
if (!$elem.size())
|
|
return true;
|
|
|
|
$widget = $('.cloudStack-widget.' + widget);
|
|
data = $elem.data('cloudStack')[widget];
|
|
elem = data.elem;
|
|
|
|
events[elem]($elem, $widget, data);
|
|
|
|
return false;
|
|
};
|
|
},
|
|
|
|
// Trigger CloudStack UI event (cloudStack.*)
|
|
call: function(eventName, data) {
|
|
$(window).trigger('cloudStack.' + eventName, data);
|
|
}
|
|
};
|
|
})(jQuery, cloudStack);
|