mixins.less 30.5 KB
Newer Older
1
2
3
//
// Mixins
// --------------------------------------------------
4

5

6
7
// Utilities
// -------------------------
8
9

// Clearfix
10
11
12
13
14
15
16
17
18
// Source: http://nicolasgallagher.com/micro-clearfix-hack/
//
// For modern browsers
// 1. The space content is one way to avoid an Opera bug when the
//    contenteditable attribute is included anywhere else in the document.
//    Otherwise it causes space to appear at the top and bottom of elements
//    that are clearfixed.
// 2. The use of `table` rather than `block` is only necessary if using
//    `:before` to contain the top-margins of child elements.
19
.clearfix() {
20
  &:before,
21
  &:after {
22
23
    content: " "; // 1
    display: table; // 2
24
25
  }
  &:after {
26
    clear: both;
27
  }
28
29
}

Chris Rebert's avatar
Chris Rebert committed
30
// WebKit-style focus
Mark Otto's avatar
Mark Otto committed
31
32
.tab-focus() {
  // Default
33
  outline: thin dotted;
34
  // WebKit
Mark Otto's avatar
Mark Otto committed
35
36
37
38
  outline: 5px auto -webkit-focus-ring-color;
  outline-offset: -2px;
}

39
// Center-align a block level element
40
.center-block() {
41
  display: block;
42
43
  margin-left: auto;
  margin-right: auto;
44
45
46
}

// Sizing shortcuts
47
.size(@width; @height) {
48
  width: @width;
49
  height: @height;
50
}
51
.square(@size) {
52
  .size(@size; @size);
53
54
}

55
// Placeholder text
Mark Otto's avatar
Mark Otto committed
56
.placeholder(@color: @input-color-placeholder) {
57
  &::-moz-placeholder           { color: @color;   // Firefox
58
                                  opacity: 1; } // See https://github.com/twbs/bootstrap/pull/11526
59
60
  &:-ms-input-placeholder       { color: @color; } // Internet Explorer 10+
  &::-webkit-input-placeholder  { color: @color; } // Safari and Chrome
61
62
}

