buttons.less 3.91 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
28
29
30
31
32
33
  border-radius: @border-radius-base;

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

  &:hover {
    text-decoration: none;
  }

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

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

}

Mark Otto's avatar
Mark Otto committed
48
49

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

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

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

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

77

78
79
80
// Icons in buttons
// -------------------------

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


86
// Block button
87
88
// -------------------------

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

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

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


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

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

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

172
173
174
175
176

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

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