/ubc-clf-min

A version of the standard CLF distribution with all unused css removed from a basic page template.

Primary LanguageCSS

ubc-clf-min

What is this?

This is a tool to create a build of the standard CLF distribution with all unused css removed. (http://clf.ubc.ca)

Do I have to install anything?

No, you should just use the CSS files located in full-width > release > optimized or standard > release > optimized.

Who is it for?

It's for developers building a UBC CLF website, who don't want to include the entire Bootstrap 2 CSS framework.

Can I use it on my existing UBC website with CLF version 7.x?

You can, but if you're relying on styling or layout from the default CLF version, these may break.

Why use it then?

You want a clean slate of CSS with just the bare minimum required by the UBC CLF.

What's included?

Only css required for the 'required' CLF elements and the primary navigation, plus the Bootstrap 2 Grid system (span and offset classes). These have been replaced from alpha versions becuase the savings wasn't significant, but the potential problems were :)

What's not included?

Everything else.

Can I get it from the CDN?

YES! Fixed width

  • //cdn.ubc.ca/clf/7.0.4-minimal/css/minimal-clf-7.0.4.css
  • //cdn.ubc.ca/clf/7.0.4-minimal/css/minimal-clf-7.0.4-bw.css
  • //cdn.ubc.ca/clf/7.0.4-minimal/css/minimal-clf-7.0.4-gw.css
  • //cdn.ubc.ca/clf/7.0.4-minimal/css/minimal-clf-7.0.4-wg.css

Full width

  • //cdn.ubc.ca/clf/7.0.4-minimal/css/minimal-clf-full-7.0.4.css
  • //cdn.ubc.ca/clf/7.0.4-minimal/css/minimal-clf-full-7.0.4-bw.css
  • //cdn.ubc.ca/clf/7.0.4-minimal/css/minimal-clf-full-7.0.4-gw.css
  • //cdn.ubc.ca/clf/7.0.4-minimal/css/minimal-clf-full-7.0.4-wg.css

File Structure

  • complete-clf-no-fontawesome -- the original full package CSS files with only Fontawesome removed
  • full-width -- full and fluid width CLF file package
  • standard -- fixed width CLF file package
  • [package]/original-css -- the unmodified CSS files, including the entire framework
  • [package]/release/css -- the compressed CSS files with unused classes removed
  • [package]/release/optimized -- the minimal release CSS files with Fontawesome removed
  • [package]/uncompressed/css -- the uncompressed CSS files with unused classes removed

Working with this repo

1. Install Node.js and Grunt

  1. If node.js is not installed, https://docs.npmjs.com/getting-started/installing-node
  2. Update Node Pakage Manager (npm) by running: sudo npm install npm -g
  3. Install grunt: npm install -g grunt-cli

2. Clone the repo and install dependencies

  1. Make a local copy of the git repo (using github app, etc)
  2. Using terminal or your cli, navigate to the repo and then into either the full-width or standard directory.
  3. Run npm to install the necessary packages: npm install

3. Run Grunt

  1. Run grunt: grunt

Description

There are two grunt tasks kicked off every time grunt is run: browsersync and watch. Browsersync opens the currently selected html file in a localhost environment,usually localhost:3000, and the Browsersync application at localhost:3001. The watch task updates your html with any updated css.

The other optional tasks are

  1. uncss
  2. cssmin
  3. criticalcss
  4. lesslint
  5. csslint
  6. imagemin
  7. cssnano
  8. optimize (runs uncss and cssmin)
  9. lint (runs csslint and lesslint)
  10. nano (runs cssnano)

Tasks

Uncss

https://www.npmjs.com/package/grunt-uncss Uncss scans the compares the used css selectors used in an associated html file and strips all unused selectors. It then saves the stripped css file to the 'uncompressed' directory. For details, refer to gruntfile.js.

Cssmin

https://www.npmjs.com/package/grunt-contrib-cssmin Cssmin minifies the css files in the 'uncompressed' directory and resaves them into the 'release' directory.

Criticalcss

https://www.npmjs.com/package/grunt-criticalcss

Lesslint

https://www.npmjs.com/package/grunt-lesslint

Csslint

https://www.npmjs.com/package/grunt-contrib-csslint

Imagemin

https://www.npmjs.com/package/grunt-contrib-imagemin

CSSNano

https://www.npmjs.com/package/grunt-cssnano This task should be run last. It's currently parsing the release/css files and doing some additional tasks, including removing the Fontawesome @font-face rule.