Mark Otto's avatar
Mark Otto committed
63
64
65
66
67
68
69
70
// Text overflow
// Requires inline-block or block for proper styling
.text-overflow() {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

71
// CSS image replacement
72
73
74
//
// Heads up! v3 launched with with only `.hide-text()`, but per our pattern for
// mixins being reused as classes with the same name, this doesn't hold up. As
75
76
// of v3.0.1 we have added `.text-hide()` and deprecated `.hide-text()`. Note
// that we cannot chain the mixins together in Less, so they are repeated.
77
//
78
// Source: https://github.com/h5bp/html5-boilerplate/commit/aa0396eae757
79

80
81
82
83
84
85
86
87
88
// Deprecated as of v3.0.1 (will be removed in v4)
.hide-text() {
  font: ~"0/0" a;
  color: transparent;
  text-shadow: none;
  background-color: transparent;
  border: 0;
}
// New mixin to use as of v3.0.1
89
.text-hide() {
90
  .hide-text();
91
}
92

93

94

95
96
97
// CSS3 PROPERTIES
// --------------------------------------------------

98
// Single side border-radius
99
.border-top-radius(@radius) {
100
101
  border-top-right-radius: @radius;
   border-top-left-radius: @radius;
102
103
}
.border-right-radius(@radius) {
104
105
  border-bottom-right-radius: @radius;
     border-top-right-radius: @radius;
Mark Otto's avatar
Mark Otto committed
106
107
}
.border-bottom-radius(@radius) {
108
109
  border-bottom-right-radius: @radius;
   border-bottom-left-radius: @radius;
Mark Otto's avatar
Mark Otto committed
110
111
}
.border-left-radius(@radius) {
112
113
  border-bottom-left-radius: @radius;
     border-top-left-radius: @radius;
114
115
}

116
// Drop shadows
117
118
119
120
//
// Note: Deprecated `.box-shadow()` as of v3.1.0 since all of Bootstrap's
//   supported browsers that have box shadow capabilities now support the
//   standard `box-shadow` property.
Mark Otto's avatar
Mark Otto committed
121
.box-shadow(@shadow) {
122
  -webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1
123
          box-shadow: @shadow;
124
125
126
}

// Transitions
Bas Bosman's avatar
Bas Bosman committed
127
128
//
// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Mark Otto's avatar
Mark Otto committed
129
130
.transition(@transition) {
  -webkit-transition: @transition;
Bas Bosman's avatar
Bas Bosman committed
131
       -o-transition: @transition;
Mark Otto's avatar
Mark Otto committed
132
          transition: @transition;
133
}
Bas Bosman's avatar
Bas Bosman committed
134
135

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
136
137
138
139
.transition-property(@transition-property) {
  -webkit-transition-property: @transition-property;
          transition-property: @transition-property;
}
Bas Bosman's avatar
Bas Bosman committed
140
141

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Tunghsiao Liu's avatar
Tunghsiao Liu committed
142
143
144
145
.transition-delay(@transition-delay) {
  -webkit-transition-delay: @transition-delay;
          transition-delay: @transition-delay;
}
Bas Bosman's avatar
Bas Bosman committed
146
147

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Tunghsiao Liu's avatar
Tunghsiao Liu committed
148
149
150
151
.transition-duration(@transition-duration) {
  -webkit-transition-duration: @transition-duration;
          transition-duration: @transition-duration;
}
Bas Bosman's avatar
Bas Bosman committed
152
153

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
154
.transition-timing-function(@timing-function) {
Bas Bosman's avatar
Bas Bosman committed
155
156
  -webkit-transition-timing-function: @timing-function;
          transition-timing-function: @timing-function;
157
}
Bas Bosman's avatar
Bas Bosman committed
158
159

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
160
161
162
163
164
165
.transition-transform(@transition) {
  -webkit-transition: -webkit-transform @transition;
     -moz-transition: -moz-transform @transition;
       -o-transition: -o-transform @transition;
          transition: transform @transition;
}
166

Mark Otto's avatar
Mark Otto committed
167
// Transformations
Bas Bosman's avatar
Bas Bosman committed
168
169
//
// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
170
171
172
.scale(@ratio) {
  -webkit-transform: scale(@ratio);
      -ms-transform: scale(@ratio); // IE9 only
Bas Bosman's avatar
Bas Bosman committed
173
       -o-transform: scale(@ratio);
174
175
          transform: scale(@ratio);
}
Bas Bosman's avatar
Bas Bosman committed
176
177

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
178
179
180
.scale(@ratioX; @ratioY) {
  -webkit-transform: scale(@ratioX, @ratioY);
      -ms-transform: scale(@ratioX, @ratioY); // IE9 only
Bas Bosman's avatar
Bas Bosman committed
181
       -o-transform: scale(@ratioX, @ratioY);
182
183
          transform: scale(@ratioX, @ratioY);
}
Bas Bosman's avatar
Bas Bosman committed
184
185

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
186
187
188
.scaleX(@ratio) {
  -webkit-transform: scaleX(@ratio);
      -ms-transform: scaleX(@ratio); // IE9 only
Bas Bosman's avatar
Bas Bosman committed
189
       -o-transform: scaleX(@ratio);
190
191
          transform: scaleX(@ratio);
}
Bas Bosman's avatar
Bas Bosman committed
192
193

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
194
195
196
.scaleY(@ratio) {
  -webkit-transform: scaleY(@ratio);
      -ms-transform: scaleY(@ratio); // IE9 only
Bas Bosman's avatar
Bas Bosman committed
197
       -o-transform: scaleY(@ratio);
198
          transform: scaleY(@ratio);
199
}
Bas Bosman's avatar
Bas Bosman committed
200
201

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
202
203
204
.skew(@x; @y) {
  -webkit-transform: skew(@x, @y);
      -ms-transform: skewX(@x) skewY(@y); // See https://github.com/twbs/bootstrap/issues/4885; IE9+
Bas Bosman's avatar
Bas Bosman committed
205
       -o-transform: skew(@x, @y);
206
          transform: skew(@x, @y);
207
}
Bas Bosman's avatar
Bas Bosman committed
208
209

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
210
.translate(@x; @y) {
Mark Otto's avatar
Mark Otto committed
211
  -webkit-transform: translate(@x, @y);
212
      -ms-transform: translate(@x, @y); // IE9 only
Bas Bosman's avatar
Bas Bosman committed
213
       -o-transform: translate(@x, @y);
Mark Otto's avatar
Mark Otto committed
214
215
          transform: translate(@x, @y);
}
Bas Bosman's avatar
Bas Bosman committed
216
217

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
218
.translate3d(@x; @y; @z) {
219
220
  -webkit-transform: translate3d(@x, @y, @z);
          transform: translate3d(@x, @y, @z);
221
}
Bas Bosman's avatar
Bas Bosman committed
222
223

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
224
225
226
.rotate(@degrees) {
  -webkit-transform: rotate(@degrees);
      -ms-transform: rotate(@degrees); // IE9 only
Bas Bosman's avatar
Bas Bosman committed
227
       -o-transform: rotate(@degrees);
228
229
          transform: rotate(@degrees);
}
Bas Bosman's avatar
Bas Bosman committed
230
231

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
232
233
.rotateX(@degrees) {
  -webkit-transform: rotateX(@degrees);
234
      -ms-transform: rotateX(@degrees); // IE9 only
Bas Bosman's avatar
Bas Bosman committed
235
       -o-transform: rotateX(@degrees);
236
237
          transform: rotateX(@degrees);
}
Bas Bosman's avatar
Bas Bosman committed
238
239

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
240
241
.rotateY(@degrees) {
  -webkit-transform: rotateY(@degrees);
242
      -ms-transform: rotateY(@degrees); // IE9 only
Bas Bosman's avatar
Bas Bosman committed
243
       -o-transform: rotateY(@degrees);
244
245
          transform: rotateY(@degrees);
}
Bas Bosman's avatar
Bas Bosman committed
246
247

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
248
249
250
251
252
.perspective(@perspective) {
  -webkit-perspective: @perspective;
     -moz-perspective: @perspective;
          perspective: @perspective;
}
Bas Bosman's avatar
Bas Bosman committed
253
254

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
255
256
257
258
259
.perspective-origin(@perspective) {
  -webkit-perspective-origin: @perspective;
     -moz-perspective-origin: @perspective;
          perspective-origin: @perspective;
}
Bas Bosman's avatar
Bas Bosman committed
260
261

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Zlatan Vasović's avatar
Zlatan Vasović committed
262
.transform-origin(@origin) {
263
264
  -webkit-transform-origin: @origin;
     -moz-transform-origin: @origin;
265
      -ms-transform-origin: @origin; // IE9 only
266
267
268
          transform-origin: @origin;
}

Zlatan Vasović's avatar
Zlatan Vasović committed
269
// Animations
Bas Bosman's avatar
Bas Bosman committed
270
271
//
// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Zlatan Vasović's avatar
Zlatan Vasović committed
272
273
.animation(@animation) {
  -webkit-animation: @animation;
Bas Bosman's avatar
Bas Bosman committed
274
       -o-animation: @animation;
Zlatan Vasović's avatar
Zlatan Vasović committed
275
276
          animation: @animation;
}
Bas Bosman's avatar
Bas Bosman committed
277
278

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Zlatan Vasović's avatar
Zlatan Vasović committed
279
280
281
282
.animation-name(@name) {
  -webkit-animation-name: @name;
          animation-name: @name;
}
Bas Bosman's avatar
Bas Bosman committed
283
284

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Zlatan Vasović's avatar
Zlatan Vasović committed
285
286
287
288
.animation-duration(@duration) {
  -webkit-animation-duration: @duration;
          animation-duration: @duration;
}
Bas Bosman's avatar
Bas Bosman committed
289
290

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Zlatan Vasović's avatar
Zlatan Vasović committed
291
292
293
294
.animation-timing-function(@timing-function) {
  -webkit-animation-timing-function: @timing-function;
          animation-timing-function: @timing-function;
}
Bas Bosman's avatar
Bas Bosman committed
295
296

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Zlatan Vasović's avatar
Zlatan Vasović committed
297
298
299
300
.animation-delay(@delay) {
  -webkit-animation-delay: @delay;
          animation-delay: @delay;
}
Bas Bosman's avatar
Bas Bosman committed
301
302

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Zlatan Vasović's avatar
Zlatan Vasović committed
303
304
305
306
.animation-iteration-count(@iteration-count) {
  -webkit-animation-iteration-count: @iteration-count;
          animation-iteration-count: @iteration-count;
}
Bas Bosman's avatar
Bas Bosman committed
307
308

// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
Zlatan Vasović's avatar
Zlatan Vasović committed
309
310
311
312
.animation-direction(@direction) {
  -webkit-animation-direction: @direction;
          animation-direction: @direction;
}
313
314
315
316
.animation-fill-mode(@fill-mode) {
  -webkit-animation-fill-mode: @fill-mode;
          animation-fill-mode: @fill-mode;
}
317

318
319
// Backface visibility
// Prevent browsers from flickering when using CSS 3D transforms.
Chris Rebert's avatar
Chris Rebert committed
320
// Default value is `visible`, but can be changed to `hidden`
Bas Bosman's avatar
Bas Bosman committed
321
// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
322
.backface-visibility(@visibility){
323
324
325
  -webkit-backface-visibility: @visibility;
     -moz-backface-visibility: @visibility;
          backface-visibility: @visibility;
326
327
}

328
// Box sizing
Bas Bosman's avatar
Bas Bosman committed
329
// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
330
331
332
333
334
335
.box-sizing(@boxmodel) {
  -webkit-box-sizing: @boxmodel;
     -moz-box-sizing: @boxmodel;
          box-sizing: @boxmodel;
}

336
337
// User select
// For selecting text on the page
Bas Bosman's avatar
Bas Bosman committed
338
// Deprecated as of v3.2.0 due to the introduction of autoprefixer (will be removed in v4)
339
340
341
.user-select(@select) {
  -webkit-user-select: @select;
     -moz-user-select: @select;
342
      -ms-user-select: @select; // IE10+
343
344
345
          user-select: @select;
}

346
// Resize anything
347
.resizable(@direction) {
348
349
350
351
  resize: @direction; // Options: horizontal, vertical, both
  overflow: auto; // Safari fix
}

352
// CSS3 Content Columns
353
.content-columns(@column-count; @column-gap: @grid-gutter-width) {
354
355
356
357
358
359
  -webkit-column-count: @column-count;
     -moz-column-count: @column-count;
          column-count: @column-count;
  -webkit-column-gap: @column-gap;
     -moz-column-gap: @column-gap;
          column-gap: @column-gap;
360
361
}

Synchro's avatar
Synchro committed
362
363
// Optional hyphenation
.hyphens(@mode: auto) {
Mark Otto's avatar
Mark Otto committed
364
  word-wrap: break-word;
Synchro's avatar
Synchro committed
365
366
  -webkit-hyphens: @mode;
     -moz-hyphens: @mode;
367
      -ms-hyphens: @mode; // IE10+
Synchro's avatar
Synchro committed
368
       -o-hyphens: @mode;
Synchro's avatar
Synchro committed
369
370
371
          hyphens: @mode;
}

372
// Opacity
373
.opacity(@opacity) {
374
375
  opacity: @opacity;
  // IE8 filter
376
  @opacity-ie: (@opacity * 100);
377
  filter: ~"alpha(opacity=@{opacity-ie})";
378
379
380
381
}



Mark Otto's avatar
Mark Otto committed
382
// GRADIENTS
383
384
// --------------------------------------------------

385
#gradient {
Mark Otto's avatar
Mark Otto committed
386
387
388
389
390

  // Horizontal gradient, from left to right
  //
  // Creates two color stops, start and end, by specifying a color and position for each color stop.
  // Color stops are not available in IE9 and below.
391
  .horizontal(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) {
392
    background-image: -webkit-linear-gradient(left, color-stop(@start-color @start-percent), color-stop(@end-color @end-percent)); // Safari 5.1-6, Chrome 10+
Bas Bosman's avatar
Bas Bosman committed
393
394
    background-image: -o-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // Opera 12
    background-image: linear-gradient(to right, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+
395
    background-repeat: repeat-x;
Mark Otto's avatar
Mark Otto committed
396
    filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)",argb(@start-color),argb(@end-color))); // IE9 and down
397
  }
Mark Otto's avatar
Mark Otto committed
398
399
400
401
402

  // Vertical gradient, from top to bottom
  //
  // Creates two color stops, start and end, by specifying a color and position for each color stop.
  // Color stops are not available in IE9 and below.
403
  .vertical(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) {
404
    background-image: -webkit-linear-gradient(top, @start-color @start-percent, @end-color @end-percent);  // Safari 5.1-6, Chrome 10+
Bas Bosman's avatar
Bas Bosman committed
405
    background-image: -o-linear-gradient(top, @start-color @start-percent, @end-color @end-percent);  // Opera 12
406
    background-image: linear-gradient(to bottom, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+
407
    background-repeat: repeat-x;
Mark Otto's avatar
Mark Otto committed
408
    filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)",argb(@start-color),argb(@end-color))); // IE9 and down
409
  }
Mark Otto's avatar
Mark Otto committed
410

411
  .directional(@start-color: #555; @end-color: #333; @deg: 45deg) {
412
    background-repeat: repeat-x;
413
    background-image: -webkit-linear-gradient(@deg, @start-color, @end-color); // Safari 5.1-6, Chrome 10+
Bas Bosman's avatar
Bas Bosman committed
414
    background-image: -o-linear-gradient(@deg, @start-color, @end-color); // Opera 12
415
    background-image: linear-gradient(@deg, @start-color, @end-color); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+
416
  }
417
  .horizontal-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {
Mark Otto's avatar
Mark Otto committed
418
    background-image: -webkit-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);
Bas Bosman's avatar
Bas Bosman committed
419
    background-image: -o-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);
