diff options
author | Volpeon <git@volpeon.ink> | 2025-08-13 12:01:46 +0200 |
---|---|---|
committer | Volpeon <git@volpeon.ink> | 2025-08-13 12:01:46 +0200 |
commit | f0f84513f8efe533b6ee670a6f1a0c074387b2ec (patch) | |
tree | 845bc4bacf1bd99acb0dfcc7e4545a36b544d2f8 /test/bem/_multi.scss | |
parent | More fix (diff) | |
download | iro-sass-f0f84513f8efe533b6ee670a6f1a0c074387b2ec.tar.gz iro-sass-f0f84513f8efe533b6ee670a6f1a0c074387b2ec.tar.bz2 iro-sass-f0f84513f8efe533b6ee670a6f1a0c074387b2ec.zip |
Diffstat (limited to 'test/bem/_multi.scss')
-rw-r--r-- | test/bem/_multi.scss | 948 |
1 files changed, 474 insertions, 474 deletions
diff --git a/test/bem/_multi.scss b/test/bem/_multi.scss index 255fb45..88a4cf4 100644 --- a/test/bem/_multi.scss +++ b/test/bem/_multi.scss | |||
@@ -26,569 +26,569 @@ | |||
26 | // | 26 | // |
27 | 27 | ||
28 | @include it('multi') { | 28 | @include it('multi') { |
29 | @include assert('in root, 2 blocks') { /// 1 /// | 29 | @include assert('in root, 2 blocks') { /// 1 /// |
30 | @include output { | 30 | @include output { |
31 | @include bem.multi('component:' 'block1', 'object:' 'block2') { | 31 | @include bem.multi('component:' 'block1', 'object:' 'block2') { |
32 | font-size: 1em; | 32 | font-size: 1em; |
33 | 33 | ||
34 | @include bem.elem('child2') { | 34 | @include bem.elem('child2') { |
35 | font-size: 2em; | 35 | font-size: 2em; |
36 | } | 36 | } |
37 | } | 37 | } |
38 | } | 38 | } |
39 | 39 | ||
40 | @include expect { | 40 | @include expect { |
41 | .c-block1 { | 41 | .c-block1 { |
42 | font-size: 1em; | 42 | font-size: 1em; |
43 | } | 43 | } |
44 | 44 | ||
45 | .c-block1__child2 { | 45 | .c-block1__child2 { |
46 | font-size: 2em; | 46 | font-size: 2em; |
47 | } | 47 | } |
48 | 48 | ||
49 | .o-block2 { | 49 | .o-block2 { |
50 | font-size: 1em; | 50 | font-size: 1em; |
51 | } | 51 | } |
52 | 52 | ||
53 | .o-block2__child2 { | 53 | .o-block2__child2 { |
54 | font-size: 2em; | 54 | font-size: 2em; |
55 | } | 55 | } |
56 | } | 56 | } |
57 | } | 57 | } |
58 | 58 | ||
59 | @include assert('in root, 1 block, 1 manual selector') { /// 2 /// | 59 | @include assert('in root, 1 block, 1 manual selector') { /// 2 /// |
60 | @include output { | 60 | @include output { |
61 | @include bem.multi('component:' 'block1', 'a:hover') { | 61 | @include bem.multi('component:' 'block1', 'a:hover') { |
62 | font-size: 1em; | 62 | font-size: 1em; |
63 | } | 63 | } |
64 | } | 64 | } |
65 | 65 | ||
66 | @include expect { | 66 | @include expect { |
67 | .c-block1 { | 67 | .c-block1 { |
68 | font-size: 1em; | 68 | font-size: 1em; |
69 | } | 69 | } |
70 | 70 | ||
71 | a:hover { | 71 | a:hover { |
72 | font-size: 1em; | 72 | font-size: 1em; |
73 | } | 73 | } |
74 | } | 74 | } |
75 | } | 75 | } |
76 | 76 | ||
77 | @include assert('in block, 2 elements') { /// 3 /// | 77 | @include assert('in block, 2 elements') { /// 3 /// |
78 | @include output { | 78 | @include output { |
79 | @include bem.block('something') { | 79 | @include bem.block('something') { |
80 | @include bem.multi('elem:' 'child1' 'child2') { | 80 | @include bem.multi('elem:' 'child1' 'child2') { |
81 | font-size: 2em; | 81 | font-size: 2em; |
82 | 82 | ||
83 | @include bem.modifier('mod') { | 83 | @include bem.modifier('mod') { |
84 | font-size: 2.5em; | 84 | font-size: 2.5em; |
85 | } | 85 | } |
86 | } | 86 | } |
87 | } | 87 | } |
88 | } | 88 | } |
89 | 89 | ||
90 | @include expect { | 90 | @include expect { |
91 | .something__child1, | 91 | .something__child1, |
92 | .something__child2 { | 92 | .something__child2 { |
93 | font-size: 2em; | 93 | font-size: 2em; |
94 | } | 94 | } |
95 | 95 | ||
96 | .something__child1--mod, | 96 | .something__child1--mod, |
97 | .something__child2--mod { | 97 | .something__child2--mod { |
98 | font-size: 2.5em; | 98 | font-size: 2.5em; |
99 | } | 99 | } |
100 | } | 100 | } |
101 | } | 101 | } |
102 | 102 | ||
103 | @include assert('in block, 1 element, 1 modifier') { /// 4 /// | 103 | @include assert('in block, 1 element, 1 modifier') { /// 4 /// |
104 | @include output { | 104 | @include output { |
105 | @include bem.block('something') { | 105 | @include bem.block('something') { |
106 | @include bem.multi('elem:' 'child', 'modifier:' 'mod1') { | 106 | @include bem.multi('elem:' 'child', 'modifier:' 'mod1') { |
107 | font-size: 2em; | 107 | font-size: 2em; |
108 | 108 | ||
109 | @include bem.modifier('mod2') { | 109 | @include bem.modifier('mod2') { |
110 | font-size: 2.5em; | 110 | font-size: 2.5em; |
111 | } | 111 | } |
112 | } | 112 | } |
113 | } | 113 | } |
114 | } | 114 | } |
115 | 115 | ||
116 | @include expect { | 116 | @include expect { |
117 | .something__child { | 117 | .something__child { |
118 | font-size: 2em; | 118 | font-size: 2em; |
119 | } | 119 | } |
120 | 120 | ||
121 | .something__child--mod2 { | 121 | .something__child--mod2 { |
122 | font-size: 2.5em; | 122 | font-size: 2.5em; |
123 | } | 123 | } |
124 | 124 | ||
125 | .something--mod1 { | 125 | .something--mod1 { |
126 | font-size: 2em; | 126 | font-size: 2em; |
127 | } | 127 | } |
128 | 128 | ||
129 | .something--mod1.something--mod2 { | 129 | .something--mod1.something--mod2 { |
130 | font-size: 2.5em; | 130 | font-size: 2.5em; |
131 | } | 131 | } |
132 | } | 132 | } |
133 | } | 133 | } |
134 | 134 | ||
135 | @include assert('in block, 1 element, 1 extending modifier') { /// 5 /// | 135 | @include assert('in block, 1 element, 1 extending modifier') { /// 5 /// |
136 | @include output { | 136 | @include output { |
137 | @include bem.block('something') { | 137 | @include bem.block('something') { |
138 | @include bem.multi('elem:' 'child', 'modifier:' 'mod1') { | 138 | @include bem.multi('elem:' 'child', 'modifier:' 'mod1') { |
139 | font-size: 2em; | 139 | font-size: 2em; |
140 | 140 | ||
141 | @include bem.modifier('mod2' true) { | 141 | @include bem.modifier('mod2' true) { |
142 | font-size: 2.5em; | 142 | font-size: 2.5em; |
143 | } | 143 | } |
144 | } | 144 | } |
145 | } | 145 | } |
146 | } | 146 | } |
147 | 147 | ||
148 | @include expect { | 148 | @include expect { |
149 | .something__child { | 149 | .something__child { |
150 | font-size: 2em; | 150 | font-size: 2em; |
151 | } | 151 | } |
152 | 152 | ||
153 | .something__child--mod2 { | 153 | .something__child--mod2 { |
154 | font-size: 2.5em; | 154 | font-size: 2.5em; |
155 | } | 155 | } |
156 | 156 | ||
157 | .something--mod1 { | 157 | .something--mod1 { |
158 | font-size: 2em; | 158 | font-size: 2em; |
159 | } | 159 | } |
160 | 160 | ||
161 | .something--mod1--mod2 { | 161 | .something--mod1--mod2 { |
162 | font-size: 2.5em; | 162 | font-size: 2.5em; |
163 | } | 163 | } |
164 | } | 164 | } |
165 | } | 165 | } |
166 | 166 | ||
167 | @include assert('in block, 1 element, 1 & selector') { /// 6 /// | 167 | @include assert('in block, 1 element, 1 & selector') { /// 6 /// |
168 | @include output { | 168 | @include output { |
169 | @include bem.block('something') { | 169 | @include bem.block('something') { |
170 | @include bem.multi('&', 'elem:' 'child') { | 170 | @include bem.multi('&', 'elem:' 'child') { |
171 | font-size: 2em; | 171 | font-size: 2em; |
172 | 172 | ||
173 | @include bem.modifier('mod') { | 173 | @include bem.modifier('mod') { |
174 | font-size: 2.5em; | 174 | font-size: 2.5em; |
175 | } | 175 | } |
176 | } | 176 | } |
177 | } | 177 | } |
178 | } | 178 | } |
179 | 179 | ||
180 | @include expect { | 180 | @include expect { |
181 | .something { | 181 | .something { |
182 | font-size: 2em; | 182 | font-size: 2em; |
183 | } | 183 | } |
184 | 184 | ||
185 | .something--mod { | 185 | .something--mod { |
186 | font-size: 2.5em; | 186 | font-size: 2.5em; |
187 | } | 187 | } |
188 | 188 | ||
189 | .something__child { | 189 | .something__child { |
190 | font-size: 2em; | 190 | font-size: 2em; |
191 | } | 191 | } |
192 | 192 | ||
193 | .something__child--mod { | 193 | .something__child--mod { |
194 | font-size: 2.5em; | 194 | font-size: 2.5em; |
195 | } | 195 | } |
196 | } | 196 | } |
197 | } | 197 | } |
198 | 198 | ||
199 | @include assert('in block, 1 element, 1 manual selector') { /// 7 /// | 199 | @include assert('in block, 1 element, 1 manual selector') { /// 7 /// |
200 | @include output { | 200 | @include output { |
201 | @include bem.block('something') { | 201 | @include bem.block('something') { |
202 | @include bem.multi('> a:hover', 'elem:' 'child1') { | 202 | @include bem.multi('> a:hover', 'elem:' 'child1') { |
203 | font-size: 2em; | 203 | font-size: 2em; |
204 | 204 | ||
205 | @include bem.elem('child2') { | 205 | @include bem.elem('child2') { |
206 | font-size: 3em; | 206 | font-size: 3em; |
207 | } | 207 | } |
208 | } | 208 | } |
209 | } | 209 | } |
210 | } | 210 | } |
211 | 211 | ||
212 | @include expect { | 212 | @include expect { |
213 | .something > a:hover { | 213 | .something > a:hover { |
214 | font-size: 2em; | 214 | font-size: 2em; |
215 | } | 215 | } |
216 | 216 | ||
217 | .something > a:hover .something__child2 { | 217 | .something > a:hover .something__child2 { |
218 | font-size: 3em; | 218 | font-size: 3em; |
219 | } | 219 | } |
220 | 220 | ||
221 | .something__child1 { | 221 | .something__child1 { |
222 | font-size: 2em; | 222 | font-size: 2em; |
223 | } | 223 | } |
224 | 224 | ||
225 | .something__child1 .something__child2 { | 225 | .something__child1 .something__child2 { |
226 | font-size: 3em; | 226 | font-size: 3em; |
227 | } | 227 | } |
228 | } | 228 | } |
229 | } | 229 | } |
230 | 230 | ||
231 | @include assert('in element, 2 elements, 1 modifier') { /// 8 /// | 231 | @include assert('in element, 2 elements, 1 modifier') { /// 8 /// |
232 | @include output { | 232 | @include output { |
233 | @include bem.block('something') { | 233 | @include bem.block('something') { |
234 | @include bem.elem('child') { | 234 | @include bem.elem('child') { |
235 | @include bem.multi('elem:' 'subchild1' 'subchild2', 'modifier:' 'mod1') { | 235 | @include bem.multi('elem:' 'subchild1' 'subchild2', 'modifier:' 'mod1') { |
236 | font-size: 3em; | 236 | font-size: 3em; |
237 | 237 | ||
238 | @include bem.modifier('mod2') { | 238 | @include bem.modifier('mod2') { |
239 | font-size: 3.5em; | 239 | font-size: 3.5em; |
240 | } | 240 | } |
241 | } | 241 | } |
242 | } | 242 | } |
243 | } | 243 | } |
244 | } | 244 | } |
245 | 245 | ||
246 | @include expect { | 246 | @include expect { |
247 | .something__child .something__subchild1, | 247 | .something__child .something__subchild1, |
248 | .something__child .something__subchild2 { | 248 | .something__child .something__subchild2 { |
249 | font-size: 3em; | 249 | font-size: 3em; |
250 | } | 250 | } |
251 | 251 | ||
252 | .something__child .something__subchild1--mod2, | 252 | .something__child .something__subchild1--mod2, |
253 | .something__child .something__subchild2--mod2 { | 253 | .something__child .something__subchild2--mod2 { |
254 | font-size: 3.5em; | 254 | font-size: 3.5em; |
255 | } | 255 | } |
256 | 256 | ||
257 | .something__child--mod1 { | 257 | .something__child--mod1 { |
258 | font-size: 3em; | 258 | font-size: 3em; |
259 | } | 259 | } |
260 | 260 | ||
261 | .something__child--mod1.something__child--mod2 { | 261 | .something__child--mod1.something__child--mod2 { |
262 | font-size: 3.5em; | 262 | font-size: 3.5em; |
263 | } | 263 | } |
264 | } | 264 | } |
265 | } | 265 | } |
266 | 266 | ||
267 | @include assert('in element, 1 element, 1 & selector') { /// 9 /// | 267 | @include assert('in element, 1 element, 1 & selector') { /// 9 /// |
268 | @include output { | 268 | @include output { |
269 | @include bem.block('something') { | 269 | @include bem.block('something') { |
270 | @include bem.elem('child') { | 270 | @include bem.elem('child') { |
271 | @include bem.multi('elem:' 'subchild', '&') { | 271 | @include bem.multi('elem:' 'subchild', '&') { |
272 | font-size: 3em; | 272 | font-size: 3em; |
273 | 273 | ||
274 | @include bem.modifier('mod') { | 274 | @include bem.modifier('mod') { |
275 | font-size: 3.5em; | 275 | font-size: 3.5em; |
276 | } | 276 | } |
277 | } | 277 | } |
278 | } | 278 | } |
279 | } | 279 | } |
280 | } | 280 | } |
281 | 281 | ||
282 | @include expect { | 282 | @include expect { |
283 | .something__child .something__subchild { | 283 | .something__child .something__subchild { |
284 | font-size: 3em; | 284 | font-size: 3em; |
285 | } | 285 | } |
286 | 286 | ||
287 | .something__child .something__subchild--mod { | 287 | .something__child .something__subchild--mod { |
288 | font-size: 3.5em; | 288 | font-size: 3.5em; |
289 | } | 289 | } |
290 | 290 | ||
291 | .something__child { | 291 | .something__child { |
292 | font-size: 3em; | 292 | font-size: 3em; |
293 | } | 293 | } |
294 | 294 | ||
295 | .something__child--mod { | 295 | .something__child--mod { |
296 | font-size: 3.5em; | 296 | font-size: 3.5em; |
297 | } | 297 | } |
298 | } | 298 | } |
299 | } | 299 | } |
300 | 300 | ||
301 | @include assert('in element in manual selector, 2 elements') { /// 10 /// | 301 | @include assert('in element in manual selector, 2 elements') { /// 10 /// |
302 | @include output { | 302 | @include output { |
303 | @include bem.block('something') { | 303 | @include bem.block('something') { |
304 | @include bem.elem('child') { | 304 | @include bem.elem('child') { |
305 | &:hover { | 305 | &:hover { |
306 | @include bem.multi('elem:' 'subchild1' 'subchild2') { | 306 | @include bem.multi('elem:' 'subchild1' 'subchild2') { |
307 | font-size: 3em; | 307 | font-size: 3em; |
308 | 308 | ||
309 | @include bem.modifier('mod2') { | 309 | @include bem.modifier('mod2') { |
310 | font-size: 3.5em; | 310 | font-size: 3.5em; |
311 | } | 311 | } |
312 | } | 312 | } |
313 | } | 313 | } |
314 | } | 314 | } |
315 | } | 315 | } |
316 | } | 316 | } |
317 | 317 | ||
318 | @include expect { | 318 | @include expect { |
319 | .something__child:hover .something__subchild1, | 319 | .something__child:hover .something__subchild1, |
320 | .something__child:hover .something__subchild2 { | 320 | .something__child:hover .something__subchild2 { |
321 | font-size: 3em; | 321 | font-size: 3em; |
322 | } | 322 | } |
323 | 323 | ||
324 | .something__child:hover .something__subchild1--mod2, | 324 | .something__child:hover .something__subchild1--mod2, |
325 | .something__child:hover .something__subchild2--mod2 { | 325 | .something__child:hover .something__subchild2--mod2 { |
326 | font-size: 3.5em; | 326 | font-size: 3.5em; |
327 | } | 327 | } |
328 | } | 328 | } |
329 | } | 329 | } |
330 | 330 | ||
331 | @include assert('in element in manual selector, 1 element, 1 & selector') { /// 11 /// | 331 | @include assert('in element in manual selector, 1 element, 1 & selector') { /// 11 /// |
332 | @include output { | 332 | @include output { |
333 | @include bem.block('something') { | 333 | @include bem.block('something') { |
334 | @include bem.elem('child') { | 334 | @include bem.elem('child') { |
335 | &:hover { | 335 | &:hover { |
336 | @include bem.multi('elem:' 'subchild', '&') { | 336 | @include bem.multi('elem:' 'subchild', '&') { |
337 | font-size: 3em; | 337 | font-size: 3em; |
338 | } | 338 | } |
339 | } | 339 | } |
340 | } | 340 | } |
341 | } | 341 | } |
342 | } | 342 | } |
343 | 343 | ||
344 | @include expect { | 344 | @include expect { |
345 | .something__child:hover .something__subchild { | 345 | .something__child:hover .something__subchild { |
346 | font-size: 3em; | 346 | font-size: 3em; |
347 | } | 347 | } |
348 | 348 | ||
349 | .something__child:hover { | 349 | .something__child:hover { |
350 | font-size: 3em; | 350 | font-size: 3em; |
351 | } | 351 | } |
352 | } | 352 | } |
353 | } | 353 | } |
354 | 354 | ||
355 | @include assert('in multiple elements, 2 elements, 1 modifier') { /// 12 /// | 355 | @include assert('in multiple elements, 2 elements, 1 modifier') { /// 12 /// |
356 | @include output { | 356 | @include output { |
357 | @include bem.block('something') { | 357 | @include bem.block('something') { |
358 | @include bem.elem('child1', 'child2') { | 358 | @include bem.elem('child1', 'child2') { |
359 | @include bem.multi('elem:' 'subchild1' 'subchild2', 'modifier:' 'mod') { | 359 | @include bem.multi('elem:' 'subchild1' 'subchild2', 'modifier:' 'mod') { |
360 | font-size: 3em; | 360 | font-size: 3em; |
361 | } | 361 | } |
362 | } | 362 | } |
363 | } | 363 | } |
364 | } | 364 | } |
365 | 365 | ||
366 | @include expect { | 366 | @include expect { |
367 | .something__child1 .something__subchild1, | 367 | .something__child1 .something__subchild1, |
368 | .something__child2 .something__subchild1, | 368 | .something__child2 .something__subchild1, |
369 | .something__child1 .something__subchild2, | 369 | .something__child1 .something__subchild2, |
370 | .something__child2 .something__subchild2 { | 370 | .something__child2 .something__subchild2 { |
371 | font-size: 3em; | 371 | font-size: 3em; |
372 | } | 372 | } |
373 | 373 | ||
374 | .something__child1--mod, | 374 | .something__child1--mod, |
375 | .something__child2--mod { | 375 | .something__child2--mod { |
376 | font-size: 3em; | 376 | font-size: 3em; |
377 | } | 377 | } |
378 | } | 378 | } |
379 | } | 379 | } |
380 | 380 | ||
381 | @include assert('in multiple elements, 1 element, 1 & selector') { /// 13 /// | 381 | @include assert('in multiple elements, 1 element, 1 & selector') { /// 13 /// |
382 | @include output { | 382 | @include output { |
383 | @include bem.block('something') { | 383 | @include bem.block('something') { |
384 | @include bem.elem('child1', 'child2') { | 384 | @include bem.elem('child1', 'child2') { |
385 | @include bem.multi('elem:' 'subchild', '&') { | 385 | @include bem.multi('elem:' 'subchild', '&') { |
386 | font-size: 3em; | 386 | font-size: 3em; |
387 | 387 | ||
388 | @include bem.modifier('mod') { | 388 | @include bem.modifier('mod') { |
389 | font-size: 3.5em; | 389 | font-size: 3.5em; |
390 | } | 390 | } |
391 | } | 391 | } |
392 | } | 392 | } |
393 | } | 393 | } |
394 | } | 394 | } |
395 | 395 | ||
396 | @include expect { | 396 | @include expect { |
397 | .something__child1 .something__subchild, | 397 | .something__child1 .something__subchild, |
398 | .something__child2 .something__subchild { | 398 | .something__child2 .something__subchild { |
399 | font-size: 3em; | 399 | font-size: 3em; |
400 | } | 400 | } |
401 | 401 | ||
402 | .something__child1 .something__subchild--mod, | 402 | .something__child1 .something__subchild--mod, |
403 | .something__child2 .something__subchild--mod { | 403 | .something__child2 .something__subchild--mod { |
404 | font-size: 3.5em; | 404 | font-size: 3.5em; |
405 | } | 405 | } |
406 | 406 | ||
407 | .something__child1, | 407 | .something__child1, |
408 | .something__child2 { | 408 | .something__child2 { |
409 | font-size: 3em; | 409 | font-size: 3em; |
410 | } | 410 | } |
411 | 411 | ||
412 | .something__child1--mod, | 412 | .something__child1--mod, |
413 | .something__child2--mod { | 413 | .something__child2--mod { |
414 | font-size: 3.5em; | 414 | font-size: 3.5em; |
415 | } | 415 | } |
416 | } | 416 | } |
417 | } | 417 | } |
418 | 418 | ||
419 | @include assert('in related elements, 2 elements, 1 modifier') { /// 14 /// | 419 | @include assert('in related elements, 2 elements, 1 modifier') { /// 14 /// |
420 | @include output { | 420 | @include output { |
421 | @include bem.block('something') { | 421 | @include bem.block('something') { |
422 | @include bem.elem('child1') { | 422 | @include bem.elem('child1') { |
423 | @include bem.next-elem('child2', 'child3') { | 423 | @include bem.next-elem('child2', 'child3') { |
424 | @include bem.multi('elem:' 'subchild1' 'subchild2', 'modifier:' 'mod') { | 424 | @include bem.multi('elem:' 'subchild1' 'subchild2', 'modifier:' 'mod') { |
425 | font-size: 3em; | 425 | font-size: 3em; |
426 | } | 426 | } |
427 | } | 427 | } |
428 | } | 428 | } |
429 | } | 429 | } |
430 | } | 430 | } |
431 | 431 | ||
432 | @include expect { | 432 | @include expect { |
433 | .something__child1 + .something__child2 .something__subchild1, | 433 | .something__child1 + .something__child2 .something__subchild1, |
434 | .something__child1 + .something__child3 .something__subchild1, | 434 | .something__child1 + .something__child3 .something__subchild1, |
435 | .something__child1 + .something__child2 .something__subchild2, | 435 | .something__child1 + .something__child2 .something__subchild2, |
436 | .something__child1 + .something__child3 .something__subchild2 { | 436 | .something__child1 + .something__child3 .something__subchild2 { |
437 | font-size: 3em; | 437 | font-size: 3em; |
438 | } | 438 | } |
439 | 439 | ||
440 | .something__child1 + .something__child2--mod, | 440 | .something__child1 + .something__child2--mod, |
441 | .something__child1 + .something__child3--mod { | 441 | .something__child1 + .something__child3--mod { |
442 | font-size: 3em; | 442 | font-size: 3em; |
443 | } | 443 | } |
444 | } | 444 | } |
445 | } | 445 | } |
446 | 446 | ||
447 | @include assert('in related elements, 1 element, 1 & selector') { /// 15 /// | 447 | @include assert('in related elements, 1 element, 1 & selector') { /// 15 /// |
448 | @include output { | 448 | @include output { |
449 | @include bem.block('something') { | 449 | @include bem.block('something') { |
450 | @include bem.elem('child1') { | 450 | @include bem.elem('child1') { |
451 | @include bem.next-elem('child2', 'child3') { | 451 | @include bem.next-elem('child2', 'child3') { |
452 | @include bem.multi('elem:' 'subchild', '&') { | 452 | @include bem.multi('elem:' 'subchild', '&') { |
453 | font-size: 4em; | 453 | font-size: 4em; |
454 | 454 | ||
455 | @include bem.modifier('mod') { | 455 | @include bem.modifier('mod') { |
456 | font-size: 4.5em; | 456 | font-size: 4.5em; |
457 | } | 457 | } |
458 | } | 458 | } |
459 | } | 459 | } |
460 | } | 460 | } |
461 | } | 461 | } |
462 | } | 462 | } |
463 | 463 | ||
464 | @include expect { | 464 | @include expect { |
465 | .something__child1 + .something__child2 .something__subchild, | 465 | .something__child1 + .something__child2 .something__subchild, |
466 | .something__child1 + .something__child3 .something__subchild { | 466 | .something__child1 + .something__child3 .something__subchild { |
467 | font-size: 4em; | 467 | font-size: 4em; |
468 | } | 468 | } |
469 | 469 | ||
470 | .something__child1 + .something__child2 .something__subchild--mod, | 470 | .something__child1 + .something__child2 .something__subchild--mod, |
471 | .something__child1 + .something__child3 .something__subchild--mod { | 471 | .something__child1 + .something__child3 .something__subchild--mod { |
472 | font-size: 4.5em; | 472 | font-size: 4.5em; |
473 | } | 473 | } |
474 | 474 | ||
475 | .something__child1 + .something__child2, | 475 | .something__child1 + .something__child2, |
476 | .something__child1 + .something__child3 { | 476 | .something__child1 + .something__child3 { |
477 | font-size: 4em; | 477 | font-size: 4em; |
478 | } | 478 | } |
479 | 479 | ||
480 | .something__child1 + .something__child2--mod, | 480 | .something__child1 + .something__child2--mod, |
481 | .something__child1 + .something__child3--mod { | 481 | .something__child1 + .something__child3--mod { |
482 | font-size: 4.5em; | 482 | font-size: 4.5em; |
483 | } | 483 | } |
484 | } | 484 | } |
485 | } | 485 | } |
486 | 486 | ||
487 | @include assert('in element, 2 related elements, 1 modifier') { /// 16 /// | 487 | @include assert('in element, 2 related elements, 1 modifier') { /// 16 /// |
488 | @include output { | 488 | @include output { |
489 | @include bem.block('something') { | 489 | @include bem.block('something') { |
490 | @include bem.elem('child1') { | 490 | @include bem.elem('child1') { |
491 | @include bem.multi('next-elem:' 'child2' 'child3', 'modifier:' 'mod1') { | 491 | @include bem.multi('next-elem:' 'child2' 'child3', 'modifier:' 'mod1') { |
492 | font-size: 3em; | 492 | font-size: 3em; |
493 | 493 | ||
494 | @include bem.modifier('mod2') { | 494 | @include bem.modifier('mod2') { |
495 | font-size: 3.5em; | 495 | font-size: 3.5em; |
496 | } | 496 | } |
497 | } | 497 | } |
498 | } | 498 | } |
499 | } | 499 | } |
500 | } | 500 | } |
501 | 501 | ||
502 | @include expect { | 502 | @include expect { |
503 | .something__child1 + .something__child2, | 503 | .something__child1 + .something__child2, |
504 | .something__child1 + .something__child3 { | 504 | .something__child1 + .something__child3 { |
505 | font-size: 3em; | 505 | font-size: 3em; |
506 | } | 506 | } |
507 | 507 | ||
508 | .something__child1 + .something__child2--mod2, | 508 | .something__child1 + .something__child2--mod2, |
509 | .something__child1 + .something__child3--mod2 { | 509 | .something__child1 + .something__child3--mod2 { |
510 | font-size: 3.5em; | 510 | font-size: 3.5em; |
511 | } | 511 | } |
512 | 512 | ||
513 | .something__child1--mod1 { | 513 | .something__child1--mod1 { |
514 | font-size: 3em; | 514 | font-size: 3em; |
515 | } | 515 | } |
516 | 516 | ||
517 | .something__child1--mod1.something__child1--mod2 { | 517 | .something__child1--mod1.something__child1--mod2 { |
518 | font-size: 3.5em; | 518 | font-size: 3.5em; |
519 | } | 519 | } |
520 | } | 520 | } |
521 | } | 521 | } |
522 | 522 | ||
523 | @include assert('in element, 1 twin element, 1 modifier') { /// 17 /// | 523 | @include assert('in element, 1 twin element, 1 modifier') { /// 17 /// |
524 | @include output { | 524 | @include output { |
525 | @include bem.block('something') { | 525 | @include bem.block('something') { |
526 | @include bem.elem('child') { | 526 | @include bem.elem('child') { |
527 | @include bem.multi('next-twin-elem', 'modifier:' 'mod1') { | 527 | @include bem.multi('next-twin-elem', 'modifier:' 'mod1') { |
528 | font-size: 3em; | 528 | font-size: 3em; |
529 | 529 | ||
530 | @include bem.modifier('mod2') { | 530 | @include bem.modifier('mod2') { |
531 | font-size: 3.5em; | 531 | font-size: 3.5em; |
532 | } | 532 | } |
533 | } | 533 | } |
534 | } | 534 | } |
535 | } | 535 | } |
536 | } | 536 | } |
537 | 537 | ||
538 | @include expect { | 538 | @include expect { |
539 | .something__child + .something__child { | 539 | .something__child + .something__child { |
540 | font-size: 3em; | 540 | font-size: 3em; |
541 | } | 541 | } |
542 | 542 | ||
543 | .something__child + .something__child--mod2 { | 543 | .something__child + .something__child--mod2 { |
544 | font-size: 3.5em; | 544 | font-size: 3.5em; |
545 | } | 545 | } |
546 | 546 | ||
547 | .something__child--mod1 { | 547 | .something__child--mod1 { |
548 | font-size: 3em; | 548 | font-size: 3em; |
549 | } | 549 | } |
550 | 550 | ||
551 | .something__child--mod1.something__child--mod2 { | 551 | .something__child--mod1.something__child--mod2 { |
552 | font-size: 3.5em; | 552 | font-size: 3.5em; |
553 | } | 553 | } |
554 | } | 554 | } |
555 | } | 555 | } |
556 | 556 | ||
557 | @include assert('in multiple elements, 1 twin element, 1 modifier') { /// 18 /// | 557 | @include assert('in multiple elements, 1 twin element, 1 modifier') { /// 18 /// |
558 | @include output { | 558 | @include output { |
559 | @include bem.block('something') { | 559 | @include bem.block('something') { |
560 | @include bem.elem('child1', 'child2') { | 560 | @include bem.elem('child1', 'child2') { |
561 | @include bem.multi('next-twin-elem', 'modifier:' 'mod1') { | 561 | @include bem.multi('next-twin-elem', 'modifier:' 'mod1') { |
562 | font-size: 3em; | 562 | font-size: 3em; |
563 | 563 | ||
564 | @include bem.modifier('mod2') { | 564 | @include bem.modifier('mod2') { |
565 | font-size: 3.5em; | 565 | font-size: 3.5em; |
566 | } | 566 | } |
567 | } | 567 | } |
568 | } | 568 | } |
569 | } | 569 | } |
570 | } | 570 | } |
571 | 571 | ||
572 | @include expect { | 572 | @include expect { |
573 | .something__child1 + .something__child1, | 573 | .something__child1 + .something__child1, |
574 | .something__child2 + .something__child2 { | 574 | .something__child2 + .something__child2 { |
575 | font-size: 3em; | 575 | font-size: 3em; |
576 | } | 576 | } |
577 | 577 | ||
578 | .something__child1 + .something__child1--mod2, | 578 | .something__child1 + .something__child1--mod2, |
579 | .something__child2 + .something__child2--mod2 { | 579 | .something__child2 + .something__child2--mod2 { |
580 | font-size: 3.5em; | 580 | font-size: 3.5em; |
581 | } | 581 | } |
582 | 582 | ||
583 | .something__child1--mod1, | 583 | .something__child1--mod1, |
584 | .something__child2--mod1 { | 584 | .something__child2--mod1 { |
585 | font-size: 3em; | 585 | font-size: 3em; |
586 | } | 586 | } |
587 | 587 | ||
588 | .something__child1--mod1.something__child1--mod2, | 588 | .something__child1--mod1.something__child1--mod2, |
589 | .something__child2--mod1.something__child2--mod2 { | 589 | .something__child2--mod1.something__child2--mod2 { |
590 | font-size: 3.5em; | 590 | font-size: 3.5em; |
591 | } | 591 | } |
592 | } | 592 | } |
593 | } | 593 | } |
594 | } | 594 | } |