@geoffcox/sterling-svelte-themes 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (117) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +13 -0
  3. package/css/sterling/Button.base.css +54 -0
  4. package/css/sterling/Button.colorful.css +17 -0
  5. package/css/sterling/Button.css +8 -0
  6. package/css/sterling/Button.disabled.css +22 -0
  7. package/css/sterling/Button.secondary.colorful.css +15 -0
  8. package/css/sterling/Button.secondary.css +11 -0
  9. package/css/sterling/Button.shapes.css +14 -0
  10. package/css/sterling/Button.tool.colorful.css +13 -0
  11. package/css/sterling/Button.tool.css +18 -0
  12. package/css/sterling/Callout.base.css +59 -0
  13. package/css/sterling/Callout.colorful.css +5 -0
  14. package/css/sterling/Callout.css +2 -0
  15. package/css/sterling/Checkbox.base.css +121 -0
  16. package/css/sterling/Checkbox.colorful.css +17 -0
  17. package/css/sterling/Checkbox.css +3 -0
  18. package/css/sterling/Checkbox.disabled.css +28 -0
  19. package/css/sterling/Dialog.base.css +114 -0
  20. package/css/sterling/Dialog.css +1 -0
  21. package/css/sterling/Dropdown.base.css +105 -0
  22. package/css/sterling/Dropdown.colorful.css +23 -0
  23. package/css/sterling/Dropdown.composed.css +11 -0
  24. package/css/sterling/Dropdown.css +4 -0
  25. package/css/sterling/Dropdown.disabled.css +32 -0
  26. package/css/sterling/Input.base.css +72 -0
  27. package/css/sterling/Input.colorful.css +22 -0
  28. package/css/sterling/Input.composed.css +12 -0
  29. package/css/sterling/Input.css +4 -0
  30. package/css/sterling/Input.disabled.css +36 -0
  31. package/css/sterling/Label.base.css +116 -0
  32. package/css/sterling/Label.boxed.colorful.css +21 -0
  33. package/css/sterling/Label.boxed.css +31 -0
  34. package/css/sterling/Label.colorful.css +3 -0
  35. package/css/sterling/Label.css +5 -0
  36. package/css/sterling/Label.disabled.css +9 -0
  37. package/css/sterling/Link.base.css +43 -0
  38. package/css/sterling/Link.colorful.css +15 -0
  39. package/css/sterling/Link.css +11 -0
  40. package/css/sterling/Link.disabled.css +10 -0
  41. package/css/sterling/Link.ghost.colorful.css +7 -0
  42. package/css/sterling/Link.ghost.css +11 -0
  43. package/css/sterling/Link.text-underline.css +8 -0
  44. package/css/sterling/Link.text-underline.ghost.css +13 -0
  45. package/css/sterling/Link.undecorated.colorful.css +8 -0
  46. package/css/sterling/Link.undecorated.css +8 -0
  47. package/css/sterling/Link.undecorated.ghost.css +8 -0
  48. package/css/sterling/Link.undecorated.underline.css +8 -0
  49. package/css/sterling/List.base.css +84 -0
  50. package/css/sterling/List.composed.css +8 -0
  51. package/css/sterling/List.css +3 -0
  52. package/css/sterling/List.disabled.css +7 -0
  53. package/css/sterling/ListItem.base.css +33 -0
  54. package/css/sterling/ListItem.css +2 -0
  55. package/css/sterling/ListItem.disabled.css +28 -0
  56. package/css/sterling/Menu.base.css +21 -0
  57. package/css/sterling/Menu.css +1 -0
  58. package/css/sterling/MenuBar.base.css +9 -0
  59. package/css/sterling/MenuBar.css +1 -0
  60. package/css/sterling/MenuButton.base.css +13 -0
  61. package/css/sterling/MenuButton.css +1 -0
  62. package/css/sterling/MenuItem.base.css +48 -0
  63. package/css/sterling/MenuItem.css +1 -0
  64. package/css/sterling/MenuItemDisplay.base.css +84 -0
  65. package/css/sterling/MenuItemDisplay.css +2 -0
  66. package/css/sterling/MenuItemDisplay.disabled.css +28 -0
  67. package/css/sterling/MenuSeparator.base.css +5 -0
  68. package/css/sterling/MenuSeparator.css +1 -0
  69. package/css/sterling/Popover.css +21 -0
  70. package/css/sterling/Progress.base.css +93 -0
  71. package/css/sterling/Progress.css +2 -0
  72. package/css/sterling/Progress.disabled.css +17 -0
  73. package/css/sterling/Radio.base.css +109 -0
  74. package/css/sterling/Radio.colorful.css +18 -0
  75. package/css/sterling/Radio.css +3 -0
  76. package/css/sterling/Radio.disabled.css +28 -0
  77. package/css/sterling/Select.base.css +101 -0
  78. package/css/sterling/Select.colorful.css +24 -0
  79. package/css/sterling/Select.composed.css +12 -0
  80. package/css/sterling/Select.css +4 -0
  81. package/css/sterling/Select.disabled.css +28 -0
  82. package/css/sterling/Slider.base.css +153 -0
  83. package/css/sterling/Slider.colorful.css +11 -0
  84. package/css/sterling/Slider.composed.css +8 -0
  85. package/css/sterling/Slider.css +4 -0
  86. package/css/sterling/Slider.disabled.css +30 -0
  87. package/css/sterling/Switch.base.css +175 -0
  88. package/css/sterling/Switch.colorful.css +45 -0
  89. package/css/sterling/Switch.css +3 -0
  90. package/css/sterling/Switch.disabled.css +30 -0
  91. package/css/sterling/Tab.base.css +96 -0
  92. package/css/sterling/Tab.colorful.css +13 -0
  93. package/css/sterling/Tab.css +3 -0
  94. package/css/sterling/Tab.disabled.css +36 -0
  95. package/css/sterling/TabList.base.css +34 -0
  96. package/css/sterling/TabList.css +1 -0
  97. package/css/sterling/TextArea.base.css +62 -0
  98. package/css/sterling/TextArea.colorful.css +17 -0
  99. package/css/sterling/TextArea.composed.css +8 -0
  100. package/css/sterling/TextArea.css +4 -0
  101. package/css/sterling/TextArea.disabled.css +28 -0
  102. package/css/sterling/Tooltip.base.css +6 -0
  103. package/css/sterling/Tooltip.css +1 -0
  104. package/css/sterling/Tree.base.css +49 -0
  105. package/css/sterling/Tree.composed.css +8 -0
  106. package/css/sterling/Tree.css +3 -0
  107. package/css/sterling/Tree.disabled.css +27 -0
  108. package/css/sterling/TreeChevron.base.css +86 -0
  109. package/css/sterling/TreeChevron.css +1 -0
  110. package/css/sterling/TreeItem.base.css +41 -0
  111. package/css/sterling/TreeItem.colorful.css +9 -0
  112. package/css/sterling/TreeItem.css +3 -0
  113. package/css/sterling/TreeItem.disabled.css +34 -0
  114. package/css/sterling/dark-mode.css +134 -0
  115. package/css/sterling/light-mode.css +134 -0
  116. package/css/sterling.css +32 -0
  117. package/package.json +35 -0
