@spectrum-css/progressbar
Version:
The Spectrum CSS progress bar component
163 lines (161 loc) • 8.28 kB
CSS
/*!
* Copyright 2024 Adobe. All rights reserved.
*
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. You may obtain a copy
* of the License at <http://www.apache.org/licenses/LICENSE-2.0>
*
* Unless required by applicable law or agreed to in writing, software distributed under
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
* OF ANY KIND, either express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
.spectrum-ProgressBar,
.spectrum-ProgressBar--sizeM {
--spectrum-progressbar-sized-size-default: var(--spectrum-progressbar-size-2400);
--spectrum-progressbar-sized-font-size: var(--spectrum-font-size-75);
--spectrum-progressbar-sized-thickness: var(--spectrum-progress-bar-thickness-large);
--spectrum-progressbar-sized-spacing-top-to-text: var(--spectrum-component-top-to-text-100);
}
.spectrum-ProgressBar--sizeS {
--spectrum-progressbar-sized-size-default: var(--spectrum-progressbar-size-2400);
--spectrum-progressbar-sized-font-size: var(--spectrum-font-size-75);
--spectrum-progressbar-sized-thickness: var(--spectrum-progress-bar-thickness-small);
--spectrum-progressbar-sized-spacing-top-to-text: var(--spectrum-component-top-to-text-75);
}
.spectrum-ProgressBar--sizeL {
--spectrum-progressbar-sized-size-default: var(--spectrum-progressbar-size-2500);
--spectrum-progressbar-sized-font-size: var(--spectrum-font-size-100);
--spectrum-progressbar-sized-thickness: var(--spectrum-progress-bar-thickness-large);
--spectrum-progressbar-sized-spacing-top-to-text: var(--spectrum-component-top-to-text-200);
}
.spectrum-ProgressBar--sizeXL {
--spectrum-progressbar-sized-size-default: var(--spectrum-progressbar-size-2800);
--spectrum-progressbar-sized-font-size: var(--spectrum-font-size-200);
--spectrum-progressbar-sized-thickness: var(--spectrum-progress-bar-thickness-extra-large);
--spectrum-progressbar-sized-spacing-top-to-text: var(--spectrum-component-top-to-text-300);
}
.spectrum-ProgressBar {
--spectrum-progressbar-size-default: var(--mod-progressbar-size-default, var(--spectrum-progressbar-sized-size-default));
--spectrum-progressbar-font-size: var(--mod-progressbar-font-size, var(--spectrum-progressbar-sized-font-size));
--spectrum-progressbar-thickness: var(--mod-progressbar-thickness, var(--spectrum-progressbar-sized-thickness));
--spectrum-progressbar-spacing-top-to-text: var(--mod-progressbar-spacing-top-to-text, var(--spectrum-progressbar-sized-spacing-top-to-text));
--spectrum-progressbar-animation-ease-in-out-indeterminate: var(--mod-progressbar-animation-ease-in-out-indeterminate, var(--spectrum-animation-ease-in-out));
--spectrum-progressbar-animation-duration-indeterminate: var(--mod-progressbar-animation-duration-indeterminate, var(--spectrum-animation-duration-2000));
--spectrum-progressbar-corner-radius: var(--spectrum-corner-radius-100);
--spectrum-progressbar-fill-size-indeterminate: var(--mod-progressbar-fill-size-indeterminate, 70%);
--spectrum-progressbar-dir-indeterminate-multiplier: 1;
--spectrum-progressbar-size-2400: 192px;
--spectrum-progressbar-size-2500: 200px;
--spectrum-progressbar-size-2800: 224px;
--spectrum-progressbar-line-height-cjk: var(--mod-progressbar-line-height-cjk, var(--spectrum-cjk-line-height-100));
--spectrum-progressbar-min-size: var(--mod-progressbar-min-size, var(--spectrum-progress-bar-minimum-width));
--spectrum-progressbar-max-size: var(--mod-progressbar-max-size, var(--spectrum-progress-bar-maximum-width));
--spectrum-progressbar-line-height: var(--mod-progressbar-line-height, var(--spectrum-line-height-100));
--spectrum-progressbar-spacing-label-to-progressbar: var(--mod-progressbar-spacing-label-to-progressbar, var(--spectrum-spacing-75));
--spectrum-progressbar-spacing-label-to-text: var(--mod-progressbar-spacing-label-to-text, var(--spectrum-spacing-200));
--spectrum-progressbar-fill-color: var(--highcontrast-progressbar-fill-color, var(--mod-progressbar-fill-color, var(--spectrum-accent-color-900)));
--spectrum-progressbar-track-color-default: var(--highcontrast-progressbar-track-color, var(--mod-progressbar-track-color, var(--spectrum-progressbar-track-color)));
--spectrum-progressbar-text-color: var(--mod-progressbar-text-color, var(--spectrum-neutral-content-color-default));
--spectrum-progressbar-label-and-value-white: var(--mod-progressbar-label-and-value-white, var(--spectrum-white));
--spectrum-progressbar-fill-color-white: var(--mod-progressbar-fill-color-white, var(--spectrum-white));
--spectrum-progressbar-static-white-track-color: var(--spectrum-progressbar-track-color-white);
--mod-fieldlabel-font-size: var(--spectrum-progressbar-font-size);
}
.spectrum-ProgressBar:dir(rtl),
[dir="rtl"] .spectrum-ProgressBar {
--spectrum-progressbar-dir-indeterminate-multiplier: -1;
}
.spectrum-ProgressBar:lang(ja),
.spectrum-ProgressBar:lang(ko),
.spectrum-ProgressBar:lang(zh) {
--mod-progressbar-line-height: var(--spectrum-progressbar-line-height-cjk);
}
@media (forced-colors: active) {
.spectrum-ProgressBar {
--highcontrast-progressbar-fill-color: ButtonText;
--highcontrast-progressbar-track-color: ButtonFace;
}
.spectrum-ProgressBar-track {
forced-color-adjust: none;
border: 1px solid ButtonText;
}
}
.spectrum-ProgressBar {
position: relative;
display: inline-flex;
flex-flow: row wrap;
justify-content: space-between;
align-items: center;
vertical-align: top;
inline-size: var(--spectrum-progressbar-size-default);
max-inline-size: var(--spectrum-progressbar-max-size);
min-inline-size: var(--spectrum-progressbar-min-size);
}
.spectrum-ProgressBar.spectrum-ProgressBar--sideLabel {
flex-flow: row;
justify-content: space-between;
}
.spectrum-ProgressBar.spectrum-ProgressBar--staticWhite {
--mod-progressbar-fill-color: var(--spectrum-progressbar-fill-color-white);
--mod-progressbar-text-color: var(--spectrum-progressbar-label-and-value-white);
--mod-progressbar-track-color: var(--spectrum-progressbar-static-white-track-color);
}
.spectrum-ProgressBar-label,
.spectrum-ProgressBar-percentage {
text-align: start;
margin-block-start: var(--spectrum-progressbar-spacing-top-to-text);
margin-block-end: var(--spectrum-progressbar-spacing-label-to-progressbar);
line-height: var(--spectrum-progressbar-line-height);
color: var(--spectrum-progressbar-text-color);
}
.spectrum-ProgressBar-label {
flex: 1 1 0%;
}
.spectrum-ProgressBar--sideLabel .spectrum-ProgressBar-label {
flex-grow: 0;
margin-inline-end: var(--spectrum-progressbar-spacing-label-to-text);
margin-block-end: 0;
}
.spectrum-ProgressBar-percentage {
align-self: flex-start;
margin-inline-start: var(--spectrum-progressbar-spacing-label-to-text);
}
.spectrum-ProgressBar--sideLabel .spectrum-ProgressBar-percentage {
order: 3;
text-align: end;
margin-block-end: 0;
}
.spectrum-ProgressBar-track {
overflow: hidden;
inline-size: 100%;
block-size: var(--spectrum-progressbar-thickness);
border-radius: var(--spectrum-progressbar-corner-radius);
background: var(--spectrum-progressbar-track-color-default);
}
.spectrum-ProgressBar--sideLabel .spectrum-ProgressBar-track {
flex: 1 1 var(--spectrum-progressbar-size-default);
}
.spectrum-ProgressBar-fill {
block-size: var(--spectrum-progressbar-thickness);
border: none;
background: var(--spectrum-progressbar-fill-color);
transition: width 1s;
}
.spectrum-ProgressBar--indeterminate .spectrum-ProgressBar-fill {
position: relative;
inline-size: var(--spectrum-progressbar-fill-size-indeterminate);
will-change: transform;
animation-name: indeterminate-loop;
animation-timing-function: var(--spectrum-progressbar-animation-ease-in-out-indeterminate);
animation-duration: var(--spectrum-progressbar-animation-duration-indeterminate);
animation-iteration-count: infinite;
}
@keyframes indeterminate-loop {
0% {
transform: translate(calc(var(--spectrum-progressbar-dir-indeterminate-multiplier) * -1 * var(--spectrum-progressbar-fill-size-indeterminate)));
}
to {
transform: translate(calc(var(--spectrum-progressbar-dir-indeterminate-multiplier) * var(--spectrum-progressbar-size-default)));
}
}