# Jekyll::Assets
[![Gem Version](https://badge.fury.io/rb/jekyll-assets.svg)](http://badge.fury.io/rb/jekyll-assets)
[![Build Status](https://travis-ci.org/ixti/jekyll-assets.svg?branch=master)](http://travis-ci.org/ixti/jekyll-assets)
[![Dependency Status](https://gemnasium.com/ixti/jekyll-assets.svg)](https://gemnasium.com/ixti/jekyll-assets)
[![Code Climate](https://codeclimate.com/github/ixti/jekyll-assets.svg)](https://codeclimate.com/github/ixti/jekyll-assets)
[![Coverage Status](https://coveralls.io/repos/ixti/jekyll-assets/badge.svg?branch=master)](https://coveralls.io/r/ixti/jekyll-assets?branch=master)
Jekyll plugin, that adds Rails-alike assets pipeline, that means that:
- It allows you to write javascript/css assets in other languages such as
CoffeeScript, Sass, Less and ERB.
- It allows you to specify dependencies between your assets and automatically
concatenates them.
- It allows you to minify/compress your JavaScript and CSS assets using
compressor you like: YUI, SASS, Uglifier or no compression at all.
- It supports JavaScript templates for client-side rendering of strings or
markup. JavaScript templates have the special format extension `.jst` and are
compiled to JavaScript functions.
- Adds MD5 fingerprint suffix for _cache busting_. That means your `app.css`
will become `app-908e25f4bf641868d8683022a5b62f54.css`. See `cachebust`
configuration option for other variants.
- Produce gzipped versions of assets. See `gzip` configuration option for
details.
[compass]: http://compass-style.org/
[bourbon]: http://bourbon.io/
[neat]: http://neat.bourbon.io/
[autoprefixer]: https://github.com/postcss/autoprefixer
[rails_assets]: https://rails-assets.org/
Jekyll-Assets uses fabulous [Sprockets][sprockets] under the hood, so you may
refer to Rails guide about [Asset Pipeline][rails-guide] for detailed
information about amazing features it gives you.
*Note:* You must have an [ExecJS][extjs] supported runtime in order to use
CoffeeScript.
[rails-guide]: http://guides.rubyonrails.org/asset_pipeline.html
[sprockets]: https://github.com/sstephenson/sprockets#readme
[extjs]: https://github.com/sstephenson/execjs#readme
For a quick start check out [jekyll-assets introduction][jekyll-assets-intro]
that shows how to use it step by step. Also you might want to take a look on
[my blog sources][ixti-blog-src] as a real-world example as well.
[jekyll-assets-intro]: http://ixti.net/software/2012/12/30/unleash-mr-hyde-introduction-of-jekyll-assets.html
[ixti-blog-src]: https://github.com/ixti/ixti.github.com
## Installation
Add this line to your application's Gemfile:
gem 'jekyll-assets'
And then execute:
$ bundle
Or install it yourself as:
$ gem install jekyll-assets
## How to Use Jekyll-Assets
First of all make sure to require it. Common practice is to add following line
into `_plugins/ext.rb` file:
``` ruby
require "jekyll/assets"
```
Once plugin installed, you'll have following Liquid tags available:
- `{% javascript app %}`: Generates `
{% asset_path "my logo.png" %}
{% asset_path 'my logo.png' %}
```
Also you'll have complimentary Liquid filters as well:
- `{{ 'app' | javascript }}`: Generates `