buttons.less 3.22 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 13px;
Mark Otto's avatar
Mark Otto committed
13
14
15
  margin-bottom: 0; // For input.btn
  font-size: @font-size-base;
  line-height: @line-height-base;
16
  color: @gray;
Mark Otto's avatar
Mark Otto committed
17
18
  text-align: center;
  text-shadow: 0 1px 0 rgba(255,255,255,.75);
Mark Otto's avatar
Mark Otto committed
19
20
  vertical-align: middle;
  cursor: pointer;
Mark Otto's avatar
Mark Otto committed
21
22
  #gradient > .vertical(@btn-background, @btn-background-highlight);
  border: 1px solid darken(@btn-background, 20%);
Mark Otto's avatar
Mark Otto committed
23
  border-radius: @border-radius-base;
Mark Otto's avatar
Mark Otto committed
24
  .box-shadow(inset 0 1px 0 rgba(255,255,255,.25));
Mark Otto's avatar
Mark Otto committed
25
26
27
28
29
30
31
32
33
34
35
36

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

  &:hover {
    text-decoration: none;
  }

  &:active,
  &.active {
    outline: 0;
Mark Otto's avatar
Mark Otto committed
37
38
    background-image: none;
    .box-shadow(~"inset 0 3px 5px rgba(0,0,0,.15), 0 1px 0 rgba(255,255,255,.1)");
Mark Otto's avatar
Mark Otto committed
39
40
41
  }

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

}

Mark Otto's avatar
Mark Otto committed
51
52

// Button Sizes
53
// -------------------------
Mark Otto's avatar
Mark Otto committed
54
55

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

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

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

80

81
82
83
// Icons in buttons
// -------------------------

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


89
// Block button
90
91
// -------------------------

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

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

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


Mark Otto's avatar
Mark Otto committed
115
116
117
118

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

119
.btn-primary {
Mark Otto's avatar
Mark Otto committed
120
  .buttonBackground(@btn-background-primary, @btn-background-primary-highlight);
121
}
Mark Otto's avatar
Mark Otto committed
122
// Warning appears are orange
123
.btn-warning {
Mark Otto's avatar
Mark Otto committed
124
  .buttonBackground(@btn-background-warning, @btn-background-warning-highlight);
Mark Otto's avatar
Mark Otto committed
125
126
}
// Danger and error appear as red
127
.btn-danger {
Mark Otto's avatar
Mark Otto committed
128
  .buttonBackground(@btn-background-danger, @btn-background-danger-highlight);
Mark Otto's avatar
Mark Otto committed
129
130
}
// Success appears as green
131
.btn-success {
Mark Otto's avatar
Mark Otto committed
132
  .buttonBackground(@btn-background-success, @btn-background-success-highlight);
Mark Otto's avatar
Mark Otto committed
133
134
}

135
136
137
138
139

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

// Make a button look and behave like a link
140
.btn-link,
141
.btn-link:active,
142
143
.btn-link[disabled],
fieldset[disabled] .btn-link {
144
145
  background-color: transparent;
  background-image: none;
146
  .box-shadow(none);
147
148
}
.btn-link {
149
150
  border-color: transparent;
  cursor: pointer;
Mark Otto's avatar
Mark Otto committed
151
  color: @link-color;
152
  border-radius: 0;
153
154
}
.btn-link:hover {
Mark Otto's avatar
Mark Otto committed
155
  color: @link-color-hover;
156
157
158
  text-decoration: underline;
  background-color: transparent;
}
159
160
161
162
163
164
165
166
.btn-link {
  &[disabled],
  fieldset[disabled] & {
    &:hover {
      color: @grayDark;
      text-decoration: none;
    }
  }
167
}