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