LESS.css

Less is a CSS pre-processor, meaning that it extends the CSS language, adding features that allow variables, mixins, functions and many other techniques that allow you to make CSS that is more maintainable, themable and extendable. For example:

  1. @base: #f938ab;
  2. .box-shadow(@style, @c) when (iscolor(@c)) {
  3. -webkit-box-shadow: @style @c;
  4. box-shadow: @style @c;
  5. }
  6. .box-shadow(@style, @alpha: 50%) when (isnumber(@alpha)) {
  7. .box-shadow(@style, rgba(0, 0, 0, @alpha));
  8. }
  9. .box {
  10. color: saturate(@base, 5%);
  11. border-color: lighten(@base, 30%);
  12. div { .box-shadow(0 0 5px, 30%) }
  13. }

This would compile to:

  1. .box {
  2. color: #fe33ac;
  3. border-color: #fdcdea;
  4. }
  5. .box div {
  6. -webkit-box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
  7. box-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
  8. }

The /blockstrap/js/less.js and /themes/<active-theme>/less/blockstrap.less files are only ever included if less: true is set within the configuration.

The most obvious benefit of programatic pre-processing CSS is the use of variables, which for the default theme are stored at themes/default/less/variables.less and include:

  1. /*
  2. COLORS
  3. */
  4. // HEADER
  5. @header-bg: #475862;
  6. @nav-bg: transparent;
  7. @nav-bg-active: #2B3F4B;
  8. @nav-bg-hover: #2F2F2F;
  9. @nav-border: transparent;
  10. @nav-border-active: #111E27;
  11. @nav-border-hover: #000000;
  12. @nav-color: #EDEDED;
  13. @nav-color-active: #AAAAAA;
  14. @nav-color-hover: #FFFF99;
  15. // SIDEBAR
  16. @sidebar-bg: #102634;
  17. @sidebar-link-color: #FFFFBB;
  18. @sidebar-sub-color: #0085B2;
  19. @sidebar-panel-bg: #111E27;
  20. @sidebar-panel-border: #214760;
  21. @sidebar-panel-color: #666666;
  22. // CONTENT
  23. @content-bg: #DDDDDD;
  24. @content-link: #069;
  25. @content-link-hover: #757575;
  26. @panel-header-bg: #111E27;
  27. @panel-header-color: #EEEEEE;
  28. @panel-border: #CCCCCC;
  29. // BUTTONS
  30. @btn-primary-top: #0085B2;
  31. @btn-primary-bottom: #214E6B;
  32. @btn-primary-border: #000000;
  33. @btn-primary-color: #FFFFFF;
  34. @btn-success-top: #398235;
  35. @btn-success-bottom: #176002;
  36. @btn-success-border: #888;
  37. @btn-success-color: #FFF;
  38. @btn-default-top: #475862;
  39. @btn-default-bottom: #283238;
  40. @btn-default-border: #000000;
  41. @btn-default-color: #FFFFFF;
  42. @btn-danger-top: #8C0000;
  43. @btn-danger-bottom: #400000;
  44. @btn-danger-border: #000000;
  45. @btn-danger-color: #FFFFFF;
  46. @btn-subtle-top: #F9F9F9;
  47. @btn-subtle-bottom: #EBEAEB;
  48. @btn-subtle-color: #069;
  49. @btn-subtle-border: #BBB;
  50. // RIBBONS
  51. @ribbon-default: #214E6B;
  52. @ribbon-default-color: #FFFFEE;
  53. @ribbon-from: #008C23;
  54. @ribbon-to: #8C0000;
  55. // TABLES
  56. @table-bg: #EEEEEE;
  57. @table-bg-alt: #FFFFFF;
  58. @table-color: #757575;
  59. @table-border: #BBBBBB;
  60. @table-header-bg: #111E27;
  61. @table-header-bg-active: #214862;
  62. @table-header-color: #EDEDED;
  63. // MODALS
  64. @modal-bg: #000F26;
  65. @modal-bg-opacity: 0.85;
  66. @modal-header-bg: #EEE;
  67. @modal-header-color: #757575;
  68. @modal-body-bg: #FFF;
  69. @modal-body-color: #555;
  70. @modal-border: #BBB;
  71. @modal-form-bg: #FFFFEE;
  72. // FORMS
  73. @form-horizontal-label-bg: #DDD;
  74. @form-horizontal-label-border: #CCC;
  75. @form-horizontal-label-color: #555;
  76. @form-alternative-bg: #FFFFEE;
  77. /*
  78. DIMENSIONS
  79. */
  80. @header-height: 60px;
  81. @sidebar-width: 250px;
  82. @panel-padding: 20px;
  83. /*
  84. CURVES
  85. */
  86. @border-radius: 4px;

Changing the variables above should allow you to create completely new skins and theme styles without needing to edit anything further. More information is available for $.fn.blockstrap.core.less.


  1. Related Articles
  2. Back to Assets
  3. Dependencies
  4. Boostrap
  5. Mustache
  6. LESS.css
  7. Table of Contents