bbr-wsm 1.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (34) hide show
  1. checksums.yaml +7 -0
  2. data/MIT-LICENSE +20 -0
  3. data/README.md +146 -0
  4. data/Rakefile +48 -0
  5. data/lib/backbone-rails.rb +6 -0
  6. data/lib/generators/backbone/install/install_generator.rb +42 -0
  7. data/lib/generators/backbone/install/templates/app.coffee +11 -0
  8. data/lib/generators/backbone/model/model_generator.rb +19 -0
  9. data/lib/generators/backbone/model/templates/model.coffee +11 -0
  10. data/lib/generators/backbone/resource_helpers.rb +55 -0
  11. data/lib/generators/backbone/router/router_generator.rb +44 -0
  12. data/lib/generators/backbone/router/templates/router.coffee +14 -0
  13. data/lib/generators/backbone/router/templates/template.jst +2 -0
  14. data/lib/generators/backbone/router/templates/view.coffee +8 -0
  15. data/lib/generators/backbone/scaffold/scaffold_generator.rb +31 -0
  16. data/lib/generators/backbone/scaffold/templates/model.coffee +11 -0
  17. data/lib/generators/backbone/scaffold/templates/router.coffee +31 -0
  18. data/lib/generators/backbone/scaffold/templates/templates/edit.jst +17 -0
  19. data/lib/generators/backbone/scaffold/templates/templates/index.jst +16 -0
  20. data/lib/generators/backbone/scaffold/templates/templates/model.jst +7 -0
  21. data/lib/generators/backbone/scaffold/templates/templates/new.jst +17 -0
  22. data/lib/generators/backbone/scaffold/templates/templates/show.jst +9 -0
  23. data/lib/generators/backbone/scaffold/templates/views/edit_view.coffee +24 -0
  24. data/lib/generators/backbone/scaffold/templates/views/index_view.coffee +20 -0
  25. data/lib/generators/backbone/scaffold/templates/views/model_view.coffee +19 -0
  26. data/lib/generators/backbone/scaffold/templates/views/new_view.coffee +37 -0
  27. data/lib/generators/backbone/scaffold/templates/views/show_view.coffee +8 -0
  28. data/lib/rails-backbone.rb +2 -0
  29. data/lib/tasks/backbone-rails_tasks.rake +4 -0
  30. data/vendor/assets/javascripts/backbone.js +1582 -0
  31. data/vendor/assets/javascripts/backbone_datalink.js +21 -0
  32. data/vendor/assets/javascripts/backbone_rails_sync.js +32 -0
  33. data/vendor/assets/javascripts/underscore.js +1276 -0
  34. metadata +216 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 1f39089fa98ee0fea9e701fa501f3526f476ecef
