buttons.less 3.92 KB
Newer Older
1
2
3
//
// Buttons
// --------------------------------------------------
4

5
6

// Base styles
Mark Otto's avatar
Mark Otto committed
7
// --------------------------------------------------
8

Mark Otto's avatar
Mark Otto committed
9
10
11
// Core styles
.btn {
  display: inline-block;
Mark Otto's avatar
Mark Otto committed
12
  padding: 6px 12px;
Mark Otto's avatar
Mark Otto committed
13
14
  margin-bottom: 0; // For input.btn
  font-size: @font-size-base;
Mark Otto's avatar
Mark Otto committed
15
  font-weight: bold;
Mark Otto's avatar
Mark Otto committed
16
  line-height: @line-height-base;
Mark Otto's avatar
Mark Otto committed
17
  text-align: center;
Mark Otto's avatar
Mark Otto committed
18
19
  vertical-align: middle;
  cursor: pointer;
Mark Otto's avatar
Mark Otto committed
20
  border: 1px solid @btn-border;
Mark Otto's avatar
Mark Otto committed
21
22
23
24
25
26
27
  border-radius: @border-radius-base;

  &:focus {
    .tab-focus();
  }

  &:hover {
28
    color: #fff;
Mark Otto's avatar
Mark Otto committed
29
30
31
32
33
34
    text-decoration: none;
  }

  &:active,
  &.active {
    outline: 0;
Mark Otto's avatar
Mark Otto committed
35
    background-image: none;
Mark Otto's avatar
Mark Otto committed
36
    .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));
Mark Otto's avatar
Mark Otto committed
37
38
39
  }

  &.disabled,
40
41
  &[disabled],
  fieldset[disabled] & {
Mark Otto's avatar
Mark Otto committed
42
43
44
45
46
47
48
    cursor: default;
    .opacity(65);
    .box-shadow(none);
  }

}

Mark Otto's avatar
Mark Otto committed
49
50

// Button Sizes
51
// -------------------------
Mark Otto's avatar
Mark Otto committed
52
53

// Large
54
.btn-large {
55
56
57
  padding: @padding-large;
  font-size: @font-size-large;
  border-radius: @border-radius-large;
Mark Otto's avatar
Mark Otto committed
58
59
60
}

// Small
61
.btn-small {
62
63
64
  padding: @padding-small;
  font-size: @font-size-small;
  border-radius: @border-radius-small;
Mark Otto's avatar
Mark Otto committed
65
}
66
67
68
69
.btn-mini [class^="icon-"],
.btn-mini [class*=" icon-"] {
  margin-top: -1px;
}
Mark Otto's avatar
Mark Otto committed
70

Mark Otto's avatar
Mark Otto committed
71
72
// Mini
.btn-mini {
73
74
75
  padding: @padding-mini;
  font-size: @font-size-mini;
  border-radius: @border-radius-small;
Mark Otto's avatar
Mark Otto committed
76
77
}

78

79
80
81
// Icons in buttons
// -------------------------

82
83
84
.btn [class^="glyphicon-"]::before       { vertical-align: -2px; }
.btn-small [class^="glyphicon-"]::before,
.btn-mini [class^="glyphicon-"]::before  { vertical-align: -1px; }
85
86


87
// Block button
88
89
// -------------------------

90
91
92
93
94
95
96
.btn-block {
  display: block;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
  .box-sizing(border-box);
}
97
98

// Vertically space out multiple block buttons
Mark Otto's avatar
Mark Otto committed
99
100
101
.btn-block + .btn-block {
  margin-top: 5px;
}
102

103
104
105
106
107
108
109
110
111
112
// Specificity overrides
input[type="submit"],
input[type="reset"],
input[type="button"] {
  &.btn-block {
    width: 100%;
  }
}


Mark Otto's avatar
Mark Otto committed
113
114
115
116

// Alternate buttons
// --------------------------------------------------

117
.btn {
Mark Otto's avatar
Mark Otto committed
118
  color: #fff;
Mark Otto's avatar
Mark Otto committed
119
120
121
122
123
124
125
126
  background-color: @btn-background;
  border-color: @btn-border;
  &:hover,
  &:focus,
  &:active {
    background-color: darken(@btn-background, 5%);
        border-color: darken(@btn-border, 10%);
  }
127
128
}
// Primary appears as blue
129
.btn-primary {
Mark Otto's avatar
Mark Otto committed
130
  background-color: @btn-background-primary;
Mark Otto's avatar
Mark Otto committed
131
132
133
134
135
136
137
      border-color: @btn-border-primary;
  &:hover,
  &:focus,
  &:active {
    background-color: darken(@btn-background-primary, 5%);
        border-color: darken(@btn-border-primary, 10%);
  }
138
}
Mark Otto's avatar
Mark Otto committed
139
// Warning appears are orange
140
.btn-warning {
Mark Otto's avatar
Mark Otto committed
141
  background-color: @btn-background-warning;
Mark Otto's avatar
Mark Otto committed
142
143
144
145
146
147
148
      border-color: @btn-border-warning;
  &:hover,
  &:focus,
  &:active {
    background-color: darken(@btn-background-warning, 5%);
        border-color: darken(@btn-border-warning, 10%);
  }
Mark Otto's avatar
Mark Otto committed
149
150
}
// Danger and error appear as red
151
.btn-danger {
Mark Otto's avatar
Mark Otto committed
152
  background-color: @btn-background-danger;
Mark Otto's avatar
Mark Otto committed
153
154
155
156
157
158
159
      border-color: @btn-border-danger;
  &:hover,
  &:focus,
  &:active {
    background-color: darken(@btn-background-danger, 5%);
        border-color: darken(@btn-border-danger, 10%);
  }
Mark Otto's avatar
Mark Otto committed
160
161
}
// Success appears as green
162
.btn-success {
Mark Otto's avatar
Mark Otto committed
163
  background-color: @btn-background-success;
Mark Otto's avatar
Mark Otto committed
164
165
166
167
168
169
170
      border-color: @btn-border-success;
  &:hover,
  &:focus,
  &:active {
    background-color: darken(@btn-background-success, 5%);
        border-color: darken(@btn-border-success, 10%);
  }
Mark Otto's avatar
Mark Otto committed
171
172
}

173
174
175
176
177

// Link buttons
// --------------------------------------------------

// Make a button look and behave like a link
178
.btn-link,
179
.btn-link:active,
180
181
.btn-link[disabled],
fieldset[disabled] .btn-link {
182
183
  background-color: transparent;
  background-image: none;
184
  .box-shadow(none);
185
186
}
.btn-link {
Mark Otto's avatar
Mark Otto committed
187
  color: @link-color;
Mark Otto's avatar
Mark Otto committed
188
189
190
  font-weight: normal;
  cursor: pointer;
  border-color: transparent;
191
  border-radius: 0;
192
193
}
.btn-link:hover {
Mark Otto's avatar
Mark Otto committed
194
  color: @link-color-hover;
195
196
197
  text-decoration: underline;
  background-color: transparent;
}
198
199
200
201
202
203
204
205
.btn-link {
  &[disabled],
  fieldset[disabled] & {
    &:hover {
      color: @grayDark;
      text-decoration: none;
    }
  }
206
}