Greased Lightning

Sinatra Exstatic Assets

Helpers for your JS, CSS and anything static

Usage

Note that there is a Main App and an App2. This is to demonstrate that you can give links relative to the app, but if they are mounted with an extra prefix (using Rack#map, for example) the helper will respect that and produce the right href attribute.

Installation and loading

Start by installing:

gem 'sinatra-exstatic-assets'

Then require it in your Sinatra app.

require 'sinatra/exstatic_assets'

The helpers

Use these helpers in your views.

To add an attribute to a helper, pass it as an option, e.g. width: "500"

Sometimes, you won't want the script tag (e.g. "/app2") prepended to the url, like in the case of a favicon. In that case you can pass in url_options: {script_tag: false} to the helper, e.g. favicon_tag url_options: {script_tag: false}

stylesheet_tag

The code:

stylesheet_tag "/css/screen.css"

Output:

<link charset="utf-8" href="/app2/css/screen.css?ts=1367612251" media="screen" rel="stylesheet" />

Also known as:

  • css_tag
  • stylesheet

javascript_tag

The code:

javascript_tag "http://code.jquery.com/jquery-1.9.1.min.js"

Output:

<script charset="utf-8" src="http://code.jquery.com/jquery-1.9.1.min.js"></script>

The code:

javascript_tag "/js/helpers.js"

Output:

<script charset="utf-8" src="/app2/js/helpers.js?ts=1367612251"></script>

Also known as:

  • javascript_include_tag
  • js_tag
  • script_tag

image_tag

The code:

image_tag "http://farm1.staticflickr.com/10/12470738_fc0212bf8c.jpg", width: "500", height: "375", alt: "Greased Lightning"

Output:

<img alt="Greased Lightning" height="375" src="http://farm1.staticflickr.com/10/12470738_fc0212bf8c.jpg" width="500" />

The code:

image_tag "/images/turnip.jpg", width: "500", height: "375", alt: "Turnip"

Output:

<img alt="Turnip" height="375" src="/app2/images/turnip.jpg?ts=1367612251" width="500" />

Also known as:

  • img_tag
  • img

favicon_tag

The code:

favicon_tag

Output:

<link href="/app2/favicon.ico" rel="icon" />