lbry-desktop/ui/scss/component/_navigation.scss

344 lines
6.4 KiB
SCSS
Raw Normal View History

2020-08-11 22:32:03 +02:00
.navigation__wrapper {
2019-06-11 20:10:58 +02:00
width: var(--side-nav-width);
2020-08-11 22:32:03 +02:00
height: calc(100vh - var(--header-height));
2021-12-21 14:47:24 +01:00
@media (max-width: $breakpoint-small) {
height: calc(100vh - var(--header-height-mobile));
}
2020-08-11 22:32:03 +02:00
}
.navigation__wrapper--micro {
width: var(--side-nav-width--micro);
2019-12-18 06:27:08 +01:00
@media (max-width: $breakpoint-small) {
2020-08-11 22:32:03 +02:00
width: 0;
}
}
2020-08-11 22:32:03 +02:00
.navigation__wrapper--absolute {
&:not(.navigation__wrapper--micro) {
width: 0;
}
}
.navigation {
2020-08-10 22:47:39 +02:00
position: fixed;
left: 0;
overflow-y: auto;
2021-12-11 15:59:32 +01:00
overflow-x: hidden;
2020-08-11 22:32:03 +02:00
top: var(--header-height);
width: var(--side-nav-width);
2020-08-10 22:47:39 +02:00
height: calc(100vh - var(--header-height));
2020-08-11 22:32:03 +02:00
border-right: 1px solid var(--color-border);
padding-top: var(--spacing-m);
2021-04-26 21:19:17 +02:00
padding-bottom: var(--spacing-l);
display: flex;
flex-direction: column;
2021-12-11 17:09:23 +01:00
box-shadow: var(--card-box-shadow);
2021-12-11 15:59:32 +01:00
animation-timing-function: var(--resizing-animation-function);
transition: transform var(--resizing-animation-timing);
z-index: 4;
background-color: var(--color-card-background);
transform: translateX(0);
transform-origin: left;
@media (min-width: $breakpoint-small) {
overflow-y: hidden;
2021-04-26 21:19:17 +02:00
justify-content: space-between;
&:hover {
overflow-y: auto;
}
}
2021-12-21 14:47:24 +01:00
@media (max-width: $breakpoint-small) {
top: var(--header-height-mobile);
height: calc(100vh - var(--header-height-mobile));
}
ul {
padding-bottom: var(--spacing-s);
border-bottom: 1px solid var(--color-border);
}
2020-08-11 22:32:03 +02:00
}
2021-12-11 15:59:32 +01:00
.navigation--push-back {
2021-12-14 20:21:14 +01:00
transform: translateX(calc(var(--side-nav-width--micro) - var(--side-nav-width)));
2021-12-11 15:59:32 +01:00
}
.navigation--push {
transform: translateX(0);
}
.navigation--mac {
top: calc(var(--header-height) + var(--mac-titlebar-height));
}
2021-12-11 15:59:32 +01:00
.navigation-file-page-and-mobile {
transform: translateX(calc(-1 * var(--side-nav-width)));
2019-07-21 23:31:22 +02:00
}
2020-08-10 22:47:39 +02:00
.navigation--micro {
2020-08-11 22:32:03 +02:00
@extend .navigation;
2021-12-14 20:21:14 +01:00
transform: translateX(calc(var(--side-nav-width--micro) - var(--side-nav-width)));
2020-08-11 22:32:03 +02:00
@media (max-width: $breakpoint-small) {
display: none;
}
2019-09-27 20:56:15 +02:00
}
2020-08-10 22:47:39 +02:00
.navigation__secondary {
margin-top: var(--spacing-m);
.button__content {
align-items: flex-start;
}
2019-03-28 17:53:13 +01:00
}
.navigation__tertiary {
margin-top: var(--spacing-m);
}
2019-07-21 23:31:22 +02:00
.navigation-link {
display: block;
position: relative;
2019-06-11 20:10:58 +02:00
overflow: hidden;
white-space: nowrap;
2019-06-11 20:10:58 +02:00
text-overflow: ellipsis;
width: 100%;
2019-11-22 22:13:00 +01:00
color: var(--color-navigation-link);
2020-08-10 22:47:39 +02:00
padding-left: var(--spacing-s);
2020-08-11 22:32:03 +02:00
font-size: var(--font-body);
font-weight: var(--font-weight-bold);
2019-06-19 07:05:43 +02:00
2019-07-22 04:05:37 +02:00
.icon {
2020-08-10 22:47:39 +02:00
height: 1.5rem;
width: 1.5rem;
2020-08-11 22:32:03 +02:00
stroke: var(--color-navigation-icon);
}
2020-08-10 22:47:39 +02:00
.button__content {
2021-12-11 15:59:32 +01:00
margin-left: auto;
2020-08-10 22:47:39 +02:00
padding: var(--spacing-s);
justify-content: flex-start;
flex-direction: column;
}
2021-06-09 21:20:19 +02:00
&.navigation-link--with-thumbnail .button__content {
flex-direction: row;
.channel-thumbnail {
@include handleChannelGif(1.5rem);
flex-shrink: 0;
margin-right: var(--spacing-s);
}
.channel-staked__wrapper {
margin-bottom: 0.2rem;
left: -0.55rem;
.channel-staked__indicator {
height: 0.75rem;
width: 0.75rem;
margin-left: 0;
}
}
2021-06-09 21:20:19 +02:00
}
2020-08-11 22:32:03 +02:00
&:hover:not(.navigation-link--active),
&:focus {
@extend .navigation-link--highlighted;
2020-08-10 22:47:39 +02:00
}
@media (min-width: $breakpoint-medium) {
text-align: left;
margin-bottom: 0;
.icon {
2021-06-09 21:20:19 +02:00
height: 1.5rem;
width: 1.5rem;
2020-08-10 22:47:39 +02:00
}
.button__content {
flex-direction: row;
}
.button__label {
margin-top: 0;
}
&:focus {
box-shadow: none;
}
}
2020-08-10 22:47:39 +02:00
}
2020-08-10 22:47:39 +02:00
.navigation-link--active {
2020-08-11 22:32:03 +02:00
background-color: var(--color-navigation-active);
color: var(--color-navigation-active-text);
2020-08-10 22:47:39 +02:00
.icon {
2020-08-11 22:32:03 +02:00
stroke: var(--color-navigation-active-text);
}
}
2020-05-21 17:38:28 +02:00
.navigation-link--pulse {
overflow: visible;
.icon {
animation: shadow-pulse 2.5s infinite;
}
}
2020-08-11 22:32:03 +02:00
.navigation-link--highlighted {
background-color: var(--color-navigation-hover);
color: var(--color-navigation-hover-text);
.icon {
stroke: var(--color-navigation-hover-text);
}
2020-08-10 22:47:39 +02:00
}
.navigation-links {
@extend .ul--no-style;
flex-direction: column;
align-items: flex-start;
list-style: none;
}
2021-12-11 15:59:32 +01:00
.navigation-inner-container {
width: var(--side-nav-width);
}
2020-08-10 22:47:39 +02:00
.navigation-links--micro {
.icon {
height: 1.5rem;
width: 1.5rem;
2020-05-21 17:38:28 +02:00
}
2020-08-10 22:47:39 +02:00
.button__content {
padding: var(--spacing-s);
justify-content: flex-start;
flex-direction: column;
width: var(--side-nav-width--micro);
2020-08-10 22:47:39 +02:00
}
.button__label {
font-size: var(--font-xsmall);
margin-left: 0;
margin-top: var(--spacing-xs);
}
.navigation-link {
padding-left: 0;
2020-05-21 17:38:28 +02:00
}
2020-08-10 22:47:39 +02:00
@media (max-width: $breakpoint-small) {
display: none;
}
}
.navigation-links--absolute {
@extend .navigation-links;
.navigation-link {
margin-bottom: 0;
.icon {
2021-06-09 21:20:19 +02:00
height: 1.5rem;
width: 1.5rem;
2020-08-10 22:47:39 +02:00
}
.button__content {
flex-direction: row;
}
.button__label {
margin-top: 0;
font-size: var(--font-body);
font-weight: var(--font-weight-bold);
}
&:focus {
box-shadow: none;
}
}
}
.navigation-links--small {
@extend .navigation-links;
margin-right: 0;
padding-right: 0;
2021-04-26 21:19:17 +02:00
margin-top: var(--spacing-xl);
margin-bottom: 0;
.navigation-link {
font-size: var(--font-small);
}
.button__label {
color: var(--color-text-help);
}
2020-08-10 22:47:39 +02:00
.button__content {
align-items: flex-start;
}
}
2022-01-28 00:26:18 +01:00
.navigation-item {
.empty {
padding: var(--spacing-s);
}
}
2020-08-10 22:47:39 +02:00
.navigation__overlay {
position: fixed;
width: 100vw;
height: 100vh;
2020-10-01 22:59:11 +02:00
background-color: var(--color-background-overlay);
2020-08-10 22:47:39 +02:00
z-index: 3;
left: 0;
top: var(--header-height);
2021-12-11 15:59:32 +01:00
visibility: hidden;
opacity: 0;
animation-timing-function: var(--resizing-animation-function);
transition: visibility var(--resizing-animation-timing), opacity var(--resizing-animation-timing);
&.navigation__overlay--mac {
top: calc(var(--header-height) + var(--mac-titlebar-height));
}
2021-12-21 14:47:24 +01:00
@media (max-width: $breakpoint-small) {
top: var(--header-height-mobile);
}
2020-05-21 17:38:28 +02:00
}
2020-11-10 06:21:04 +01:00
2021-12-11 15:59:32 +01:00
.navigation__overlay--active {
opacity: 1;
visibility: visible;
animation: fadeIn var(--resizing-animation-timing) var(--resizing-animation-function);
}
2020-11-10 06:21:04 +01:00
.navigation__auth-nudge {
@extend .card;
margin: var(--spacing-s);
margin-top: var(--spacing-l);
padding: var(--spacing-xs);
display: flex;
flex-direction: column;
.button {
margin-top: var(--spacing-s);
}
.button__content {
justify-content: center;
}
.icon {
margin-bottom: -2px;
}
}