mirror of
https://github.com/retspen/webvirtcloud
synced 2025-01-12 08:25:18 +00:00
735 lines
14 KiB
SCSS
Executable file
735 lines
14 KiB
SCSS
Executable file
// Materia 4.5.0
|
|
// Bootswatch
|
|
|
|
|
|
// Variables ===================================================================
|
|
|
|
$web-font-path: "https://fonts.googleapis.com/css?family=Roboto:300,400,500,700&display=swap" !default;
|
|
@import url($web-font-path);
|
|
|
|
// Effects =====================================================================
|
|
|
|
@mixin ripple($color){
|
|
position: relative;
|
|
|
|
&:after {
|
|
content: "";
|
|
display: block;
|
|
position: absolute;
|
|
width: 100%;
|
|
height: 100%;
|
|
top: 0;
|
|
left: 0;
|
|
margin-left: 0;
|
|
@include gradient-radial($color 10%, transparent 10.01%);
|
|
background-size: 1000% 1000%;
|
|
background-position: 50%;
|
|
border: none;
|
|
opacity: 0;
|
|
pointer-events: none;
|
|
transition: background .5s, opacity 1s;
|
|
}
|
|
|
|
&:active:after {
|
|
background-size: 0 0;
|
|
opacity: .2;
|
|
transition: 0s;
|
|
}
|
|
|
|
&.disabled,
|
|
&[disabled] {
|
|
&:after {
|
|
display: none;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Navbar ======================================================================
|
|
|
|
.navbar {
|
|
border: none;
|
|
box-shadow: 0 1px 2px rgba(0,0,0,.3);
|
|
|
|
&-brand {
|
|
font-size: 24px;
|
|
}
|
|
|
|
&-nav .nav-link {
|
|
padding-top: 0.9rem;
|
|
padding-bottom: 0.9rem;
|
|
}
|
|
|
|
&.bg-dark,
|
|
&.bg-primary {
|
|
|
|
input[type=text],
|
|
input[type=password],
|
|
input[type=email],
|
|
input[type=number],
|
|
input[type=tel] {
|
|
color: #fff;
|
|
box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.5);
|
|
|
|
&:focus {
|
|
box-shadow: inset 0 -2px 0 #fff;
|
|
}
|
|
|
|
&::placeholder {
|
|
color: rgba(255, 255, 255, 0.5);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// Buttons =====================================================================
|
|
|
|
@mixin btn($class,$bg,$color){
|
|
.btn-#{$class} {
|
|
&:focus {
|
|
background-color: $bg;
|
|
box-shadow: 0 0 0 2px rgba(204, 204, 204, 0.5);
|
|
}
|
|
|
|
&:hover,
|
|
&:active:hover {
|
|
background-color: darken($bg, 6%);
|
|
}
|
|
|
|
&:active {
|
|
box-shadow: 2px 2px 4px rgba(0,0,0,.4);
|
|
}
|
|
|
|
@include ripple($color);
|
|
}
|
|
|
|
.btn-outline-#{$class} {
|
|
@include ripple($color);
|
|
}
|
|
}
|
|
|
|
@include btn(primary,$primary,$white);
|
|
@include btn(secondary,$secondary,$gray-500);
|
|
@include btn(success,$success,$white);
|
|
@include btn(info,$info,$white);
|
|
@include btn(warning,$warning,$white);
|
|
@include btn(danger,$danger,$white);
|
|
@include btn(dark,$dark,$white);
|
|
@include btn(light,$light,$white);
|
|
|
|
.btn {
|
|
text-transform: uppercase;
|
|
border: none;
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.4);
|
|
transition: all 0.4s;
|
|
|
|
&-link {
|
|
box-shadow: none;
|
|
color: $link-color;
|
|
|
|
&:hover,
|
|
&:focus {
|
|
box-shadow: none;
|
|
color: $link-hover-color;
|
|
text-decoration: $link-hover-decoration;
|
|
}
|
|
|
|
&.disabled, // Although btn-link is intended for buttons, which want to look like link, I include here a.disable for the sake of consistency
|
|
&[disabled],
|
|
fieldset[disabled] & {
|
|
&:hover,
|
|
&:active:hover {
|
|
color: $btn-link-disabled-color;
|
|
text-decoration: none;
|
|
}
|
|
}
|
|
}
|
|
|
|
&-secondary {
|
|
&.disabled,
|
|
&[disabled],
|
|
fieldset[disabled] & {
|
|
background-color: rgba(0, 0, 0, 0.1);
|
|
color: rgba(0, 0, 0, 0.4);
|
|
opacity: 1;
|
|
|
|
&:hover,
|
|
&:focus {
|
|
background-color: rgba(0, 0, 0, 0.1);
|
|
}
|
|
}
|
|
}
|
|
|
|
&-outline-secondary {
|
|
border-color: $gray-200;
|
|
color: $gray-300;
|
|
}
|
|
|
|
&-warning {
|
|
color: $white;
|
|
}
|
|
|
|
&.dropdown-toggle::before {
|
|
display: inline-block;
|
|
width: 0;
|
|
height: 0;
|
|
margin-left: 0.3em;
|
|
vertical-align: middle;
|
|
content: "";
|
|
border-top: 0.3em solid;
|
|
border-right: 0.3em solid transparent;
|
|
border-left: 0.3em solid transparent;
|
|
}
|
|
}
|
|
|
|
.btn-group {
|
|
.btn + .btn,
|
|
.btn + .btn-group,
|
|
.btn-group + .btn,
|
|
.btn-group + .btn-group {
|
|
margin-left: 0;
|
|
}
|
|
|
|
&-vertical {
|
|
> .btn + .btn,
|
|
> .btn + .btn-group,
|
|
> .btn-group + .btn,
|
|
> .btn-group + .btn-group {
|
|
margin-top: 0;
|
|
}
|
|
}
|
|
|
|
.btn + .btn,
|
|
.btn + .btn-group > .dropdown-toggle {
|
|
box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.4);
|
|
}
|
|
}
|
|
|
|
.border-secondary {
|
|
border: 1px solid #dfdfdf !important;
|
|
}
|
|
|
|
// Typography ==================================================================
|
|
|
|
body,
|
|
input,
|
|
button {
|
|
-webkit-font-smoothing: antialiased;
|
|
letter-spacing: .1px;
|
|
}
|
|
|
|
p {
|
|
margin: 0 0 1em;
|
|
}
|
|
|
|
.text-secondary {
|
|
color: $gray-500 !important;
|
|
}
|
|
|
|
// Tables ======================================================================
|
|
|
|
.table-hover {
|
|
> tbody > tr,
|
|
> tbody > tr > th,
|
|
> tbody > tr > td {
|
|
transition: all 0.2s;
|
|
}
|
|
}
|
|
|
|
.thead-inverse th {
|
|
background-color: $primary;
|
|
color: $white;
|
|
}
|
|
|
|
// Forms =======================================================================
|
|
|
|
.col-form-label {
|
|
font-size: 16px;
|
|
|
|
&-sm {
|
|
font-size: $font-size-sm;
|
|
}
|
|
|
|
&-lg {
|
|
font-size: $font-size-lg;
|
|
}
|
|
}
|
|
|
|
textarea,
|
|
textarea.form-control,
|
|
input.form-control,
|
|
input[type=text],
|
|
input[type=password],
|
|
input[type=email],
|
|
input[type=number],
|
|
[type=text].form-control,
|
|
[type=password].form-control,
|
|
[type=email].form-control,
|
|
[type=tel].form-control,
|
|
[contenteditable].form-control {
|
|
box-shadow: inset 0 -1px 0 #ddd;
|
|
transition: box-shadow 0.2s;
|
|
|
|
&:focus {
|
|
box-shadow: inset 0 -2px 0 $primary;
|
|
}
|
|
|
|
&[disabled],
|
|
&[readonly] {
|
|
box-shadow: none;
|
|
border-bottom: 1px dotted #ddd;
|
|
}
|
|
|
|
&[disabled],
|
|
&[disabled]::placeholder {
|
|
color: #ddd;
|
|
}
|
|
|
|
&::-ms-clear {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
select,
|
|
select.form-control {
|
|
appearance: none;
|
|
padding: 0.5rem 0;
|
|
background-image: url();
|
|
background-size: 13px;
|
|
background-repeat: no-repeat;
|
|
background-position: right center;
|
|
box-shadow: inset 0 -1px 0 #ddd;
|
|
|
|
&::-ms-expand {
|
|
display: none;
|
|
}
|
|
|
|
&.input {
|
|
&-sm {
|
|
font-size: $font-size-sm;
|
|
}
|
|
|
|
&-lg {
|
|
font-size: $font-size-lg;
|
|
}
|
|
}
|
|
|
|
&:focus {
|
|
box-shadow: inset 0 -2px 0 $primary;
|
|
background-image: url();
|
|
}
|
|
|
|
&[multiple] {
|
|
background: none;
|
|
}
|
|
}
|
|
|
|
.custom-control {
|
|
min-height: 1.5rem;
|
|
}
|
|
|
|
.custom-control-label {
|
|
&::before {
|
|
top: 0;
|
|
border: 2px solid $gray-400;
|
|
}
|
|
&::after {
|
|
top: 0;
|
|
}
|
|
|
|
.custom-control-input:checked ~ &::before {
|
|
border-color: $primary;
|
|
}
|
|
}
|
|
|
|
.custom-checkbox .custom-control-input:checked {
|
|
~ .custom-control-label::after {
|
|
transform: scale(1.5);
|
|
}
|
|
}
|
|
|
|
.custom-radio .custom-control-input {
|
|
&:checked {
|
|
~ .custom-control-label::before {
|
|
background: $white;
|
|
}
|
|
~ .custom-control-label::after {
|
|
transform: scale(1.125);
|
|
transition: 240ms;
|
|
}
|
|
}
|
|
& {
|
|
~ .custom-control-label::after {
|
|
transform: scale(.75);
|
|
}
|
|
}
|
|
}
|
|
|
|
.custom-switch {
|
|
|
|
.custom-control-label::before {
|
|
top: 0.125rem;
|
|
height: 0.875rem;
|
|
background: $gray-500;
|
|
border: none;
|
|
}
|
|
|
|
.custom-control-input:disabled ~ .custom-control-label {
|
|
opacity: 0.7;
|
|
}
|
|
|
|
.custom-control-input:disabled ~ .custom-control-label::before {
|
|
background: $gray-500;
|
|
}
|
|
|
|
.custom-control-label::after {
|
|
background-color: #fff;
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.3);
|
|
}
|
|
|
|
.custom-control-input:checked ~ .custom-control-label::before {
|
|
opacity: 0.38;
|
|
}
|
|
|
|
.custom-control-input:checked ~ .custom-control-label::after {
|
|
background-color: $primary;
|
|
}
|
|
|
|
.custom-control-input:hover:not(:disabled) ~ .custom-control-label::after {
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.3), 0 0 0 9px rgba(0,0,0,0.05);
|
|
}
|
|
|
|
.custom-control-input:focus:not(:disabled) ~ .custom-control-label::after {
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.3), 0 0 0 9px rgba(0,0,0,0.09);
|
|
}
|
|
|
|
.custom-control-input:active:not(:disabled) ~ .custom-control-label::after {
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.3), 0 0 0 9px rgba(0,0,0,0.16);
|
|
}
|
|
|
|
.custom-control-input:hover:checked:not(:disabled) ~ .custom-control-label::after {
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.3), 0 0 0 9px rgba(33,150,243,0.05);
|
|
}
|
|
|
|
.custom-control-input:focus:checked:not(:disabled) ~ .custom-control-label::after {
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.3), 0 0 0 9px rgba(33,150,243,0.09);
|
|
}
|
|
|
|
.custom-control-input:active:checked:not(:disabled) ~ .custom-control-label::after {
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.3), 0 0 0 9px rgba(33,150,243,0.16);
|
|
}
|
|
|
|
.custom-control-input:active:not(:checked) ~ .custom-control-label::before {
|
|
background-color: $gray-500;
|
|
}
|
|
|
|
.custom-control-input:active:not(:checked) ~ .custom-control-label::before {
|
|
background-color: $gray-500;
|
|
}
|
|
}
|
|
|
|
.has-warning {
|
|
input:not([type=checkbox]),
|
|
.form-control,
|
|
input.form-control[readonly],
|
|
input[type=text][readonly],
|
|
[type=text].form-control[readonly],
|
|
input:not([type=checkbox]):focus,
|
|
.form-control:focus {
|
|
border-bottom: none;
|
|
box-shadow: inset 0 -2px 0 $warning;
|
|
}
|
|
}
|
|
|
|
.has-danger {
|
|
input:not([type=checkbox]),
|
|
.form-control,
|
|
input.form-control[readonly],
|
|
input[type=text][readonly],
|
|
[type=text].form-control[readonly],
|
|
input:not([type=checkbox]):focus,
|
|
.form-control:focus {
|
|
border-bottom: none;
|
|
box-shadow: inset 0 -2px 0 $danger;
|
|
}
|
|
}
|
|
|
|
.has-success {
|
|
input:not([type=checkbox]),
|
|
.form-control,
|
|
input.form-control[readonly],
|
|
input[type=text][readonly],
|
|
[type=text].form-control[readonly],
|
|
input:not([type=checkbox]):focus,
|
|
.form-control:focus {
|
|
border-bottom: none;
|
|
box-shadow: inset 0 -2px 0 $success;
|
|
}
|
|
}
|
|
|
|
// Remove the Bootstrap feedback styles for input addons
|
|
.input-group-addon {
|
|
.has-warning &, .has-danger &, .has-success & {
|
|
color: $input-color;
|
|
border-color: $input-group-addon-border-color;
|
|
background-color: $input-group-addon-bg;
|
|
}
|
|
}
|
|
|
|
.input-group {
|
|
|
|
> .input-group-prepend > .input-group-text {
|
|
padding-right: 0.25rem;
|
|
}
|
|
|
|
> .input-group-append > .input-group-text {
|
|
padding-left: 0.25rem;
|
|
}
|
|
|
|
.form-control {
|
|
padding-left: 0.25rem;
|
|
padding-right: 0.25rem;
|
|
}
|
|
}
|
|
|
|
.input-group-sm {
|
|
|
|
> .input-group-prepend > .btn,
|
|
> .input-group-append > .btn {
|
|
padding: $input-btn-padding-y-sm $input-btn-padding-x-sm;
|
|
}
|
|
|
|
> .input-group-prepend > .input-group-text {
|
|
padding: $input-btn-padding-y-sm $input-btn-padding-x-sm $input-btn-padding-y-sm 0;
|
|
}
|
|
|
|
> .input-group-append > .input-group-text {
|
|
padding: $input-btn-padding-y-sm 0 $input-btn-padding-y-sm $input-btn-padding-x-sm;
|
|
}
|
|
|
|
> .input-group-prepend > .btn {
|
|
border-top-left-radius: $btn-border-radius-sm;
|
|
border-bottom-left-radius: $btn-border-radius-sm;
|
|
}
|
|
|
|
> .input-group-append > .btn {
|
|
border-top-right-radius: $btn-border-radius-sm;
|
|
border-bottom-right-radius: $btn-border-radius-sm;
|
|
}
|
|
}
|
|
|
|
.input-group-lg {
|
|
|
|
> .input-group-prepend > .btn,
|
|
> .input-group-append > .btn {
|
|
padding: $input-btn-padding-y-lg $input-btn-padding-x-lg;
|
|
}
|
|
|
|
> .input-group-prepend > .input-group-text {
|
|
padding: $input-btn-padding-y-lg $input-btn-padding-x-lg $input-btn-padding-y-lg 0;
|
|
}
|
|
|
|
> .input-group-append > .input-group-text {
|
|
padding: $input-btn-padding-y-lg 0 $input-btn-padding-y-lg $input-btn-padding-x-lg;
|
|
}
|
|
|
|
> .input-group-prepend > .btn {
|
|
border-top-left-radius: $btn-border-radius-lg;
|
|
border-bottom-left-radius: $btn-border-radius-lg;
|
|
}
|
|
|
|
> .input-group-append > .btn {
|
|
border-top-right-radius: $btn-border-radius-lg;
|
|
border-bottom-right-radius: $btn-border-radius-lg;
|
|
}
|
|
}
|
|
|
|
|
|
.form-group-lg {
|
|
select,
|
|
select.form-control {
|
|
line-height: 1.5;
|
|
}
|
|
}
|
|
|
|
// Navs ========================================================================
|
|
|
|
.nav-tabs {
|
|
.nav-item + .nav-item {
|
|
margin-left: 0;
|
|
}
|
|
|
|
.nav-link,
|
|
.nav-link:focus {
|
|
margin-right: 0;
|
|
background-color: transparent;
|
|
border: none;
|
|
color: $body-color;
|
|
box-shadow: inset 0 -1px 0 #ddd;
|
|
transition: all 0.2s;
|
|
|
|
&:hover {
|
|
background-color: transparent;
|
|
box-shadow: inset 0 -2px 0 $primary;
|
|
color: $primary;
|
|
}
|
|
}
|
|
|
|
.nav-link.active,
|
|
.nav-link.active:focus {
|
|
border: none;
|
|
box-shadow: inset 0 -2px 0 $primary;
|
|
color: $primary;
|
|
|
|
&:hover {
|
|
border: none;
|
|
color: $primary;
|
|
}
|
|
}
|
|
|
|
.nav-link.disabled {
|
|
box-shadow: inset 0 -1px 0 #ddd;
|
|
}
|
|
|
|
&.nav-justified {
|
|
|
|
.nav-link,
|
|
.nav-link:hover,
|
|
.nav-link:focus,
|
|
.nav-link.active,
|
|
.nav-link.active:hover,
|
|
.nav-link.active:focus {
|
|
border: none;
|
|
}
|
|
}
|
|
|
|
.dropdown-menu {
|
|
margin-top: 0;
|
|
}
|
|
}
|
|
|
|
.dropdown-menu {
|
|
margin-top: 0;
|
|
border: none;
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.3);
|
|
}
|
|
|
|
// Indicators ==================================================================
|
|
|
|
.alert {
|
|
padding-right: 2.5rem;
|
|
border: none;
|
|
|
|
&, h1, h2, h3, h4, h5, h6 {
|
|
color: #fff;
|
|
}
|
|
|
|
@each $color, $value in $theme-colors {
|
|
&-#{$color} {
|
|
@if $enable-gradients {
|
|
background: $value linear-gradient(180deg, mix($body-bg, $value, 15%), $value) repeat-x;
|
|
} @else {
|
|
background-color: $value;
|
|
}
|
|
}
|
|
}
|
|
|
|
a:not(.btn),
|
|
.alert-link {
|
|
color: #fff;
|
|
font-weight: bold;
|
|
}
|
|
|
|
.close {
|
|
color: #fff;
|
|
}
|
|
|
|
&-secondary,
|
|
&-light {
|
|
&,
|
|
& a:not(.btn),
|
|
& .alert-link {
|
|
color: $body-color;
|
|
}
|
|
}
|
|
}
|
|
|
|
.badge {
|
|
|
|
&-secondary {
|
|
background-color: $gray-500;
|
|
color: $white;
|
|
}
|
|
|
|
&-light {
|
|
background-color: $gray-200;
|
|
}
|
|
|
|
&-warning {
|
|
color: $white;
|
|
}
|
|
}
|
|
|
|
.tag {
|
|
padding: 4px 6px 4px;
|
|
}
|
|
|
|
// Progress bars ===============================================================
|
|
|
|
// Containers ==================================================================
|
|
|
|
.close {
|
|
line-height: 0.5;
|
|
opacity: 0.6;
|
|
transition: all 0.2s;
|
|
|
|
&:hover {
|
|
opacity: 1;
|
|
}
|
|
}
|
|
|
|
.card {
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.4);
|
|
|
|
&.border-primary,
|
|
&.border-secondary,
|
|
&.border-success,
|
|
&.border-info,
|
|
&.border-warning,
|
|
&.border-danger,
|
|
&.border-light,
|
|
&.border-dark {
|
|
border-width: 1px;
|
|
}
|
|
}
|
|
|
|
.alert-dismissible {
|
|
.close {
|
|
padding: 0.5rem 0.75rem;
|
|
}
|
|
}
|
|
|
|
.list-group {
|
|
&-item-action.active {
|
|
h1, h2, h3, h4, h5, h6 {
|
|
color: $white;
|
|
}
|
|
}
|
|
}
|
|
|
|
.modal-content {
|
|
border-radius: 0.2rem;
|
|
box-shadow: 0 6px 36px rgba(0,0,0,.3);
|
|
}
|
|
|
|
.popover {
|
|
border: none;
|
|
box-shadow: 0 1px 4px rgba(0,0,0,.3);
|
|
}
|
|
|
|
.carousel {
|
|
&-caption {
|
|
h1, h2, h3, h4, h5, h6 {
|
|
color: inherit;
|
|
}
|
|
}
|
|
}
|