mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
Adds a CSS file <pluginName>.css to the plugin structure, which allows developer to specify custom CSS to be loaded after their JS code.
48 lines
1.0 KiB
JavaScript
48 lines
1.0 KiB
JavaScript
(function($, cloudStack, require) {
|
|
var loadCSS = function(path) {
|
|
var $link = $('<link>');
|
|
|
|
$link.attr({
|
|
rel: 'stylesheet',
|
|
type: 'text/css',
|
|
href: path
|
|
});
|
|
|
|
$('head').append($link);
|
|
};
|
|
|
|
var pluginAPI = {
|
|
addSection: function(section) {
|
|
cloudStack.sections[section.id] = section;
|
|
},
|
|
extend: function(obj) {
|
|
$.extend(true, cloudStack, obj);
|
|
}
|
|
};
|
|
|
|
cloudStack.sections.plugins = {
|
|
title: 'Plugins',
|
|
show: cloudStack.uiCustom.plugins
|
|
};
|
|
|
|
// Load plugins
|
|
$(cloudStack.plugins).map(function(index, pluginID) {
|
|
var basePath = 'plugins/' + pluginID + '/';
|
|
var pluginJS = basePath + pluginID + '.js';
|
|
var configJS = basePath + 'config.js';
|
|
var pluginCSS = basePath + pluginID + '.css';
|
|
|
|
require([pluginJS], function() {
|
|
require([configJS]);
|
|
loadCSS(pluginCSS);
|
|
|
|
// Execute plugin
|
|
cloudStack.plugins[pluginID]({
|
|
ui: pluginAPI
|
|
});
|
|
});
|
|
|
|
// Load CSS
|
|
});
|
|
}(jQuery, cloudStack, require));
|