Project

rang

0.0
No commit activity in last 3 years
No release in over 3 years
Provides a suite of generators and adjustments that make Rails a seamless AngularJS development environment to rival Grunt and Gulp.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.6
~> 10.0
~> 3.0
~> 2.0

Runtime

 Project Readme

Rang

This is a gem that makes Rails and Angular play nicely together.

It should replace all the strange initializers and bag of angular_* gems you've got in your Rails & Angular project.

Where existing solutions are effective and well-maintained, they are included. Otherwise, we've included our own.

Installation

Add this to your Gemfile:

gem 'rang'

Then:

$ bundle install

Quickstart

# Prompts you to run each of the generators below.
$ rails g rang:install

Features

This gem collects quite a few things. Summary:

  • Facilitates the Angular best practice structure.
  • Serves and precompiles Angular templates.
  • Precompiles Angular with DI annotations.
  • Uses rails-assets to manage Bower dependencies.
  • Gets Angular + Rails working together on CSRF protection.
  • Provides an ng-view root route.
  • Provides a generator to install and configure Teaspoon for Angular.
  • Configures slim, if available, to ignore { and }.

Frontend structure

Instead of using /assets/javascripts, /assets/stylesheets, etc, this gem supports following the best practice structure recommended by Google. This very readable post sets out the rationale and walks through the recommended structure.

What this means in practice is that assets in assets/frontend are served and compiled just like assets/javascripts and assets/stylesheets would be.

To get started:

# This should be non-destructive, but it's your assets on the line.
$ rails g rang:assets:init

This moves your existing /app/assets to /app/assets.removed and sets up a fresh assets directory following the best practice structure.

Caveats:

  • CSS might still need some special treatment.
  • The structure is still under active refinement. However, this gem is flexible enough to accept most changes.

Templates

In line with the structure above, Rang also compiles templates into Angular's $templateCache. You should load them in your routes like this:

angular
  .module('blog.posts', ['ngRoute'])
  .config(function($routeProvider) {
    $routeProvider
      .when('/posts', {
        templateUrl: '/assets/posts/posts.html', // Use .html, not .slim, etc
        controller: 'PostsController'
      });
  });

And then in your application.js, follow this structure:

//= require angular
//= require angular-route
//= require posts/posts
//= require angular-templates

angular.module('blog', ['blog.posts', 'ngRoute'])
  .config(function($routeProvider){
    $routeProvider.otherwise({
      redirectTo: '/posts'
    });
  })
  .run(AngularTemplates.load);

AngularTemplates.load is DI'd with $templateCache and includes all the templates in your directory tree.

Slim is automatically supported for assets if it's in your Gemfile.

Annotation (minification)

Rang employs ng-annotate (via ngannotiate-rails) to make sure your Angular code is minified properly.

Bower dependencies

Rang uses rails-assets.org to include bower packages. While a little slow sometimes, it's still a better solution than requiring npm and bower / having a load of useless stuff in source control. For now.

It manages the rails-assets dependencies in an auxilliary gemfile called Gemfile.bower. This can be created and managed with generators.

Usage:

# Not strictly necessary, but take a look at what it generates.
$ rails g rang:bower:init

# Adds angular-cookies gem to Gemfile.bower.
$ rails g rang:bower:add angular-cookies '~ 1.2.0'

# As above, but runs bundler after.
$ rails g rang:bower:add angular@ '~ 1.2.0'

Teaspoon

$ rails g rang:teaspoon:install

This does the following:

  • Adds teaspoon & phantomjs to your Gemfile.
  • Runs the normal teaspoon:install generator.
  • Adds angular-mocks to your Gemfile.bower and includes it in spec_helper.js.
  • Preconfigures Teaspoon to fix some issues (#120, #197).
  • Configures Teaspoon to enable putting specs alongside your code (optional).

API Configuration

$ rails g rang:api:configure

This does the following:

  • Installs and confgures active_model_serializers to serve Angular-appropriate JSON out of the box.
  • Installs and requires angular-restmod, a Rails-inspired ORM for Angular.
  • Sets up an api/ route and controller scope for your API controllers.

CSRF

Rang uses angular_rails_csrf to join up Rails + Angular's CSRF protection.

So you don't need to feel bad turning it off anymore!

Root route

To avoid having a controller just to serve 'ng-view' there's a convenience action for you to wire your root to.

$ rails g rang:add_root

Adds this to config/routes.rb:

mount Rang::Engine => "/"

Contributing

  1. Fork it ( https://github.com/[my-github-username]/rails-meet-angular/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request