icingaweb2/public/css/icinga/menu.less

541 lines
9.8 KiB
Plaintext

/*! Icinga Web 2 | (c) 2014 Icinga Development Team | GPLv2+ */
#menu [class^="icon-"],
#menu [class*=" icon-"] {
&:before {
width: 1.5em;
}
}
@icon-width: 1.7em; // 1.5em width + 0.2em right margin
#menu {
background-color: @menu-bg-color;
box-shadow: inset -.5em 0 1em rgba(0, 0, 0, .3);
width: 100%;
flex: 1;
overflow: auto;
overflow-x: hidden;
}
#layout:not(.minimal-layout) #menu {
// Space for the #toggle-sidebar button
&:after {
content: "";
display: block;
padding-bottom: 2.25em;
}
}
#menu .nav-item {
vertical-align: middle;
> a {
position: relative;
&:focus {
outline: none;
}
&:hover {
text-decoration: none;
}
}
.nav-level-2 {
z-index: 1;
}
}
#layout:not(.sidebar-collapsed) #menu .nav-item > a {
// Respect overflowing content
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
#layout:not(.minimal-layout).sidebar-collapsed #menu .nav-level-1 > .nav-item {
overflow: hidden;
}
#layout:not(.minimal-layout).sidebar-collapsed #menu .nav-level-1 > .nav-item > a {
// Clip overflowing content
overflow: hidden;
width: 4em;
}
#menu .nav-level-1 > .nav-item {
line-height: 2.167em; // 26 px
color: @menu-color;
&.active {
> a > .badge {
display: none;
}
background-color: @menu-active-bg-color;
}
&.no-icon > a {
padding-left: @icon-width + .75em;
}
> a {
padding: 0.5em 0.5em 0.5em .75em;
}
&.active:not(.selected) > a:focus,
&.active:not(.selected) > a:hover {
background-color: darken(@menu-active-bg-color, 20);
}
&:not(.selected) > a:hover,
&:not(.selected) > a:focus {
background-color: mix(#000, @menu-bg-color, 20);
}
// Balance icon weight for non active menu items
&:not(.active) > a > i {
opacity: .8;
}
& > a > .icon-letter:before {
content: attr(data-letter);
font-family: @font-family;
font-weight: 800;
text-transform: uppercase;
}
}
ul:not(.nav-level-2) > .selected > a {
background-color: @menu-highlight-color;
color: @text-color-inverted;
&:hover {
color: @text-color-inverted;
}
&:after {
.transform(rotate(45deg));
position: absolute;
right: -.75em;
background-color: #fff;
box-shadow: 0 0 1em 0 rgba(0,0,0,0.6);
content: "";
display: block;
height: 1.25em;
margin-top: -1.75em;
width: 1.25em;
}
}
#menu .nav-level-2 > .nav-item {
// Collapse menu by default
display: none;
line-height: 1.833em; // 22px
> a {
color: @menu-2ndlvl-color;
font-size: @font-size-small;
padding: 0.364em 0.545em 0.364em (@icon-width + .75em)/@font-size-small;
}
&.active {
background-color: @menu-highlight-color;
overflow: hidden;
position: relative;
}
// Little caret on active level-2 item
&.active:after {
.transform(rotate(45deg));
background-color: @body-bg-color;
box-shadow: 0 0 1em 0 rgba(0,0,0,.6);
content: "";
display: block;
height: 1.25em;
width: 1.25em;
position: absolute;
top: .5em;
right: -.75em;
}
&.active > a {
color: @menu-color;
}
}
.no-js #menu .nav-level-2 > .nav-item {
// Expand menu if JavaScript is disabled
display: block;
}
#layout:not(.sidebar-collapsed) {
#menu .nav-level-1 > .nav-item {
&.active {
.nav-level-2 > li {
// Expand menu if active
display: block;
}
}
}
}
#menu img.icon {
line-height: 1;
margin: 0 0.5em -.05em 0.25em;
width: 1em;
}
#menu img[src*="/img/icons/"] {
&:not([src$="tux.png"]):not([src$="win.png"]):not([src$="_white.png"]) {
-webkit-filter: invert(100%);
-moz-filter: invert(100%);
-ms-filter: invert(100%);
filter: invert(100%);
}
}
.nav-item:hover img.icon {
opacity: .6;
}
#menu input.search {
background: transparent url('../img/icons/search_white.png') no-repeat 1em center;
background-size: 1em auto;
border: none;
color: @menu-color;
line-height: 2.167em;
padding: .25em;
padding-left: @icon-width + .75em;
width: 100%;
&.active {
background-color: @menu-active-bg-color;
}
&:hover,
&:focus {
background-color: darken(@menu-bg-color, 20);
}
}
// Badge offset correction
#menu > nav > .nav-level-1 > .badge-nav-item > a > .badge {
margin-top: 0.2em;
}
#menu .nav-level-2 > .badge-nav-item > a > .badge {
margin-top: 0.2em;
margin-right: .5em
}
// Hovered menu
#layout:not(.minimal-layout).sidebar-collapsed #menu .nav-level-1 > .nav-item.hover,
#layout:not(.minimal-layout) #menu .nav-level-1 > .nav-item:not(.active).hover {
> .nav-level-2 {
background-color: @menu-flyout-bg-color;
border: 1px solid @gray-light;
border-radius: .25em;
box-shadow: 0 0 1em 0 rgba(0,0,0,.3);
padding: @vertical-padding 0;
width: 14em;
position: fixed;
z-index: 1;
&:after {
.transform(rotate(45deg));
background-color: @body-bg-color;
border-bottom: 1px solid @gray-light;
border-left: 1px solid @gray-light;
content: "";
display: block;
height: 1.1em;
width: 1.1em;
position: absolute;
top: 1em;
left: -.6em;
z-index: -1;
}
> .nav-item {
display: block;
padding-left: 0;
position: relative;
> a {
color: @menu-flyout-color;
padding-left: 1.5em;
}
&:not(.active) {
&:hover, &:focus {
background-color: @tr-active-color;
}
}
&.active > a {
color: @menu-color;
}
// Hide activity caret when displayed as flyout
&:after {
display: none;
}
}
}
> a > .badge {
display: none;
}
img.icon {
opacity: .6;
}
}
#layout:not(.minimal-layout) #menu .nav-level-1 > .nav-item:not(.active).hover {
> .nav-level-2 {
// Position relative to parent
margin-left: 16em;
margin-top: -3.167em;
}
}
#layout:not(.minimal-layout).sidebar-collapsed #menu .nav-level-1 > .nav-item.hover {
> .nav-level-2 {
// Position relative to parent
margin-left: 4em;
margin-top: -3.333em;
> .badge-nav-item {
display: flex;
align-items: center;
a:not(.badge) {
flex: 1 1 auto;
width: 0;
}
a.badge {
color: white;
flex: 0 1 auto;
margin-right: 1em;
padding: .25em;
width: auto;
&:hover {
opacity: .6;
}
}
}
}
}
// Accessibility skip links
.skip-links {
position: relative;
font-size: 1/.75em;
ul {
list-style-type: none;
margin: 0;
padding: 0;
li {
display: block;
a, button[type="submit"] {
background-color: @body-bg-color;
border: none;
left: -999px;
padding: @vertical-padding @horizontal-padding;
position: absolute;
width: 100%;
z-index: 1;
&:focus {
left: 0;
outline-offset: -3px;
}
}
button[type="submit"] {
text-align: left;
}
}
}
}
#sidebar.expanded {
#mobile-menu-toggle .icon-menu {
display: none;
}
#mobile-menu-toggle .icon-cancel {
display: inline-block;
}
}
.search-control {
position: relative;
}
.search-input:focus ~ .search-reset:hover {
background-color: darken(@menu-active-bg-color, 20);
}
.search-reset {
background: none;
border: 0;
color: @menu-color;
cursor: pointer;
display: none;
height: 100%;
padding: 0;
user-select: none;
position: absolute;
right: 0;
top: 0;
&:focus,
&:hover {
background-color: darken(@menu-bg-color, 20);
outline: none;
}
}
// Override forms.less
input[type=text].search-input {
padding-right: 1.4em;
text-overflow: ellipsis;
transition: none;
}
.search-input:focus:-moz-placeholder { // FF 18-
color: @gray-light;
}
.search-input:focus::-moz-placeholder { // FF 19+
color: @gray-light;
}
.search-input:focus:-ms-input-placeholder {
color: @gray-light;
}
.search-input:focus::-webkit-input-placeholder {
color: @gray-light;
}
.search-input ~ .search-reset {
opacity: 0;
}
.search-input:valid ~ .search-reset {
display: block;
opacity: 1;
}
.search-input:invalid,
.search-input:-moz-submit-invalid,
.search-input:-moz-ui-invalid {
// Disable glow
box-shadow: none;
}
// Toggle sidebar button
#toggle-sidebar {
font-size: 1/.75em;
// Reset button styles
background: none;
border: none;
padding: 0;
color: @gray-light;
position: absolute;
bottom: 0.2em;
right: 0;
i {
background-color: @body-bg-color;
border-radius: .25em 0 0 .25em;
font-size: 1.125em;
width: 2em;
}
&:focus {
outline: none;
}
&:hover, &:focus {
i {
color: @menu-highlight-color;
}
}
}
#layout.minimal-layout #toggle-sidebar {
display: none;
}
#open-sidebar {
display: none;
}
#open-sidebar:before,
#close-sidebar:before {
width: 1.4em;
margin-right: 0;
}
#layout:not(.sidebar-collapsed) #menu .nav-level-1 > .nav-item.active .nav-level-2 > li {
&.nav-item:not(.badge-nav-item) {
&:not(.selected):not(.active):hover,
&:not(.selected):not(.active):focus {
background-color: darken(@menu-bg-color, 20);
> a {
color: @menu-2ndlvl-highlight-color;
}
}
}
}
#layout:not(.sidebar-collapsed) #menu .nav-level-1 > .nav-item.active .nav-level-2 > li,
#layout:not(.sidebar-collapsed) #menu .nav-level-1 > .nav-item:not(.active).hover .nav-level-2 > li {
&.badge-nav-item {
display: flex;
align-items: center;
}
&.badge-nav-item a:not(.badge) {
flex: 1 1 auto;
width: 0;
}
&.badge-nav-item a.badge {
color: white;
flex: 0 1 auto;
margin-right: 1em;
padding: .25em;
width: auto;
&:hover {
opacity: .6;
}
}
}
#layout:not(.sidebar-collapsed) #menu .nav-level-1 > .nav-item.active .nav-level-2 > li {
&.badge-nav-item:not(.selected) {
&:hover {
background-color: darken(@menu-bg-color, 20);
a {
color: white;
}
}
}
}