@import "node_modules/bootstrap/scss/functions"; @import "node_modules/bootstrap/scss/variables"; /* * Sidebar */ .sidebar { position: fixed; top: 0; bottom: 0; left: 0; z-index: 995; /* Behind the navbar */ padding: 50px 0 0; /* Height of navbar */ box-shadow: inset -1px 0 0 rgba(0, 0, 0, .1); .sidebar-heading .spinner-border { width: 0.8em; height: 0.8em; } // These come from the col-md-3 col-lg-2 classes for regular sidebar, needed for animation @media (min-width: 768px) { max-width: 25%; } @media (min-width: 992px) { max-width: 16.66666667%; } transition: all .2s ease; } @media (max-width: 767.98px) { .sidebar { top: 3.5rem; } } main { transition: all .2s ease; } .sidebar-slim-toggler { display: none; // hide on mobile } .sidebar li.nav-item span, .sidebar .sidebar-heading span { transition: all .1s ease; } @media(min-width: 768px) { .sidebar.slim { max-width: 50px; li.nav-item span.badge { display: inline-block; margin-right: 2px; } } .sidebar.slim:not(.animating) { li.nav-item span, .sidebar-heading span { display: none; } } .sidebar.animating { li.nav-item span, .sidebar-heading span { display: unset; position: absolute; opacity: 0; overflow: hidden; } } .sidebar:not(.slim):not(.animating) { li.nav-item span, .sidebar-heading span { position: unset; opacity: 1; overflow: auto; } } .sidebar.slim, .sidebar.animating { .text-truncate { text-overflow: unset !important; word-wrap: break-word !important; } } .sidebar.slim { li.nav-item span.badge { display: inline-block; margin-right: 2px; } } .col-slim { padding-left: calc(50px + $grid-gutter-width) !important; } .sidebar-slim-toggler { display: block; position: absolute; right: -12px; top: 60px; z-index: 996; --bs-btn-padding-x: 0.35rem; --bs-btn-padding-y: 0.125rem; } } ::ng-deep .popover-slim .popover-body { --bs-popover-body-padding-x: .5rem; --bs-popover-body-padding-y: .5rem; } .sidebar-sticky { position: relative; top: 0; height: 100%; padding-top: 0.5rem; overflow-x: hidden; overflow-y: auto; /* Scrollable contents if viewport is shorter than content. */ min-height: min-content; } @supports ((position: -webkit-sticky) or (position: sticky)) { .sidebar-sticky { position: -webkit-sticky; position: sticky; } } .sidebar .nav-link { font-weight: 500; white-space: nowrap; &:hover, &.active, &:focus { color: var(--bs-primary); } &:focus-visible { outline: none; background-color: var(--bs-body-bg); } &.active { font-weight: bold; } .sidebaricon { margin-right: 4px; color: inherit; } } .sidebar-heading { font-size: 0.75rem; text-transform: uppercase; } .nav { flex-wrap: nowrap; } .nav-item { position: relative; &:hover .close { display: block; } .close { display: none; position: absolute !important; cursor: pointer; opacity: 1; top: 0; padding: .25rem .3rem 0; right: .4rem; width: 1.8rem; height: 100%; svg { opacity: 0.5; } &:hover svg { opacity: 1; } } .nav-link-additional { margin-top: 0.1rem; margin-left: 0.25rem; padding-top: 0.5rem; text-decoration: none; &:hover { text-decoration: underline; } svg { margin-bottom: 2px; } } } /* * Navbar */ .navbar-brand { padding-top: 0.75rem; padding-bottom: 0.75rem; font-size: 1rem; } @media screen and (min-width: 768px) { .navbar-brand.slim { max-width: 50px; } } .dropdown.show .dropdown-toggle, .dropdown-toggle:hover { opacity: 0.7; } .dropdown-toggle::after { margin-left: 0.4em; vertical-align: 0.155em; } .navbar .dropdown-menu { font-size: 0.875rem; // body size a svg { opacity: 0.6; } } .navbar .search-form-container { max-width: 550px; form { position: relative; > svg { position: absolute; left: 0.6rem; top: 0.5rem; color: rgba(255, 255, 255, 0.6); } } &:focus-within { form > svg { display: none; } .form-control::placeholder { color: rgba(255, 255, 255, 0); } } .form-control { color: rgba(255, 255, 255, 0.3); background-color: rgba(0, 0, 0, 0.15); padding-left: 1.8rem; border-color: rgba(255, 255, 255, 0.2); transition: all .3s ease, padding-left 0s ease, background-color 0s ease; // Safari requires all max-width: 600px; min-width: 300px; // 1/2 max &::placeholder { color: rgba(255, 255, 255, 0.4); } &:focus { background-color: rgba(0, 0, 0, 0.3); color: var(--bs-light); flex-grow: 1; padding-left: 0.5rem; } } } .version-check { animation: pulse 2s ease-in-out 0s 1; } @keyframes pulse { 0% { opacity: 0; } 25% { opacity: 100%; } 75% { opacity: 0; } 100% { opacity: 100%; } }