Mark Otto's avatar
Mark Otto committed
420
    background-image: linear-gradient(to right, @start-color, @mid-color @color-stop, @end-color);
Francisco arenas's avatar
Francisco arenas committed
421
    background-repeat: no-repeat;
Mark Otto's avatar
Mark Otto committed
422
    filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)",argb(@start-color),argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback
Francisco arenas's avatar
Francisco arenas committed
423
  }
424
  .vertical-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {
Mark Otto's avatar
Mark Otto committed
425
    background-image: -webkit-linear-gradient(@start-color, @mid-color @color-stop, @end-color);
Bas Bosman's avatar
Bas Bosman committed
426
    background-image: -o-linear-gradient(@start-color, @mid-color @color-stop, @end-color);
Mark Otto's avatar
Mark Otto committed
427
    background-image: linear-gradient(@start-color, @mid-color @color-stop, @end-color);
428
    background-repeat: no-repeat;
Mark Otto's avatar
Mark Otto committed
429
    filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)",argb(@start-color),argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback
430
  }
431
  .radial(@inner-color: #555; @outer-color: #333) {
Mark Otto's avatar
Mark Otto committed
432
433
    background-image: -webkit-radial-gradient(circle, @inner-color, @outer-color);
    background-image: radial-gradient(circle, @inner-color, @outer-color);
434
435
    background-repeat: no-repeat;
  }
