mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	Allows UI plugins to contribute their own internationalized strings to the global js dictionary. Each plugin would define a dictionary.js and several dictionary_<locale>.js files. As each plugin is loaded, the appropriate plugin dictionary is loaded into the global js dictionary (with the global dictionary taking precedence in the event of a conflict). Original author: Chris Suich <chris.suich@netapp.com> Reviewed by: Brian Federle <brian.federle@citrix.com>
		
			
				
	
	
		
			145 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			145 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // Licensed to the Apache Software Foundation (ASF) under one
 | |
| // or more contributor license agreements.  See the NOTICE file
 | |
| // distributed with this work for additional information
 | |
| // regarding copyright ownership.  The ASF licenses this file
 | |
| // to you under the Apache License, Version 2.0 (the
 | |
| // "License"); you may not use this file except in compliance
 | |
| // with the License.  You may obtain a copy of the License at
 | |
| //
 | |
| //   http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing,
 | |
| // software distributed under the License is distributed on an
 | |
| // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 | |
| // KIND, either express or implied.  See the License for the
 | |
| // specific language governing permissions and limitations
 | |
| // under the License.
 | |
| (function($, cloudStack, require) {
 | |
|     if (!cloudStack.pluginAPI) {
 | |
|         cloudStack.pluginAPI = {};
 | |
|     }
 | |
| 
 | |
|     var loadCSS = function(path) {
 | |
|         if (document.createStyleSheet) {
 | |
|             // IE-compatible CSS loading
 | |
|             document.createStyleSheet(path);
 | |
|         } else {
 | |
|             var $link = $('<link>');
 | |
| 
 | |
|             $link.attr({
 | |
|                 rel: 'stylesheet',
 | |
|                 type: 'text/css',
 | |
|                 href: path
 | |
|             });
 | |
| 
 | |
|             $('html head').append($link);
 | |
|         }
 | |
|     };
 | |
| 
 | |
|     $.extend(cloudStack.pluginAPI, {
 | |
|         ui: {
 | |
|             pollAsyncJob: pollAsyncJobResult,
 | |
|             apiCall: function(command, args) {
 | |
|                 $.ajax({
 | |
|                     url: createURL(command),
 | |
|                     data: args.data,
 | |
|                     success: args.success,
 | |
|                     error: function(json) {
 | |
|                         args.error(parseXMLHttpResponse(json));
 | |
|                     }
 | |
|                 });
 | |
|             },
 | |
|             addSection: function(section) {
 | |
|                 cloudStack.sections[section.id] = $.extend(section, {
 | |
|                     customIcon: 'plugins/' + section.id + '/icon.png'
 | |
|                 });
 | |
|             },
 | |
|             extend: function(obj) {
 | |
|                 $.extend(true, cloudStack, obj);
 | |
|             }
 | |
|         }
 | |
|     });
 | |
| 
 | |
|     cloudStack.sections.plugins = {
 | |
|         title: 'label.plugins',
 | |
|         show: cloudStack.uiCustom.pluginListing
 | |
|     };
 | |
| 
 | |
|     var loadedPlugins = 0;
 | |
|     var pluginTotal = cloudStack.plugins.length + cloudStack.modules.length;
 | |
| 
 | |
|     // Load
 | |
|     $(['modules', 'plugins']).each(function() {
 | |
|         var type = this;
 | |
|         var paths = $(cloudStack[type]).map(function(index, id) {
 | |
|             return type + '/' + id + '/' + id;
 | |
|         }).toArray();
 | |
| 
 | |
|         // Load modules
 | |
|         require(
 | |
|             paths,
 | |
|             function() {
 | |
|                 $(cloudStack[type]).map(function(index, id) {
 | |
|                     var basePath = type + '/' + id + '/';
 | |
|                     var css = basePath + id + '.css';
 | |
|                     var configJS = type == 'plugins' ? basePath + 'config' : null;
 | |
| 
 | |
|                     var pluginDictionary;
 | |
|                     var locale;
 | |
|                     if (type == 'plugins') {
 | |
|                         pluginDictionary = basePath + 'dictionary';
 | |
|                         locale = $.cookie('lang');
 | |
|                     }
 | |
| 
 | |
|                     if (configJS) {
 | |
|                         // Load config metadata
 | |
|                         require([configJS]);
 | |
|                     }
 | |
| 
 | |
|                     // Execute module
 | |
|                     cloudStack[type][id](
 | |
|                         $.extend(true, {}, cloudStack.pluginAPI, {
 | |
|                             pluginAPI: {
 | |
|                                 extend: function(api) {
 | |
|                                     cloudStack.pluginAPI[id] = api;
 | |
|                                 }
 | |
|                             }
 | |
|                         })
 | |
|                     );
 | |
| 
 | |
|                     if (pluginDictionary) {
 | |
|                         // Callback for extending the dictionary with new entries
 | |
|                         var addToDictionary = function() {
 | |
|                             var additions = cloudStack[type][id].dictionary;
 | |
|                             $.extend(dictionary, additions);
 | |
|                         };
 | |
| 
 | |
|                         // Only add a suffix if the locale is defined and not english/US
 | |
|                         var suffix = '';
 | |
|                         if (locale && (locale != '' && locale != 'en' & locale != 'en_US'))
 | |
|                             suffix = '_'+locale;
 | |
| 
 | |
|                         // Attempt to load the locale's dictionary
 | |
|                         require([pluginDictionary+suffix], addToDictionary, function() {
 | |
|                             // If the load failed and there was no suffix, don't try again
 | |
|                             if (!suffix)
 | |
|                                 return;
 | |
| 
 | |
|                             // Otherwise try to load the default dictionary
 | |
|                             require([pluginDictionary], addToDictionary);
 | |
|                         });
 | |
|                     }
 | |
| 
 | |
|                     loadedPlugins = loadedPlugins + 1;
 | |
| 
 | |
|                     if (loadedPlugins === pluginTotal) {
 | |
|                         $(window).trigger('cloudStack.pluginReady');
 | |
|                     }
 | |
| 
 | |
|                     loadCSS(css);
 | |
|                 });
 | |
|             }
 | |
|         );
 | |
|     });
 | |
| }(jQuery, cloudStack, require));
 |