Fix highlight display for enhanced mode
[lhc/web/wiklou.git] / resources / src / mediawiki.rcfilters / styles / mw.rcfilters.ui.ChangesListWrapperWidget.less
1 @import 'mw.rcfilters.mixins';
2
3 @keyframes fadeBlue {
4 60% {
5 border-top-color: #36c;
6 }
7 100% {
8 border-top-color: #c8ccd1;
9 }
10 }
11
12 .mw-rcfilters-ui-changesListWrapperWidget {
13
14 &-newChanges {
15 min-height: 34px;
16 margin: 8px 0 0 0;
17 text-align: center;
18 }
19
20 &-previousChangesIndicator {
21 margin: 10px 0;
22 border-top: 2px solid #c8ccd1;
23 animation: 1s ease fadeBlue;
24 }
25
26 &-results {
27 width: 35em;
28 margin: 5em auto;
29
30 &-noresult,
31 &-conflict {
32 font-weight: bold;
33 margin-bottom: 0.5em;
34 }
35 }
36
37 // Rule needs to be specific
38 // We want the expand button to appear outside the color
39 // to match the way the general highlight background appears
40 &-enhanced-grey td:not( :nth-child( -n+2 ) ) {
41 background-color: #dee0e3;
42 }
43
44 h4:first-of-type {
45 margin-top: 0;
46 padding-top: 0;
47 }
48
49 ul {
50 // Each li's margin-left should be the width of the highlights
51 // element + the margin
52 margin-left: ~'calc( ( @{result-circle-diameter} + @{result-circle-margin} ) * 5 + @{result-circle-general-margin} )';
53 }
54
55 &-highlighted {
56 ul {
57 list-style: none;
58
59 li {
60 list-style: none;
61 }
62 }
63 }
64
65 .mw-changeslist-legend {
66 background-color: #fff;
67 }
68
69 // Correction for Enhanced RC
70 // This is outside the scope of the 'highlights' wrapper
71 table.mw-enhanced-rc {
72 margin-left: ~'calc( ( @{result-circle-diameter} + @{result-circle-margin} ) * 5 + @{result-circle-general-margin} )';
73
74 td:last-child {
75 width: 100%;
76 }
77 }
78
79 &-highlights {
80 display: none;
81 padding: 0 @result-circle-general-margin 0 0;
82 text-align: right;
83 // The width is 5 circles times their diameter + individual margin
84 // and then plus the general margin
85 width: ~'calc( ( @{result-circle-diameter} + @{result-circle-margin} ) * 5 )';
86 // And we want to shift the entire block to the left of the li
87 position: relative;
88 // Negative left margin of width + padding
89 margin-left: ~'calc( ( @{result-circle-diameter} + @{result-circle-margin} ) * -5 - @{result-circle-general-margin} )';
90
91 .mw-rcfilters-ui-changesListWrapperWidget-highlighted & {
92 display: inline-block;
93 }
94
95 div {
96 .box-sizing( border-box );
97 margin-right: @result-circle-margin;
98 vertical-align: middle;
99 // This is to make the dots appear at the center of the
100 // text itself; it's a horrendous hack and blame JamesF for it.
101 margin-top: -2px;
102 }
103
104 &-color {
105
106 &-none {
107 .mw-rcfilters-mixin-circle( @highlight-none, @result-circle-diameter, 0, true );
108 display: inline-block;
109
110 .mw-rcfilters-highlight-color-c1 &,
111 .mw-rcfilters-highlight-color-c2 &,
112 .mw-rcfilters-highlight-color-c3 &,
113 .mw-rcfilters-highlight-color-c4 &,
114 .mw-rcfilters-highlight-color-c5 & {
115 display: none;
116 }
117 }
118 .result-circle( c1 );
119 .result-circle( c2 );
120 .result-circle( c3 );
121 .result-circle( c4 );
122 .result-circle( c5 );
123 }
124 }
125 }
126
127 // One color
128 .mw-rcfilters-highlight-color-c1 {
129 .highlight-changesListWrapperWidget( tint( @highlight-c1, 70% ); );
130 }
131
132 .mw-rcfilters-highlight-color-c2 {
133 .highlight-changesListWrapperWidget( tint( @highlight-c2, 70% ); );
134 }
135
136 .mw-rcfilters-highlight-color-c3 {
137 .highlight-changesListWrapperWidget( tint( @highlight-c3, 70% ); );
138 }
139
140 .mw-rcfilters-highlight-color-c4 {
141 .highlight-changesListWrapperWidget( tint( @highlight-c4, 70% ); );
142 }
143
144 .mw-rcfilters-highlight-color-c5 {
145 .highlight-changesListWrapperWidget( tint( @highlight-c5, 70% ); );
146 }
147
148 // Two colors
149 .highlight-color-mix( c1, c2 );
150 // Overriding .highlight-color-mix( c1, c3 ); to produce
151 // a custom color rather than the computed tint
152 // see https://phabricator.wikimedia.org/T161267
153 .mw-rcfilters-highlight-color-c1.mw-rcfilters-highlight-color-c3 {
154 .highlight-changesListWrapperWidget( #ccdecc );
155 }
156 .highlight-color-mix( c1, c4 );
157 .highlight-color-mix( c1, c5 );
158 .highlight-color-mix( c2, c3 );
159 .highlight-color-mix( c2, c4 );
160 .highlight-color-mix( c2, c5 );
161 .highlight-color-mix( c3, c4 );
162 .highlight-color-mix( c3, c5 );
163 .highlight-color-mix( c4, c5 );
164
165 // Three colors
166 .highlight-color-mix( c1, c2, c3 );
167 .highlight-color-mix( c1, c2, c5 );
168 .highlight-color-mix( c1, c2, c4 );
169 .highlight-color-mix( c1, c3, c4 );
170 .highlight-color-mix( c1, c3, c5 );
171 .highlight-color-mix( c1, c4, c5 );
172 .highlight-color-mix( c2, c3, c4 );
173 .highlight-color-mix( c2, c3, c5 );
174 .highlight-color-mix( c2, c4, c5 );
175 .highlight-color-mix( c3, c4, c5 );
176
177 // Four colors
178 .highlight-color-mix( c1, c2, c3, c4 );
179 .highlight-color-mix( c1, c2, c3, c5 );
180 .highlight-color-mix( c1, c2, c4, c5 );
181 .highlight-color-mix( c1, c3, c4, c5 );
182 .highlight-color-mix( c2, c3, c4, c5 );
183
184 // Five colors:
185 .mw-rcfilters-highlight-color-c1.mw-rcfilters-highlight-color-c2.mw-rcfilters-highlight-color-c3.mw-rcfilters-highlight-color-c4.mw-rcfilters-highlight-color-c5 {
186 .highlight-changesListWrapperWidget( tint( mix( @highlight-c1, mix( @highlight-c2, mix( @highlight-c3, average( @highlight-c4, @highlight-c5 ), 20% ), 20% ), 20% ), 15% ) );
187 }