436
437
  .striped(@color: rgba(255,255,255,.15); @angle: 45deg) {
    background-image: -webkit-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);
Bas Bosman's avatar
Bas Bosman committed
438
    background-image: -o-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);
439
    background-image: linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);
Piotrek Okoński's avatar
Piotrek Okoński committed
440
  }
441
}
Mark Otto's avatar
Mark Otto committed
442

443
// Reset filters for IE
Mark Otto's avatar
Mark Otto committed
444
//
Mike Pagé's avatar
Mike Pagé committed
445
// When you need to remove a gradient background, do not forget to use this to reset
Mark Otto's avatar
Mark Otto committed
446
// the IE filter for IE9 and below.
447
.reset-filter() {
448
  filter: e(%("progid:DXImageTransform.Microsoft.gradient(enabled = false)"));
449
}
450

451

Mark Otto's avatar
Mark Otto committed
452

453
454
// Retina images
//
Mark Otto's avatar
Mark Otto committed
455
456
// Short retina mixin for setting background-image and -size. Note that the
// spelling of `min--moz-device-pixel-ratio` is intentional.
457

458
.img-retina(@file-1x; @file-2x; @width-1x; @height-1x) {
Mark Otto's avatar
Mark Otto committed
459
460
461
462
  background-image: url("@{file-1x}");

  @media
  only screen and (-webkit-min-device-pixel-ratio: 2),
Mark Otto's avatar
Mark Otto committed
463
  only screen and (   min--moz-device-pixel-ratio: 2),
Mark Otto's avatar
Mark Otto committed
464
465
466
467
468
469
470
  only screen and (     -o-min-device-pixel-ratio: 2/1),
  only screen and (        min-device-pixel-ratio: 2),
  only screen and (                min-resolution: 192dpi),
  only screen and (                min-resolution: 2dppx) {
    background-image: url("@{file-2x}");
    background-size: @width-1x @height-1x;
  }
Danny Keane's avatar
Danny Keane committed
471
472
}

