_main-sidebar.scss 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. /**
  2. * Component: Sidebar
  3. * ------------------
  4. */
  5. .main-sidebar {
  6. z-index: $zindex-main-sidebar;
  7. height: 100vh;
  8. overflow-y: hidden;
  9. }
  10. .sidebar {
  11. padding-bottom: $sidebar-padding-y;
  12. padding-top: $sidebar-padding-y;
  13. padding-left: $sidebar-padding-x;
  14. padding-right: $sidebar-padding-x;
  15. overflow-y: auto;
  16. height: calc(100% - 4rem);
  17. }
  18. // Sidebar user panel
  19. .user-panel {
  20. position: relative;
  21. [class*="sidebar-dark"] & {
  22. border-bottom: 1px solid lighten($dark, 12%);
  23. }
  24. [class*="sidebar-light"] & {
  25. border-bottom: 1px solid $gray-300;
  26. }
  27. &,
  28. .info {
  29. overflow: hidden;
  30. white-space: nowrap;
  31. }
  32. .image {
  33. padding-left: $nav-link-padding-x - .2;
  34. display: inline-block;
  35. }
  36. img {
  37. width: $sidebar-user-image-width;
  38. height: auto;
  39. }
  40. .info {
  41. display: inline-block;
  42. padding: 5px 5px 5px 10px;
  43. }
  44. .status,
  45. .dropdown-menu {
  46. font-size: $font-size-sm;
  47. }
  48. }
  49. // Sidebar navigation menu
  50. .nav-sidebar {
  51. // All levels
  52. .nav-item {
  53. > .nav-link {
  54. margin-bottom: 0.2rem;
  55. .right {
  56. @include transition(transform $transition-fn $transition-speed);
  57. }
  58. }
  59. }
  60. .nav-link > p > .right {
  61. position: absolute;
  62. right: 1rem;
  63. top: 12px;
  64. }
  65. .menu-open {
  66. > .nav-treeview {
  67. display: block;
  68. }
  69. > .nav-link {
  70. .right {
  71. @include rotate(-90deg);
  72. }
  73. }
  74. }
  75. // First Level
  76. > .nav-item {
  77. margin-bottom: 0;
  78. .nav-icon {
  79. text-align: center;
  80. width: $sidebar-nav-icon-width;
  81. font-size: 1.2rem;
  82. margin-right: .2rem;
  83. }
  84. .float-right {
  85. margin-top: 3px;
  86. }
  87. }
  88. // Tree view menu
  89. .nav-treeview {
  90. display: none;
  91. list-style: none;
  92. padding: 0;
  93. > .nav-item {
  94. > .nav-link {
  95. > .nav-icon {
  96. width: $sidebar-nav-icon-width;
  97. }
  98. }
  99. }
  100. }
  101. .nav-header {
  102. font-size: .9rem;
  103. padding: $nav-link-padding-y;
  104. &:not(:first-of-type) {
  105. padding: 1.7rem 1rem .5rem 1rem;
  106. }
  107. }
  108. .nav-link p {
  109. display: inline-block;
  110. margin: 0;
  111. }
  112. }
  113. #sidebar-overlay {
  114. position: fixed;
  115. top: 0;
  116. left: 0;
  117. right: 0;
  118. bottom: 0;
  119. display: none;
  120. background-color: rgba(0, 0, 0, 0.1);
  121. z-index: $zindex-main-sidebar - 1;
  122. @include media-breakpoint-down(md) {
  123. .sidebar-open & {
  124. display: block;
  125. }
  126. }
  127. }
  128. // Sidebar variants
  129. @each $name, $color in $theme-colors {
  130. .sidebar-dark-#{$name} {
  131. @include skin-dark-sidebar($color)
  132. }
  133. .sidebar-light-#{$name} {
  134. @include skin-light-sidebar($color)
  135. }
  136. }