rails_app_generator 0.2.20 → 0.2.23
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.builders/generators/project-plan.rb +19 -5
- data/CHANGELOG.md +22 -0
- data/after_templates/addons/annotate/_.rb +27 -0
- data/after_templates/addons/annotate/app/controllers/home_controller.rb +4 -0
- data/after_templates/addons/annotate/app/views/home/index.html.erb +20 -0
- data/after_templates/addons/annotate/app/views/layouts/_footer.html.erb +3 -0
- data/after_templates/addons/annotate/app/views/layouts/_navbar.html.erb +5 -0
- data/after_templates/addons/annotate/app/views/layouts/application.html.erb +23 -0
- data/after_templates/addons/avo/_.rb +54 -0
- data/after_templates/addons/avo/app/controllers/home_controller.rb +4 -0
- data/after_templates/addons/avo/app/views/home/index.html.erb +3 -0
- data/after_templates/addons/avo/app/views/layouts/_footer.html.erb +3 -0
- data/after_templates/addons/avo/app/views/layouts/_navbar.html.erb +8 -0
- data/after_templates/addons/avo/app/views/layouts/application.html.erb +23 -0
- data/after_templates/addons/avo/db/seeds.rb +132 -0
- data/after_templates/addons/devise/_.rb +70 -0
- data/after_templates/addons/devise/app/controllers/home_controller.rb +4 -0
- data/after_templates/addons/devise/app/controllers/posts_controller.rb +81 -0
- data/after_templates/addons/devise/app/models/post.rb +11 -0
- data/after_templates/addons/devise/app/models/user.rb +17 -0
- data/after_templates/addons/devise/app/views/home/index.html.erb +40 -0
- data/after_templates/addons/devise/app/views/layouts/_footer.html.erb +1 -0
- data/after_templates/addons/devise/app/views/layouts/_navbar.html.erb +10 -0
- data/after_templates/addons/devise/app/views/layouts/application.html.erb +38 -0
- data/after_templates/addons/devise/app/views/posts/_form.html.erb +27 -0
- data/after_templates/addons/devise/app/views/posts/_post.html.erb +14 -0
- data/after_templates/addons/devise/app/views/posts/index.html.erb +12 -0
- data/after_templates/addons/devise/app/views/posts/show.html.erb +8 -0
- data/after_templates/addons/devise/db/seeds.rb +11 -0
- data/after_templates/rag/devise/_.rb +14 -17
- data/after_templates/rag/devise/app/controllers/home_controller.rb +4 -0
- data/after_templates/rag/devise/{post → app/controllers}/posts_controller.rb +0 -0
- data/after_templates/rag/devise/{post → app/models}/post.rb +0 -0
- data/after_templates/rag/devise/app/views/home/index.html.erb +3 -0
- data/after_templates/rag/devise/app/views/layouts/_footer.html.erb +3 -0
- data/after_templates/rag/devise/app/views/layouts/_navbar.html.erb +8 -0
- data/after_templates/rag/devise/app/views/layouts/application.html.erb +24 -0
- data/after_templates/rag/devise/{post → app/views/post}/_post.html.erb +0 -0
- data/after_templates/rag/test/_.rb +64 -0
- data/after_templates/rag/test/app/controllers/home_controller.rb +4 -0
- data/after_templates/rag/test/app/views/home/index.html.erb +3 -0
- data/after_templates/rag/test/app/views/layouts/_footer.html.erb +1 -0
- data/after_templates/rag/test/app/views/layouts/_navbar.html.erb +5 -0
- data/after_templates/rag/test/app/views/layouts/application.html.erb +29 -0
- data/after_templates/rag/test/db/seeds.rb +7 -0
- data/after_templates/rag/testy/_.rb +64 -0
- data/after_templates/rag/testy/app/controllers/home_controller.rb +4 -0
- data/after_templates/rag/testy/app/views/home/index.html.erb +3 -0
- data/after_templates/rag/testy/app/views/layouts/_footer.html.erb +1 -0
- data/after_templates/rag/testy/app/views/layouts/_navbar.html.erb +5 -0
- data/after_templates/rag/testy/app/views/layouts/application.html.erb +29 -0
- data/after_templates/rag/testy/db/seeds.rb +7 -0
- data/docs/last_run/app_generator_class.json +42 -34
- data/docs/last_run/app_generator_data.json +11 -10
- data/docs/last_run/rails_options_class.json +32 -24
- data/docs/last_run/rails_options_data.json +11 -10
- data/docs/project-plan/project.drawio +65 -59
- data/docs/project-plan/project_done.svg +1 -1
- data/lib/rails_app_generator/addon.rb +20 -2
- data/lib/rails_app_generator/addons/avo.rb +27 -0
- data/lib/rails_app_generator/addons/devise.rb +78 -28
- data/lib/rails_app_generator/addons/devise_old.rb +22 -0
- data/lib/rails_app_generator/app_generator.rb +40 -22
- data/lib/rails_app_generator/gem_query.rb +34 -0
- data/lib/rails_app_generator/rag_initializer.rb +22 -8
- data/lib/rails_app_generator/version.rb +1 -1
- data/lib/rails_app_generator.rb +1 -0
- data/package-lock.json +2 -2
- data/package.json +1 -1
- data/profiles/addons/annotate.json +12 -0
- data/profiles/addons/avo.json +16 -0
- data/profiles/addons/devise.json +16 -0
- data/profiles/addons/{rails-html-sanitizer.json → rails_html_sanitizer.json} +0 -0
- data/profiles/rag/testy.json +12 -0
- data/tasks/addon.thor +7 -3
- data/tasks/profile.thor +3 -3
- data/templates/Gemfile.erb +1 -0
- data/{after_templates/rag/devise/turbo_controller.rb → templates/addons/devise/app/controllers/turbo_devise_controller.rb} +4 -10
- data/templates/addons/devise/app/controllers/users/registrations_controller.rb +62 -0
- data/templates/addons/devise/app/views/devise/registrations/edit.html.erb +40 -54
- data/templates/addons/devise/app/views/devise/registrations/new.html.erb +32 -43
- data/templates/addons/devise/app/views/layouts/_alerts.html.erb +2 -0
- data/{after_templates/rag → templates/addons}/devise/config/initializers/devise_turbo.rb +1 -1
- data/templates/thor_task/profile/after_template.rb +3 -2
- data/templates/thor_task/profile/app/views/layouts/_footer.html.erb.tt +1 -3
- data/templates/thor_task/profile/app/views/layouts/_navbar.html.erb +5 -8
- data/templates/thor_task/profile/app/views/layouts/application.html.erb.tt +8 -2
- data/templates/thor_task/profile/db/seeds.rb +2 -11
- metadata +63 -18
- data/after_templates/rag/devise/application.html.erb +0 -20
- data/tasks/gem_info.rb +0 -47
- data/templates/addons/devise/app/views/devise/confirmations/new.html.erb +0 -24
- data/templates/addons/devise/app/views/devise/passwords/edit.html.erb +0 -34
- data/templates/addons/devise/app/views/devise/passwords/new.html.erb +0 -23
- data/templates/addons/devise/app/views/devise/sessions/new.html.erb +0 -33
- data/templates/addons/devise/app/views/devise/shared/_error_messages.html.erb +0 -15
- data/templates/addons/devise/app/views/devise/shared/_form_wrap.html.erb +0 -5
- data/templates/addons/devise/app/views/devise/shared/_links.html.erb +0 -25
- data/templates/addons/devise/app/views/devise/unlocks/new.html.erb +0 -22
@@ -0,0 +1,38 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<title><%= camelized %></title>
|
5
|
+
<meta name="viewport" content="width=device-width,initial-scale=1">
|
6
|
+
<%%= csrf_meta_tags %>
|
7
|
+
<%%= csp_meta_tag %>
|
8
|
+
|
9
|
+
<%- if options[:skip_hotwire] || options[:skip_javascript] -%>
|
10
|
+
<%%= stylesheet_link_tag "application" %>
|
11
|
+
<%- else -%>
|
12
|
+
<%%= stylesheet_link_tag "application", "data-turbo-track": "reload" %>
|
13
|
+
<%- end -%>
|
14
|
+
<%%= javascript_include_tag "application", "data-turbo-track": "reload", defer: true %>
|
15
|
+
<style>
|
16
|
+
.notice {
|
17
|
+
color: green;
|
18
|
+
}
|
19
|
+
.alert {
|
20
|
+
color: red;
|
21
|
+
}
|
22
|
+
</style>
|
23
|
+
</head>
|
24
|
+
|
25
|
+
<body>
|
26
|
+
<header>
|
27
|
+
<%%= render 'layouts/navbar' %>
|
28
|
+
<hr />
|
29
|
+
<%%= render 'layouts/alerts' %>
|
30
|
+
</header>
|
31
|
+
<main>
|
32
|
+
<%%= yield %>
|
33
|
+
</main>
|
34
|
+
<footer>
|
35
|
+
<%%= render 'layouts/footer' %>
|
36
|
+
</footer>
|
37
|
+
</body>
|
38
|
+
</html>
|
@@ -0,0 +1,27 @@
|
|
1
|
+
<%= form_with(model: post) do |form| %>
|
2
|
+
<% if post.errors.any? %>
|
3
|
+
<div style="color: red">
|
4
|
+
<h2><%= pluralize(post.errors.count, "error") %> prohibited this post from being saved:</h2>
|
5
|
+
|
6
|
+
<ul>
|
7
|
+
<% post.errors.each do |error| %>
|
8
|
+
<li><%= error.full_message %></li>
|
9
|
+
<% end %>
|
10
|
+
</ul>
|
11
|
+
</div>
|
12
|
+
<% end %>
|
13
|
+
|
14
|
+
<div>
|
15
|
+
<%= form.label :title, style: "display: block" %>
|
16
|
+
<%= form.text_field :title %>
|
17
|
+
</div>
|
18
|
+
|
19
|
+
<div>
|
20
|
+
<%= form.label :body, style: "display: block" %>
|
21
|
+
<%= form.text_area :body %>
|
22
|
+
</div>
|
23
|
+
|
24
|
+
<div>
|
25
|
+
<%= form.submit %>
|
26
|
+
</div>
|
27
|
+
<% end %>
|
@@ -0,0 +1,14 @@
|
|
1
|
+
<div id="<%= dom_id post %>">
|
2
|
+
<h3>posted by <%= post.user.name || post.user.email %></h4>
|
3
|
+
<h4><%= pluralize(post.views, 'view') %></h4>
|
4
|
+
|
5
|
+
<p>
|
6
|
+
<strong>Title:</strong>
|
7
|
+
<%= post.title %>
|
8
|
+
</p>
|
9
|
+
|
10
|
+
<p>
|
11
|
+
<strong>Body:</strong>
|
12
|
+
<%= post.body %>
|
13
|
+
</p>
|
14
|
+
</div>
|
@@ -0,0 +1,11 @@
|
|
1
|
+
david = User.create(email: 'david@site.com', name: 'david', password: 'password', password_confirmation: 'password', role: :admin)
|
2
|
+
james = User.create(email: 'james@site.com', name: 'james', password: 'password', password_confirmation: 'password')
|
3
|
+
sally = User.create(email: 'sally@site.com', name: 'sally', password: 'password', password_confirmation: 'password', role: :moderator)
|
4
|
+
|
5
|
+
10.times do
|
6
|
+
Post.create(
|
7
|
+
title: "Post #{Faker::Lorem.words(number: rand(1..3)).join(' ')}",
|
8
|
+
body: "#{Faker::Lorem.sentences(number: 8).join("<br />")}",
|
9
|
+
views: 0,
|
10
|
+
user: User.all.sample)
|
11
|
+
end
|
@@ -7,35 +7,32 @@ self.local_template_path = File.dirname(__FILE__)
|
|
7
7
|
|
8
8
|
gac 'base rails 7 image created'
|
9
9
|
|
10
|
-
|
10
|
+
prepare_environment
|
11
11
|
|
12
|
+
add_controller('home', 'index')
|
12
13
|
add_scaffold('post', 'title', 'body:text')
|
13
|
-
route("root 'posts#index'")
|
14
|
+
# route("root 'posts#index'")
|
15
|
+
# generate('devise:views')
|
14
16
|
|
15
17
|
force_copy
|
16
18
|
|
17
|
-
|
18
|
-
|
19
|
+
directory "app/controllers"
|
20
|
+
directory "app/views"
|
19
21
|
|
20
|
-
copy_file '
|
21
|
-
copy_file 'layouts/_navbar.html.erb' , 'app/views/layouts/_navbar.html.erb'
|
22
|
-
copy_file 'layouts/_footer.html.erb' , 'app/views/layouts/_footer.html.erb'
|
23
|
-
template 'layouts/application.html.erb' , 'app/views/layouts/application.html.erb'
|
22
|
+
# copy_file 'application_controller.rb' , 'app/controllers/application_controller.rb'
|
24
23
|
|
25
|
-
copy_file '
|
26
|
-
|
27
|
-
copy_file '
|
28
|
-
|
29
|
-
copy_file 'post/post.rb' , 'app/models/post.rb'
|
24
|
+
# copy_file 'layouts/_alerts.html.erb' , 'app/views/layouts/_alerts.html.erb'
|
25
|
+
# copy_file 'layouts/_navbar.html.erb' , 'app/views/layouts/_navbar.html.erb'
|
26
|
+
# copy_file 'layouts/_footer.html.erb' , 'app/views/layouts/_footer.html.erb'
|
27
|
+
# template 'layouts/application.html.erb' , 'app/views/layouts/application.html.erb'
|
30
28
|
|
31
29
|
copy_file 'user.rb' , 'app/models/user.rb'
|
32
30
|
|
33
|
-
copy_file 'application.html.erb' , 'app/views/layouts/application.html.erb'
|
34
|
-
copy_file 'application_controller.rb' , 'app/controllers/application_controller.rb'
|
35
|
-
|
36
|
-
add_migration('add_user_to_posts', 'user:belongs_to')
|
31
|
+
# copy_file 'application.html.erb' , 'app/views/layouts/application.html.erb'
|
32
|
+
# copy_file 'application_controller.rb' , 'app/controllers/application_controller.rb'
|
37
33
|
|
38
34
|
after_bundle do
|
35
|
+
add_migration('add_user_to_posts', 'user:belongs_to')
|
39
36
|
db_migrate
|
40
37
|
|
41
38
|
append_to_file('db/seeds.rb', read_template('seed_data.rb'))
|
File without changes
|
File without changes
|
@@ -0,0 +1,24 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<title><%= camelized %></title>
|
5
|
+
<meta name="viewport" content="width=device-width,initial-scale=1">
|
6
|
+
<%%= csrf_meta_tags %>
|
7
|
+
<%%= csp_meta_tag %>
|
8
|
+
|
9
|
+
<%- if options[:skip_hotwire] || options[:skip_javascript] -%>
|
10
|
+
<%%= stylesheet_link_tag "application" %>
|
11
|
+
<%- else -%>
|
12
|
+
<%%= stylesheet_link_tag "application", "data-turbo-track": "reload" %>
|
13
|
+
<%- end -%>
|
14
|
+
</head>
|
15
|
+
|
16
|
+
<body>
|
17
|
+
<%%= render 'layouts/navbar' %>
|
18
|
+
<%%= render 'layouts/alert' %>
|
19
|
+
<main>
|
20
|
+
<%%= yield %>
|
21
|
+
</main>
|
22
|
+
<%%= render 'layouts/footer' %>
|
23
|
+
</body>
|
24
|
+
</html>
|
File without changes
|
@@ -0,0 +1,64 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Description goes here
|
4
|
+
#
|
5
|
+
# exe/rag addons/test
|
6
|
+
|
7
|
+
self.local_template_path = File.dirname(__FILE__)
|
8
|
+
|
9
|
+
gac 'base rails 7 image created'
|
10
|
+
|
11
|
+
prepare_environment
|
12
|
+
|
13
|
+
add_controller('home', 'index')
|
14
|
+
|
15
|
+
route("root 'home#index'")
|
16
|
+
|
17
|
+
force_copy
|
18
|
+
|
19
|
+
directory "app/controllers"
|
20
|
+
directory "app/views/home"
|
21
|
+
directory "app/views/layouts"
|
22
|
+
template 'app/views/layouts/application.html.erb' , 'app/views/layouts/application.html.erb'
|
23
|
+
|
24
|
+
template 'db/seeds.rb' , 'db/seeds.rb'
|
25
|
+
|
26
|
+
after_bundle do
|
27
|
+
setup_db
|
28
|
+
end
|
29
|
+
|
30
|
+
def setup_db
|
31
|
+
# add_scaffold('post', 'title', 'body:text', 'user:references')
|
32
|
+
# add_scaffold('people', 'first_name', 'last_name', 'age:integer', 'address:text')
|
33
|
+
# add_scaffold('product', 'name', 'price:integer')
|
34
|
+
|
35
|
+
# db_migrate
|
36
|
+
# db_seed
|
37
|
+
end
|
38
|
+
|
39
|
+
# Other template command examples
|
40
|
+
# prepare_environment
|
41
|
+
# bundle_install
|
42
|
+
# css_install('tailwind')
|
43
|
+
# rails_command('db:migrate')
|
44
|
+
# rails_command('db:migrate')
|
45
|
+
# bundle_add('hotwire-rails')
|
46
|
+
# rails_command('hotwire:install')
|
47
|
+
# run('bin/importmap pin sortablejs')
|
48
|
+
# run('npm install daisyui')
|
49
|
+
# rubocop
|
50
|
+
#
|
51
|
+
# directory 'app/assets/images'
|
52
|
+
# create_file 'app/assets/stylesheets/custom-bootstrap-import.scss' , read_template('custom-bootstrap-import.scss')
|
53
|
+
# append_to_file 'app/assets/config/manifest.js' , read_template('manifest.js')
|
54
|
+
# insert_into_file 'app/views/layouts/application.html.erb', read_template('application.html.erb'),
|
55
|
+
# before: %( <%= javascript_include_tag "application", "data-turbo-track": "reload", defer: true %>)
|
56
|
+
# gsub_file 'app/views/layouts/application.html.erb', %(container mx-auto mt-28 px-5 flex), 'container mx-auto px-5'
|
57
|
+
# template 'home.css', 'app/assets/stylesheets/home.css'
|
58
|
+
#
|
59
|
+
# add_controller('page', 'benefits', 'faq', 'terms', 'privacy', '--skip-routes')
|
60
|
+
# route(<<-'RUBY')
|
61
|
+
# PageController.action_methods.each do |action|
|
62
|
+
# get "/#{action}", to: "page##{action}", as: "page_#{action}"
|
63
|
+
# end
|
64
|
+
# RUBY
|
@@ -0,0 +1 @@
|
|
1
|
+
<hr />
|
@@ -0,0 +1,29 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<title><%= camelized %></title>
|
5
|
+
<meta name="viewport" content="width=device-width,initial-scale=1">
|
6
|
+
<%%= csrf_meta_tags %>
|
7
|
+
<%%= csp_meta_tag %>
|
8
|
+
|
9
|
+
<%- if options[:skip_hotwire] || options[:skip_javascript] -%>
|
10
|
+
<%%= stylesheet_link_tag "application" %>
|
11
|
+
<%- else -%>
|
12
|
+
<%%= stylesheet_link_tag "application", "data-turbo-track": "reload" %>
|
13
|
+
<%- end -%>
|
14
|
+
</head>
|
15
|
+
|
16
|
+
<body>
|
17
|
+
<header>
|
18
|
+
<%%= render 'layouts/navbar' %>
|
19
|
+
<hr />
|
20
|
+
</header>
|
21
|
+
<main>
|
22
|
+
<%%= yield %>
|
23
|
+
</main>
|
24
|
+
<footer>
|
25
|
+
<%%= render 'layouts/footer' %>
|
26
|
+
</footer>
|
27
|
+
</body>
|
28
|
+
</html>
|
29
|
+
|
@@ -0,0 +1,7 @@
|
|
1
|
+
# david = User.create(email: 'david@site.com', name: 'david', password: 'password')
|
2
|
+
# james = User.create(email: 'james@site.com', name: 'james', password: 'password')
|
3
|
+
# sally = User.create(email: 'sally@site.com', name: 'sally', password: 'password')
|
4
|
+
|
5
|
+
# 10.times do |i|
|
6
|
+
# Post.create(title: "Post #{i}", body: "This is the body of post #{i}", user: User.all.sample)
|
7
|
+
# end
|
@@ -0,0 +1,64 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Description goes here
|
4
|
+
#
|
5
|
+
# exe/rag addons/testy
|
6
|
+
|
7
|
+
self.local_template_path = File.dirname(__FILE__)
|
8
|
+
|
9
|
+
gac 'base rails 7 image created'
|
10
|
+
|
11
|
+
prepare_environment
|
12
|
+
|
13
|
+
add_controller('home', 'index')
|
14
|
+
|
15
|
+
route("root 'home#index'")
|
16
|
+
|
17
|
+
force_copy
|
18
|
+
|
19
|
+
directory "app/controllers"
|
20
|
+
directory "app/views/home"
|
21
|
+
directory "app/views/layouts"
|
22
|
+
template 'app/views/layouts/application.html.erb' , 'app/views/layouts/application.html.erb'
|
23
|
+
|
24
|
+
template 'db/seeds.rb' , 'db/seeds.rb'
|
25
|
+
|
26
|
+
after_bundle do
|
27
|
+
setup_db
|
28
|
+
end
|
29
|
+
|
30
|
+
def setup_db
|
31
|
+
# add_scaffold('post', 'title', 'body:text', 'user:references')
|
32
|
+
# add_scaffold('people', 'first_name', 'last_name', 'age:integer', 'address:text')
|
33
|
+
# add_scaffold('product', 'name', 'price:integer')
|
34
|
+
|
35
|
+
# db_migrate
|
36
|
+
# db_seed
|
37
|
+
end
|
38
|
+
|
39
|
+
# Other template command examples
|
40
|
+
# prepare_environment
|
41
|
+
# bundle_install
|
42
|
+
# css_install('tailwind')
|
43
|
+
# rails_command('db:migrate')
|
44
|
+
# rails_command('db:migrate')
|
45
|
+
# bundle_add('hotwire-rails')
|
46
|
+
# rails_command('hotwire:install')
|
47
|
+
# run('bin/importmap pin sortablejs')
|
48
|
+
# run('npm install daisyui')
|
49
|
+
# rubocop
|
50
|
+
#
|
51
|
+
# directory 'app/assets/images'
|
52
|
+
# create_file 'app/assets/stylesheets/custom-bootstrap-import.scss' , read_template('custom-bootstrap-import.scss')
|
53
|
+
# append_to_file 'app/assets/config/manifest.js' , read_template('manifest.js')
|
54
|
+
# insert_into_file 'app/views/layouts/application.html.erb', read_template('application.html.erb'),
|
55
|
+
# before: %( <%= javascript_include_tag "application", "data-turbo-track": "reload", defer: true %>)
|
56
|
+
# gsub_file 'app/views/layouts/application.html.erb', %(container mx-auto mt-28 px-5 flex), 'container mx-auto px-5'
|
57
|
+
# template 'home.css', 'app/assets/stylesheets/home.css'
|
58
|
+
#
|
59
|
+
# add_controller('page', 'benefits', 'faq', 'terms', 'privacy', '--skip-routes')
|
60
|
+
# route(<<-'RUBY')
|
61
|
+
# PageController.action_methods.each do |action|
|
62
|
+
# get "/#{action}", to: "page##{action}", as: "page_#{action}"
|
63
|
+
# end
|
64
|
+
# RUBY
|
@@ -0,0 +1 @@
|
|
1
|
+
<hr />
|
@@ -0,0 +1,29 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<title><%= camelized %></title>
|
5
|
+
<meta name="viewport" content="width=device-width,initial-scale=1">
|
6
|
+
<%%= csrf_meta_tags %>
|
7
|
+
<%%= csp_meta_tag %>
|
8
|
+
|
9
|
+
<%- if options[:skip_hotwire] || options[:skip_javascript] -%>
|
10
|
+
<%%= stylesheet_link_tag "application" %>
|
11
|
+
<%- else -%>
|
12
|
+
<%%= stylesheet_link_tag "application", "data-turbo-track": "reload" %>
|
13
|
+
<%- end -%>
|
14
|
+
</head>
|
15
|
+
|
16
|
+
<body>
|
17
|
+
<header>
|
18
|
+
<%%= render 'layouts/navbar' %>
|
19
|
+
<hr />
|
20
|
+
</header>
|
21
|
+
<main>
|
22
|
+
<%%= yield %>
|
23
|
+
</main>
|
24
|
+
<footer>
|
25
|
+
<%%= render 'layouts/footer' %>
|
26
|
+
</footer>
|
27
|
+
</body>
|
28
|
+
</html>
|
29
|
+
|
@@ -0,0 +1,7 @@
|
|
1
|
+
# david = User.create(email: 'david@site.com', name: 'david', password: 'password')
|
2
|
+
# james = User.create(email: 'james@site.com', name: 'james', password: 'password')
|
3
|
+
# sally = User.create(email: 'sally@site.com', name: 'sally', password: 'password')
|
4
|
+
|
5
|
+
# 10.times do |i|
|
6
|
+
# Post.create(title: "Post #{i}", body: "This is the body of post #{i}", user: User.all.sample)
|
7
|
+
# end
|
@@ -40,27 +40,28 @@
|
|
40
40
|
"skip_bundle",
|
41
41
|
"note",
|
42
42
|
"test",
|
43
|
-
"add_devise",
|
44
|
-
"add_dotenv",
|
45
|
-
"add_rubocop",
|
46
|
-
"add_annotate",
|
47
|
-
"add_lograge",
|
48
43
|
"add_acts_as_list",
|
49
44
|
"add_administrate",
|
50
|
-
"
|
45
|
+
"add_annotate",
|
46
|
+
"add_avo",
|
51
47
|
"add_bcrypt",
|
48
|
+
"add_browser",
|
52
49
|
"add_chartkick",
|
50
|
+
"add_devise",
|
51
|
+
"add_dotenv",
|
53
52
|
"add_faker",
|
54
53
|
"add_groupdate",
|
55
54
|
"add_hexapdf",
|
56
55
|
"add_httparty",
|
57
56
|
"add_honeybadger",
|
57
|
+
"add_lograge",
|
58
58
|
"add_mini_magick",
|
59
59
|
"add_motor_admin",
|
60
|
-
"add_phony_rails",
|
61
60
|
"add_public_suffix",
|
61
|
+
"add_phony_rails",
|
62
62
|
"add_rails_html_sanitizer",
|
63
63
|
"add_redcarpet",
|
64
|
+
"add_rubocop",
|
64
65
|
"add_twilio_ruby"
|
65
66
|
],
|
66
67
|
"class_options": [
|
@@ -345,22 +346,15 @@
|
|
345
346
|
"required": false
|
346
347
|
},
|
347
348
|
{
|
348
|
-
"name": "
|
349
|
-
"description": "Indicates when to generate add
|
350
|
-
"type": "boolean",
|
351
|
-
"default": false,
|
352
|
-
"required": false
|
353
|
-
},
|
354
|
-
{
|
355
|
-
"name": "add_dotenv",
|
356
|
-
"description": "Indicates when to generate add dotenv",
|
349
|
+
"name": "add_acts_as_list",
|
350
|
+
"description": "Indicates when to generate add acts as list",
|
357
351
|
"type": "boolean",
|
358
352
|
"default": false,
|
359
353
|
"required": false
|
360
354
|
},
|
361
355
|
{
|
362
|
-
"name": "
|
363
|
-
"description": "Indicates when to generate add
|
356
|
+
"name": "add_administrate",
|
357
|
+
"description": "Indicates when to generate add administrate",
|
364
358
|
"type": "boolean",
|
365
359
|
"default": false,
|
366
360
|
"required": false
|
@@ -373,43 +367,43 @@
|
|
373
367
|
"required": false
|
374
368
|
},
|
375
369
|
{
|
376
|
-
"name": "
|
377
|
-
"description": "Indicates when to generate add
|
370
|
+
"name": "add_avo",
|
371
|
+
"description": "Indicates when to generate add avo",
|
378
372
|
"type": "boolean",
|
379
373
|
"default": false,
|
380
374
|
"required": false
|
381
375
|
},
|
382
376
|
{
|
383
|
-
"name": "
|
384
|
-
"description": "Indicates when to generate add
|
377
|
+
"name": "add_bcrypt",
|
378
|
+
"description": "Indicates when to generate add bcrypt",
|
385
379
|
"type": "boolean",
|
386
380
|
"default": false,
|
387
381
|
"required": false
|
388
382
|
},
|
389
383
|
{
|
390
|
-
"name": "
|
391
|
-
"description": "Indicates when to generate add
|
384
|
+
"name": "add_browser",
|
385
|
+
"description": "Indicates when to generate add browser",
|
392
386
|
"type": "boolean",
|
393
387
|
"default": false,
|
394
388
|
"required": false
|
395
389
|
},
|
396
390
|
{
|
397
|
-
"name": "
|
398
|
-
"description": "Indicates when to generate add
|
391
|
+
"name": "add_chartkick",
|
392
|
+
"description": "Indicates when to generate add chartkick",
|
399
393
|
"type": "boolean",
|
400
394
|
"default": false,
|
401
395
|
"required": false
|
402
396
|
},
|
403
397
|
{
|
404
|
-
"name": "
|
405
|
-
"description": "Indicates when to generate add
|
398
|
+
"name": "add_devise",
|
399
|
+
"description": "Indicates when to generate add devise",
|
406
400
|
"type": "boolean",
|
407
401
|
"default": false,
|
408
402
|
"required": false
|
409
403
|
},
|
410
404
|
{
|
411
|
-
"name": "
|
412
|
-
"description": "Indicates when to generate add
|
405
|
+
"name": "add_dotenv",
|
406
|
+
"description": "Indicates when to generate add dotenv",
|
413
407
|
"type": "boolean",
|
414
408
|
"default": false,
|
415
409
|
"required": false
|
@@ -449,6 +443,13 @@
|
|
449
443
|
"default": false,
|
450
444
|
"required": false
|
451
445
|
},
|
446
|
+
{
|
447
|
+
"name": "add_lograge",
|
448
|
+
"description": "Indicates when to generate add lograge",
|
449
|
+
"type": "boolean",
|
450
|
+
"default": false,
|
451
|
+
"required": false
|
452
|
+
},
|
452
453
|
{
|
453
454
|
"name": "add_mini_magick",
|
454
455
|
"description": "Indicates when to generate add mini magick",
|
@@ -464,15 +465,15 @@
|
|
464
465
|
"required": false
|
465
466
|
},
|
466
467
|
{
|
467
|
-
"name": "
|
468
|
-
"description": "Indicates when to generate add
|
468
|
+
"name": "add_public_suffix",
|
469
|
+
"description": "Indicates when to generate add public suffix",
|
469
470
|
"type": "boolean",
|
470
471
|
"default": false,
|
471
472
|
"required": false
|
472
473
|
},
|
473
474
|
{
|
474
|
-
"name": "
|
475
|
-
"description": "Indicates when to generate add
|
475
|
+
"name": "add_phony_rails",
|
476
|
+
"description": "Indicates when to generate add phony rails",
|
476
477
|
"type": "boolean",
|
477
478
|
"default": false,
|
478
479
|
"required": false
|
@@ -491,6 +492,13 @@
|
|
491
492
|
"default": false,
|
492
493
|
"required": false
|
493
494
|
},
|
495
|
+
{
|
496
|
+
"name": "add_rubocop",
|
497
|
+
"description": "Indicates when to generate add rubocop",
|
498
|
+
"type": "boolean",
|
499
|
+
"default": false,
|
500
|
+
"required": false
|
501
|
+
},
|
494
502
|
{
|
495
503
|
"name": "add_twilio_ruby",
|
496
504
|
"description": "Indicates when to generate add twilio ruby",
|