473

474
475
476
477
// Responsive image
//
// Keep images from scaling beyond the width of their parents.

Zlatan Vasović's avatar
Zlatan Vasović committed
478
.img-responsive(@display: block) {
479
480
481
482
483
484
  display: @display;
  max-width: 100%; // Part 1: Set a maximum relative to the parent
  height: auto; // Part 2: Scale the height according to the width, otherwise you get stretching
}


485
486
487
// COMPONENT MIXINS
// --------------------------------------------------

488
// Horizontal dividers
489
490
// -------------------------
// Dividers (basically an hr) within dropdowns and nav lists
Mark Otto's avatar
Mark Otto committed
491
492
.nav-divider(@color: #e5e5e5) {
  height: 1px;
493
  margin: ((@line-height-computed / 2) - 1) 0;
Jacob Thornton's avatar
Jacob Thornton committed
494
  overflow: hidden;
Mark Otto's avatar
Mark Otto committed
495
  background-color: @color;
496
497
}

498
499
// Panels
// -------------------------
500
.panel-variant(@border; @heading-text-color; @heading-bg-color; @heading-border) {
501
  border-color: @border;
Mark Otto's avatar
spacing    
Mark Otto committed
502

503
  & > .panel-heading {
504
505
506
    color: @heading-text-color;
    background-color: @heading-bg-color;
    border-color: @heading-border;
Mark Otto's avatar
spacing    
Mark Otto committed
507

508
    + .panel-collapse > .panel-body {
Mark Otto's avatar
Mark Otto committed
509
510
511
      border-top-color: @border;
    }
  }
512
  & > .panel-footer {
513
    + .panel-collapse > .panel-body {
Mark Otto's avatar
Mark Otto committed
514
515
      border-bottom-color: @border;
    }
516
517
518
  }
}

Chris Rebert's avatar
Chris Rebert committed
519
520
// Alerts
// -------------------------
521
.alert-variant(@background; @border; @text-color) {
Chris Rebert's avatar
Chris Rebert committed
522
523
524
  background-color: @background;
  border-color: @border;
  color: @text-color;
Mark Otto's avatar
spacing    
Mark Otto committed
525

Chris Rebert's avatar
Chris Rebert committed
526
527
528
529
530
531
532
533
  hr {
    border-top-color: darken(@border, 5%);
  }
  .alert-link {
    color: darken(@text-color, 10%);
  }
}

ggam's avatar
ggam committed
534
535
// Tables
// -------------------------
Zlatan Vasović's avatar
Zlatan Vasović committed
536
.table-row-variant(@state; @background) {
ggam's avatar
ggam committed
537
538
  // Exact selectors below required to override `.table-striped` and prevent
  // inheritance to nested tables.
539
540
541
542
543
544
545
546
  .table > thead > tr,
  .table > tbody > tr,
  .table > tfoot > tr {
    > td.@{state},
    > th.@{state},
    &.@{state} > td,
    &.@{state} > th {
      background-color: @background;
ggam's avatar
ggam committed
547
548
    }
  }
549

ggam's avatar
ggam committed
550
551
  // Hover states for `.table-hover`
  // Note: this is not available for cells or rows within `thead` or `tfoot`.
552
553
554
555
556
  .table-hover > tbody > tr {
    > td.@{state}:hover,
    > th.@{state}:hover,
    &.@{state}:hover > td,
    &.@{state}:hover > th {
ggam's avatar
ggam committed
557
558
559
560
561
      background-color: darken(@background, 5%);
    }
  }
}

