Yeoman generator for AngularJS + Sinatra
MIT License
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.
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.
In a new directory, generate the service:
yo angular-sinatra
Run the service:
rackup
Your service will run at http://localhost:9292.
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.