diff options
author | Volpeon <git@volpeon.ink> | 2024-06-22 19:30:00 +0200 |
---|---|---|
committer | Volpeon <git@volpeon.ink> | 2024-06-22 19:30:00 +0200 |
commit | 6b0fcac695aa7a5517f6f53cec50da493acc4582 (patch) | |
tree | 05b1ec4bfd484c75f1ee82f06f674aba69ad1408 /src/objects/_badge.scss | |
parent | WIP: Refactoring (diff) | |
download | iro-design-6b0fcac695aa7a5517f6f53cec50da493acc4582.tar.gz iro-design-6b0fcac695aa7a5517f6f53cec50da493acc4582.tar.bz2 iro-design-6b0fcac695aa7a5517f6f53cec50da493acc4582.zip |
Update
Diffstat (limited to 'src/objects/_badge.scss')
-rw-r--r-- | src/objects/_badge.scss | 194 |
1 files changed, 194 insertions, 0 deletions
diff --git a/src/objects/_badge.scss b/src/objects/_badge.scss new file mode 100644 index 0000000..0d95751 --- /dev/null +++ b/src/objects/_badge.scss | |||
@@ -0,0 +1,194 @@ | |||
1 | @use 'iro-sass/src/index' as iro; | ||
2 | @use '../functions' as fn; | ||
3 | |||
4 | $themes: accent positive negative warning; | ||
5 | |||
6 | @include iro.props-namespace('badge') { | ||
7 | @include iro.props-store(( | ||
8 | --dims: ( | ||
9 | --pad-b: fn.global-dim(--size --100), | ||
10 | --pad-i: fn.global-dim(--size --150), | ||
11 | --pad-i-pill: fn.global-dim(--size --200), | ||
12 | --rounding: fn.global-dim(--rounding), | ||
13 | --font-size: fn.global-dim(--font-size --100), | ||
14 | |||
15 | --50: ( | ||
16 | --pad-b: fn.global-dim(--size --50), | ||
17 | --pad-i: fn.global-dim(--size --115), | ||
18 | --pad-i-pill: fn.global-dim(--size --150), | ||
19 | --font-size: fn.global-dim(--font-size --75), | ||
20 | ), | ||
21 | --200: ( | ||
22 | --pad-b: fn.global-dim(--size --125), | ||
23 | --pad-i: fn.global-dim(--size --175), | ||
24 | --pad-i-pill: fn.global-dim(--size --225), | ||
25 | --font-size: fn.global-dim(--font-size --150), | ||
26 | ), | ||
27 | --300: ( | ||
28 | --pad-b: fn.global-dim(--size --160), | ||
29 | --pad-i: fn.global-dim(--size --225), | ||
30 | --pad-i-pill: fn.global-dim(--size --300), | ||
31 | --font-size: fn.global-dim(--font-size --200), | ||
32 | ), | ||
33 | ), | ||
34 | --colors: ( | ||
35 | --bg: fn.global-color(--heading), | ||
36 | --label: fn.global-color(--bg-l2), | ||
37 | --hover: ( | ||
38 | --bg: fn.global-color(--text), | ||
39 | ), | ||
40 | --active: ( | ||
41 | --bg: fn.global-color(--text), | ||
42 | ), | ||
43 | --key-focus: ( | ||
44 | --bg: fn.global-color(--base --50), | ||
45 | --label: fn.global-color(--heading), | ||
46 | --border: fn.global-color(--yellow-static --400), | ||
47 | ), | ||
48 | |||
49 | --quiet: ( | ||
50 | --bg: fn.global-color(--border-mute), | ||
51 | --label: fn.global-color(--heading), | ||
52 | --hover: ( | ||
53 | --bg: fn.global-color(--border), | ||
54 | ), | ||
55 | --active: ( | ||
56 | --bg: fn.global-color(--border-strong), | ||
57 | ), | ||
58 | ), | ||
59 | ), | ||
60 | )); | ||
61 | |||
62 | @each $theme in $themes { | ||
63 | @include iro.props-store(( | ||
64 | --colors: ( | ||
65 | --#{$theme}: ( | ||
66 | --bg: fn.global-color(--#{$theme} --800), | ||
67 | --label: fn.global-color(--#{$theme} --800-text), | ||
68 | --hover: ( | ||
69 | --bg: fn.global-color(--#{$theme} --900), | ||
70 | ), | ||
71 | --active: ( | ||
72 | --bg: fn.global-color(--#{$theme} --900), | ||
73 | ), | ||
74 | ), | ||
75 | |||
76 | --#{$theme}-quiet: ( | ||
77 | --bg: fn.global-color(--#{$theme} --200), | ||
78 | --label: fn.global-color(--#{$theme} --1100), | ||
79 | --hover: ( | ||
80 | --bg: fn.global-color(--#{$theme} --300), | ||
81 | ), | ||
82 | --active: ( | ||
83 | --bg: fn.global-color(--#{$theme} --300), | ||
84 | ), | ||
85 | ) | ||
86 | ), | ||
87 | )); | ||
88 | } | ||
89 | |||
90 | @include iro.bem-object(iro.props-namespace()) { | ||
91 | display: inline-block; | ||
92 | padding-block: fn.dim(--pad-b); | ||
93 | padding-inline: fn.dim(--pad-i); | ||
94 | border-radius: fn.dim(--rounding); | ||
95 | background-color: fn.color(--bg); | ||
96 | color: fn.color(--label); | ||
97 | font-size: fn.dim(--font-size); | ||
98 | line-height: fn.global-dim(--font --standard --line-height); | ||
99 | text-align: center; | ||
100 | text-decoration: none; | ||
101 | |||
102 | &:link, | ||
103 | &:visited, | ||
104 | &:enabled { | ||
105 | &:hover { | ||
106 | background-color: fn.color(--hover --bg); | ||
107 | } | ||
108 | |||
109 | &:active { | ||
110 | background-color: fn.color(--active --bg); | ||
111 | } | ||
112 | } | ||
113 | |||
114 | @include iro.bem-modifier('quiet') { | ||
115 | background-color: fn.color(--quiet --bg); | ||
116 | color: fn.color(--quiet --label); | ||
117 | |||
118 | &:link, | ||
119 | &:visited, | ||
120 | &:enabled { | ||
121 | &:hover { | ||
122 | background-color: fn.color(--quiet --hover --bg); | ||
123 | } | ||
124 | |||
125 | &:active { | ||
126 | background-color: fn.color(--quiet --active --bg); | ||
127 | } | ||
128 | } | ||
129 | } | ||
130 | |||
131 | @each $theme in $themes { | ||
132 | @include iro.bem-modifier($theme) { | ||
133 | background-color: fn.color(--#{$theme} --bg); | ||
134 | color: fn.color(--#{$theme} --label); | ||
135 | |||
136 | &:link, | ||
137 | &:visited, | ||
138 | &:enabled { | ||
139 | &:hover { | ||
140 | background-color: fn.color(--#{$theme} --hover --bg); | ||
141 | } | ||
142 | |||
143 | &:active { | ||
144 | background-color: fn.color(--#{$theme} --active --bg); | ||
145 | } | ||
146 | } | ||
147 | |||
148 | @include iro.bem-modifier('quiet') { | ||
149 | background-color: fn.color(--#{$theme}-quiet --bg); | ||
150 | color: fn.color(--#{$theme}-quiet --label); | ||
151 | |||
152 | &:link, | ||
153 | &:visited, | ||
154 | &:enabled { | ||
155 | &:hover { | ||
156 | background-color: fn.color(--#{$theme}-quiet --hover --bg); | ||
157 | } | ||
158 | |||
159 | &:active { | ||
160 | background-color: fn.color(--#{$theme}-quiet --active --bg); | ||
161 | } | ||
162 | } | ||
163 | } | ||
164 | } | ||
165 | } | ||
166 | |||
167 | &:link, | ||
168 | &:visited, | ||
169 | &:enabled { | ||
170 | &:focus-visible { | ||
171 | background-color: fn.color(--key-focus --bg); | ||
172 | box-shadow: 0 0 0 fn.global-dim(--border --thick) fn.color(--key-focus --border); | ||
173 | color: fn.color(--key-focus --label); | ||
174 | } | ||
175 | } | ||
176 | |||
177 | @include iro.bem-modifier('pill') { | ||
178 | padding-inline: fn.dim(--pad-i-pill); | ||
179 | border-radius: 10em; | ||
180 | } | ||
181 | |||
182 | @each $size in '50' '200' '300' { | ||
183 | @include iro.bem-modifier($size) { | ||
184 | padding-block: fn.dim(--#{$size} --pad-b); | ||
185 | padding-inline: fn.dim(--#{$size} --pad-i); | ||
186 | font-size: fn.dim(--#{$size} --font-size); | ||
187 | |||
188 | @include iro.bem-modifier('pill') { | ||
189 | padding-inline: fn.dim(--#{$size} --pad-i-pill); | ||
190 | } | ||
191 | } | ||
192 | } | ||
193 | } | ||
194 | } | ||