forked from epicweb-dev/advanced-react-patterns
-
Notifications
You must be signed in to change notification settings - Fork 0
/
switch.styles.css
70 lines (70 loc) · 1.49 KB
/
switch.styles.css
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
/*
toggle styles copied and modified from
https://codepen.io/mallendeo/pen/eLIiG
by Mauricio Allende (https://mallendeo.com/)
*/
.toggle-btn {
box-sizing: initial;
display: inline-block;
outline: 0;
width: 8em;
height: 4em;
position: relative;
cursor: pointer;
user-select: none;
background: #fbfbfb;
border-radius: 4em;
padding: 4px;
transition: all 0.4s ease;
border: 2px solid #e8eae9;
}
.toggle-input:focus + .toggle-btn::after,
.toggle-btn:active::after {
box-sizing: initial;
box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.1), 0 4px 0 rgba(0, 0, 0, 0.08),
inset 0px 0px 0px 3px #9c9c9c;
}
.toggle-btn::after {
left: 0;
position: relative;
display: block;
content: '';
width: 50%;
height: 100%;
border-radius: 4em;
background: #fbfbfb;
transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275),
padding 0.3s ease, margin 0.3s ease;
box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.1), 0 4px 0 rgba(0, 0, 0, 0.08);
}
.toggle-btn.toggle-btn-on::after {
left: 50%;
}
.toggle-btn.toggle-btn-on {
background: #86d993;
}
.toggle-btn.toggle-btn-on:active {
box-shadow: none;
}
.toggle-btn.toggle-btn-on:active::after {
margin-left: -1.6em;
}
.toggle-btn:active::after {
padding-right: 1.6em;
}
.toggle-btn[disabled] {
opacity: 0.7;
cursor: auto;
}
.toggle-input {
/* visually hidden but still accessible */
border: 0;
clip: rect(0 0 0 0);
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
width: 1px;
white-space: nowrap;
}