Skip to content
This repository

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP

Collection of useful frontend helpers for Rails 3.1 applications

Fetching latest commit…

Octocat-spinner-32-eaf2f5

Cannot retrieve the latest commit at this time

Octocat-spinner-32 config
Octocat-spinner-32 lib
Octocat-spinner-32 script
Octocat-spinner-32 test
Octocat-spinner-32 vendor
Octocat-spinner-32 .gitignore
Octocat-spinner-32 Gemfile
Octocat-spinner-32 Gemfile.lock
Octocat-spinner-32 LICENSE.txt
Octocat-spinner-32 MIT-LICENSE
Octocat-spinner-32 README.md
Octocat-spinner-32 Rakefile
Octocat-spinner-32 frontend-helpers.gemspec
README.md

Frontend Helpers

HARD DEPENDENCY: HAML & SASS I do plan on making it work for both ERB & HAML but currently all my projects use both, so I haven't found the time to add this option.

This is a collection of Rails 3.1 Helpers that I have compiled together into one nice neat special little gem... it'll handle doing things such as a few HTML5 helpers, Meta tag creation, Facebook Open Graph Tag Creation, javascript integration for, Google Analytics, Chartbeat, Inspectlet, Mixpanel, Woopra, Kissmetrics, Quantcast, and Olark, as well I've packaged in a few of my favorite/most used javascript libraries for building amazing web apps, and last but not least, added a great reset.css.sass file that goes really nicely with my variables.css.sass file, for a basic clean view.

Try it on your next project, I'm sure you'll like it.

Getting Started

First in your Rails 3.1 Project start by adding this to your Gemfile:

gem "frontend-helpers"

Then run bundle install to install the gem from RubyGems

Next Steps

If you plan on using the gem for the Rails Helpers, keep reading if you'd only like to use it for the access to the javascript assets & css assets you can skip ahead...

Anyways for the helpers your going to need to generate a few files first to do so run:

$ rails g frontend:install

This should come up and tell you that it's copying config/settings.yml, config/services.yml & app/assets/stylesheets/variables.css.sass

Then you can start editing them:

HTML5

before you use the HTML5 HTML tag as Paul Irish wrote for the HTML5 Boilerplate application_controller.rb add:

include FrontendHelpers::Html5Helper

Then in your application.html.haml instead of using %html use

- html_tag class: 'no-js' do

Settings.yml

Before you start adding your content to the settings.yml you should probably start by including the helper in your application_controller.rb add:

include FrontendHelpers::MetatagHelper

Next where ever you want the metatags to appear use:

- meta_tags

In the settings.yml you'll find a list of tags that can be filled out with your applications information all of these tags will get replicated into meta tags, if you choose not to use one you can either leave it blank or remove it.

Of course just because they are set in this file does not mean you can't change them per page this is how you would do that....

Say for instance you set the key title

:title: "Chris Hein's Site"

And on the homepage you liked that, but maybe on the about page you would like it to say About Chris Hein with this plugin that's really simple, in your action for your about page simple add an instance variable as so:

@meta_title = "About Chris Hein"

This will overwrite the current title with whatever you'd like. This is the list of available tags and how to overwrite them:

title: @meta_title,
keywords: @meta_keywords,
description: @meta_description,
author: @meta_author,
email: @meta_email,
copyright: @meta_copyright,
generator: @meta_generator,
rating: @meta_rating,
language: @meta_language,
distribution: @meta_distribution,
robots: @robots,
:"fb:app_id" => @meta_fb_app_id,
:"og:title" => @meta_og_title,
:"og:description" => @meta_og_description,
:"og:url" => request.url,
:"og:site_name" => @meta_og_site_name,
:"og:type" => @meta_og_type,
:"og:image" => @meta_og_image,
:"og:locality" => @meta_og_locality,
:"og:region" => @meta_og_region,
:"og:country_name" => @meta_og_country_name,
:"og:phone_number" => @meta_og_phone_number

Services.yml

Before you start adding your content to the services.yml you should probably start by including the helper in your application_controller.rb add:

include FrontendHelpers::ServicesHelper

Next where ever you want the services javascript to appear (I'd recommend using it at the end of the body) use:

- webservice [:google, :olark, :chartbeat, :inspectlet, :mixpanel, :woopra, :kissmetrics, :quantcast]

This example shows all of the services that can be included although you will not see any of them unless you have added the necessary information in the services.yml you can remove any of them from the array if need be.

Inside the services.yml you will find all of variables that should be set to use each one of the services. All of them are pretty self explanatory and the keys can be gotten from each service.

Assets

As far as the assets I've added a few of my favorite and most used javascript libraries, those are:

Backbone Underscore DD Belated PNG jQuery Asynchronous Plugin jQuery Cookie plugin jQuery Lifestream jQuery Validation Log Helper Modernizr Shortcut JS SWF Object

All of these can be added to your manifest file for Sprockets like this

//= require backbone
//= require ie
//= require jquery.async
//= require jquery.cookie
//= require jquery.lifestream
//= require jquery.validate
//= require log
//= require modernizr
//= require shortcut
//= require swfobject

Not only did I add a bunch of wonderfully awesome javascript libs I also added a css reset that can be used, as well as a base variables... Although with sprockets currently you cannot include files with persistent variables, so I would highly recommend using SASS's built in @import to include files to do so include both files like so rename application.css to application.css.sass then add:

@import "variables.css.sass"
@import "reset.css.sass"

Thanks

I hope you enjoy using this Rubygem, if you have any questions, issues, or feature requests please make them in the issues section, I'll be continually adding to this so please keep checking in on the progress.

Contributing to Frontend Helpers

  • Check out the latest master to make sure the feature hasn't been implemented or the bug hasn't been fixed yet
  • Check out the issue tracker to make sure someone already hasn't requested it and/or contributed it
  • Fork the project
  • Start a feature/bugfix branch
  • Commit and push until you are happy with your contribution
  • Make sure to add tests for it. This is important so I don't break it in a future version unintentionally.
  • Please try not to mess with the Rakefile, version, or history. If you want to have your own version, or is otherwise necessary, that is fine, but please isolate to its own commit so I can cherry-pick around it.

Copyright

Copyright (c) 2011 Christopher Hein. See LICENSE.txt for further details.

All javascript libraries are still copyrighted to their respective owners, this is just a way to easy add them to any project without having to deal with the files themselves.

Something went wrong with that request. Please try again.