tao-test/app/tao/views/scss/inc/_header-footer.scss

457 lines
12 KiB
SCSS
Raw Normal View History

2022-08-29 20:14:13 +02:00
@import "inc/bootstrap";
$navHeight: 64;
$footerHeight: 34;
@mixin menu-states($state: normal) {
@if($state == 'hover') {
@include vendor-prefix(transition, opacity .1s, top 0s);
@include vendor-prefix(transition-delay, .2s);
opacity: 1;
top: $navHeight * 1px;
}
@else {
top: -5000px;
opacity: .3;
}
}
#requirement-check {
margin: 40px auto;
width: 60%;
min-width: 500px;
max-width: 1000px
}
.version-warning {
margin: 0;
border-radius: 0;
border: none;
padding: 0 20px 0 45px !important;
line-height: 2;
border-bottom: 1px $uiGeneralContentBorder solid;
span {
top: 5px !important;
}
}
// html.no-version-warning added by JS
.no-version-warning {
.version-warning {
display:none;
}
}
#tao-main-logo {
margin: 6px 30px 6px 30px;
display: block;
max-width: 200px;
height: 52px;
}
//Navigation
.dark-bar {
// requires extra space for bottom border
max-height: ($navHeight + 1) * 1px;
background: $darkBar;
color: $darkBarTxt;
a {
color: $darkBarTxt;
&:hover {
color: white;
text-decoration: none;
}
}
.nav,
nav {
background:inherit;
position: relative;
z-index: 1000;
li {
float: left;
position: relative;
@include font-size(13);
& > a, & > .a {
text-align: center;
display: block;
height: $navHeight * 1px;
outline: 0 !important;
[class^="icon-"], [class*=" icon-"] {
text-shadow: 0 0 0 transparent !important;
line-height: 1;
color: inherit;
position: relative;
top: 2px;
}
.svg-glyph {
height: 23px;
width: 23px;
display:block;
margin: auto;
}
}
& > a {
&:hover {
@include vendor-prefix(transition, background-color 0.2s ease);
background-color: rgba($info, .5);
text-decoration: none;
span {
color: inherit;
}
}
}
& > .a {
cursor: default
}
&.active {
& > a {
background-color: whiten($info, .05);
opacity: 1;
color: white(.9);
&.hover {
color: white;
}
}
}
//override default disabled style
&.disabled {
background: none !important;
text-shadow: inherit !important;
opacity : 0.45 !important;
color: inherit !important;
a {
cursor: not-allowed !important;
}
}
&[data-control="logout"] .logout:focus {
outline-offset: -5px;
outline: 3px solid $uiGeneralContentBorder !important;
}
// sub menu
ul {
background: $darkBar;
position: absolute;
li {
display: block;
width: 100%;
a {
background: $darkBar;
padding: 6px 20px !important;
text-align: left;
display: block;
height: auto;
white-space: nowrap;
&:hover {
background: rgba($info, .5);
}
}
}
}
}
.plugin-box-menu{
position: relative;
}
.setting-menu-container {
position: relative;
top: 0;
right: 0;
background: inherit;
}
.main-menu, .settings-menu, .persistent-menu {
background:inherit;
ul {
background:inherit;
}
li {
@include font-size(13);
background:inherit;
ul {
min-width: 130px;
background:inherit;
position: absolute;
left: 0px;
border-top: 1px solid #666;
padding: 5px 0 !important;
@include menu-states(normal);
li {
background:inherit;
}
}
// display sub menu on hover
&:hover {
& > ul {
@include menu-states(hover);
}
}
}
}
.main-menu {
li {
min-width: 80px;
@include font-size(13);
& > a {
padding: 13px 15px 11px;
span {
@include font-size(20);
padding-bottom: 3px;
display: block;
}
}
}
}
.settings-menu {
//creates a stacking index to have the setting menu always on top of the others
z-index: 1;
position: relative;
// when resizing the window .settings-menu can slip under .main-menu
// until the JS class toggle kicks in
overflow-y: hidden;
// this makes sure that after the previous fix
// sub menus are still available
&:hover {
overflow-y: visible;
~ .persistent-menu .overflown-element{// replace task-listing by the more generic class e.g. overflown-element
filter: grayscale(0.7) contrast(60%) brightness(1.2);
}
}
.reduced-menu-trigger {
display:none;
}
padding-right: 20px;
}
.settings-menu, .persistent-menu{
li {
min-width: 25px;
@include font-size(13);
& > a, & > .a {
padding: 22px 8px 0px 8px;
span {
@include font-size(13);
display: inline-block;
}
[class^="icon-"], [class*=" icon-"] {
@include font-size(18);
padding: 0 2px;
}
}
&.li-help, &.li-user_settings, &.sep-before {
padding-left: 15px;
position: relative;
&:before {
content: ' ';
background: #666;
width: 1px;
position: absolute;
top: 25px;
left: 7px;
height: 20px;
}
}
ul {
left: auto;
right: -1px;
}
}
}
}
.title-box {
&:empty{
display:none;
}
}
}
.content-wrap > header, body > header {
position: relative;
border-bottom: 1px $uiGeneralContentBorder solid;
z-index: 1000;
}
// Footer
body > footer, .content-wrap:after {
// must be the same height as footer
height: $footerHeight * 1px;
}
body > footer {
z-index: 10000;
position: relative;
font-size: 11px;
padding: 10px;
border-top: 1px $uiGeneralContentBorder solid;
a {
text-decoration: underline
}
.icon-warning {
text-shadow: 0 0 0 transparent;
color: #fc6;
padding-right: 2px;
position: relative;
top: 1px;
}
}
.content-wrap {
min-height: 100%;
// equal to footer height
margin-bottom: -1px * $footerHeight;
}
.content-wrap:after {
content: "";
display: block;
}
// everything required for mobile navi
@mixin mobile-navi () {
.dark-bar {
.nav,
nav {
.main-menu {
li {
min-width: 0;
& > a {
padding: 13px 10px 11px;
}
}
}
.settings-menu {
position: absolute;
right: 0px;
top: 0px;
&:hover {
& > ul {
right: 20px;
left: auto;
@include menu-states(hover);
}
}
.reduced-menu-trigger {
text-align: center;
display: block;
height: $navHeight * 1px;
outline: 0 !important;
cursor:pointer;
min-width: 70px;
padding: 13px 10px 11px;
&.active {
background-color: whiten($info, .05);
opacity: 1;
color: white(.9) !important;
&.hover {
color: white !important;
}
}
&:hover {
background: rgba($info, .5);
text-decoration: none;
span {
color: white;
}
}
[class^="icon-"], [class*=" icon-"] {
text-shadow: 0 0 0 transparent !important;
line-height: 1;
color: $darkBarIcon;
position: relative;
top: 2px;
@include font-size(20);
padding-bottom: 3px;
display: block;
margin: auto;
}
}
& > ul {
border-top: 1px #666 solid;
position: absolute;
@include menu-states(normal);
left: -20000px;
right: auto;
white-space: nowrap;
background: $darkBar;
padding: 5px 0;
.username {
display:none;
}
& > li {
float:none;
display: list-item;
overflow:hidden;
padding: 0 !important;
&:before {
display:none !important;
}
a {
height: auto;
line-height: 2.2;
padding: 0 20px;
text-align: left;
&:after {
content: attr(title)
}
span {
padding: 0px 3px 0 0 !important;
display:inline-block;
width: 20px;
top: 0px;
@include font-size(13, true);
}
}
ul {
display:none;
}
}
}
}
.persistent-menu {
right: 90px;
position: absolute;
}
}
}
}
@media (max-width: 1024px) {
body {
&:not(.delivery-scope):not(.small-navi) {
@include mobile-navi();
}
}
}
// works in conjunction with layout/nav.js
body {
&.oversized-nav {
&:not(.delivery-scope):not(.small-navi) {
@include mobile-navi();
}
}
}