_dropdown.scss 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359
  1. // The dropdown menu
  2. .dropdown{
  3. // split warning dropdown toggle
  4. &.show{
  5. .btn-outline-warning,
  6. .btn-outline-light{
  7. &.dropdown-toggle{
  8. color: $white;
  9. }
  10. }
  11. }
  12. .btn:not(.btn-sm):not(.btn-lg),
  13. .btn:not(.btn-sm):not(.btn-lg).dropdown-toggle {
  14. padding: $dropdown-btn-padding-y $dropdown-btn-padding-x;
  15. &.btn-round {
  16. @include button-round-variant(2rem);
  17. }
  18. }
  19. .btn.dropdown-toggle.dropdown-toggle-split {
  20. padding: $dropdown-btn-padding-y $dropdown-btn-split-padding-x;
  21. border-left-color: rgba($white, 0.2) !important;
  22. border-top-left-radius: 0;
  23. border-bottom-left-radius: 0;
  24. }
  25. [class*="btn-outline-"].dropdown-toggle.dropdown-toggle-split {
  26. border-left: 0 !important;
  27. &:active {
  28. color: $white;
  29. }
  30. }
  31. // dropdown menu
  32. .dropdown-menu {
  33. border: 1px solid rgba($pure-black, .05); // border opacity has been reduced to make it look same as vue's dropdown border [component page, list view page]
  34. border-radius: $dropdown-border-radius;
  35. transform: scale(1, 0);
  36. box-shadow: 0 5px 25px rgba($pure-black, 0.1); // this according to vue version
  37. // left: 5px; // it creates issue in navbar - notification dropdown
  38. min-width: 8rem;
  39. &::before {
  40. content: '';
  41. position: absolute;
  42. top: -1px;
  43. left: 1.2rem;
  44. width: .75rem;
  45. height: .75rem;
  46. display: block;
  47. background: $white;
  48. transform: rotate(45deg) translate(-7px);
  49. border-top: 1px solid rgba($pure-black, .1);
  50. border-left: 1px solid rgba($pure-black, .1);
  51. z-index: 10;
  52. box-sizing: border-box;
  53. }
  54. &.dropdown-menu-right {
  55. &::before {
  56. right: .6rem;
  57. left: auto;
  58. }
  59. }
  60. .dropdown-header {
  61. padding: .714rem 1.428rem;
  62. margin-top: .714rem;
  63. }
  64. .dropdown-item {
  65. padding: .5rem 1rem;
  66. color: $body-color;
  67. width: auto;
  68. cursor: pointer;
  69. &:hover{
  70. background-color: $body-bg;
  71. color: $primary;
  72. }
  73. &.active {
  74. color: $white;
  75. }
  76. &:active {
  77. background-color: transparent;
  78. color: $dropdown-color;
  79. }
  80. }
  81. }
  82. i {
  83. margin-right: 0.5rem;
  84. }
  85. // If don't won't dropdown/up arrow
  86. &.no-arrow{
  87. .dropdown-toggle{
  88. &:after{
  89. display: none;
  90. }
  91. i{
  92. margin-right: 0;
  93. }
  94. }
  95. }
  96. }
  97. // same padding for diffrent directions
  98. .dropdown,
  99. .dropup,
  100. .dropright,
  101. .dropleft{
  102. position: relative;
  103. .dropdown-menu{
  104. .dropdown-item{
  105. padding: .714rem 1.428rem;
  106. }
  107. }
  108. }
  109. .show {
  110. >.dropdown-menu {
  111. transform: scale(1, 1);
  112. opacity: 1;
  113. display: block;
  114. }
  115. }
  116. .dropdown-toggle {
  117. // changed icon caret
  118. &::after {
  119. border: none !important;
  120. font-family: 'feather';
  121. content: "\e842" !important;
  122. position: relative;
  123. top: 1px;
  124. right: 0px;
  125. left: .714rem;
  126. padding: 0;
  127. // left: 1.4rem;
  128. margin: 0;
  129. vertical-align: 0;
  130. }
  131. &.dropdown-toggle-split {
  132. border-left: 1px solid rgba($white, 0.2);
  133. &:after {
  134. left: 0;
  135. }
  136. }
  137. // hide default arrow to show custom icon DD
  138. &.nav-hide-arrow {
  139. &::after {
  140. display: none;
  141. }
  142. }
  143. // Prevent the focus on the dropdown toggle when closing dropdowns
  144. &:focus {
  145. outline: 0;
  146. }
  147. }
  148. // Color theme active & hover
  149. .btn-secondary~.dropdown-menu {
  150. .dropdown-item {
  151. &.active,
  152. &:hover {
  153. background-color: darken($white, 20%);
  154. }
  155. }
  156. }
  157. // DropUp
  158. .dropup {
  159. position: relative;
  160. .btn,
  161. .btn.dropdown-toggle {
  162. padding: $dropdown-btn-padding-y $dropdown-btn-padding-x;
  163. }
  164. .btn.dropdown-toggle.dropdown-toggle-split {
  165. padding: $dropdown-btn-padding-y $dropdown-btn-split-padding-x;
  166. border-color: rgba($white, 0.2) !important;
  167. }
  168. .dropdown-toggle {
  169. // changed icon dropup caret
  170. &::after {
  171. content: "\e845" !important;
  172. vertical-align: 0.05rem;
  173. }
  174. }
  175. .dropdown-menu {
  176. &::before {
  177. content: '';
  178. position: absolute;
  179. bottom: -.714rem;
  180. left: 1.214rem;
  181. width: .714rem;
  182. height: .714rem;
  183. display: block;
  184. background: $white;
  185. transform: rotate(45deg) translate(-7px);
  186. border-bottom: 1px solid rgba($pure-black, .1);
  187. border-right: 1px solid rgba($pure-black, .1);
  188. z-index: 10;
  189. box-sizing: border-box;
  190. }
  191. &.dropdown-menu-right{
  192. &::before{
  193. left: auto;
  194. right: .714rem;
  195. }
  196. }
  197. }
  198. .dropdown-submenu {
  199. .dropdown-menu {
  200. bottom: auto;
  201. top: 0;
  202. }
  203. }
  204. }
  205. // DropLeft
  206. .dropleft {
  207. .btn,
  208. .btn.dropdown-toggle {
  209. padding: $dropdown-btn-padding-y $dropdown-btn-padding-x;
  210. }
  211. .btn.dropdown-toggle.dropdown-toggle-split {
  212. padding: $dropdown-btn-padding-y $dropdown-btn-split-padding-x;
  213. }
  214. .dropdown-toggle {
  215. // changed icon dropup caret
  216. &::before {
  217. border: none !important;
  218. font-family: 'feather';
  219. content: "\e843" !important;
  220. }
  221. }
  222. .dropdown-menu {
  223. &::before {
  224. content: '';
  225. position: absolute;
  226. top: 1.285rem;
  227. right: 0;
  228. width: .714rem;
  229. height: .714rem;
  230. display: block;
  231. background: $white;
  232. transform: rotate(130deg) translate(-8px);
  233. border-top: 1px solid rgba($pure-black, .1);
  234. border-left: 1px solid rgba($pure-black, .1);
  235. z-index: 10;
  236. box-sizing: border-box;
  237. }
  238. }
  239. }
  240. // DropRight
  241. .dropright {
  242. .btn,
  243. .btn.dropdown-toggle {
  244. padding: $dropdown-btn-padding-y $dropdown-btn-padding-x;
  245. }
  246. .btn.dropdown-toggle.dropdown-toggle-split {
  247. padding: $dropdown-btn-padding-y $dropdown-btn-split-padding-x;
  248. }
  249. .dropdown-toggle {
  250. // changed icon dropup caret
  251. &::after {
  252. border: none !important;
  253. font-family: 'feather';
  254. content: "\e844" !important;
  255. }
  256. }
  257. .dropdown-menu {
  258. &::before {
  259. content: '';
  260. position: absolute;
  261. top: 1.285rem;
  262. left: -0.9rem;
  263. width: .714rem;
  264. height: .714rem;
  265. display: block;
  266. background: $white;
  267. transform: rotate(140deg) translate(-9px);
  268. border-bottom: 1px solid rgba($pure-black, .1);
  269. border-right: 1px solid rgba($pure-black, .1);
  270. z-index: 10;
  271. box-sizing: border-box;
  272. }
  273. }
  274. }
  275. // Dropdown icon
  276. .dropdown,
  277. .dropup {
  278. &.dropdown-icon-wrapper {
  279. .dropdown-toggle {
  280. &:after {
  281. display: none;
  282. }
  283. }
  284. .dropdown-menu {
  285. min-width: auto;
  286. .dropdown-item {
  287. padding: 0.5rem 1.1rem;
  288. cursor: pointer;
  289. i {
  290. font-size: 1.3rem;
  291. color: $body-color;
  292. }
  293. &:hover{
  294. color: $white;
  295. }
  296. }
  297. }
  298. }
  299. }
  300. // for white button
  301. .btn.btn-white ~ .dropdown-menu {
  302. .dropdown-item:not(.acitve):hover{
  303. color: $body-color !important;
  304. }
  305. .dropdown-item.active{
  306. color: $body-color;
  307. }
  308. }
  309. // Dropdown menu animation
  310. .horizontal-menu-wrapper .dropdown-menu,
  311. .header-navbar .dropdown-menu{
  312. animation-duration: 0.3s;
  313. animation-fill-mode: both;
  314. animation-name: slideIn;
  315. }
  316. @keyframes slideIn {
  317. 0% {
  318. transform: translateY(1rem);
  319. opacity: 0;
  320. }
  321. 100% {
  322. transform:translateY(0rem);
  323. opacity: 1;
  324. }
  325. 0% {
  326. transform: translateY(1rem);
  327. opacity: 0;
  328. }
  329. }