562
563
// List Groups
// -------------------------
Mark Otto's avatar
Mark Otto committed
564
565
566
.list-group-item-variant(@state; @background; @color) {
  .list-group-item-@{state} {
    color: @color;
567
    background-color: @background;
Mark Otto's avatar
Mark Otto committed
568

569
    a& {
Mark Otto's avatar
Mark Otto committed
570
      color: @color;
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585

      .list-group-item-heading { color: inherit; }

      &:hover,
      &:focus {
        color: @color;
        background-color: darken(@background, 5%);
      }
      &.active,
      &.active:hover,
      &.active:focus {
        color: #fff;
        background-color: @color;
        border-color: @color;
      }
Mark Otto's avatar
Mark Otto committed
586
    }
587
588
589
  }
}

590
// Button variants
591
592
593
// -------------------------
// Easily pump out default styles, as well as :hover, :focus, :active,
// and disabled options for all buttons
594
.button-variant(@color; @background; @border) {
595
  color: @color;
596
597
  background-color: @background;
  border-color: @border;
598

Mark Otto's avatar
Mark Otto committed
599
  &:hover,
600
  &:focus,
601
  &:active,
602
603
  &.active,
  .open .dropdown-toggle& {
604
    color: @color;
605
    background-color: darken(@background, 10%);
606
        border-color: darken(@border, 12%);
Mark Otto's avatar
Mark Otto committed
607
  }
608
609
610
611
612
  &:active,
  &.active,
  .open .dropdown-toggle& {
    background-image: none;
  }
613
  &.disabled,
614
  &[disabled],
615
  fieldset[disabled] & {
616
    &,
617
618
    &:hover,
    &:focus,
619
620
    &:active,
    &.active {
621
      background-color: @background;
Zlatan Vasović's avatar
Zlatan Vasović committed
622
          border-color: @border;
623
    }
624
  }
625
626
627

  .badge {
    color: @background;
628
    background-color: @color;
629
  }
630
631
}