4
+ data.tar.gz: 041b48535594d49ba963b0cacef2b5dee4378685
5
+ SHA512:
6
+ metadata.gz: c7a4f2b06d8cd4a00e23ed11161df0cb60fdf6b5a56b3055357ff12815e19466991cf1c95b8b37865054560387509e7cb64524d21554b637427fcd2eac14d94e
7
+ data.tar.gz: 14c248985c15734ad97b8c5f3d9bdcc371a584d8b6f2c18fd49a11525d96ab7260802e102e423bc4edd4d1241bf6a9be886f219bf76e379b4c435e0d4eee9e60
data/MIT-LICENSE ADDED
@@ -0,0 +1,20 @@
1
+ Copyright 2011 Ryan Fitzgerald
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,146 @@
1
+ # Backbone-Rails [![Build Status](https://secure.travis-ci.org/codebrew/backbone-rails.png)](http://travis-ci.org/codebrew/backbone-rails)[![Gem Version](https://badge.fury.io/rb/rails-backbone.png)](http://badge.fury.io/rb/rails-backbone)
2
+
3
+ Easily setup and use backbone.js (1.1.0) with Rails 3.1 and greater
4
+
5
+ ##Version##
6
+
7
+ ###Github master branch###
8
+
9
+ Gem version : 1.1.0
10
+
11
+ Backbone version : 1.1.0
12
+
13
+ Underscore version : 1.5.2
14
+
15
+ ###Rubygems###
16
+
17
+ Gem version : 0.9.10
18
+
19
+ Backbone version : 0.9.10
20
+
21
+ Underscore version : 1.4.3
22
+
23
+
24
+ ##Credits##
25
+ ###Author###
26
+ [Ryan Fitzgerald](http://twitter.com/#!/TheRyanFitz)
27
+ ###Current Maintainer
28
+ [Manu S Ajith](http://twitter.com/manusajith)
29
+ ###Contributors###
30
+ These [awesome people](https://github.com/codebrew/backbone-rails/graphs/contributors) helped to keep this gem updated
31
+
32
+ ## Rails setup
33
+ This gem requires the use of rails 3.1 and greater, coffeescript and the new rails asset pipeline provided by sprockets.
34
+
35
+ This gem vendors the latest version of underscore.js and backbone.js for Rails 3.1 and greater. The files will be added to the asset pipeline and available for you to use.
36
+
37
+ ### Installation
38
+
39
+ In your Gemfile, add this line:
40
+
41
+ gem "rails-backbone"
42
+
43
+ Then run the following commands:
44
+
45
+ bundle install
46
+ rails g backbone:install
47
+
48
+ ### Layout and namespacing
49
+
50
+ Running `rails g backbone:install` will create the following directory structure under `app/assets/javascripts/backbone`:
51
+
52
+ routers/
53
+ models/
54
+ templates/
55
+ views/
56
+
57
+ It will also create a toplevel app_name.coffee file to setup namespacing and setup initial requires.
58
+
59
+ ## Generators
60
+ backbone-rails provides 3 simple generators to help get you started using backbone.js with rails 3.1 and greater.
61
+ The generators will only create client side code (javascript).
62
+
63
+ ### Model Generator
64
+
65
+ rails g backbone:model
66
+
67
+ This generator creates a backbone model and collection inside `app/assets/javascript/backbone/models` to be used to talk to the rails backend.
68
+
69
+ ### Routers
70
+
71
+ rails g backbone:router
72
+
73
+ This generator creates a backbone router with corresponding views and templates for the given actions provided.
74
+
75
+ ### Scaffolding
76
+
77
+ rails g backbone:scaffold
78
+
79
+ This generator creates a router, views, templates, model and collection to create a simple crud single page app
80
+
81
+ ## Example Usage
82
+
83
+ Created a new rails application called `blog`.
84
+
85
+ rails new blog
86
+
87
+ Edit your Gemfile and add
88
+
89
+ gem 'rails-backbone'
90
+
91
+ Install the gem and generate scaffolding.
92
+
93
+ bundle install
94
+ rails g backbone:install
95
+ rails g scaffold Post title:string content:string
96
+ rake db:migrate
97
+ rails g backbone:scaffold Post title:string content:string
98
+
99
+ You now have installed the backbone-rails gem, setup a default directory structure for your frontend backbone code.
100
+ Then you generated the usual rails server side crud scaffolding and finally generated backbone.js code to provide a simple single page crud app.
101
+ You have one last step:
102
+
103
+ Edit your posts index view `app/views/posts/index.html.erb` with the following contents:
104
+
105
+ <div id="posts"></div>
106
+
107
+ <script type="text/javascript">
108
+ $(function() {
109
+ // Blog is the app name
110
+ window.router = new Blog.Routers.PostsRouter({posts: <%= @posts.to_json.html_safe -%>});
111
+ Backbone.history.start();
112
+ });
113
+ </script>
114
+
115
+ If you prefer haml, this is equivalent to inserting the following code into `app/views/posts/index.html.haml`:
116
+
117
+ #posts
118
+
119
+ :javascript
120
+ $(function() {
121
+ // Blog is the app name
122
+ window.router = new Blog.Routers.PostsRouter({posts: #{@posts.to_json.html_safe}});
123
+ Backbone.history.start();
124
+ });
125
+
126
+
127
+ Now start your server `rails s` and browse to [localhost:3000/posts](http://localhost:3000/posts)
128
+ You should now have a fully functioning single page crud app for Post models.
129
+
130
+ ##Note:##
131
+ ####Overrides backbone sync function####
132
+ This gem overrides the backbone sync function. Check [here](https://github.com/codebrew/backbone-rails/blob/master/vendor/assets/javascripts/backbone_rails_sync.js) for details.
133
+
134
+ ####With Rails 4:####
135
+ If you are using the default Rails 4 scaffold generators, you will need to adjust the default JSON show view (IE, 'show.json') to render the 'id' attribute.
136
+
137
+ default rails generated show.json.jbuilder
138
+
139
+ `json.extract! @post, :title, :content, :created_at, :updated_at, :id`
140
+
141
+ Change it to add `id` attribute as well
142
+
143
+ `json.extract! @book, :id, :title, :author, :created_at, :updated_at`
144
+
145
+ Without adjusting the JSON show view, you will be redirected to a "undefined" url after creating an object.
146
+
data/Rakefile ADDED
@@ -0,0 +1,48 @@
1
+ #!/usr/bin/env rake
2
+ begin
3
+ require 'bundler/setup'
4
+ rescue LoadError
5
+ puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
6
+ end
7
+
8
+ require 'bundler/gem_tasks'
9
+ require 'rdoc/task'
10
+
11
+ RDoc::Task.new(:rdoc) do |rdoc|
12
+ rdoc.rdoc_dir = 'rdoc'
13
+ rdoc.title = 'BackboneRails'
14
+ rdoc.options << '--line-numbers' << '--inline-source'
15
+ rdoc.rdoc_files.include('README.md')
16
+ rdoc.rdoc_files.include('lib/**/*.rb')
17
+ end
18
+
19
+ require 'rake/testtask'
20
+
21
+ Rake::TestTask.new(:test) do |t|
22
+ t.libs << 'lib'
23
+ t.libs << 'test'
24
+ t.pattern = 'test/**/*_test.rb'
25
+ t.verbose = false
26
+ end
27
+
28
+ task :default => :test
29
+
30
+ namespace :backbone do
31
+ desc "Download the latest released versions of underscore and backbone.js"
32
+ task :download_latest do
33
+ files = {
34
+ 'underscore.js'=>'http://underscorejs.org/underscore.js',
35
+ 'backbone.js' => 'http://backbonejs.org/backbone.js'
36
+ }
37
+
38
+ vendor_dir = "vendor/assets/javascripts"
39
+
40
+ require 'open-uri'
41
+ files.each do |local,remote|
42
+ puts "Downloading #{local}"
43
+ File.open "#{vendor_dir}/#{local}", 'w' do |f|
44
+ f.write open(remote).read
45
+ end
46
+ end
47
+ end
48
+ end
@@ -0,0 +1,6 @@
1
+ require 'rails'
2
+
3
+ module BackboneRails
4
+ class Engine < Rails::Engine
5
+ end
6
+ end
@@ -0,0 +1,42 @@
1
+ require 'generators/backbone/resource_helpers'
2
+
3
+ module Backbone
4
+ module Generators
5
+ class InstallGenerator < Rails::Generators::Base
6
+ include Backbone::Generators::ResourceHelpers
7
+
8
+ source_root File.expand_path("../templates", __FILE__)
9
+
10
+ desc "This generator installs backbone.js with a default folder layout in app/assets/javascripts/backbone"
11
+
12
+ class_option :skip_git, :type => :boolean, :aliases => "-G", :default => false,
13
+ :desc => "Skip Git ignores and keeps"
14
+
15
+ def inject_backbone
16
+ # for JavaScript application.js manifest:
17
+ if File.exists? "#{Rails.root}/app/assets/javascripts/application.js"
18
+ append_to_file "app/assets/javascripts/application.js" do
19
+ "//= require underscore\n//= require backbone\n//= require backbone_rails_sync\n//= require backbone_datalink\n//= require backbone/#{application_name.underscore}\n"
20
+ end
21
+ # ...or for CoffeeScript application.js.coffee manifest:
22
+ elsif File.exists? "#{Rails.root}/app/assets/javascripts/application.js.coffee"
23
+ append_to_file "app/assets/javascripts/application.js.coffee" do
24
+ "\n#= require underscore\n#= require backbone\n#= require backbone_rails_sync\n#= require backbone_datalink\n#= require backbone/#{application_name.underscore}\n"
25
+ end
26
+ end
27
+ end
28
+
29
+ def create_dir_layout
30
+ %W{routers models views templates}.each do |dir|
31
+ empty_directory "app/assets/javascripts/backbone/#{dir}"
32
+ create_file "app/assets/javascripts/backbone/#{dir}/.gitkeep" unless options[:skip_git]
33
+ end
34
+ end
35
+
36
+ def create_app_file
37
+ template "app.coffee", "app/assets/javascripts/backbone/#{application_name.underscore}.js.coffee"
38
+ end
39
+
40
+ end
41
+ end
42
+ end
@@ -0,0 +1,11 @@
1
+ #= require_self
2
+ #= require_tree ./templates
3
+ #= require_tree ./models
4
+ #= require_tree ./views
5
+ #= require_tree ./routers
6
+
7
+ window.<%= js_app_name %> =
8
+ Models: {}
9
+ Collections: {}
10
+ Routers: {}
11
+ Views: {}
@@ -0,0 +1,19 @@
1
+ require 'generators/backbone/resource_helpers'
2
+
3
+ module Backbone
4
+ module Generators
5
+ class ModelGenerator < Rails::Generators::NamedBase
6
+ include Backbone::Generators::ResourceHelpers
7
+
8
+ source_root File.expand_path("../templates", __FILE__)
9
+ desc "This generator creates a backbone model"
10
+
11
+ argument :attributes, :type => :array, :default => [], :banner => "field:type field:type"
12
+
13
+ def create_backbone_model
14
+ template "model.coffee", "#{backbone_path}/models/#{file_name}.js.coffee"
15
+ end
16
+
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,11 @@
1
+ class <%= model_namespace %> extends Backbone.Model
2
+ paramRoot: '<%= singular_table_name %>'
3
+
4
+ defaults:
5
+ <% attributes.each do |attribute| -%>
6
+ <%= attribute.name %>: null
7
+ <% end -%>
8
+
9
+ class <%= collection_namespace %>Collection extends Backbone.Collection
10
+ model: <%= model_namespace %>
11
+ url: '<%= route_url %>'
@@ -0,0 +1,55 @@
1
+ module Backbone
2
+ module Generators
3
+ module ResourceHelpers
4
+
5
+ def backbone_path
6
+ "app/assets/javascripts/backbone"
7
+ end
8
+
9
+ def model_namespace
10
+ [js_app_name, "Models", class_name].join(".")
11
+ end
12
+
13
+ def singular_model_name
14
+ uncapitalize singular_name.camelize
15
+ end
16
+
17
+ def plural_model_name
18
+ uncapitalize(plural_name.camelize)
19
+ end
20
+
21
+ def collection_namespace
22
+ [js_app_name, "Collections", plural_name.camelize].join(".")
23
+ end
24
+
25
+ def view_namespace
26
+ [js_app_name, "Views", plural_name.camelize].join(".")
27
+ end
28
+
29
+ def router_namespace
30
+ [js_app_name, "Routers", plural_name.camelize].join(".")
31
+ end
32
+
33
+ def jst(action)
34
+ "backbone/templates/#{plural_name}/#{action}"
35
+ end
36
+
37
+ def js_app_name
38
+ application_name.camelize
39
+ end
40
+
41
+ def application_name
42
+ if defined?(Rails) && Rails.application
43
+ Rails.application.class.name.split('::').first
44
+ else
45
+ "application"
46
+ end
47
+ end
48
+
49
+ def uncapitalize(str)
50
+ str[0, 1].downcase << str[1..-1]
51
+ end
52
+
53
+ end
54
+ end
55
+ end
@@ -0,0 +1,44 @@
1
+ require 'generators/backbone/resource_helpers'
2
+
3
+ module Backbone
4
+ module Generators
5
+ class RouterGenerator < Rails::Generators::NamedBase
6
+ include Backbone::Generators::ResourceHelpers
7
+
8
+ source_root File.expand_path("../templates", __FILE__)
9
+ desc "This generator creates a backbone router with views and templates for the provided actions"
10
+
11
+ argument :actions, :type => :array, :default => [], :banner => "action action"
12
+
13
+ RESERVED_JS_WORDS = %W{
14
+ break case catch continue debugger default delete do else finally for
15
+ function if in instanceof new return switch this throw try typeof var void while with
16
+ }
17
+
18
+ def validate_no_reserved_words
19
+ actions.each do |action|
20
+ if RESERVED_JS_WORDS.include? action
21
+ raise Thor::Error, "The name '#{action}' is reserved by javascript " <<
22
+ "Please choose an alternative action name and run this generator again."
23
+ end
24
+ end
25
+ end
26
+
27
+ def create_router_files
28
+ template 'router.coffee', File.join(backbone_path, "routers", class_path, "#{file_name}_router.js.coffee")
29
+ end
30
+
31
+ def create_view_files
32
+ actions.each do |action|
33
+ @action = action
34
+ @view_path = File.join(backbone_path, "views", plural_name, "#{action}_view.js.coffee")
35
+ @jst_path = File.join(backbone_path,"templates", plural_name, "#{action}.jst.ejs")
36
+
37
+ template "view.coffee", @view_path
38
+ template "template.jst", @jst_path
39
+ end
40
+ end
41
+
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,14 @@
1
+ class <%= router_namespace %>Router extends Backbone.Router
2
+ initialize: (options) ->
3
+
4
+ routes:
5
+ <% actions.each do |action| -%>
6
+ "<%= action %>": "<%= action %>"
7
+ <% end -%>
8
+
9
+ <% actions.each do |action| -%>
10
+ <%= action %>: ->
11
+ @view = new <%= "#{view_namespace}.#{action.camelize}View()" %>
12
+ $("#<%= plural_name %>").html(@view.render().el)
13
+
14
+ <% end -%>
@@ -0,0 +1,2 @@
1
+ <h1><%= class_name %>#<%= @action %></h1>
2
+ <p>Find me in <%= @jst_path %></p>