Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jdsteinbach/boilerplate-sass

Some boilerplate Sass partials
https://github.com/jdsteinbach/boilerplate-sass

Last synced: 2 days ago
JSON representation

Some boilerplate Sass partials

Awesome Lists containing this project

README

        

# Sass

The repo [README.md](README.md) contains instructions from compiling Sass with Gulp and an intro to our component naming convention.

## Folders

Each folder contains an "index" file that's named after the folder. This file imports everything else in that folder. For example: `/vendor/` contains `_vendor.scss` and that file imports all its siblings.

When using `@import`, alphabetize the order of imports unless the cascade requires otherwise. In that case, leave a comment explaining the cascade goal.

### `/vendor/`

Most vendor libraries (Sass libs you get from another dev/source & don't change) will end up in `/node_modules/`, but if not, they'll go here.

### `/base/`

Base is a boilerplate category: variables, functions, mixins, etc. It doesn't contain blocks of styles, but helper code you'll use to write other styles. IOW, if you compiled the `/base/` dir alone, you should get an empty CSS file.

### `/elements/`

Elements contain styles that only apply to HTML tags, for the most part: typography, form elements, etc.

### `/components/`

Components are the smallest reusable patterns. They contain multiple elements, but not other components.

Whenever possible, scope component variations to selectors availabe on the component itself. For example, a "label + field component" _inside a modal_ might have different colors/borders from the default. Scope the variation to `.label-field.in-modal`, not `.modal .label-field`.

Components should usually have matching PHP. Small components might be generated by functions, included partials, or shortcodes. Sass partials should be named after the component's root class.

### `/modules/`

Modules can contain components and other modules. Modules styled in this folder are available to multiple pages, but not necessarily used on _every_ page.

Whenever possible, scope module variations to selectors availabe on the module itself. For example, a sidebar _on the home page_ might have different styles from the default. Scope the variation to `.sidebar.on-home-page`, not `.home-page .sidebar`.

Modules will have matching PHP files: included partials, or shortcodes. Sass & PHP file names should match the module's root class.

### `/global/`

Global contains the modules are part of the site global design and appear on every page.

Same rule about handling scoping as above: add a unique selector, not a parent scope.

### `/pages/`

Most of the code you would've been tempted to put into page-specific scopes on individual modules will already be handled through on-element variant selectors as described above. Occasionally you'll still find a page that has some unique styles that no other page should ever use. In that case, create a partial for that page here. The Sass partial should have the same file name as the WP template file that generates the markup. For example, any styles unique to `page-home.php` would be stored in `/pages/page-home.scss`.

This directory should be prone to frequent refactoring: as soon as any part of a "unique" page design is used on another template, refactor and move it to `/modules/`. Refactor your PHP too.