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

Namespace dropdown menu CSS

This commit is contained in:
Nick O'Leary 2019-05-07 14:46:44 +01:00
parent 67f8ec7f87
commit 3f1c4b4117
No known key found for this signature in database
GPG Key ID: 4F2157149161A6C9
11 changed files with 264 additions and 334 deletions

View File

@ -481,8 +481,8 @@ var RED = (function() {
menuOptions.push({id:"menu-item-node-red-version", label:"v"+RED.settings.version, onselect: "core:show-about" }); menuOptions.push({id:"menu-item-node-red-version", label:"v"+RED.settings.version, onselect: "core:show-about" });
$('<li><a id="btn-sidemenu" class="button" href="#"><i class="fa fa-bars"></i></a></li>').appendTo(".red-ui-header-toolbar") $('<li><a id="red-ui-header-button-sidemenu" class="button" href="#"><i class="fa fa-bars"></i></a></li>').appendTo(".red-ui-header-toolbar")
RED.menu.init({id:"btn-sidemenu",options: menuOptions}); RED.menu.init({id:"red-ui-header-button-sidemenu",options: menuOptions});
} }

View File

@ -61,7 +61,7 @@ RED.menu = (function() {
item = $('<li></li>'); item = $('<li></li>');
if (opt.group) { if (opt.group) {
item.addClass("menu-group-"+opt.group); item.addClass("rd-ui-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="#">';
@ -79,10 +79,10 @@ RED.menu = (function() {
} }
if (opt.sublabel) { if (opt.sublabel) {
linkContent += '<span class="menu-label-container"><span class="menu-label">'+opt.label+'</span>'+ linkContent += '<span class="red-ui-menu-label-container"><span class="red-ui-menu-label">'+opt.label+'</span>'+
'<span class="menu-sublabel">'+opt.sublabel+'</span></span>' '<span class="red-ui-menu-sublabel">'+opt.sublabel+'</span></span>'
} else { } else {
linkContent += '<span class="menu-label">'+opt.label+'</span>' linkContent += '<span class="red-ui-menu-label">'+opt.label+'</span>'
} }
linkContent += '</a>'; linkContent += '</a>';
@ -130,8 +130,8 @@ RED.menu = (function() {
}); });
} }
if (opt.options) { if (opt.options) {
item.addClass("dropdown-submenu pull-left"); item.addClass("red-ui-menu-dropdown-submenu pull-left");
var submenu = $('<ul id="'+opt.id+'-submenu" class="dropdown-menu"></ul>').appendTo(item); var submenu = $('<ul id="'+opt.id+'-submenu" class="red-ui-menu-dropdown"></ul>').appendTo(item);
for (var i=0;i<opt.options.length;i++) { for (var i=0;i<opt.options.length;i++) {
var li = createMenuItem(opt.options[i]); var li = createMenuItem(opt.options[i]);
@ -150,7 +150,7 @@ RED.menu = (function() {
} }
function createMenu(options) { function createMenu(options) {
var topMenu = $("<ul/>",{class:"red-ui-menu dropdown-menu pull-right"}); var topMenu = $("<ul/>",{class:"red-ui-menu red-ui-menu-dropdown pull-right"});
if (options.id) { if (options.id) {
topMenu.attr({id:options.id+"-submenu"}); topMenu.attr({id:options.id+"-submenu"});
@ -239,13 +239,13 @@ RED.menu = (function() {
function addItem(id,opt) { function addItem(id,opt) {
var item = createMenuItem(opt); var item = createMenuItem(opt);
if (opt.group) { if (opt.group) {
var groupItems = $("#"+id+"-submenu").children(".menu-group-"+opt.group); var groupItems = $("#"+id+"-submenu").children(".red-ui-menu-group-"+opt.group);
if (groupItems.length === 0) { if (groupItems.length === 0) {
item.appendTo("#"+id+"-submenu"); item.appendTo("#"+id+"-submenu");
} else { } else {
for (var i=0;i<groupItems.length;i++) { for (var i=0;i<groupItems.length;i++) {
var groupItem = groupItems[i]; var groupItem = groupItems[i];
var label = $(groupItem).find(".menu-label").html(); var label = $(groupItem).find(".red-ui-menu-label").html();
if (opt.label < label) { if (opt.label < label) {
$(groupItem).before(item); $(groupItem).before(item);
break; break;

View File

@ -36,7 +36,7 @@ RED.deploy = (function() {
function changeDeploymentType(type) { function changeDeploymentType(type) {
deploymentType = type; deploymentType = type;
$("#btn-deploy-icon").attr("src",deploymentTypes[type].img); $("#red-ui-header-button-deploy-icon").attr("src",deploymentTypes[type].img);
} }
/** /**
@ -51,19 +51,19 @@ RED.deploy = (function() {
var type = options.type || "default"; var type = options.type || "default";
if (type == "default") { if (type == "default") {
$('<li><span class="deploy-button-group button-group">'+ $('<li><span class="red-ui-deploy-button-group button-group">'+
'<a id="btn-deploy" class="deploy-button disabled" href="#">'+ '<a id="red-ui-header-button-deploy" class="red-ui-deploy-button disabled" href="#">'+
'<span class="deploy-button-content">'+ '<span class="red-ui-deploy-button-content">'+
'<img id="btn-deploy-icon" src="red/images/deploy-full-o.png"> '+ '<img id="red-ui-header-button-deploy-icon" src="red/images/deploy-full-o.png"> '+
'<span>'+RED._("deploy.deploy")+'</span>'+ '<span>'+RED._("deploy.deploy")+'</span>'+
'</span>'+ '</span>'+
'<span class="deploy-button-spinner hide">'+ '<span class="red-ui-deploy-button-spinner hide">'+
'<img src="red/images/spin.svg"/>'+ '<img src="red/images/spin.svg"/>'+
'</span>'+ '</span>'+
'</a>'+ '</a>'+
'<a id="btn-deploy-options" class="deploy-button" href="#"><i class="fa fa-caret-down"></i></a>'+ '<a id="red-ui-header-button-deploy-options" class="red-ui-deploy-button" href="#"><i class="fa fa-caret-down"></i></a>'+
'</span></li>').prependTo(".red-ui-header-toolbar"); '</span></li>').prependTo(".red-ui-header-toolbar");
RED.menu.init({id:"btn-deploy-options", RED.menu.init({id:"red-ui-header-button-deploy-options",
options: [ options: [
{id:"deploymenu-item-full",toggle:"deploy-type",icon:"red/images/deploy-full.png",label:RED._("deploy.full"),sublabel:RED._("deploy.fullDesc"),selected: true, onselect:function(s) { if(s){changeDeploymentType("full")}}}, {id:"deploymenu-item-full",toggle:"deploy-type",icon:"red/images/deploy-full.png",label:RED._("deploy.full"),sublabel:RED._("deploy.fullDesc"),selected: true, onselect:function(s) { if(s){changeDeploymentType("full")}}},
{id:"deploymenu-item-flow",toggle:"deploy-type",icon:"red/images/deploy-flows.png",label:RED._("deploy.modifiedFlows"),sublabel:RED._("deploy.modifiedFlowsDesc"), onselect:function(s) {if(s){changeDeploymentType("flows")}}}, {id:"deploymenu-item-flow",toggle:"deploy-type",icon:"red/images/deploy-flows.png",label:RED._("deploy.modifiedFlows"),sublabel:RED._("deploy.modifiedFlowsDesc"), onselect:function(s) {if(s){changeDeploymentType("flows")}}},
@ -80,20 +80,20 @@ RED.deploy = (function() {
icon = options.icon; icon = options.icon;
} }
$('<li><span class="deploy-button-group button-group">'+ $('<li><span class="red-ui-deploy-button-group button-group">'+
'<a id="btn-deploy" class="deploy-button disabled" href="#">'+ '<a id="red-ui-header-button-deploy" class="red-ui-deploy-button disabled" href="#">'+
'<span class="deploy-button-content">'+ '<span class="red-ui-deploy-button-content">'+
(icon?'<img id="btn-deploy-icon" src="'+icon+'"> ':'')+ (icon?'<img id="red-ui-header-button-deploy-icon" src="'+icon+'"> ':'')+
'<span>'+label+'</span>'+ '<span>'+label+'</span>'+
'</span>'+ '</span>'+
'<span class="deploy-button-spinner hide">'+ '<span class="red-ui-deploy-button-spinner hide">'+
'<img src="red/images/spin.svg"/>'+ '<img src="red/images/spin.svg"/>'+
'</span>'+ '</span>'+
'</a>'+ '</a>'+
'</span></li>').prependTo(".red-ui-header-toolbar"); '</span></li>').prependTo(".red-ui-header-toolbar");
} }
$('#btn-deploy').on("click", function(event) { $('#red-ui-header-button-deploy').on("click", function(event) {
event.preventDefault(); event.preventDefault();
save(); save();
}); });
@ -107,10 +107,10 @@ RED.deploy = (function() {
window.onbeforeunload = function() { window.onbeforeunload = function() {
return RED._("deploy.confirm.undeployedChanges"); return RED._("deploy.confirm.undeployedChanges");
} }
$("#btn-deploy").removeClass("disabled"); $("#red-ui-header-button-deploy").removeClass("disabled");
} else { } else {
window.onbeforeunload = null; window.onbeforeunload = null;
$("#btn-deploy").addClass("disabled"); $("#red-ui-header-button-deploy").addClass("disabled");
} }
}); });
@ -266,10 +266,10 @@ RED.deploy = (function() {
} }
function restart() { function restart() {
var startTime = Date.now(); var startTime = Date.now();
$(".deploy-button-content").css('opacity',0); $(".red-ui-deploy-button-content").css('opacity',0);
$(".deploy-button-spinner").show(); $(".red-ui-deploy-button-spinner").show();
var deployWasEnabled = !$("#btn-deploy").hasClass("disabled"); var deployWasEnabled = !$("#red-ui-header-button-deploy").hasClass("disabled");
$("#btn-deploy").addClass("disabled"); $("#red-ui-header-button-deploy").addClass("disabled");
deployInflight = true; deployInflight = true;
$("#red-ui-header-shade").show(); $("#red-ui-header-shade").show();
$("#red-ui-editor-shade").show(); $("#red-ui-editor-shade").show();
@ -284,12 +284,12 @@ RED.deploy = (function() {
} }
}).done(function(data,textStatus,xhr) { }).done(function(data,textStatus,xhr) {
if (deployWasEnabled) { if (deployWasEnabled) {
$("#btn-deploy").removeClass("disabled"); $("#red-ui-header-button-deploy").removeClass("disabled");
} }
RED.notify('<p>'+RED._("deploy.successfulRestart")+'</p>',"success"); RED.notify('<p>'+RED._("deploy.successfulRestart")+'</p>',"success");
}).fail(function(xhr,textStatus,err) { }).fail(function(xhr,textStatus,err) {
if (deployWasEnabled) { if (deployWasEnabled) {
$("#btn-deploy").removeClass("disabled"); $("#red-ui-header-button-deploy").removeClass("disabled");
} }
if (xhr.status === 401) { if (xhr.status === 401) {
RED.notify(RED._("deploy.deployFailed",{message:RED._("user.notAuthorized")}),"error"); RED.notify(RED._("deploy.deployFailed",{message:RED._("user.notAuthorized")}),"error");
@ -304,8 +304,8 @@ RED.deploy = (function() {
deployInflight = false; deployInflight = false;
var delta = Math.max(0,300-(Date.now()-startTime)); var delta = Math.max(0,300-(Date.now()-startTime));
setTimeout(function() { setTimeout(function() {
$(".deploy-button-content").css('opacity',1); $(".red-ui-deploy-button-content").css('opacity',1);
$(".deploy-button-spinner").hide(); $(".red-ui-deploy-button-spinner").hide();
$("#red-ui-header-shade").hide(); $("#red-ui-header-shade").hide();
$("#red-ui-editor-shade").hide(); $("#red-ui-editor-shade").hide();
$("#red-ui-palette-shade").hide(); $("#red-ui-palette-shade").hide();
@ -314,7 +314,7 @@ RED.deploy = (function() {
}); });
} }
function save(skipValidation,force) { function save(skipValidation,force) {
if (!$("#btn-deploy").hasClass("disabled")) { if (!$("#red-ui-header-button-deploy").hasClass("disabled")) {
if (!RED.user.hasPermission("flows.write")) { if (!RED.user.hasPermission("flows.write")) {
RED.notify(RED._("user.errors.deploy"),"error"); RED.notify(RED._("user.errors.deploy"),"error");
return; return;
@ -411,9 +411,9 @@ RED.deploy = (function() {
var nns = RED.nodes.createCompleteNodeSet(); var nns = RED.nodes.createCompleteNodeSet();
var startTime = Date.now(); var startTime = Date.now();
$(".deploy-button-content").css('opacity',0); $(".red-ui-deploy-button-content").css('opacity',0);
$(".deploy-button-spinner").show(); $(".red-ui-deploy-button-spinner").show();
$("#btn-deploy").addClass("disabled"); $("#red-ui-header-button-deploy").addClass("disabled");
var data = {flows:nns}; var data = {flows:nns};
@ -476,7 +476,7 @@ RED.deploy = (function() {
RED.events.emit("deploy"); RED.events.emit("deploy");
}).fail(function(xhr,textStatus,err) { }).fail(function(xhr,textStatus,err) {
RED.nodes.dirty(true); RED.nodes.dirty(true);
$("#btn-deploy").removeClass("disabled"); $("#red-ui-header-button-deploy").removeClass("disabled");
if (xhr.status === 401) { if (xhr.status === 401) {
RED.notify(RED._("deploy.deployFailed",{message:RED._("user.notAuthorized")}),"error"); RED.notify(RED._("deploy.deployFailed",{message:RED._("user.notAuthorized")}),"error");
} else if (xhr.status === 409) { } else if (xhr.status === 409) {
@ -490,8 +490,8 @@ RED.deploy = (function() {
deployInflight = false; deployInflight = false;
var delta = Math.max(0,300-(Date.now()-startTime)); var delta = Math.max(0,300-(Date.now()-startTime));
setTimeout(function() { setTimeout(function() {
$(".deploy-button-content").css('opacity',1); $(".red-ui-deploy-button-content").css('opacity',1);
$(".deploy-button-spinner").hide(); $(".red-ui-deploy-button-spinner").hide();
$("#red-ui-header-shade").hide(); $("#red-ui-header-shade").hide();
$("#red-ui-editor-shade").hide(); $("#red-ui-editor-shade").hide();
$("#red-ui-palette-shade").hide(); $("#red-ui-palette-shade").hide();

View File

@ -205,7 +205,7 @@ RED.library = (function() {
'<a id="node-input-'+options.type+'-lookup" class="editor-button"><i class="fa fa-book"></i> <i class="fa fa-caret-down"></i></a>'+ '<a id="node-input-'+options.type+'-lookup" class="editor-button"><i class="fa fa-book"></i> <i class="fa fa-caret-down"></i></a>'+
'</div>' '</div>'
// '<ul class="dropdown-menu pull-right" role="menu">'+ // '<ul class="red-ui-menu-dropdown pull-right" role="menu">'+
// '<li><a id="node-input-'+options.type+'-menu-open-library" tabindex="-1" href="#">'+RED._("library.openLibrary")+'</a></li>'+ // '<li><a id="node-input-'+options.type+'-menu-open-library" tabindex="-1" href="#">'+RED._("library.openLibrary")+'</a></li>'+
// '<li><a id="node-input-'+options.type+'-menu-save-library" tabindex="-1" href="#">'+RED._("library.saveToLibrary")+'</a></li>'+ // '<li><a id="node-input-'+options.type+'-menu-save-library" tabindex="-1" href="#">'+RED._("library.saveToLibrary")+'</a></li>'+
// '</ul></div>' // '</ul></div>'

View File

@ -178,9 +178,9 @@ RED.user = (function() {
} }
function updateUserMenu() { function updateUserMenu() {
$("#btn-usermenu-submenu li").remove(); $("#red-ui-header-button-user-submenu li").remove();
if (RED.settings.user.anonymous) { if (RED.settings.user.anonymous) {
RED.menu.addItem("btn-usermenu",{ RED.menu.addItem("red-ui-header-button-user",{
id:"usermenu-item-login", id:"usermenu-item-login",
label:RED._("menu.label.login"), label:RED._("menu.label.login"),
onselect: function() { onselect: function() {
@ -194,11 +194,11 @@ RED.user = (function() {
} }
}); });
} else { } else {
RED.menu.addItem("btn-usermenu",{ RED.menu.addItem("red-ui-header-button-user",{
id:"usermenu-item-username", id:"usermenu-item-username",
label:"<b>"+RED.settings.user.username+"</b>" label:"<b>"+RED.settings.user.username+"</b>"
}); });
RED.menu.addItem("btn-usermenu",{ RED.menu.addItem("red-ui-header-button-user",{
id:"usermenu-item-logout", id:"usermenu-item-logout",
label:RED._("menu.label.logout"), label:RED._("menu.label.logout"),
onselect: function() { onselect: function() {
@ -213,7 +213,7 @@ RED.user = (function() {
if (RED.settings.user) { if (RED.settings.user) {
if (!RED.settings.editorTheme || !RED.settings.editorTheme.hasOwnProperty("userMenu")) { if (!RED.settings.editorTheme || !RED.settings.editorTheme.hasOwnProperty("userMenu")) {
var userMenu = $('<li><a id="btn-usermenu" class="button hide" href="#"></a></li>') var userMenu = $('<li><a id="red-ui-header-button-user" class="button hide" href="#"></a></li>')
.prependTo(".red-ui-header-toolbar"); .prependTo(".red-ui-header-toolbar");
if (RED.settings.user.image) { if (RED.settings.user.image) {
$('<span class="user-profile"></span>').css({ $('<span class="user-profile"></span>').css({
@ -223,7 +223,7 @@ RED.user = (function() {
$('<i class="fa fa-user"></i>').appendTo(userMenu.find("a")); $('<i class="fa fa-user"></i>').appendTo(userMenu.find("a"));
} }
RED.menu.init({id:"btn-usermenu", RED.menu.init({id:"red-ui-header-button-user",
options: [] options: []
}); });
updateUserMenu(); updateUserMenu();

View File

@ -37,6 +37,19 @@ body {
overflow:hidden; overflow:hidden;
} }
#red-ui-palette-shade, #red-ui-editor-shade, #red-ui-header-shade, #red-ui-sidebar-shade {
@include shade;
z-index: 2;
}
#red-ui-sidebar-shade {
left: -8px;
top: -1px;
bottom: -1px;
}
#red-ui-full-shade {
@include shade;
z-index: 15;
}
a { a {
color: #0088cc; color: #0088cc;

View File

@ -83,3 +83,13 @@ $diff-state-unchanged: #bbb;
$diff-state-conflicted: purple; $diff-state-conflicted: purple;
$diff-state-moved: #3f81b3; $diff-state-moved: #3f81b3;
$diff-state-conflict: #9b45ce; $diff-state-conflict: #9b45ce;
$menuBackground: #f3f3f3;
$menuDivider: #e5e5e5;
$menuColor: #444;
$menuActiveColor: #ffffff;
$menuActiveBackground: #777;
$menuDisabledColor: #999;
$menuHoverColor: #ffffff;
$menuHoverBackground: #999;
$menuCaret: #e0e0e0;

View File

@ -14,131 +14,118 @@
* limitations under the License. * limitations under the License.
**/ **/
.dropdown-menu { .red-ui-menu-dropdown {
position: absolute; position: absolute;
top: 100%; top: 100%;
width: 200px;
left: 0; left: 0;
z-index: 1000; z-index: 1000;
display: none; display: none;
float: left; float: left;
min-width: 160px;
padding: 5px 0;
margin: 2px 0 0; margin: 2px 0 0;
margin-left: 0px !important;
padding: 5px 0;
list-style: none; list-style: none;
background-color: #ffffff; background: $menuBackground;
border: 1px solid #ccc; border: 1px solid $secondary-border-color;
border: 1px solid rgba(0, 0, 0, 0.2);
*border-right-width: 2px;
*border-bottom-width: 2px;
-webkit-border-radius: 6px;
-moz-border-radius: 6px;
border-radius: 6px;
-webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
-moz-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
-webkit-background-clip: padding-box;
-moz-background-clip: padding;
background-clip: padding-box;
}
.dropdown-menu.pull-right { &.pull-right {
right: 0; right: 0;
left: auto; left: auto;
} }
.pull-right > .dropdown-menu { .divider {
right: 0;
left: auto;
}
.dropdown-menu .divider {
*width: 100%;
height: 1px; height: 1px;
margin: 9px 1px; margin: 9px 1px;
*margin: -5px 0 5px;
overflow: hidden; overflow: hidden;
background-color: #e5e5e5; background-color: $menuDivider;
border-bottom: 1px solid #ffffff; }
} & > li > a {
.dropdown-menu > li > a {
display: block; display: block;
padding: 3px 20px; padding: 3px 0 3px 32px;
clear: both; clear: both;
font-weight: normal; font-weight: normal;
line-height: 20px; line-height: 20px;
color: #333333; color: $menuColor;
white-space: nowrap; white-space: normal !important;
} }
.dropdown-menu > li > a:hover, & > .active > a,
.dropdown-menu > li > a:focus, & > .active > a:hover,
.dropdown-submenu:hover > a, & > .active > a:focus {
.dropdown-submenu:focus > a { color: $menuActiveColor;
color: #ffffff;
text-decoration: none; text-decoration: none;
background-color: #0081c2; background-color: $menuActiveBackground;
background-image: -moz-linear-gradient(top, #0088cc, #0077b3);
background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#0088cc), to(#0077b3));
background-image: -webkit-linear-gradient(top, #0088cc, #0077b3);
background-image: -o-linear-gradient(top, #0088cc, #0077b3);
background-image: linear-gradient(to bottom, #0088cc, #0077b3);
background-repeat: repeat-x;
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0088cc', endColorstr='#ff0077b3', GradientType=0);
}
.dropdown-menu > .active > a,
.dropdown-menu > .active > a:hover,
.dropdown-menu > .active > a:focus {
color: #ffffff;
text-decoration: none;
background-color: #0081c2;
background-image: -moz-linear-gradient(top, #0088cc, #0077b3);
background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#0088cc), to(#0077b3));
background-image: -webkit-linear-gradient(top, #0088cc, #0077b3);
background-image: -o-linear-gradient(top, #0088cc, #0077b3);
background-image: linear-gradient(to bottom, #0088cc, #0077b3);
background-repeat: repeat-x;
outline: 0; outline: 0;
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0088cc', endColorstr='#ff0077b3', GradientType=0); }
}
.dropdown-menu > .disabled > a, & > .disabled > a,
.dropdown-menu > .disabled > a:hover, & > .disabled > a:hover,
.dropdown-menu > .disabled > a:focus { & > .disabled > a:focus {
color: #999999; color: $menuDisabledColor;
} }
.dropdown-menu > .disabled > a:hover, & > .disabled > a:hover,
.dropdown-menu > .disabled > a:focus { & > .disabled > a:focus {
text-decoration: none; text-decoration: none;
cursor: default; cursor: default;
background-color: transparent; background-color: transparent;
background-image: none; background-image: none;
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); }
a {
.fa {
width: 20px;
margin-left: -25px;
margin-top: 3px;
text-align: center;
}
.fa-check-square {
display: none;
}
.fa-square {
display: inline-block;
}
&.active {
.fa-check-square {
display: inline-block;
}
.fa-square {
display: none;
}
}
}
}
.pull-right > .red-ui-menu-dropdown {
right: 0;
left: auto;
} }
.red-ui-menu-dropdown > li > a:hover,
.red-ui-menu-dropdown > li > a:focus,
.red-ui-menu-dropdown-submenu:hover > a,
.red-ui-menu-dropdown-submenu:focus > a {
color: $menuHoverColor;
text-decoration: none;
background-color: $menuHoverBackground;
}
.dropdown-submenu { .red-ui-menu-dropdown-submenu {
position: relative; position: relative;
} & > .red-ui-menu-dropdown {
.dropdown-submenu > .dropdown-menu {
top: 0; top: 0;
left: 100%; left: 100%;
margin-top: -6px; margin-top: -6px;
margin-left: -1px; margin-left: -1px;
-webkit-border-radius: 0 6px 6px 6px; }
-moz-border-radius: 0 6px 6px 6px; &:hover > .red-ui-menu-dropdown {
border-radius: 0 6px 6px 6px;
}
.dropdown-submenu:hover > .dropdown-menu {
display: block; display: block;
} }
& > a:after {
.dropdown-submenu > a:after {
display: block; display: block;
float: right; float: right;
width: 0; width: 0;
@ -146,99 +133,38 @@
margin-top: 5px; margin-top: 5px;
margin-right: -10px; margin-right: -10px;
border-color: transparent; border-color: transparent;
border-left-color: #cccccc; border-left-color: $menuCaret;
border-style: solid; border-style: solid;
border-width: 5px 0 5px 5px; border-width: 5px 0 5px 5px;
content: " "; content: " ";
} }
&.pull-left {
.dropdown-submenu:hover > a:after {
border-left-color: #ffffff;
}
.dropdown-submenu.pull-left {
float: none; float: none;
} & > .red-ui-menu-dropdown {
.dropdown-submenu.pull-left > .dropdown-menu {
left: -100%; left: -100%;
margin-left: 10px; margin-left: 10px;
-webkit-border-radius: 6px 0 6px 6px; }
-moz-border-radius: 6px 0 6px 6px;
border-radius: 6px 0 6px 6px;
}
.dropdown-menu>li>a:hover, .dropdown-menu>li>a:focus, .dropdown-submenu:hover>a, .dropdown-submenu:focus>a {
background: #999;
}
.dropdown-menu {
background: #f3f3f3;
border-color: $secondary-border-color;
&>li>a {
color: #444;
} }
} }
.red-ui-menu-dropdown-submenu>a:after {
.dropdown-menu * .fa-check-square {
display: none;
color: #e0e0e0;
margin-left: -25px;
margin-top: 3px;
}
.dropdown-menu * a.active > .fa-check-square {
display: inline-block;
}
.dropdown-menu * .fa-square {
display: inline-block;
color: #e0e0e0;
margin-left: -25px;
margin-top: 3px;
}
.dropdown-menu * a.active > .fa-square {
display: none; display: none;
} }
.red-ui-menu-dropdown-submenu>a:before {
/** Fix for unreachable dropdown menu **/
.dropdown-menu {
border-radius: 0;
width: 200px !important;
margin-left: 0px !important;
}
.dropdown-menu > li > a > i {
width: 10px;
text-align: center;
margin-left: -8px;
}
.dropdown-menu > li > a {
padding-left: 38px ;
text-indent: -8px ;
white-space: normal !important;
}
.dropdown-submenu>a:after {
display: none;
}
.dropdown-submenu>a:before {
display: block; display: block;
float: left; float: left;
width: 0; width: 0;
height: 0; height: 0;
margin-top: 5px; margin-top: 5px;
margin-left: -30px; margin-left: -30px;
/* Caret Arrow */
border-color: transparent; border-color: transparent;
border-right-color: #e0e0e0; border-right-color: $menuCaret;
border-style: solid; border-style: solid;
border-width: 5px 5px 5px 0; border-width: 5px 5px 5px 0;
content: " "; content: " ";
} }
.dropdown-submenu.disabled > a:before { .red-ui-menu-dropdown-submenu.disabled > a:before {
border-right-color: #444; border-right-color: #444;
} }
.dropdown-submenu.pull-left>.dropdown-menu {
border-radius: 0;
}

View File

@ -154,21 +154,8 @@
background: $background-color; background: $background-color;
color: $workspace-button-color; color: $workspace-button-color;
} }
#red-ui-palette-shade, #red-ui-editor-shade, #red-ui-header-shade, #red-ui-sidebar-shade {
@include shade;
z-index: 2;
}
#red-ui-sidebar-shade {
left: -8px;
top: -1px;
bottom: -1px;
}
#red-ui-full-shade {
@include shade;
z-index: 15;
}
.dialog-form,#dialog-form, #node-config-dialog-edit-form { .dialog-form, #dialog-form, #node-config-dialog-edit-form {
height: 100%; height: 100%;
} }

View File

@ -764,8 +764,8 @@ select:focus:invalid:focus {
.input-prepend select, .input-prepend select,
.input-append .uneditable-input, .input-append .uneditable-input,
.input-prepend .uneditable-input, .input-prepend .uneditable-input,
.input-append .dropdown-menu, .input-append .red-ui-menu-dropdown,
.input-prepend .dropdown-menu, .input-prepend .red-ui-menu-dropdown,
.input-append .popover, .input-append .popover,
.input-prepend .popover { .input-prepend .popover {
font-size: 14px; font-size: 14px;

View File

@ -24,6 +24,7 @@ $deployDisabledButton: #444;
$deployDisabledButtonHover: #555; $deployDisabledButtonHover: #555;
$deployDisabledButtonActive: #444; $deployDisabledButtonActive: #444;
$headerMenuColor: #C7C7C7;
$headerMenuBackground: #121212; $headerMenuBackground: #121212;
$headerMenuItemHover: #323232; $headerMenuItemHover: #323232;
$headerMenuItemDivider: #464646; $headerMenuItemDivider: #464646;
@ -42,7 +43,7 @@ $headerMenuItemDivider: #464646;
background: #000; background: #000;
box-sizing: border-box; box-sizing: border-box;
padding: 0px 0px 0px 20px; padding: 0px 0px 0px 20px;
color: #C7C7C7; color: $headerMenuColor;
font-size: 14px; font-size: 14px;
span.red-ui-header-logo { span.red-ui-header-logo {
@ -95,7 +96,7 @@ $headerMenuItemDivider: #464646;
font-size: 20px; font-size: 20px;
padding: 0px 12px; padding: 0px 12px;
text-decoration: none; text-decoration: none;
color: #C7C7C7; color: $headerMenuColor;
margin: auto 5px; margin: auto 5px;
vertical-align: middle; vertical-align: middle;
border-left: 2px solid #000; border-left: 2px solid #000;
@ -129,7 +130,7 @@ $headerMenuItemDivider: #464646;
} }
} }
.deploy-button { .red-ui-deploy-button {
background: $deployButton; background: $deployButton;
color: #eee !important; color: #eee !important;
@ -143,7 +144,7 @@ $headerMenuItemDivider: #464646;
} }
} }
.deploy-button-spinner { .red-ui-deploy-button-spinner {
position: absolute; position: absolute;
left: 0; left: 0;
top: 0; top: 0;
@ -157,35 +158,35 @@ $headerMenuItemDivider: #464646;
} }
} }
#btn-deploy { #red-ui-header-button-deploy {
padding: 4px 12px; padding: 4px 12px;
&.disabled { &.disabled {
cursor: default; cursor: default;
background: $deployDisabledButton; background: $deployDisabledButton;
color: #999 !important; color: #999 !important;
.deploy-button-content>img { .red-ui-deploy-button-content>img {
opacity: 0.3; opacity: 0.3;
} }
&+ #btn-deploy-options { &+ #red-ui-header-button-deploy-options {
background: $deployDisabledButton; background: $deployDisabledButton;
color: #ddd; color: #ddd;
} }
&+ #btn-deploy-options:hover { &+ #red-ui-header-button-deploy-options:hover {
background: $deployDisabledButtonHover; background: $deployDisabledButtonHover;
} }
&+ #btn-deploy-options:active { &+ #red-ui-header-button-deploy-options:active {
background: $deployDisabledButton; background: $deployDisabledButton;
} }
} }
.deploy-button-content>img { .red-ui-deploy-button-content>img {
margin-right: 8px; margin-right: 8px;
} }
} }
.deploy-button-group.open { .red-ui-deploy-button-group.open {
#btn-deploy-options { #red-ui-header-button-deploy-options {
background: $activeButton !important; background: $activeButton !important;
} }
} }
@ -196,88 +197,81 @@ $headerMenuItemDivider: #464646;
} }
ul.dropdown-menu { ul.red-ui-menu-dropdown {
background: $headerMenuBackground; background: $headerMenuBackground;
border: 1px solid rgba(0,0,0,0.2); border: 1px solid rgba(0,0,0,0.2);
width: 250px !important; width: 250px !important;
margin-top: 0; margin-top: 0;
} li a {
color: $headerMenuColor;
ul.dropdown-menu li a {
color: #C7C7C7;
padding: 3px 40px; padding: 3px 40px;
} img {
ul.dropdown-menu li a img {
margin-right: 10px; margin-right: 10px;
padding: 4px; padding: 4px;
border: 3px solid rgba(0,0,0,0); border: 3px solid rgba(0,0,0,0);
} }
ul.dropdown-menu li a.active img { &.active img {
border: 3px solid #777677; border: 3px solid #777677;
} }
ul.dropdown-menu li a span.menu-label-container { span.red-ui-menu-label-container {
width: 180px; width: 180px;
vertical-align: top; vertical-align: top;
display: inline-block; display: inline-block;
text-indent: 0px; text-indent: 0px;
} }
ul.dropdown-menu li a span.menu-label { span.red-ui-menu-label {
font-size: 14px; font-size: 14px;
display: inline-block; display: inline-block;
text-indent: 0px; text-indent: 0px;
} }
ul.dropdown-menu li a span.menu-sublabel { span.red-ui-menu-sublabel {
color: #aeaeae; color: #aeaeae;
font-size: 13px; font-size: 13px;
display: inline-block; display: inline-block;
text-indent: 0px; text-indent: 0px;
} }
}
ul.dropdown-menu > li:hover > a, > li:hover > a,
ul.dropdown-menu > li:focus > a { > li:focus > a {
background: $headerMenuItemHover !important; background: $headerMenuItemHover !important;
} }
li.divider {
ul.dropdown-menu li.divider {
background: $headerMenuItemDivider; background: $headerMenuItemDivider;
border-bottom-color: $headerMenuItemHover; border-bottom-color: $headerMenuItemHover;
} }
ul.dropdown-menu li.disabled a { li.disabled a {
color: #666; color: #666;
} }
> li.disabled:hover > a,
ul.dropdown-menu > li.disabled:hover > a, > li.disabled:focus > a {
ul.dropdown-menu > li.disabled:focus > a {
background: none !important; background: none !important;
} }
}
/* Deploy menu customisations */ /* Deploy menu customisations */
ul#btn-deploy-options-submenu { ul#red-ui-header-button-deploy-options-submenu {
width: 300px !important; width: 300px !important;
} li a {
ul#btn-deploy-options-submenu li a span.menu-label { padding: 10px 30px;
color: #fff;
span.red-ui-menu-label {
font-size: 16px; font-size: 16px;
display: inline-block; display: inline-block;
text-indent: 0px; text-indent: 0px;
} }
ul#btn-deploy-options-submenu li a { > i.fa {
padding: 10px 30px;
color: #fff;
}
ul#btn-deploy-options-submenu li a > i.fa {
display: none !important; display: none !important;
} }
}
}
/* User menu customisations */ /* User menu customisations */
ul#btn-usermenu-submenu li a#btn-username > .menu-label { #usermenu-item-username > .red-ui-menu-label {
font-size: 16px;
color: #fff; color: #fff;
} }
#btn-usermenu .user-profile { #red-ui-header-button-user .user-profile {
background-position: center center; background-position: center center;
background-repeat: no-repeat; background-repeat: no-repeat;
background-size: contain; background-size: contain;