signal-desktop/stylesheets/components/LeftPaneDialog.scss
2024-11-15 15:09:31 -08:00

303 lines
6.2 KiB
SCSS

// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
@use '../mixins';
@use '../variables';
@keyframes progress-animation {
0% {
background-position: 100%;
}
100% {
background-position: -100%;
}
}
.LeftPaneDialog {
$default-background-color: variables.$color-ultramarine;
$default-text-color: variables.$color-white;
$error-background-color: variables.$color-accent-red;
$error-text-color: $default-text-color;
$warning-background-color: variables.$color-accent-yellow;
$warning-text-color: variables.$color-black;
align-items: center;
background: $default-background-color;
color: $default-text-color;
cursor: inherit;
display: flex;
min-height: 64px;
padding-block: 12px;
padding-inline: 16px 14px;
user-select: none;
width: 100%;
font-size: 13px;
line-height: 18px;
letter-spacing: -0.0025em;
font-weight: 400;
&--width-narrow {
padding-inline-start: 36px;
}
&__retry {
@include mixins.button-reset;
& {
@include mixins.font-body-1-bold;
}
}
&--clickable {
cursor: pointer;
}
&__container {
display: flex;
align-items: center;
flex-grow: 1;
}
&__container-close {
display: flex;
justify-content: flex-end;
}
&__spinner-container {
margin-inline-end: 18px;
}
&__spinner {
&__arc {
background-color: variables.$color-black;
// Needed for specificity
@include mixins.dark-theme {
background-color: variables.$color-black;
}
}
&__circle {
background-color: variables.$color-accent-yellow;
}
}
&__icon {
width: 24px;
height: 24px;
margin-inline-end: 18px;
background-color: variables.$color-white;
-webkit-mask-size: contain;
@media (forced-colors: active) {
background-color: WindowText;
}
&--relink {
-webkit-mask: url('../images/icons/v3/link/link-slash.svg') no-repeat
center;
}
&--network {
-webkit-mask: url('../images/icons/v3/wifi/wifi-error.svg') no-repeat
center;
}
&--update {
-webkit-mask: url('../images/icons/v3/refresh/refresh.svg') no-repeat
center;
}
&--warning {
-webkit-mask: url('../images/icons/v3/error/error-triangle.svg') no-repeat
center;
}
&--error {
-webkit-mask: url('../images/icons/v3/error/error-circle.svg') no-repeat
center;
}
}
&__action-text {
@include mixins.button-reset;
& {
text-decoration: none;
color: variables.$color-white-alpha-80;
}
}
&__close-button {
@include mixins.button-reset;
& {
border-radius: 4px;
float: inline-end;
height: 20px;
width: 20px;
}
&::before {
-webkit-mask: url('../images/icons/v3/x/x.svg') no-repeat center;
background-color: variables.$color-white;
content: '';
display: block;
width: 100%;
height: 100%;
@media (forced-colors: active) {
background-color: WindowText;
@include mixins.dark-theme {
background-color: WindowText;
}
}
}
&:hover,
&:focus {
background-color: variables.$color-white-alpha-20;
}
&:active {
background-color: variables.$color-white-alpha-20;
}
@media (forced-colors: active) {
&:hover,
&:focus,
&:active {
background-color: none;
}
@include mixins.dark-theme {
&:hover,
&:focus,
&:active {
background-color: none;
}
}
}
}
&__message {
width: 100%;
}
&__message,
&__tooltip {
max-width: 250px;
h3 {
@include mixins.font-body-1-bold;
padding: 0px;
margin: 0px;
}
span {
@include mixins.font-body-1;
display: inline-block;
}
a {
font-weight: bold;
text-decoration: none;
}
}
&__tooltip {
--tooltip-background-color: #{$default-background-color};
--tooltip-text-color: #{$default-text-color};
min-width: 280px;
text-align: inherit;
}
&,
&__tooltip {
&--error {
background-color: $error-background-color;
color: $error-text-color;
@include mixins.any-theme {
--tooltip-background-color: #{$error-background-color};
--tooltip-text-color: #{$error-text-color};
}
a {
color: $error-text-color;
}
.LeftPaneDialog__action-text {
color: $error-text-color;
}
}
&--warning {
background-color: $warning-background-color;
color: $warning-text-color;
@include mixins.any-theme {
--tooltip-background-color: #{$warning-background-color};
--tooltip-text-color: #{$warning-text-color};
}
a {
color: $warning-text-color;
}
.LeftPaneDialog__icon {
background-color: $warning-text-color;
@media (forced-colors: active) {
background-color: WindowText;
}
}
.LeftPaneDialog__close-button::before {
background-color: $warning-text-color;
@media (forced-colors: active) {
background-color: WindowText;
}
}
.LeftPaneDialog__action-text {
color: $warning-text-color;
}
}
}
&__progress {
&--container {
background: variables.$color-white-alpha-20;
border-radius: 2px;
height: 4px;
max-width: 210px;
overflow: hidden;
width: 100%;
margin-block: 10px 6px;
margin-inline: 0;
}
&--bar {
animation: progress-animation 2s linear infinite;
background: linear-gradient(
90deg,
variables.$color-white-alpha-40,
variables.$color-white-alpha-60,
variables.$color-white-alpha-90,
variables.$color-white-alpha-60,
variables.$color-white-alpha-40
);
background-size: 200% 100%;
border-radius: 2px;
display: block;
height: 100%;
width: 100%;
&:dir(ltr) {
/* stylelint-disable-next-line declaration-property-value-disallowed-list */
transform: translateX(-100%);
}
&:dir(rtl) {
/* stylelint-disable-next-line declaration-property-value-disallowed-list */
transform: translateX(100%);
}
transition: transform 500ms ease-out;
}
}
}