Home

Awesome

The Angular-Sinatra generator

A Yeoman generator for AngularJS and Sinatra.

Sinatra is a Ruby-based micro-framework. For AngularJS integration with other micro-frameworks, see https://github.com/rayokota/MicroFrameworkRosettaStone.

Installation

Install Git, node.js, and Ruby 1.9 or JRuby (1.9 mode). Install the Bundler gem. The development mode also requires SQLite.

Install Yeoman:

npm install -g yo

Install the Angular-Sinatra generator:

npm install -g generator-angular-sinatra

The above prerequisites can be installed to a VM using the Angular-Sinatra provisioner.

Creating a Sinatra service

In a new directory, generate the service:

yo angular-sinatra

Run the service:

rackup

Your service will run at http://localhost:9292.

Creating a persistent entity

Generate the entity:

yo angular-sinatra:entity [myentity]

You will be asked to specify attributes for the entity, where each attribute has the following:

Files that are regenerated will appear as conflicts. Allow the generator to overwrite these files as long as no custom changes have been made.

Run the service:

rackup

A client-side AngularJS application will now be available by running

grunt server

The Grunt server will run at http://localhost:9000. It will proxy REST requests to the Sinatra service running at http://localhost:9292.

At this point you should be able to navigate to a page to manage your persistent entities.

The Grunt server supports hot reloading of client-side HTML/CSS/Javascript file changes.