ggam's avatar
ggam committed
632
633
634
635
636
637
638
639
640
// Button sizes
// -------------------------
.button-size(@padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {
  padding: @padding-vertical @padding-horizontal;
  font-size: @font-size;
  line-height: @line-height;
  border-radius: @border-radius;
}

ggam's avatar
ggam committed
641
642
// Pagination
// -------------------------
Guillermo González de Agüero's avatar
Guillermo González de Agüero committed
643
.pagination-size(@padding-vertical; @padding-horizontal; @font-size; @border-radius) {
ggam's avatar
ggam committed
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
  > li {
    > a,
    > span {
      padding: @padding-vertical @padding-horizontal;
      font-size: @font-size;
    }
    &:first-child {
      > a,
      > span {
        .border-left-radius(@border-radius);
      }
    }
    &:last-child {
      > a,
      > span {
        .border-right-radius(@border-radius);
      }
    }
  }
}

Chris Rebert's avatar
Chris Rebert committed
665
666
667
668
669
670
671
672
673
674
675
676
// Labels
// -------------------------
.label-variant(@color) {
  background-color: @color;
  &[href] {
    &:hover,
    &:focus {
      background-color: darken(@color, 10%);
    }
  }
}

677
678
679
680
681
682
683
684
685
// Contextual backgrounds
// -------------------------
.bg-variant(@color) {
  background-color: @color;
  a&:hover {
    background-color: darken(@color, 10%);
  }
}

686
687
688
689
// Typography
// -------------------------
.text-emphasis-variant(@color) {
  color: @color;
690
  a&:hover {
691
692
693
694
    color: darken(@color, 10%);
  }
}

695
696
697
// Navbar vertical align
// -------------------------
// Vertically center elements in the navbar.
698
// Example: an element has a height of 30px, so write out `.navbar-vertical-align(30px);` to calculate the appropriate top margin.
Mark Otto's avatar
Mark Otto committed
699
.navbar-vertical-align(@element-height) {
700
701
  margin-top: ((@navbar-height - @element-height) / 2);
  margin-bottom: ((@navbar-height - @element-height) / 2);
702
703
}

704
705
706
707
708
// Progress bars
// -------------------------
.progress-bar-variant(@color) {
  background-color: @color;
  .progress-striped & {
709
    #gradient > .striped();
710
711
712
  }
}

Mark Otto's avatar
Mark Otto committed
713
714
715
716
717
// Responsive utilities
// -------------------------
// More easily include all the states for responsive-utilities.less.
.responsive-visibility() {
  display: block !important;
718
719
  table&  { display: table; }
  tr&     { display: table-row !important; }
Mark Otto's avatar
Mark Otto committed
720
  th&,
721
  td&     { display: table-cell !important; }
Mark Otto's avatar
Mark Otto committed
722
723
}

724
.responsive-invisibility() {
Zlatan Vasović's avatar
Zlatan Vasović committed
725
  display: none !important;
726
727
}

728

729
730
731
// Grid System
// -----------

732
// Centered container element
733
734
.container-fixed() {
  margin-right: auto;
Jacob Thornton's avatar
Jacob Thornton committed
735
  margin-left: auto;
736
737
  padding-left:  (@grid-gutter-width / 2);
  padding-right: (@grid-gutter-width / 2);
738
  &:extend(.clearfix all);
739
740
}

741
// Creates a wrapper for a series of columns
742
.make-row(@gutter: @grid-gutter-width) {
743
744
  margin-left:  (@gutter / -2);
  margin-right: (@gutter / -2);
745
  &:extend(.clearfix all);
746
}
Mark Otto's avatar
Mark Otto committed
747

748
749
// Generate the extra small columns
.make-xs-column(@columns; @gutter: @grid-gutter-width) {
750
751
  position: relative;
  float: left;
752
  width: percentage((@columns / @grid-columns));
753
754
755
756
  min-height: 1px;
  padding-left:  (@gutter / 2);
  padding-right: (@gutter / 2);
}
757
.make-xs-column-offset(@columns) {
758
  margin-left: percentage((@columns / @grid-columns));
759
760
}
.make-xs-column-push(@columns) {
761
  left: percentage((@columns / @grid-columns));
762
763
}
.make-xs-column-pull(@columns) {
764
  right: percentage((@columns / @grid-columns));
765
}
766

Mark Otto's avatar
Mark Otto committed
767

768
// Generate the small columns
769
.make-sm-column(@columns; @gutter: @grid-gutter-width) {
770
  position: relative;
771
  min-height: 1px;
772
773
  padding-left:  (@gutter / 2);
  padding-right: (@gutter / 2);
774

775
  @media (min-width: @screen-sm-min) {
776
    float: left;
777
778
    width: percentage((@columns / @grid-columns));
  }
779
}
780
.make-sm-column-offset(@columns) {
781
  @media (min-width: @screen-sm-min) {
782
783
784
    margin-left: percentage((@columns / @grid-columns));
  }
}
785
.make-sm-column-push(@columns) {
786
  @media (min-width: @screen-sm-min) {
787
788
789
    left: percentage((@columns / @grid-columns));
  }
}
790
.make-sm-column-pull(@columns) {
791
  @media (min-width: @screen-sm-min) {
792
793
    right: percentage((@columns / @grid-columns));
  }
794
}
795

Mark Otto's avatar
Mark Otto committed
796

797
798
// Generate the medium columns
.make-md-column(@columns; @gutter: @grid-gutter-width) {
Bass Jobsen's avatar
Bass Jobsen committed
799
800
  position: relative;
  min-height: 1px;
801
802
  padding-left:  (@gutter / 2);
  padding-right: (@gutter / 2);
Mark Otto's avatar
Mark Otto committed
803

804
  @media (min-width: @screen-md-min) {
805
    float: left;
Bass Jobsen's avatar
Bass Jobsen committed
806
807
808
    width: percentage((@columns / @grid-columns));
  }
}
809
.make-md-column-offset(@columns) {
810
  @media (min-width: @screen-md-min) {
811
812
813
    margin-left: percentage((@columns / @grid-columns));
  }
}
814
.make-md-column-push(@columns) {
815
  @media (min-width: @screen-md-min) {
816
817
818
    left: percentage((@columns / @grid-columns));
  }
}
819
.make-md-column-pull(@columns) {
820
  @media (min-width: @screen-md-min) {
821
822
823
824
    right: percentage((@columns / @grid-columns));
  }
}

Mark Otto's avatar
Mark Otto committed
825

826
827
828
829
830
831
832
// Generate the large columns
.make-lg-column(@columns; @gutter: @grid-gutter-width) {
  position: relative;
  min-height: 1px;
  padding-left:  (@gutter / 2);
  padding-right: (@gutter / 2);

833
  @media (min-width: @screen-lg-min) {
834
835
836
837
838
    float: left;
    width: percentage((@columns / @grid-columns));
  }
}
.make-lg-column-offset(@columns) {
839
  @media (min-width: @screen-lg-min) {
840
841
842
843
    margin-left: percentage((@columns / @grid-columns));
  }
}
.make-lg-column-push(@columns) {
844
  @media (min-width: @screen-lg-min) {
845
846
847
848
    left: percentage((@columns / @grid-columns));
  }
}
.make-lg-column-pull(@columns) {
849
  @media (min-width: @screen-lg-min) {
850
851
852
853
    right: percentage((@columns / @grid-columns));
  }
}

Mark Otto's avatar
Mark Otto committed
854

855
856
857
858
859
860
861
862
863
// Framework grid generation
//
// Used only by Bootstrap to generate the correct number of grid classes given
// any value of `@grid-columns`.

.make-grid-columns() {
  // Common styles for all sizes of grid columns, widths 1-12
  .col(@index) when (@index = 1) { // initial
    @item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";
864
    .col((@index + 1), @item);
865
866
867
  }
  .col(@index, @list) when (@index =< @grid-columns) { // general; "=<" isn't a typo
    @item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";
868
    .col((@index + 1), ~"@{list}, @{item}");
869
870
871
872
873
874
875
876
877
878
879
880
881
882
  }
  .col(@index, @list) when (@index > @grid-columns) { // terminal
    @{list} {
      position: relative;
      // Prevent columns from collapsing when empty
      min-height: 1px;
      // Inner gutter via padding
      padding-left:  (@grid-gutter-width / 2);
      padding-right: (@grid-gutter-width / 2);
    }
  }
  .col(1); // kickstart it
}

883
.float-grid-columns(@class) {
884
885
  .col(@index) when (@index = 1) { // initial
    @item: ~".col-@{class}-@{index}";
886
    .col((@index + 1), @item);
887
  }
888
  .col(@index, @list) when (@index =< @grid-columns) { // general
889
    @item: ~".col-@{class}-@{index}";
890
    .col((@index + 1), ~"@{list}, @{item}");
891
  }
892
  .col(@index, @list) when (@index > @grid-columns) { // terminal
893
894
895
896
897
898
899
    @{list} {
      float: left;
    }
  }
  .col(1); // kickstart it
}

900
.calc-grid-column(@index, @class, @type) when (@type = width) and (@index > 0) {
901
902
903
904
  .col-@{class}-@{index} {
    width: percentage((@index / @grid-columns));
  }
}
905
.calc-grid-column(@index, @class, @type) when (@type = push) and (@index > 0) {
906
907
908
909
  .col-@{class}-push-@{index} {
    left: percentage((@index / @grid-columns));
  }
}
910
911
912
913
914
915
.calc-grid-column(@index, @class, @type) when (@type = push) and (@index = 0) {
  .col-@{class}-push-0 {
    left: auto;
  }
}
.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index > 0) {
916
917
918
919
  .col-@{class}-pull-@{index} {
    right: percentage((@index / @grid-columns));
  }
}
920
921
922
923
924
.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index = 0) {
  .col-@{class}-pull-0 {
    right: auto;
  }
}
925
.calc-grid-column(@index, @class, @type) when (@type = offset) {
926
927
928
929
930
931
  .col-@{class}-offset-@{index} {
    margin-left: percentage((@index / @grid-columns));
  }
}

