[libadwaita/wip/exalm/scales: 2/2] stylesheet: Update scales and progress bars
- From: Alexander Mikhaylenko <alexm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libadwaita/wip/exalm/scales: 2/2] stylesheet: Update scales and progress bars
- Date: Thu, 20 May 2021 14:07:07 +0000 (UTC)
commit 3e85b1b88c490732cd9eec2e953d39b2b713c747
Author: Alexander Mikhaylenko <alexm gnome org>
Date: Thu May 20 14:08:55 2021 +0500
stylesheet: Update scales and progress bars
Use a similar style to the new checks, radios, switches and level bars.
Use an always light slider with a drop shadow, change that shadow for hover
and active. Since the shadow is not visible in dark variant, also change
the slider color in a way that will only affect dark.
Since progress bars use the same styles, update them too.
src/stylesheet/widgets/_progress-bar.scss | 17 ++--
src/stylesheet/widgets/_scale.scss | 135 ++++++++++++++----------------
2 files changed, 68 insertions(+), 84 deletions(-)
---
diff --git a/src/stylesheet/widgets/_progress-bar.scss b/src/stylesheet/widgets/_progress-bar.scss
index e82e0356..8cfb203e 100644
--- a/src/stylesheet/widgets/_progress-bar.scss
+++ b/src/stylesheet/widgets/_progress-bar.scss
@@ -3,37 +3,34 @@ progressbar {
&.horizontal {
> trough {
min-width: 150px;
- &, > progress { min-height: 2px; }
+ &, > progress { min-height: 4px; }
}
}
&.vertical {
> trough {
min-height: 80px;
- &, > progress { min-width: 2px; }
+ &, > progress { min-width: 4px; }
}
}
- &.horizontal > trough > progress { margin: 0 -1px; } // the progress node is positioned after the trough
border
- &.vertical > trough > progress { margin: -1px 0; } // this moves it over it.
-
// FIXME: insensitive state missing and some other state should be set probably
font-size: smaller;
color: transparentize($fg_color, 0.6);
font-feature-settings: "tnum";
+ &:disabled {
+ filter: opacity(.5);
+ }
+
> trough {
@extend %scale_trough;
> progress {
@extend %scale_highlight; /* share most of scales' */
- /* override insensitive that is specific to progress */
- &:disabled {
- background-color: $insensitive_fg_color;
- border-color: $insensitive_fg_color;
- }
border-radius: 1.5px;
+
$_progress-radius: 5px;
&.left {
border-top-left-radius: $_progress-radius;
diff --git a/src/stylesheet/widgets/_scale.scss b/src/stylesheet/widgets/_scale.scss
index 6e916027..dc410185 100644
--- a/src/stylesheet/widgets/_scale.scss
+++ b/src/stylesheet/widgets/_scale.scss
@@ -1,40 +1,20 @@
%scale_trough {
- border: 1px solid $dark_fill;
border-radius: 3px;
- background-color: $dark_fill;
+ background-color: transparentize($text_color, .85);
- headerbar & { background-color: darken($dark_fill,8%); } //3504
-
- &:disabled {
- background-color: $insensitive_bg_color;
- border-color: $insensitive_borders_color;
+ @if $contrast == "high" {
+ box-shadow: inset 0 0 0 1px $borders_color;
}
// OSD
.osd & {
- border-color: $osd_borders_color;
- background-color: transparentize($osd_borders_color, 0.2);
-
- &:disabled { background-color: $osd_insensitive_bg_color; }
+ background-color: transparentize($osd_text_color, .85);
}
}
%scale_highlight {
- border: 1px solid $selected_bg_color;
border-radius: 3px;
background-color: $selected_bg_color;
-
- &:disabled {
- background-color: transparent;
- border-color: transparent;
- }
-
- // OSD
- .osd & {
- border-color: $osd_borders_color;
-
- &:disabled { border-color: transparent; }
- }
}
scale {
@@ -52,10 +32,6 @@ scale {
transition: $focus_transition;
@extend %scale_trough;
- // those are inside the trough node, I need them to show their own border over the trough one, so
negative margin
- > fill,
- > highlight { margin: -1px; }
-
// the colored part of the backing bit
> highlight { @extend %scale_highlight; }
@@ -64,82 +40,82 @@ scale {
> fill {
@extend %scale_trough;
- &:disabled {
- border-color: transparent;
- background-color: transparent;
- }
-
// OSD
.osd & {
background-color: mix($osd_fg_color, $osd_borders_color, 25%);
-
- &:disabled {
- border-color: transparent;
- background-color: transparent;
- }
}
}
> slider {
- @include button(normal);
- border-width: 1px;
- border-style: solid;
+ background-color: mix(white, $base_color, 80%);
+ box-shadow: 0 2px 4px transparentize(black, .8);
+ outline: 1px solid transparentize(black, .9);
+
border-radius: 100%;
transition: $button_transition;
transition-property: background, border, box-shadow;
// the slider is inside the trough, so to have make it bigger there's a negative margin
- min-height: 18px;
- min-width: 18px;
- margin: -9px;
+ min-width: 20px;
+ min-height: 20px;
+ margin: -8px;
+ }
+ }
- &:hover { @include button(hover); }
+ &:hover {
+ > trough {
+ background-color: transparentize($text_color, .75);
- &:active { border-color: $selected_borders_color; }
+ > highlight {
+ background-color: mix($selected_bg_color, $text_color, 80%);
+ }
- &:disabled { @include button(insensitive); }
+ > slider {
+ background-color: white;
+ outline-color: transparentize(black, .8);
+ box-shadow: 0 2px 4px transparentize(black, .6);
+ }
+ }
+ }
- // OSD
- .osd & {
- @include button(osd);
- border-color: darken($osd_borders_color, 3%);
- background-color: opacify($osd_bg_color, 1); // solid background needed here
+ &.dragging > trough > slider {
+ background-color: mix(white, $base_color, 60%);
+ outline-color: transparentize(black, .7);
+ box-shadow: 0 0 0 1px transparent;
+ }
- &:hover {
- @include button(osd-hover);
- background-color: opacify($osd_bg_color, 1); // solid background needed here
- }
+ &:disabled {
+ filter: opacity(.5);
- &:active {
- @include button(osd-active);
- background-color: opacify($osd_bg_color, 1); // solid background needed here
- }
+ > trough > slider {
+ box-shadow: 0 2px 4px transparent;
+ outline-color: transparentize(black, .8);
+ }
+ }
- &:disabled {
- @include button(osd-insensitive);
- background-color: opacify($osd_bg_color, 1); // solid background needed here
- }
+ @if $contrast == "high" {
+ &, &:hover, &.dragging, &:disabled {
+ > trough > slider {
+ outline-color: transparentize(black, .5);
}
}
}
// click-and-hold the slider to activate
&.fine-tune {
+ padding: 9px;
+
&.horizontal {
- padding-top: 9px;
- padding-bottom: 9px;
min-height: 16px;
}
&.vertical {
- padding-left: 9px;
- padding-right: 9px;
min-width: 16px;
}
> trough {
// to make the trough grow in fine-tune mode
- > slider { margin: -6px; }
+ > slider { margin: -5px; }
> fill,
> highlight,
@@ -155,13 +131,24 @@ scale {
}
&.marks-before, &.marks-after {
- > trough > slider {
- // Adjust box-shadow for the 45deg rotation, for 0 1px we ideally want
- // 1/√2px 1/√2px, round that to 1px 1px
- $_button_shadow: 1px 1px 2px transparentize($shadow_color, 0.03);
+ // Adjust box-shadow for the 45deg rotation, for 0px 2px we ideally want
+ // 1/√2px 1/√2px, round that to 1px 1px
+ $_shadow_size: 1px 1px;
- box-shadow: $_button_shadow;
+ > trough > slider {
transform: rotate(45deg);
+
+ box-shadow: $_shadow_size 4px transparentize(black, .8);
+ }
+
+ &:hover > trough > slider {
+ box-shadow: $_shadow_size 4px transparentize(black, .6);
+ }
+
+ &.dragging, &:disabled {
+ > trough > slider {
+ box-shadow: $_shadow_size 4px transparent;
+ }
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]