-
Notifications
You must be signed in to change notification settings - Fork 31
/
slider.scss
141 lines (121 loc) · 3.85 KB
/
slider.scss
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
@import "../style/base";
@import "slider-vars";
:host {
--_buffer-perc: 0;
--_perc: 0;
--_slider-track-bg: #{$slider-bg};
--_slider-track-bg-buffer: #{$slider-bg-buffer};
--_slider-track-bg-active: #{$slider-bg-active};
--_slider-thumb-bg: #{$slider-thumb-bg};
}
:host([disabled]) {
--_slider-track-bg: #{$slider-bg-disabled};
--_slider-track-bg-buffer: #{$slider-bg-buffer-disabled};
--_slider-track-bg-active: #{$slider-bg-active-disabled};
--_slider-thumb-bg: #{$slider-thumb-bg-disabled};
}
#container {
overflow: visible;
border: none;
}
#slider {
height: $slider-height;
background: linear-gradient(to right,
var(--_slider-track-bg-active) 0%, var(--_slider-track-bg-active) calc(var(--_perc) * 100%),
var(--_slider-track-bg-buffer) calc(var(--_perc) * 100%), var(--_slider-track-bg-buffer) calc(var(--_buffer-perc) * 100%),
var(--_slider-track-bg) calc(var(--_buffer-perc) * 100%), var(--_slider-track-bg) 100%);
cursor: grab;
appearance: none;
border: none;
outline: none;
box-sizing: border-box;
width: 100%;
margin: 0;
border-radius: 0;
// Move the slider a bit up to center it in the wrapper.
top: calc((#{$slider-height} * -1) / 2);
position: relative;
}
#thumb-container {
position: relative;
width: 100%;
}
#thumb-label {
--_thumb-label-transform-y: #{size(10)};
/*
To understand the bellow computation we first need to understand what had to be dealt with.
The percentage of var(--_perc) is a percentage of much of the slider is filled.
If we simply use that percentage as the left offset we will discover that when var(--_perc) is 100%
the thumb label will be at slightly slightly wrong offset because left: 100% will make the thumb label appear
outside it's relative box. The solution is to subtract #{$slider-thumb-size} * var(--_perc))) which will subtract
the whole width of the thumb when 100% and none when 0%.
*/
left: calc((var(--_perc) * 100%) - (#{$slider-thumb-size} * var(--_perc)));
transform: translate(calc(-50% + (#{$slider-thumb-size} / 2)), var(--_thumb-label-transform-y));
width: $slider-thumb-label-size;
height: $slider-thumb-label-size;
border-radius: $slider-thumb-label-border-radius;
color: $slider-thumb-label-color;
background: $slider-thumb-label-bg;
font-size: $slider-thumb-label-font-size;
transition: $slider-thumb-label-transition;
opacity: 0;
position: absolute;
display: flex;
align-items: center;
justify-content: center;
pointer-events: none;
text-overflow: ellipsis;
// Move the label above the thumb dot.
bottom: calc(100% + #{$slider-thumb-size} + #{$slider-height} + #{$slider-thumb-space});
// Add droplet shape.
&:before {
content: "";
background: $slider-thumb-label-bg;
border-radius: 0 50% 50% 50%;
position: absolute;
transform: rotate(225deg); /* 90 * 2.5 = 225*/
width: 100%;
left: 0;
top: 0;
height: 100%;
z-index: -1;
}
}
:host:focus, #slider:focus + #thumb-container {
#thumb-label {
// Animate the thumb label in
--_thumb-label-transform-y: 0;
opacity: 1;
}
}
@mixin slider-thumb-styles() {
background: var(--_slider-thumb-bg);
width: $slider-thumb-size;
height: $slider-thumb-size;
border-radius: $slider-thumb-border-radius;
transition: $slider-thumb-transition;
box-shadow: 0 0 0 0 $slider-thumb-focus-ring-bg;
appearance: none;
border: none;
cursor: grab;
// Required to center the thumb on the track
position: relative;
}
@mixin slider-thumb-focus-styles() {
transform: $slider-thumb-transform-focus;
box-shadow: 0 0 0 $slider-thumb-focus-ring-size $slider-thumb-focus-ring-bg;
}
/* We had to split the styles into two declarations for some reason */
#slider::-webkit-slider-thumb {
@include slider-thumb-styles();
}
#slider::-moz-range-thumb {
@include slider-thumb-styles();
}
#slider:focus::-webkit-slider-thumb {
@include slider-thumb-focus-styles()
}
#slider:focus::-moz-range-thumb {
@include slider-thumb-focus-styles()
}