icingaweb2/public/css/themes/solarized-dark.less

442 lines
8.7 KiB
Plaintext

/*! Icinga Web 2 | (c) 2017 Icinga Development Team | GPLv2+ */
/* solarized colors: http://simianuprising.com/wp-content/uploads/2012/08/solarized-reference-horizontal.png */
// Solarized base colors
@base01: #586e75;
@base00: #657b83;
@base02: #073645;
@base03: #002b36;
@base0: #839496;
@base1: #93a1a1;
@base2: #eee8d5;
// Gray colors
@gray: @base1;
@gray-light: @base01;
@gray-lighter: #00222b;
@gray-lightest: @base02;
// Icinga colors
@icinga-blue: @base1;
@low-sat-blue: @base00;
@color-ok: #859900;
@color-critical: #dc322f;
@color-critical-handled: #a82523;
@color-warning: #cf9b00;
@color-warning-handled: #b58900;
@color-unknown: #6c71c4;
@color-unknown-handled: #444f83;
@color-unreachable: #2aa198;
@color-unreachable-handled: #1d736c;
@color-pending: #268bd2;
// Notification colors
// Background color for <body>
@body-bg-color: @base03;
// Text colors
@text-color: @base2;
@text-color-light: @base1;
@text-color-on-icinga-blue: @base2;
@text-color-inverted: @base02;
// Text color on <a>
@link-color: @base0;
@tr-active-color: @base01;
@tr-hover-color: @base02;
// Menu colors
@menu-bg-color: @base02;
@menu-active-bg-color: @base03;
@menu-highlight-color: @icinga-blue;
@menu-2ndlvl-color: #c4c4c4;
@menu-flyout-color: @text-color;
// Form colors
@button-primary-color: lighten(@base02, 20);
// Datetime picker colors
@fp-calendarBackground: #3f4458;
@fp-calendarBorderColor: darken(#3f4458, 50%);
@fp-monthForeground: #fff;
@fp-monthBackground: #3f4458;
@fp-weekdaysBackground: transparent;
@fp-weekdaysForeground: #fff;
@fp-dayForeground: fadeout(white, 5%);
@fp-dayHoverBackground: lighten(@fp-calendarBackground, 25%);
@fp-todayColor: #eee;
@fp-today_fg_color: #3f4458;
@fp-selectedDayBackground: #80CBC4;
.icinga-datetime-picker .flatpickr-day.today {
&:hover,
&:focus {
color: @fp-today_fg_color;
}
}
// Datetime picker colors (end)
#sidebar {
background-color: @base02;
box-shadow: inset -0.5em 0 1em rgba(0,0,0,0.3);
}
#header-logo-container {
background-color: transparent;
}
#menu {
background-color: transparent;
box-shadow: none;
}
.tabs {
background-color: @base02;
> li > a {
color: @base00;
}
}
.action-link {
color: @link-color;
}
.button-link {
background-color: @base02;
&:hover {
background-color: darken(@base03, 5);
}
}
input, select {
background-color: @body-bg-color;
}
#login {
background: @base02;
.control-label {
color: @base0;
}
input[type=submit] {
color: @base0;
background-color: @base02;
}
}
#login-footer {
color: @base01;
}
#about > img {
width: 0;
height: 0;
padding: 55.5px 160px;
background: url(../img/icinga-logo-big.png);
background-size: contain;
}
textarea {
background-color: @base01;
}
.control-button, input[type="submit"] {
color: @base0;
}
.badge.handled {
background-color: @body-bg-color !important;
color: @text-color;
&.state-warning {
border: 1px solid @color-warning-handled;
margin-top: -1px;
}
&.state-critical {
border: 1px solid @color-critical-handled;
margin-top: -1px;
}
&.state-down {
border: 1px solid @color-critical-handled;
margin-top: -1px;
}
&.state-unreachable {
border: 1px solid @color-unreachable-handled;
margin-top: -1px;
}
&.state-unknown {
border: 1px solid @color-unknown-handled;
margin-top: -1px;
}
}
#menu {
input.search {
color: @text-color;
background-image: url(../img/icons/search_white.png);
&:focus {
background-image: url(../img/icons/search_white.png) !important;
}
}
.nav-level-1 > .nav-item {
color: @text-color;
&.active, &:hover {
color: @text-color;
background-color: darken(@base03, 5);
}
&.active:not(.selected) {
background-color: darken(@base03, 3);
& > a:focus,
& > a:hover {
background-color: darken(@base03, 5);
}
}
}
.nav-level-2, .nav-level-2:after {
background-color: darken(@base03, 3) !important;
}
.nav-level-2 > .nav-item {
color: @text-color;
&.active, &:hover {
a {
color: @text-color !important;
}
background-color: @base00;
}
&.active.selected {
background-color: @base02;
}
&:not(.selected):not(.active) > a:hover,
&:not(.selected):not(.active) > a:focus {
color: @text-color;
}
}
ul:not(.nav-level-2) > .selected > a {
background-color: darken(@base03, 3);
color: @text-color;
&:after {
background-color: darken(@base03, 3);
box-shadow: 0 0 1em 0 rgba(0,0,0,0.6);
}
}
.nav-level-2 > .nav-item:not(.selected):not(.active) {
& > a:hover,
& > a:focus {
background-color: darken(@base03, 5);
}
}
.nav-itemxx{
&:hover,
&:hover > a,
&.active,
&.active > a {
color: @text-color !important;
//background-color: @base01 !important;
}
}
}
.boxview a:focus {
color: @text-color;
text-decoration: underline;
}
table.avp tbody th {
background-color: transparent;
}
.icinga-module.module-monitoring {
@timeline-notification-color: #1650CF;
@timeline-hard-state-color: #A24600;
@timeline-comment-color: #346964;
@timeline-ack-color: #855D18;
@timeline-downtime-start-color: #515151;
@timeline-downtime-end-color: #5e5e2f;
// Unfortunately it does not suffice to only override the timeline colors here, because our less compiler seems to
// have the related style block in module.less already evaluated
.timeline-notification {
background-color: @timeline-notification-color;
&.extrapolated {
background-color: lighten(@timeline-notification-color, 20%);
}
}
.timeline-hard-state {
background-color: @timeline-hard-state-color;
&.extrapolated {
background-color: lighten(@timeline-hard-state-color, 20%);
}
}
.timeline-comment {
background-color: @timeline-comment-color;
&.extrapolated {
background-color: lighten(@timeline-comment-color, 20%);
}
}
.timeline-ack {
background-color: @timeline-ack-color;
&.extrapolated {
background-color: lighten(@timeline-ack-color, 20%);
}
}
.timeline-downtime-start {
background-color: @timeline-downtime-start-color;
&.extrapolated {
background-color: lighten(@timeline-downtime-start-color, 20%);
}
}
.timeline-downtime-end {
background-color: @timeline-downtime-end-color;
&.extrapolated {
background-color: lighten(@timeline-downtime-end-color, 20%);
}
}
}
.icinga-module.module-monitoring {
.tactical {
.box {
border-color: @body-bg-color !important;
}
div.box.contents {
background: @body-bg-color;
}
}
}
.icinga-module.module-director {
form {
input[type=text], input[type=password], textarea, select, .director-suggestions li {
background-color: @body-bg-color;
border-bottom: 1px solid @gray-light;
}
.director-suggestions li:hover {
background-color: @icinga-blue;
}
ul.extensible-set input[type=text] {
background-color: @icinga-blue;
color: @base2;
}
p.description {
background-color: @base02;
}
option {
background-color: @body-bg-color;
}
}
dd.active ul.extensible-set input[type=text], ul.extensible-set.sortable input[type=text] {
background: @body-bg-color;
border: 1px solid @gray-light;
}
ul.main-actions li a {
color: @icinga-blue;
}
}
/* Form styles */
@input-background: lighten(@base02, 5);
.icinga-controls {
input[type="text"],
input[type="password"],
input[type="number"],
input[type="datetime-local"],
input[type="date"],
input[type="time"],
textarea,
select {
background-color: @input-background;
}
& .toggle-switch .toggle-slider {
background: @input-background;
border: 2px solid @input-background;
}
& .toggle-switch .toggle-slider:before {
background: @body-bg-color;
border: 1px solid @body-bg-color;
}
& input[type="checkbox"]:checked + .toggle-switch .toggle-slider {
background-color: @button-primary-color;
border: 1px solid @button-primary-color;
}
& input[type="checkbox"]:focus + .toggle-switch .toggle-slider {
box-shadow: 0 0 0 2px @body-bg-color, 0 0 0 4px fade(@button-primary-color, 40);
}
& input[type="checkbox"]:checked + .toggle-switch .toggle-slider:before {
border: 1px solid @button-primary-color;
}
}
.button {
background-color: @input-background;
border: 2px solid @input-background;
color: @text-color;
&:focus,
&:hover,
&.btn-primary {
background-color: lighten(@base02, 15);
border-color: lighten(@base02, 15);
color: @text-color;
}
&.btn-primary:focus,
&.btn-primary:hover {
background-color: @button-primary-color;
border-color: @button-primary-color;
color: @text-color;
}
}