theme-dark.scss 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. // Dark Mode Theme Variables and Overrides.
  2. @use 'sass:map';
  3. @import './theme-base.scss';
  4. $primary: $blue-300;
  5. $secondary: $gray-500;
  6. $success: $green-300;
  7. $info: $cyan-300;
  8. $warning: $yellow-300;
  9. $danger: $red-300;
  10. $light: $gray-300;
  11. $dark: $gray-500;
  12. $theme-colors: (
  13. 'primary': $primary,
  14. 'secondary': $secondary,
  15. 'success': $success,
  16. 'info': $info,
  17. 'warning': $warning,
  18. 'danger': $danger,
  19. 'light': $light,
  20. 'dark': $dark,
  21. );
  22. $theme-colors: map-merge($theme-colors, $theme-color-addons);
  23. // Gradient
  24. $gradient: linear-gradient(180deg, rgba($white, 0.15), rgba($white, 0));
  25. // Body
  26. $body-bg: #1b1f22;
  27. $body-color: $white;
  28. $body-text-align: null;
  29. $border-color: $gray-700;
  30. $box-shadow: 0 0.5rem 1rem rgba($black, 0.15);
  31. $box-shadow-sm: 0 0.125rem 0.25rem rgba($black, 0.075);
  32. $box-shadow-lg: 0 1rem 3rem rgba($black, 0.175);
  33. $box-shadow-inset: inset 0 1px 2px rgba($black, 0.075);
  34. $text-muted: $gray-400;
  35. $blockquote-footer-color: $gray-600;
  36. $mark-bg: #fcf8e3;
  37. $link-color: $blue-200;
  38. $link-hover-color: $blue-100;
  39. // Tables
  40. $table-color: $gray-100;
  41. $table-border-color: $border-color;
  42. $table-striped-color: $table-color;
  43. $table-striped-bg: rgba($white, $table-striped-bg-factor);
  44. $table-active-color: $table-color;
  45. $table-active-bg: rgba($white, $table-active-bg-factor);
  46. $table-hover-color: $table-color;
  47. $table-hover-bg: rgba($white, $table-hover-bg-factor);
  48. $table-flush-header-bg: $gray-700;
  49. // Buttons
  50. $btn-box-shadow: inset 0 1px 0 rgba($black, 0.15), 0 1px 1px rgba($white, 0.075);
  51. $btn-active-box-shadow: inset 0 3px 5px rgba($white, 0.125);
  52. $btn-link-disabled-color: $gray-300;
  53. // Forms
  54. $component-active-bg: $primary;
  55. $form-text-color: $text-muted;
  56. $input-bg: $gray-900;
  57. $input-disabled-bg: $gray-700;
  58. $input-color: $gray-100;
  59. $input-border-color: $gray-700;
  60. $input-focus-bg: $input-bg;
  61. $input-focus-border-color: tint-color($component-active-bg, 10%);
  62. $input-focus-color: $input-color;
  63. $input-placeholder-color: $gray-300;
  64. $input-plaintext-color: $body-color;
  65. $form-check-input-active-filter: brightness(90%);
  66. $form-check-input-bg: $input-bg;
  67. $form-check-input-border: 1px solid rgba(255, 255, 255, 0.25);
  68. $form-check-input-checked-color: $component-active-color;
  69. $form-check-input-checked-bg-color: $component-active-bg;
  70. $form-check-input-checked-border-color: $form-check-input-checked-bg-color;
  71. $form-check-input-indeterminate-color: $component-active-color;
  72. $form-check-input-indeterminate-bg-color: $component-active-bg;
  73. $form-check-input-indeterminate-border-color: $form-check-input-indeterminate-bg-color;
  74. $form-switch-color: rgba(255, 255, 255, 0.25);
  75. $form-switch-focus-color: $input-focus-border-color;
  76. $form-switch-checked-color: $component-active-color;
  77. $input-group-addon-color: $input-color;
  78. $input-group-addon-bg: $gray-700;
  79. $input-group-addon-border-color: $input-border-color;
  80. $form-select-color: $input-color;
  81. $form-select-disabled-color: $gray-700;
  82. $form-select-bg: $input-bg;
  83. $form-select-disabled-bg: $input-disabled-bg;
  84. $form-select-indicator-color: $form-select-color;
  85. $form-select-indicator: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path fill='none' stroke='#{$form-select-indicator-color}' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/></svg>");
  86. $form-select-border-color: $input-border-color;
  87. $form-range-track-bg: $gray-300;
  88. $form-range-thumb-bg: $component-active-bg;
  89. $form-range-thumb-box-shadow: 0 0.1rem 0.25rem rgba($black, 0.1);
  90. $form-range-thumb-focus-box-shadow: 0 0 0 1px $body-bg, $input-focus-box-shadow;
  91. $form-range-thumb-active-bg: tint-color($component-active-bg, 70%);
  92. $form-range-thumb-disabled-bg: $gray-500;
  93. $form-file-button-color: $input-color;
  94. $form-file-button-bg: $input-group-addon-bg;
  95. $form-file-button-hover-bg: shade-color($form-file-button-bg, 5%);
  96. $form-feedback-valid-color: $success;
  97. $form-feedback-invalid-color: $danger;
  98. // Navs
  99. $nav-link-color: $body-color;
  100. $nav-link-hover-color: null;
  101. $nav-link-disabled-color: $gray-800;
  102. $nav-tabs-border-color: $border-color;
  103. $nav-tabs-link-hover-border-color: rgba($gray-800, 0.5) rgba($gray-800, 0.5) $nav-tabs-border-color;
  104. $nav-tabs-link-active-color: $gray-100;
  105. $nav-tabs-link-active-bg: $body-bg;
  106. $nav-tabs-link-active-border-color: $gray-800 $gray-800 $nav-tabs-link-active-bg;
  107. $nav-pills-link-active-color: $component-active-color;
  108. $nav-pills-link-active-bg: $component-active-bg;
  109. $navbar-light-color: $gray-500;
  110. $navbar-light-toggler-icon-bg: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'><path stroke='#{$navbar-light-color}' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/></svg>");
  111. $navbar-light-toggler-border-color: $gray-700;
  112. // Dropdowns
  113. $dropdown-color: $body-color;
  114. $dropdown-bg: $gray-900;
  115. $dropdown-border-color: rgba($white, 0.15);
  116. $dropdown-link-color: $gray-100;
  117. $dropdown-link-hover-color: $white;
  118. $dropdown-link-hover-bg: $gray-600;
  119. $dropdown-link-disabled-color: $gray-800;
  120. $dropdown-header-color: $gray-300;
  121. // Pagination
  122. $pagination-color: $link-color;
  123. $pagination-bg: $gray-800;
  124. $pagination-border-color: $gray-600;
  125. $pagination-focus-color: $link-hover-color;
  126. $pagination-focus-bg: $gray-400;
  127. $pagination-hover-color: $link-hover-color;
  128. $pagination-hover-bg: $gray-400;
  129. $pagination-hover-border-color: $gray-500;
  130. $pagination-active-color: $component-active-color;
  131. $pagination-active-bg: $component-active-bg;
  132. $pagination-active-border-color: $pagination-active-bg;
  133. $pagination-disabled-color: $gray-600;
  134. $pagination-disabled-bg: $gray-800;
  135. $pagination-disabled-border-color: $gray-600;
  136. // Cards
  137. $card-border-color: rgba($white, 0.125);
  138. $card-inner-border-radius: subtract($card-border-radius, $card-border-width);
  139. $card-cap-color: null;
  140. $card-height: null;
  141. $card-color: null;
  142. $card-bg: $gray-900;
  143. // Accordion
  144. $accordion-color: $body-color;
  145. $accordion-bg: transparent;
  146. $accordion-border-color: $border-color;
  147. $accordion-button-color: $accordion-color;
  148. $accordion-button-bg: $accordion-bg;
  149. $accordion-body-active-bg: rgba($blue-300, 0.2);
  150. $accordion-button-active-bg: rgba($blue-300, 0.25);
  151. $accordion-button-active-color: $gray-300;
  152. $accordion-button-focus-border-color: $input-focus-border-color;
  153. $accordion-icon-color: $accordion-color;
  154. $accordion-icon-active-color: $accordion-button-active-color;
  155. $accordion-button-icon: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$accordion-icon-color}'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>");
  156. $accordion-button-active-icon: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$accordion-icon-active-color}'><path fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/></svg>");
  157. // Tooltips
  158. $tooltip-color: $body-color;
  159. $tooltip-bg: $gray-700;
  160. $tooltip-arrow-color: $tooltip-bg;
  161. $form-feedback-tooltip-opacity: $tooltip-opacity;
  162. // Popovers
  163. $popover-bg: $gray-700;
  164. $popover-border-color: rgba($white, 0.2);
  165. $popover-header-bg: shade-color($popover-bg, 6%);
  166. $popover-header-color: $headings-color;
  167. $popover-body-color: $body-color;
  168. $popover-arrow-color: $popover-bg;
  169. $popover-arrow-outer-color: fade-in($popover-border-color, 0.05);
  170. // Toasts
  171. $toast-color: null;
  172. $toast-background-color: rgba($white, 0.85);
  173. $toast-border-color: rgba(0, 0, 0, 0.1);
  174. $toast-header-color: $gray-600;
  175. $toast-header-background-color: rgba($white, 0.85);
  176. $toast-header-border-color: rgba(0, 0, 0, 0.05);
  177. // Badges
  178. $badge-color: $white;
  179. // Modals
  180. $modal-content-color: null;
  181. $modal-content-bg: $gray-800;
  182. $modal-content-border-color: rgba($white, 0.2);
  183. $modal-backdrop-bg: $black;
  184. $modal-header-border-color: $border-color;
  185. $modal-footer-border-color: $modal-header-border-color;
  186. // Progress bars
  187. $progress-bg: $gray-600;
  188. $progress-bar-color: $white;
  189. $progress-bar-bg: $primary;
  190. // List group
  191. $list-group-color: $body-color;
  192. $list-group-bg: $card-bg;
  193. $list-group-border-color: rgba($white, 0.125);
  194. $list-group-hover-bg: rgba($gray-100, 0.15);
  195. $list-group-active-color: $component-active-color;
  196. $list-group-active-bg: $component-active-bg;
  197. $list-group-active-border-color: $list-group-active-bg;
  198. $list-group-disabled-bg: $list-group-bg;
  199. $list-group-action-color: $gray-300;
  200. $list-group-action-hover-color: $body-color;
  201. $list-group-action-active-color: $body-color;
  202. $list-group-action-active-bg: rgba($gray-300, 0.125);
  203. // Image thumbnails
  204. $thumbnail-bg: $body-bg;
  205. $thumbnail-border-color: $gray-300;
  206. // Figures
  207. $figure-caption-color: $gray-600;
  208. // Breadcrumbs
  209. $breadcrumb-divider-color: $gray-100;
  210. $breadcrumb-active-color: $body-color;
  211. $breadcrumb-divider-flipped: $breadcrumb-divider;
  212. $breadcrumb-divider: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8'%3E%3Cpath d='M2.5 0L1 1.5 3.5 4 1 6.5 2.5 8l4-4-4-4z' fill='#{$breadcrumb-divider-color}'/%3E%3C/svg%3E");
  213. // Carousel
  214. $carousel-control-color: $white;
  215. $carousel-indicator-active-bg: $white;
  216. $carousel-caption-color: $white;
  217. $carousel-dark-indicator-active-bg: $black;
  218. $carousel-dark-caption-color: $black;
  219. $carousel-dark-control-icon-filter: invert(1) grayscale(100);
  220. // Close
  221. $btn-close-color: $white;
  222. $btn-close-white-filter: invert(1) grayscale(100%) brightness(200%);
  223. $btn-close-bg: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$btn-close-color}'><path d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/></svg>");
  224. @each $color, $value in $theme-colors {
  225. .bg-#{$color} button.btn-close {
  226. background: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{color-contrast($value)}'><path d='M.293.293a1 1 0 011.414 0L8 6.586 14.293.293a1 1 0 111.414 1.414L9.414 8l6.293 6.293a1 1 0 01-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 01-1.414-1.414L6.586 8 .293 1.707a1 1 0 010-1.414z'/></svg>");
  227. }
  228. }
  229. // Code
  230. $code-color: $gray-200;
  231. $kbd-color: $white;
  232. $kbd-bg: $gray-300;
  233. $pre-color: null;