mirror of
				https://github.com/node-red/node-red.git
				synced 2025-03-01 10:36:34 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			123 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * Copyright 2014 IBM Corp.
 | |
|  *
 | |
|  * Licensed 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.
 | |
|  **/
 | |
|  
 | |
| 
 | |
| 
 | |
| RED.menu = (function() {
 | |
|     
 | |
|     var menuItems = {};
 | |
|     
 | |
|     function createMenuItem(opt) {
 | |
|         var item;
 | |
|         if (opt === null) {
 | |
|             item = $('<li class="divider"></li>');
 | |
|         } else {
 | |
|             item = $('<li></li>');
 | |
|             var link = $('<a '+(opt.id?'id="'+opt.id+'" ':'')+'tabindex="-1" href="#">'+
 | |
|                 (opt.toggle?'<i class="fa fa-check pull-right"></i>':'')+
 | |
|                 (opt.icon?'<i class="'+opt.icon+'"></i> ':'')+
 | |
|                 opt.label+
 | |
|                 '</a>').appendTo(item);
 | |
|                 
 | |
|             menuItems[opt.id] = opt;
 | |
|             
 | |
|             if (opt.onselect) {
 | |
|                 link.click(function() {
 | |
|                         if ($(this).parent().hasClass("disabled")) {
 | |
|                             return;
 | |
|                         }
 | |
|                         if (opt.toggle) {
 | |
|                             setSelected(opt.id,!isSelected(opt.id));
 | |
|                         } else {
 | |
|                             opt.onselect.call(opt);
 | |
|                         }
 | |
|                 })
 | |
|             } else if (opt.href) {
 | |
|                 link.attr("target","_blank").attr("href",opt.href);
 | |
|             }
 | |
|             if (opt.options) {
 | |
|                 item.addClass("dropdown-submenu pull-left");
 | |
|                 var submenu = $('<ul id="'+opt.id+'-submenu" class="dropdown-menu"></ul>').appendTo(item);
 | |
|                 
 | |
|                 for (var i=0;i<opt.options.length;i++) {
 | |
|                     createMenuItem(opt.options[i]).appendTo(submenu);
 | |
|                 }
 | |
|             }
 | |
|             if (opt.disabled) {
 | |
|                 item.addClass("disabled");
 | |
|             }
 | |
|         }
 | |
|         
 | |
|         
 | |
|         return item;
 | |
|         
 | |
|     }
 | |
|     function createMenu(options) {
 | |
|         
 | |
|         var button = $("#"+options.id);
 | |
|         
 | |
|         var topMenu = $("<ul/>",{class:"dropdown-menu"}).insertAfter(button);
 | |
|         
 | |
|         for (var i=0;i<options.options.length;i++) {
 | |
|             var opt = options.options[i];
 | |
|             createMenuItem(opt).appendTo(topMenu);
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     function isSelected(id) {
 | |
|         return $("#"+id).hasClass("active");
 | |
|     }
 | |
|     function setSelected(id,state) {
 | |
|         if (isSelected(id) == state) {
 | |
|             return;
 | |
|         }
 | |
|         var opt = menuItems[id];
 | |
|         if (state) {
 | |
|             $("#"+id).addClass("active");
 | |
|         } else {
 | |
|             $("#"+id).removeClass("active");
 | |
|         }
 | |
|         if (opt.onselect) {
 | |
|             opt.onselect.call(opt,state);
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     function setDisabled(id,state) {
 | |
|         if (state) {
 | |
|             $("#"+id).parent().addClass("disabled");
 | |
|         } else {
 | |
|             $("#"+id).parent().removeClass("disabled");
 | |
|         }
 | |
|     }
 | |
|     
 | |
|     function addItem(id,opt) {
 | |
|         createMenuItem(opt).appendTo("#"+id+"-submenu");
 | |
|     }
 | |
|     function removeItem(id) {
 | |
|         $("#"+id).parent().remove();
 | |
|     }
 | |
|     
 | |
|     return {
 | |
|         init: createMenu,
 | |
|         setSelected: setSelected,
 | |
|         isSelected: isSelected,
 | |
|         setDisabled: setDisabled,
 | |
|         addItem: addItem,
 | |
|         removeItem: removeItem
 | |
|         //TODO: add an api for replacing a submenu - see library.js:loadFlowLibrary
 | |
|     }
 | |
| })();
 |