arohner / optimus-less

A LESS asset loader for Optimus.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

optimus-less Build Status

A LESS asset loader for Optimus.

Install

Add [optimus-less "0.2.1"] to :dependencies in your project.clj.

Usage

Add (:require optimus-less.core) to the namespace declaration where you're loading assets.

The load-less-asset function will be declared as a custom loader for .less files with Optimus' load-asset multimethod. This is in turn used by load-assets, load-bundle and load-bundles - so everything works like before, but now it also supports LESS files. Score!

Considerations

  • The .less files are immediately transpiled into .css files. This means you can safely bundle CSS and LESS files together. It also means that the bundle identifier has to be .css. Like so:

    (assets/load-bundle "public"
                        "styles.css"
                        ["/styles/reset.css"
                         "/styles/main.less"])
  • The less transpiler is fast. That doesn't mean you should be compiling the entirety of Bootstrap.less with it. It'll take about 350 ms, and make your development environment sluggish. Use precompiled CSS sources for Bootstrap, and use optimus-less for your own files.

Contribute

Yes, please do.

Maybe you'd like to add some clever caching so we could even include the raw Bootstrap LESS files without a slowdown?

If you're looking to add other transpilers, I think that would be best in a separate project. But please do let me know about it, so I can link to it in the Optimus README. :-)

Remember to add tests for your feature or fix, or I'll certainly break it later.

Running the tests

lein midje will run all tests.

lein midje :autotest will run all the tests indefinitely. It sets up a watcher on the code files. If they change, only the relevant tests will be run again.

License

Copyright © 2014 Magnar Sveen

Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.

About

A LESS asset loader for Optimus.


Languages

Language:Clojure 100.0%