1
0
mirror of https://github.com/node-red/node-red.git synced 2023-10-10 13:36:53 +02:00

Keep sidebar tab menu in alphabetical order

This commit is contained in:
Nick O'Leary 2015-07-09 16:48:53 +01:00
parent fde9d40098
commit e5a0f25d94
3 changed files with 37 additions and 12 deletions

View File

@ -53,6 +53,10 @@ RED.menu = (function() {
} else { } else {
item = $('<li></li>'); item = $('<li></li>');
if (opt.group) {
item.addClass("menu-group-"+opt.group);
}
var linkContent = '<a '+(opt.id?'id="'+opt.id+'" ':'')+'tabindex="-1" href="#">'; var linkContent = '<a '+(opt.id?'id="'+opt.id+'" ':'')+'tabindex="-1" href="#">';
if (opt.toggle) { if (opt.toggle) {
linkContent += '<i class="fa fa-square pull-left"></i>'; linkContent += '<i class="fa fa-square pull-left"></i>';
@ -208,7 +212,27 @@ RED.menu = (function() {
} }
function addItem(id,opt) { function addItem(id,opt) {
createMenuItem(opt).appendTo("#"+id+"-submenu"); var item = createMenuItem(opt);
if (opt.group) {
var groupItems = $("#"+id+"-submenu").children(".menu-group-"+opt.group);
if (groupItems.length === 0) {
item.appendTo("#"+id+"-submenu");
} else {
for (var i=0;i<groupItems.length;i++) {
var groupItem = groupItems[i];
var label = $(groupItem).find(".menu-label").html();
if (opt.label < label) {
$(groupItem).before(item);
break;
}
}
if (i === groupItems.length) {
item.appendTo("#"+id+"-submenu");
}
}
} else {
item.appendTo("#"+id+"-submenu");
}
} }
function removeItem(id) { function removeItem(id) {
$("#"+id).parent().remove(); $("#"+id).parent().remove();

View File

@ -64,7 +64,8 @@ RED.sidebar = (function() {
label:options.name, label:options.name,
onselect:function() { onselect:function() {
showSidebar(options.id); showSidebar(options.id);
} },
group: "sidebar-tabs"
}); });
knownTabs[options.id] = options; knownTabs[options.id] = options;

View File

@ -178,7 +178,7 @@
}, },
"sidebar": { "sidebar": {
"info": { "info": {
"name": "Node Information", "name": "Information",
"label": "info", "label": "info",
"node": "Node", "node": "Node",
"type": "Type", "type": "Type",