_dropdown.scss 3.02 KB
Newer Older
1
// The dropdown wrapper (`<div>`)
2
.dropup,
Guillermo González de Agüero's avatar
Guillermo González de Agüero committed
3
4
5
6
.dropdown {
  position: relative;
}

7
8
.dropdown-toggle {
  // Generate the caret automatically
9
  @include caret;
Mark Otto's avatar
Mark Otto committed
10
11
}

12
// The dropdown menu
13
14
.dropdown-menu {
  position: absolute;
15
  top: 100%;
16
  left: 0;
Mark Otto's avatar
Mark Otto committed
17
  z-index: $zindex-dropdown;
18
  display: none; // none by default, but block on "open" of the menu
Jacob Thornton's avatar
Jacob Thornton committed
19
  float: left;
20
  min-width: $dropdown-min-width;
21
  padding: $dropdown-padding-y 0;
22
  margin: $dropdown-spacer 0 0; // override default ul
23
  font-size: $font-size-base; // Redeclare because nesting can cause inheritance issues
24
  color: $body-color;
25
  text-align: left; // Ensures proper alignment if parent has it changed (e.g., modal footer)
26
  list-style: none;
Mark Otto's avatar
Mark Otto committed
27
  background-color: $dropdown-bg;
28
  background-clip: padding-box;
29
  border: $dropdown-border-width solid $dropdown-border-color;
30
  @include border-radius($dropdown-border-radius);
31
  @include box-shadow($dropdown-box-shadow);
Mark Otto's avatar
Mark Otto committed
32
}
33

34
35
36
37
38
39
40
41
42
43
44
45
46
// Allow for dropdowns to go bottom up (aka, dropup-menu)
// Just add .dropup after the standard .dropdown class and you're set.
.dropup {
  .dropdown-menu {
    margin-top: 0;
    margin-bottom: $dropdown-spacer;
  }

  .dropdown-toggle {
    @include caret(up);
  }
}

47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
.dropright {
  .dropdown-menu {
    margin-top: 0;
    margin-left: $dropdown-spacer;
  }

  .dropdown-toggle {
    @include caret(right);
    &::after {
      vertical-align: 0;
    }
  }
}

.dropleft {
  .dropdown-menu {
    margin-top: 0;
    margin-right: $dropdown-spacer;
  }

  .dropdown-toggle {
    @include caret(left);
    &::before {
      vertical-align: 0;
    }
  }
}

75
// Dividers (basically an `<hr>`) within the dropdown
Mark Otto's avatar
Mark Otto committed
76
77
.dropdown-divider {
  @include nav-divider($dropdown-divider-bg);
78
}
79

Mark Otto's avatar
Mark Otto committed
80
// Links, buttons, and more within the dropdown menu
Mark Otto's avatar
Mark Otto committed
81
//
82
// `<button>`-specific styles are denoted with `// For <button>s`
Mark Otto's avatar
Mark Otto committed
83
84
.dropdown-item {
  display: block;
Mark Otto's avatar
Mark Otto committed
85
  width: 100%; // For `<button>`s
Mark Otto's avatar
Mark Otto committed
86
  padding: $dropdown-item-padding-y $dropdown-item-padding-x;
Mark Otto's avatar
Mark Otto committed
87
  clear: both;
88
  font-weight: $font-weight-normal;
Mark Otto's avatar
Mark Otto committed
89
  color: $dropdown-link-color;
Mark Otto's avatar
Mark Otto committed
90
  text-align: inherit; // For `<button>`s
Mark Otto's avatar
Mark Otto committed
91
  white-space: nowrap; // prevent links from randomly breaking onto new lines
92
  background-color: transparent; // For `<button>`s
Mark Otto's avatar
Mark Otto committed
93
  border: 0; // For `<button>`s
94

95
  @include hover-focus {
Mark Otto's avatar
Mark Otto committed
96
    color: $dropdown-link-hover-color;
97
    text-decoration: none;
Mark Otto's avatar
Mark Otto committed
98
    @include gradient-bg($dropdown-link-hover-bg);
99
  }
100

Mark Otto's avatar
Mark Otto committed
101
102
103
104
  &.active,
  &:active {
    color: $dropdown-link-active-color;
    text-decoration: none;
Mark Otto's avatar
Mark Otto committed
105
    @include gradient-bg($dropdown-link-active-bg);
106
  }
107

Mark Otto's avatar
Mark Otto committed
108
109
110
111
112
113
114
  &.disabled,
  &:disabled {
    color: $dropdown-link-disabled-color;
    background-color: transparent;
    // Remove CSS gradients if they're enabled
    @if $enable-gradients {
      background-image: none;
Mark Otto's avatar
Mark Otto committed
115
    }
116
  }
117
118
}

Johann-S's avatar
Johann-S committed
119
120
121
122
.dropdown-menu.show {
  display: block;
}

123
124
125
// Dropdown section headers
.dropdown-header {
  display: block;
126
  padding: $dropdown-padding-y $dropdown-item-padding-x;
Mark Otto's avatar
Mark Otto committed
127
  margin-bottom: 0; // for use with heading elements
Mark Otto's avatar
Mark Otto committed
128
129
  font-size: $font-size-sm;
  color: $dropdown-header-color;
130
  white-space: nowrap; // as with > li > a
131
}