// Basic looping in LESS
932
933
.loop-grid-columns(@index, @class, @type) when (@index >= 0) {
  .calc-grid-column(@index, @class, @type);
934
  // next iteration
935
  .loop-grid-columns((@index - 1), @class, @type);
936
937
}

938
939
940
941
942
943
944
945
// Create grid for specific class
.make-grid(@class) {
  .float-grid-columns(@class);
  .loop-grid-columns(@grid-columns, @class, width);
  .loop-grid-columns(@grid-columns, @class, pull);
  .loop-grid-columns(@grid-columns, @class, push);
  .loop-grid-columns(@grid-columns, @class, offset);
}
946

Mark Otto's avatar
Mark Otto committed
947
948
949
950
951
// Form validation states
//
// Used in forms.less to generate the form validation CSS for warnings, errors,
// and successes.

952
.form-control-validation(@text-color: #555; @border-color: #ccc; @background-color: #f5f5f5) {
Mark Otto's avatar
Mark Otto committed
953
  // Color the label and help text
954
  .help-block,
955
956
957
958
959
  .control-label,
  .radio,
  .checkbox,
  .radio-inline,
  .checkbox-inline  {
Mark Otto's avatar
Mark Otto committed
960
961
962
    color: @text-color;
  }
  // Set the border and box shadow on specific inputs to match
Mark Otto's avatar
Mark Otto committed
963
  .form-control {
Mark Otto's avatar
Mark Otto committed
964
965
966
967
968
969
970
971
    border-color: @border-color;
    .box-shadow(inset 0 1px 1px rgba(0,0,0,.075)); // Redeclare so transitions work
    &:focus {
      border-color: darken(@border-color, 10%);
      @shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 6px lighten(@border-color, 20%);
      .box-shadow(@shadow);
    }
  }
972
973
974
975
976
  // Set validation states also for addons
  .input-group-addon {
    color: @text-color;
    border-color: @border-color;
    background-color: @background-color;
Mark Otto's avatar
Mark Otto committed
977
  }
978
  // Optional feedback icon
979
980
981
  .form-control-feedback {
    color: @text-color;
  }
Mark Otto's avatar
Mark Otto committed
982
}
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000

// Form control focus state
//
// Generate a customized focus state and for any input with the specified color,
// which defaults to the `@input-focus-border` variable.
//
// We highly encourage you to not customize the default value, but instead use
// this to tweak colors on an as-needed basis. This aesthetic change is based on
// WebKit's default styles, but applicable to a wider range of browsers. Its
// usability and accessibility should be taken into account with any change.
//
// Example usage: change the default blue border and shadow to white for better
// contrast against a dark gray background.

.form-control-focus(@color: @input-border-focus) {
  @color-rgba: rgba(red(@color), green(@color), blue(@color), .6);
  &:focus {
    border-color: @color;
For faster browsing, not all history is shown. View entire blame