@@ -0,0 +1,101 @@
1
+ .sterling-select {
2
+ align-content: center;
3
+ align-items: center;
4
+ background-color: var(--stsv-input__background-color);
5
+ border-color: var(--stsv-input__border-color);
6
+ border-radius: 3px;
7
+ border-style: solid;
8
+ border-width: 2px;
9
+ color: var(--stsv-input__color);
10
+ cursor: pointer;
11
+ display: grid;
12
+ grid-template-columns: 1fr auto;
13
+ grid-template-rows: auto;
14
+ outline: none;
15
+ padding: 0;
16
+ position: relative;
17
+ transition:
18
+ background-color 250ms,
19
+ color 250ms,
20
+ border-color 250ms;
21
+ }
22
+
23
+ .sterling-select:hover {
24
+ background-color: var(--stsv-input__background-color--hover);
25
+ border-color: var(--stsv-input__border-color--hover);
26
+ color: var(--stsv-input__color--hover);
27
+ }
28
+
29
+ .sterling-select:focus {
30
+ background-color: var(--stsv-input__background-color--focus);
31
+ border-color: var(--stsv-input__border-color--focus);
32
+ color: var(--stsv-input__color--focus);
33
+ outline-color: var(--stsv-common__outline-color);
34
+ outline-offset: 0;
35
+ outline-style: solid;
36
+ outline-width: 2px;
37
+ }
38
+
39
+ .sterling-select .value {
40
+ padding: 0.5em;
41
+ display: flex;
42
+ align-items: center;
43
+ }
44
+
45
+ .sterling-select .chevron {
46
+ display: block;
47
+ position: relative;
48
+ border: none;
49
+ background: none;
50
+ margin: 0;
51
+ height: 100%;
52
+ width: 32px;
53
+ }
54
+
55
+ .sterling-select .chevron::after {
56
+ position: absolute;
57
+ content: '';
58
+ top: 50%;
59
+ left: 50%;
60
+ width: 7px;
61
+ height: 7px;
62
+ border-right: 3px solid currentColor;
63
+ border-top: 3px solid currentColor;
64
+ /*
65
+ The chevron is a right triangle, rotated to face down.
66
+ It should be moved up so it is centered vertically after rotation.
67
+ The amount to move is the hypotenuse of the right triangle of the chevron.
68
+ For a right triangle with equal a and b where c=1
69
+ a^2 + b^2 = c^2
70
+ a^2 + a^2 = c^2
71
+ 2a^2 = c^2
72
+ 2a^2 = 1
73
+ a^2 = 0.5
74
+ a = sqrt(0.5)
75
+ a = 0.707
76
+ */
77
+ transform: translate(-50%, calc(-50% / 0.707)) rotate(135deg);
78
+ transform-origin: 50% 50%;
79
+ }
80
+
81
+ .sterling-select-popup-content {
82
+ background-color: var(--stsv-common__background-color);
83
+ border-color: var(--stsv-common__border-color);
84
+ border-radius: 0;
85
+ border-style: solid;
86
+ border-width: 2px;
87
+ box-shadow: var(--stsv-common__box-shadow);
88
+ padding: 0.25em;
89
+ display: grid;
90
+ grid-template-columns: 1fr;
91
+ grid-template-rows: 1fr;
92
+ overflow: hidden;
93
+ max-height: 20em;
94
+ }
95
+
96
+ @media (prefers-reduced-motion) {
97
+ .sterling-select,
98
+ .sterling-select::after {
99
+ transition: none;
100
+ }
101
+ }
@@ -0,0 +1,24 @@
1
+ .sterling-select.colorful {
2
+ background-color: var(--stsv-input--colorful__background-color);
3
+ border-color: var(--stsv-input--colorful__border-color);
4
+ color: var(--stsv-input--colorful__color);
5
+ }
6
+
7
+ .sterling-select.colorful:hover {
8
+ background-color: var(--stsv-input--colorful__background-color--hover);
9
+ border-color: var(--stsv-input--colorful__border-color--hover);
10
+ color: var(--stsv-input--colorful__color--hover);
11
+ }
12
+
13
+ .sterling-select.colorful:focus {
14
+ background-color: var(--stsv-input--colorful__background-color--focus);
15
+ border-color: var(--stsv-input--colorful__border-color--focus);
16
+ color: var(--stsv-input--colorful__color--focus);
17
+ outline-color: var(--stsv-common--colorful__outline-color);
18
+ }
19
+
20
+ .sterling-select-popup-content.colorful {
21
+ background-color: var(--stsv-common--colorful__background-color);
22
+ border-color: var(--stsv-common--colorful__border-color);
23
+ color: var(--stsv-common--colorful__color);
24
+ }
@@ -0,0 +1,12 @@
1
+ .sterling-select.composed,
2
+ .sterling-select.composed:hover,
3
+ .sterling-select.composed.focus,
4
+ .sterling-select.composed.disabled {
5
+ background: none;
6
+ border: none;
7
+ outline: none;
8
+ }
9
+
10
+ .sterling-select.composed.disabled::after {
11
+ opacity: 0;
12
+ }
@@ -0,0 +1,4 @@
1
+ @import url('./Select.base.css');
2
+ @import url('./Select.colorful.css');
3
+ @import url('./Select.composed.css');
4
+ @import url('./Select.disabled.css');
@@ -0,0 +1,28 @@
1
+ .sterling-select.disabled {
2
+ cursor: not-allowed;
3
+ outline: none;
4
+ }
5
+
6
+ .sterling-select::after {
7
+ background: repeating-linear-gradient(
8
+ var(--stsv-common--disabled__stripe-angle),
9
+ var(--stsv-common--disabled__stripe-color),
10
+ var(--stsv-common--disabled__stripe-color) var(--stsv-common--disabled__stripe-width),
11
+ var(--stsv-common--disabled__stripe-color--alt) var(--stsv-common--disabled__stripe-width),
12
+ var(--stsv-common--disabled__stripe-color--alt)
13
+ calc(2 * var(--stsv-common--disabled__stripe-width))
14
+ );
15
+ bottom: 0;
16
+ content: '';
17
+ left: 0;
18
+ opacity: 0;
19
+ position: absolute;
20
+ right: 0;
21
+ top: 0;
22
+ pointer-events: none;
23
+ transition: opacity 250ms;
24
+ }
25
+
26
+ .sterling-select.disabled::after {
27
+ opacity: 1;
28
+ }
@@ -0,0 +1,153 @@
1
+ .sterling-slider {
2
+ box-sizing: border-box;
3
+ outline: none;
4
+ padding: 0;
5
+ overflow: visible;
6
+ display: grid;
7
+ transition:
8
+ background-color 250ms,
9
+ color 250ms,
10
+ border-color 250ms;
11
+ min-width: 200px;
12
+ }
13
+
14
+ .sterling-slider.horizontal {
15
+ height: 2em;
16
+ }
17
+
18
+ .sterling-slider.vertical {
19
+ height: 100%;
20
+ width: 2em;
21
+ }
22
+
23
+ /* ----- container ----- */
24
+
25
+ .sterling-slider .container {
26
+ position: relative;
27
+ }
28
+
29
+ .sterling-slider.horizontal .container {
30
+ margin: 0 0.75em;
31
+ }
32
+
33
+ .sterling-slider.vertical .container {
34
+ margin: 0.75em 0;
35
+ }
36
+
37
+ /* ----- track ----- */
38
+
39
+ .sterling-slider .track {
40
+ position: absolute;
41
+ background: var(--stsv-common__background-color--secondary);
42
+ transition:
43
+ background-color 250ms,
44
+ color 250ms,
45
+ border-color 250ms;
46
+ }
47
+
48
+ .sterling-slider.horizontal .track {
49
+ left: 0;
50
+ right: 0;
51
+ top: 50%;
52
+ height: 3px;
53
+ transform: translate(0, -50%);
54
+ }
55
+
56
+ .sterling-slider.vertical .track {
57
+ bottom: 0;
58
+ left: 50%;
59
+ top: 0;
60
+ transform: translate(-50%, 0);
61
+ width: 3px;
62
+ }
63
+
64
+ .sterling-slider:focus-visible {
65
+ outline-color: var(--stsv-common__outline-color);
66
+ outline-offset: 0;
67
+ outline-style: solid;
68
+ outline-width: 2px;
69
+ }
70
+
71
+ /* ----- fill ----- */
72
+
73
+ .sterling-slider .fill {
74
+ background: var(--stsv-common__color);
75
+ position: absolute;
76
+ transition:
77
+ background-color 250ms,
78
+ color 250ms,
79
+ border-color 250ms;
80
+ }
81
+
82
+ .sterling-slider.horizontal .fill {
83
+ height: 3px;
84
+ top: 50%;
85
+ transform: translate(0, -50%);
86
+ }
87
+
88
+ .sterling-slider.vertical .fill {
89
+ bottom: 0;
90
+ left: 50%;
91
+ transform: translate(-50%, 0);
92
+ width: 3px;
93
+ }
94
+
95
+ /* ----- thumb ----- */
96
+
97
+ .sterling-slider .thumb {
98
+ background-color: var(--stsv-button__background-color);
99
+ border-color: var(--stsv-button__border-color);
100
+ border-radius: 10000px;
101
+ border-style: solid;
102
+ border-width: 2px;
103
+ box-sizing: border-box;
104
+ color: var(--stsv-button__color);
105
+ cursor: pointer;
106
+ display: block;
107
+ font: inherit;
108
+ height: 1.5em;
109
+ overflow: hidden;
110
+ padding: 0;
111
+ text-decoration: none;
112
+ transition:
113
+ background-color 250ms,
114
+ color 250ms,
115
+ border-color 250ms;
116
+ white-space: nowrap;
117
+ position: absolute;
118
+ width: 1.5em;
119
+ }
120
+
121
+ .sterling-slider.horizontal .thumb {
122
+ top: 50%;
123
+ transform: translate(-50%, -50%);
124
+ }
125
+
126
+ .sterling-slider.vertical .thumb {
127
+ left: 50%;
128
+ transform: translate(-50%, 50%);
129
+ }
130
+
131
+ .thumb:hover {
132
+ background-color: var(--stsv-button__background-color--hover);
133
+ border-color: var(--stsv-button__border-color--hover);
134
+ color: var(--stsv-button__color--hover);
135
+ }
136
+
137
+ .thumb:active {
138
+ background-color: var(--stsv-button__background-color--active);
139
+ border-color: var(--stsv-button__border-color--active);
140
+ color: var(--stsv-button__color--active);
141
+ }
142
+
143
+ /* ----- reduced motion ----- */
144
+
145
+ @media (prefers-reduced-motion) {
146
+ .sterling-slider,
147
+ .sterling-slider .track,
148
+ .sterling-slider .fill,
149
+ .sterling-slider .thumb,
150
+ .sterling-slider .thumb::after {
151
+ transition: none;
152
+ }
153
+ }
@@ -0,0 +1,11 @@
1
+ .sterling-slider.colorful .fill {
2
+ background: var(--stsv-input--colorful__border-color--selected);
3
+ position: absolute;
4
+ transition: background-color 250ms, color 250ms, border-color 250ms;
5
+ }
6
+
7
+ .sterling-slider.colorful .thumb {
8
+ background-color: var(--stsv-button--colorful__background-color);
9
+ border-color: var(--stsv-button--colorful__border-color);
10
+ color: var(--stsv-button--colorful__color);
11
+ }
@@ -0,0 +1,8 @@
1
+ .sterling-slider.composed,
2
+ .sterling-slider.composed:hover,
3
+ .sterling-slider.composed.focus,
4
+ .sterling-slider.composed.disabled {
5
+ background: none;
6
+ border: none;
7
+ outline: none;
8
+ }
@@ -0,0 +1,4 @@
1
+ @import url('./Slider.base.css');
2
+ @import url('./Slider.colorful.css');
3
+ @import url('./Slider.disabled.css');
4
+ @import url('./Slider.composed.css');
@@ -0,0 +1,30 @@
1
+ /* ----- thumb disabled ----- */
2
+
3
+ .sterling-slider.disabled .thumb {
4
+ cursor: not-allowed;
5
+ outline: none;
6
+ }
7
+
8
+ .sterling-slider .thumb::after {
9
+ background: repeating-linear-gradient(
10
+ var(--stsv-common--disabled__stripe-angle),
11
+ var(--stsv-common--disabled__stripe-color),
12
+ var(--stsv-common--disabled__stripe-color) var(--stsv-common--disabled__stripe-width),
13
+ var(--stsv-common--disabled__stripe-color--alt) var(--stsv-common--disabled__stripe-width),
14
+ var(--stsv-common--disabled__stripe-color--alt)
15
+ calc(2 * var(--stsv-common--disabled__stripe-width))
16
+ );
17
+ bottom: 0;
18
+ content: '';
19
+ left: 0;
20
+ opacity: 0;
21
+ position: absolute;
22
+ right: 0;
23
+ top: 0;
24
+ pointer-events: none;
25
+ transition: opacity 250ms;
26
+ }
27
+
28
+ .sterling-slider.disabled .thumb::after {
29
+ opacity: 1;
30
+ }
@@ -0,0 +1,175 @@
1
+ .sterling-switch {
2
+ cursor: pointer;
3
+ display: grid;
4
+ position: relative;
5
+ }
6
+
7
+ .sterling-switch input {
8
+ cursor: pointer;
9
+ }
10
+
11
+ .sterling-switch:not(.vertical) {
12
+ align-content: center;
13
+ align-items: center;
14
+ column-gap: 0.5em;
15
+ grid-template-columns: auto auto auto;
16
+ grid-template-rows: auto;
17
+ justify-content: flex-start;
18
+ justify-items: flex-start;
19
+ }
20
+
21
+ .sterling-switch.vertical {
22
+ align-content: flex-start;
23
+ align-items: flex-start;
24
+ grid-template-columns: auto;
25
+ grid-template-rows: auto;
26
+ justify-content: center;
27
+ justify-items: center;
28
+ row-gap: 0.5em;
29
+ }
30
+
31
+ .sterling-switch.vertical .off-label {
32
+ grid-row: 3 / span 1;
33
+ }
34
+
35
+ .sterling-switch.vertical .on-label {
36
+ grid-row: 1 / span 1;
37
+ }
38
+
39
+ /* ----- input hidden ----- */
40
+
41
+ .sterling-switch input {
42
+ font: inherit;
43
+ margin: 0;
44
+ padding: 0;
45
+ position: absolute;
46
+ left: 0;
47
+ right: 0;
48
+ bottom: 0;
49
+ top: 0;
50
+ opacity: 0;
51
+ }
52
+
53
+ /* ----- toggle ----- */
54
+
55
+ .sterling-switch .toggle {
56
+ background-color: var(--stsv-input__background-color);
57
+ border-color: var(--stsv-input__border-color);
58
+ border-radius: 10000px;
59
+ border-style: solid;
60
+ border-width: 2px;
61
+ box-sizing: border-box;
62
+ color: var(--stsv-input__color);
63
+ font: inherit;
64
+ pointer-events: none;
65
+ position: relative;
66
+ transition:
67
+ background-color 250ms,
68
+ color 250ms,
69
+ border-color 250ms;
70
+ user-select: none;
71
+ }
72
+
73
+ .sterling-switch:hover .toggle {
74
+ background-color: var(--stsv-input__background-color--hover);
75
+ border-color: var(--stsv-input__border-color--hover);
76
+ color: var(--stsv-input__color--hover);
77
+ }
78
+
79
+ input:focus-visible ~ .toggle {
80
+ background-color: var(--stsv-input__background-color--focus);
81
+ border-color: var(--stsv-input__border-color--focus);
82
+ color: var(--stsv-common__color--focux);
83
+ outline-color: var(--stsv-common__outline-color);
84
+ outline-offset: 0;
85
+ outline-style: solid;
86
+ outline-width: 2px;
87
+ }
88
+
89
+ input:checked ~ .toggle,
90
+ input:checked:hover ~ .toggle,
91
+ input:checked:focus-visible ~ .toggle {
92
+ background-color: var(--stsv-input__border-color--hover);
93
+ }
94
+
95
+ /* ----- switch vertical ----- */
96
+
97
+ .sterling-switch:not(.vertical) .toggle {
98
+ width: 2em;
99
+ height: 1.25em;
100
+ }
101
+
102
+ .sterling-switch.vertical .toggle {
103
+ width: 1.25em;
104
+ height: 2em;
105
+ }
106
+
107
+ /* ----- labels ----- */
108
+
109
+ .sterling-switch label {
110
+ color: var(--stsv-common__color);
111
+ transition: color 250ms;
112
+ font: inherit;
113
+ }
114
+
115
+ .sterling-switch .off-label,
116
+ .sterling-switch .on-label {
117
+ padding-top: 2px;
118
+ }
119
+
120
+ /* ----- thumb ----- */
121
+
122
+ .sterling-switch .thumb {
123
+ background-color: var(--stsv-button__background-color);
124
+ border-color: var(--stsv-button__border-color);
125
+ border-radius: 10000px;
126
+ border-style: solid;
127
+ border-width: 2px;
128
+ box-sizing: border-box;
129
+ color: var(--stsv-button__color);
130
+ display: block;
131
+ font: inherit;
132
+ height: 1.25em;
133
+ position: absolute;
134
+ transition:
135
+ background-color 250ms,
136
+ color 250ms,
137
+ border-color 250ms,
138
+ transform 250ms;
139
+ width: 1.25em;
140
+ }
141
+
142
+ .sterling-switch:hover .thumb {
143
+ background-color: var(--stsv-button__background-color--hover);
144
+ border-color: var(--stsv-button__border-color--hover);
145
+ color: var(--stsv-button__color--hover);
146
+ }
147
+
148
+ .sterling-switch:active .thumb {
149
+ background-color: var(--stsv-button__background-color--active);
150
+ border-color: var(--stsv-button__border-color--active);
151
+ color: var(--stsv-button__color--hover);
152
+ }
153
+
154
+ /* ----- thumb vertical ----- */
155
+
156
+ .sterling-switch:not(.vertical) .thumb {
157
+ top: calc(-1 * 2px);
158
+ transform: translateX(calc(var(--thumb-offset) - 2px));
159
+ }
160
+
161
+ .sterling-switch.vertical .thumb {
162
+ left: calc(-1 * 2px);
163
+ transform: translateY(calc(var(--thumb-offset) - 2px));
164
+ }
165
+
166
+ /* ----- reduced motion ----- */
167
+
168
+ @media (prefers-reduced-motion) {
169
+ .sterling-switch .toggle,
170
+ .sterling-switch .thumb,
171
+ .sterling-switch .thumb::after,
172
+ .sterling-switch label {
173
+ transition: none;
174
+ }
175
+ }
@@ -0,0 +1,45 @@
1
+ /* ----- switch colorful ----- */
2
+
3
+ .sterling-switch.colorful .switch {
4
+ background-color: var(--stsv-input--colorful__background-color);
5
+ border-color: var(--stsv-input--colorful__border-color);
6
+ color: var(--stsv-input--colorful__color);
7
+ }
8
+
9
+ .sterling-switch.colorful:hover .switch {
10
+ background-color: var(--stsv-input--colorful__background-color--hover);
11
+ border-color: var(--stsv-input--colorful__border-color--hover);
12
+ color: var(--stsv-input_--colorful_color--hover);
13
+ }
14
+
15
+ .sterling-switch.colorful input:focus-visible ~ .switch {
16
+ background-color: var(--stsv-input--colorful__background-color--focus);
17
+ border-color: var(--stsv-input--colorful__border-color--focus);
18
+ color: var(--stsv-input--colorful__color--focus);
19
+ }
20
+
21
+ .sterling-switch.colorful input:checked ~ .switch,
22
+ .sterling-switch.colorful input:checked:hover ~ .switch,
23
+ .sterling-switch.colorful input:checked:focus-visible ~ .switch {
24
+ background-color: var(--stsv-input--colorful__border-color--hover);
25
+ }
26
+
27
+ /* ----- thumb colorful ----- */
28
+
29
+ .sterling-switch.colorful .thumb {
30
+ background-color: var(--stsv-button--colorful__background-color);
31
+ border-color: var(--stsv-button--colorful__border-color);
32
+ color: var(--stsv-button--colorful__color);
33
+ }
34
+
35
+ .sterling-switch.colorful:hover .thumb {
36
+ background-color: var(--stsv-button--colorful__background-color--hover);
37
+ border-color: var(--stsv-button--colorful__border-color--hover);
38
+ color: var(--stsv-button--colorful__color--hover);
39
+ }
40
+
41
+ .sterling-switch.colorful:active .thumb {
42
+ background-color: var(--stsv-button--colorful__background-color--active);
43
+ border-color: var(--stsv-button--colorful__border-color--active);
44
+ color: var(--stsv-button--colorful__color--hover);
45
+ }
@@ -0,0 +1,3 @@
1
+ @import url('./Switch.base.css');
2
+ @import url('./Switch.colorful.css');
3
+ @import url('./Switch.disabled.css');
@@ -0,0 +1,30 @@
1
+ .sterling-switch.disabled input {
2
+ cursor: not-allowed;
3
+ }
4
+
5
+ /* ----- thumb disabled ----- */
6
+
7
+ .sterling-switch .thumb::after {
8
+ background: repeating-linear-gradient(
9
+ var(--stsv-common--disabled__stripe-angle),
10
+ var(--stsv-common--disabled__stripe-color),
11
+ var(--stsv-common--disabled__stripe-color) var(--stsv-common--disabled__stripe-width),
12
+ var(--stsv-common--disabled__stripe-color--alt) var(--stsv-common--disabled__stripe-width),
13
+ var(--stsv-common--disabled__stripe-color--alt)
14
+ calc(2 * var(--stsv-common--disabled__stripe-width))
15
+ );
16
+ bottom: 0;
17
+ border-radius: 10000px;
18
+ content: '';
19
+ left: 0;
20
+ opacity: 0;
21
+ position: absolute;
22
+ right: 0;
23
+ top: 0;
24
+ pointer-events: none;
25
+ transition: opacity 250ms;
26
+ }
27
+
28
+ .sterling-switch.disabled .thumb::after {
29
+ opacity: 1;
30
+ }