This repository has been archived by the owner on Jun 28, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 27
CSS LESS Guidelines
edeyoung edited this page May 30, 2019
·
5 revisions
This project utilizes LESS, which is a dynamic stylesheet language that extends and compiles to CSS. It has a lot of benefits such as variable support and the ability to nest styles. Take advantage of these patterns. Checkout lesscss.org for more information about what LESS can do.
-
application.css.less
imports all the other less files in the correct order for it to compile without errors.- External dependencies come first, followed by files holding styles that are site-wide. Files holding page specific styles come last.
-
bootstrap3.less
holds all the twitter Bootstrap classes that are overridden to fit the theme of Bonnie.- Place a comment above your styles to denote the view to which they apply.
- The order of the styles should reflect the order of the imports in
application.css.less
.
-
variables.less
contains LESS variables specific to Bonnie used in the other less files.- Place a comment above your variables to denote the view to which they apply.
- The order of the variable sections should reflect the order of the imports in
application.css.less
.
-
mixins.less
contains mix-ins that can be used across the application to get repeatable effects.- This includes classes that are used on multiple pages.
- The remaining files are page specific styles.
- Use dashed names (e.g.
.dashboard-data
) - Try to use semantic names that describe the element on the page that is being styled (e.g.
.measure-col
) or the role the class is playing (e.g..btn-default
) - We are using Twitter Bootstrap, so our naming conventions should follow theirs whenever possible.
- For example, use the form
.[name] .[name]-[status]
, where[name]
is the name of the element (btn, text, etc.) and[status]
is a descriptor indicating something what changed by the second class (e.g..btn .btn-success
).
- For example, use the form
- Use camel case (e.g.
#thisIsAnId
) - Only use ids when absolutely necessary.
- If Twitter Bootstrap defines a variable for something, use or override their variable over creating your own.
-
@brand-primary
for the standard color -
@brand-success
for success color (usually green)
-
- Use dashed names prefixed by an @ (e.g.
@gray-lighter
) - Always define them at the top of the file
- Name them to describe what the variable is controlling
- Use them for any value that will be commonly reused (e.g. color)
- Use LESS functions, when appropriate. For example, use
darken()
orlighten()
when transforming a color to a different shade.
The Bootstrap classes .row
, .pull-right
, and .pull-left
should be placed directly in the markup, while other classes such as .col-sm-2
should be used only in page specific files, hidden behind a semantic class. The goal of this is to make the markup easily readable by everyone
- Remove deprecated styles as you discover it or as you remove old HTML.
- Do not put styles in the HTML using the style attribute. All styles should be in
.less
file.
If you are unclear on something, talk to Liam (@carpeliam) about it.