answers-core 0.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/Rakefile +6 -0
- data/answers-core.gemspec +30 -0
- data/app/assets/fonts/answers/League_Gothic-webfont.eot +0 -0
- data/app/assets/fonts/answers/League_Gothic-webfont.svg +230 -0
- data/app/assets/fonts/answers/League_Gothic-webfont.ttf +0 -0
- data/app/assets/fonts/answers/League_Gothic-webfont.woff +0 -0
- data/app/assets/images/OaklandCityTree.png +0 -0
- data/app/assets/images/background_image.jpg +0 -0
- data/app/assets/images/background_pattern.png +0 -0
- data/app/assets/images/beta.png +0 -0
- data/app/assets/images/bg_transparent.png +0 -0
- data/app/assets/images/border.png +0 -0
- data/app/assets/images/brigade.png +0 -0
- data/app/assets/images/cfa.png +0 -0
- data/app/assets/images/cfa_logo.png +0 -0
- data/app/assets/images/cfa_logo_footer.png +0 -0
- data/app/assets/images/favicon.ico +0 -0
- data/app/assets/images/forest.jpeg +0 -0
- data/app/assets/images/getting_started_btn.png +0 -0
- data/app/assets/images/govuk.png +0 -0
- data/app/assets/images/openoaklandlogo.png +0 -0
- data/app/assets/images/quick_answers_icon.png +0 -0
- data/app/assets/images/quick_answers_icon_small.png +0 -0
- data/app/assets/images/searchIcon.png +0 -0
- data/app/assets/images/wmd-buttons.png +0 -0
- data/app/assets/images/yellow_bg.png +0 -0
- data/app/assets/javascripts/answers.js +19 -0
- data/app/assets/javascripts/answers/Markdown.Extra.js +304 -0
- data/app/assets/javascripts/answers/active_admin.js +62 -0
- data/app/assets/javascripts/answers/pagedown/LICENSE.txt +32 -0
- data/app/assets/javascripts/answers/pagedown/Markdown.Converter.js +1332 -0
- data/app/assets/javascripts/answers/pagedown/Markdown.Editor.js +2212 -0
- data/app/assets/javascripts/answers/pagedown/Markdown.Sanitizer.js +108 -0
- data/app/assets/javascripts/answers/pagedown/README.txt +0 -0
- data/app/assets/javascripts/answers/pagedown/demo/browser/demo.css +120 -0
- data/app/assets/javascripts/answers/pagedown/demo/browser/demo.html +83 -0
- data/app/assets/javascripts/answers/pagedown/demo/node/demo.js +44 -0
- data/app/assets/javascripts/answers/pagedown/local/Markdown.local.fr.js +43 -0
- data/app/assets/javascripts/answers/pagedown/node-pagedown.js +2 -0
- data/app/assets/javascripts/answers/pagedown/package.json +12 -0
- data/app/assets/javascripts/answers/pagedown/resources/wmd-buttons.psd +0 -0
- data/app/assets/javascripts/answers/pagedown/wmd-buttons.png +0 -0
- data/app/assets/javascripts/answers/skip_nav.js +8 -0
- data/app/assets/stylesheets/answers/active_admin.css.scss +17 -0
- data/app/assets/stylesheets/answers/active_admin_custom.css.scss +35 -0
- data/app/assets/stylesheets/answers/formatting.css +82 -0
- data/app/assets/stylesheets/answers/mobile.css +149 -0
- data/app/assets/stylesheets/answers/tags.css.scss +3 -0
- data/app/assets/stylesheets/answers/theme.css +916 -0
- data/app/controllers/answers/answers_controller.rb +26 -0
- data/app/controllers/answers/api/v1/answers_controller.rb +38 -0
- data/app/controllers/answers/api/v1/api_controller.rb +13 -0
- data/app/controllers/answers/api/v1/questions_controller.rb +39 -0
- data/app/controllers/answers/api/v1/taggings_controller.rb +46 -0
- data/app/controllers/answers/api/v1/tags_controller.rb +38 -0
- data/app/controllers/answers/application_controller.rb +27 -0
- data/app/controllers/answers/home_controller.rb +17 -0
- data/app/controllers/answers/questions_controller.rb +33 -0
- data/app/controllers/answers/search_controller.rb +22 -0
- data/app/controllers/answers/tags_controller.rb +36 -0
- data/app/helpers/answers/tags_helper.rb +7 -0
- data/app/models/.gitkeep +0 -0
- data/app/models/answers/ability.rb +28 -0
- data/app/models/answers/administrator.rb +5 -0
- data/app/models/answers/answer.rb +6 -0
- data/app/models/answers/api/v1/api_user.rb +5 -0
- data/app/models/answers/question.rb +31 -0
- data/app/models/answers/user.rb +30 -0
- data/app/views/answers/admin/contacts/_article.html.erb +0 -0
- data/app/views/answers/admin/dashboard/_dashboard.html.erb +5 -0
- data/app/views/answers/admin/guide_steps/_form.html.erb +17 -0
- data/app/views/answers/api/v1/answers/_answer.json.jbuilder +2 -0
- data/app/views/answers/api/v1/answers/index.json.jbuilder +1 -0
- data/app/views/answers/api/v1/answers/show.json.jbuilder +1 -0
- data/app/views/answers/api/v1/questions/_question.json.jbuilder +2 -0
- data/app/views/answers/api/v1/questions/index.json.jbuilder +1 -0
- data/app/views/answers/api/v1/questions/show.json.jbuilder +1 -0
- data/app/views/answers/api/v1/taggings/_tagging.json.jbuilder +3 -0
- data/app/views/answers/api/v1/taggings/index.json.jbuilder +1 -0
- data/app/views/answers/api/v1/taggings/show.json.jbuilder +1 -0
- data/app/views/answers/api/v1/tags/_tag.json.jbuilder +2 -0
- data/app/views/answers/api/v1/tags/index.json.jbuilder +1 -0
- data/app/views/answers/api/v1/tags/show.json.jbuilder +1 -0
- data/app/views/answers/devise/confirmations/new.html.erb +12 -0
- data/app/views/answers/devise/mailer/confirmation_instructions.html.erb +5 -0
- data/app/views/answers/devise/mailer/reset_password_instructions.html.erb +8 -0
- data/app/views/answers/devise/mailer/unlock_instructions.html.erb +7 -0
- data/app/views/answers/devise/passwords/edit.html.erb +24 -0
- data/app/views/answers/devise/passwords/new.html.erb +20 -0
- data/app/views/answers/devise/registrations/edit.html.erb +25 -0
- data/app/views/answers/devise/registrations/new.html.erb +18 -0
- data/app/views/answers/devise/sessions/new.html.erb +25 -0
- data/app/views/answers/devise/shared/_links.erb +25 -0
- data/app/views/answers/devise/unlocks/new.html.erb +12 -0
- data/app/views/answers/home/_article.html.erb +3 -0
- data/app/views/answers/home/_category.html.erb +8 -0
- data/app/views/answers/home/about.html.erb +72 -0
- data/app/views/answers/home/index.html.erb +44 -0
- data/app/views/answers/questions/index.html.erb +21 -0
- data/app/views/answers/questions/show.html.erb +31 -0
- data/app/views/answers/search/index.html.erb +32 -0
- data/app/views/answers/shared/_articles_sidebar.html.erb +22 -0
- data/app/views/answers/shared/_autocomplete.html.erb +8 -0
- data/app/views/answers/shared/_categories_sidebar.html.erb +12 -0
- data/app/views/answers/shared/_search_form.html.erb +4 -0
- data/app/views/answers/shared/admin/_administration.html.erb +38 -0
- data/app/views/answers/shared/admin/_article_actions.html.erb +86 -0
- data/app/views/answers/shared/admin/_article_content.html.erb +27 -0
- data/app/views/answers/shared/admin/_article_details.html.erb +11 -0
- data/app/views/answers/shared/admin/_article_form.html.erb +20 -0
- data/app/views/answers/shared/admin/_author_pic.html.erb +0 -0
- data/app/views/answers/tags/index.html.erb +34 -0
- data/app/views/answers/tags/show.html.erb +31 -0
- data/app/views/layouts/answers/application.html.erb +97 -0
- data/config.ru +5 -0
- data/config/initializers/active_admin.rb +245 -0
- data/config/initializers/devise.rb +228 -0
- data/config/locales/devise.en.yml +57 -0
- data/config/locales/en.yml +129 -0
- data/config/routes.rb +22 -0
- data/config/secrets.yml +68 -0
- data/db/migrate/20140911060606_answers_up.rb +79 -0
- data/lib/answers-core.rb +1 -0
- data/lib/answers.rb +175 -0
- data/lib/answers/admin/answer.rb +29 -0
- data/lib/answers/admin/dashboard.rb +75 -0
- data/lib/answers/admin/question.rb +57 -0
- data/lib/answers/admin/tag.rb +12 -0
- data/lib/answers/admin/users.rb +65 -0
- data/lib/answers/core.rb +25 -0
- data/lib/answers/core/configuration.rb +90 -0
- data/lib/answers/core/engine.rb +116 -0
- data/lib/answers/engine.rb +62 -0
- data/lib/answers/errors.rb +13 -0
- data/lib/answers/plugin.rb +75 -0
- data/lib/answers/plugins.rb +73 -0
- data/lib/answers/version.rb +16 -0
- data/lib/api_client.rb +20 -0
- data/lib/assets/.gitkeep +0 -0
- data/lib/assets/eng_stop.csv +1 -0
- data/lib/generators/answers/clash_keywords.yml +3 -0
- data/lib/generators/answers/cms/cms_generator.rb +314 -0
- data/lib/generators/answers/cms/templates/.gitignore +91 -0
- data/lib/generators/answers/cms/templates/app/decorators/controllers/answers/.keep +0 -0
- data/lib/generators/answers/cms/templates/app/decorators/models/answers/.keep +0 -0
- data/lib/generators/answers/cms/templates/app/views/sitemap/index.xml.builder +15 -0
- data/lib/generators/answers/cms/templates/config/database.yml.mysql +20 -0
- data/lib/generators/answers/cms/templates/config/database.yml.postgresql +58 -0
- data/lib/generators/answers/cms/templates/config/database.yml.sqlite3 +18 -0
- data/lib/generators/answers/core/core_generator.rb +10 -0
- data/lib/generators/answers/core/templates/config/initializers/answers/core.rb.erb +35 -0
- data/lib/generators/answers/dummy/dummy_generator.rb +86 -0
- data/lib/generators/answers/dummy/templates/rails/Rakefile +7 -0
- data/lib/generators/answers/dummy/templates/rails/application.js +3 -0
- data/lib/generators/answers/dummy/templates/rails/application.rb.erb +12 -0
- data/lib/generators/answers/dummy/templates/rails/boot.rb.erb +6 -0
- data/lib/generators/answers/dummy/templates/rails/database.yml +34 -0
- data/lib/generators/answers/dummy/templates/rails/routes.rb +3 -0
- data/lib/generators/answers/engine/USAGE +24 -0
- data/lib/generators/answers/engine/engine_generator.rb +44 -0
- data/lib/generators/answers/engine/templates/.gitignore +2 -0
- data/lib/generators/answers/engine/templates/Gemfile +42 -0
- data/lib/generators/answers/engine/templates/Rakefile +19 -0
- data/lib/generators/answers/engine/templates/answers-extension_plural_name.gemspec +19 -0
- data/lib/generators/answers/engine/templates/app/controllers/answers/namespace/admin/plural_name_controller.rb.erb +14 -0
- data/lib/generators/answers/engine/templates/app/controllers/answers/namespace/plural_name_controller.rb.erb +34 -0
- data/lib/generators/answers/engine/templates/app/models/answers/namespace/singular_name.rb.erb +37 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/admin/plural_name/_actions.html.erb +25 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/admin/plural_name/_form.html.erb +65 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/admin/plural_name/_plural_name.html.erb +2 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/admin/plural_name/_records.html.erb +16 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/admin/plural_name/_singular_name.html.erb +33 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/admin/plural_name/_sortable_list.html.erb +5 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/admin/plural_name/edit.html.erb +1 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/admin/plural_name/index.html.erb +7 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/admin/plural_name/new.html.erb +1 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/plural_name/index.html.erb +11 -0
- data/lib/generators/answers/engine/templates/app/views/answers/namespace/plural_name/show.html.erb +39 -0
- data/lib/generators/answers/engine/templates/config/locales/cs.yml +28 -0
- data/lib/generators/answers/engine/templates/config/locales/en.yml +28 -0
- data/lib/generators/answers/engine/templates/config/locales/es.yml +29 -0
- data/lib/generators/answers/engine/templates/config/locales/fr.yml +28 -0
- data/lib/generators/answers/engine/templates/config/locales/it.yml +28 -0
- data/lib/generators/answers/engine/templates/config/locales/nb.yml +28 -0
- data/lib/generators/answers/engine/templates/config/locales/nl.yml +28 -0
- data/lib/generators/answers/engine/templates/config/locales/sk.yml +28 -0
- data/lib/generators/answers/engine/templates/config/locales/tr.yml +28 -0
- data/lib/generators/answers/engine/templates/config/locales/zh-CN.yml +30 -0
- data/lib/generators/answers/engine/templates/config/routes.rb.erb +19 -0
- data/lib/generators/answers/engine/templates/db/migrate/1_create_namespace_plural_name.rb.erb +39 -0
- data/lib/generators/answers/engine/templates/db/seeds.rb.erb +21 -0
- data/lib/generators/answers/engine/templates/lib/answers-extension_plural_name.rb.erb +1 -0
- data/lib/generators/answers/engine/templates/lib/answers/plural_name.rb.erb +21 -0
- data/lib/generators/answers/engine/templates/lib/answers/plural_name/engine.rb.erb +23 -0
- data/lib/generators/answers/engine/templates/lib/generators/answers/extension_plural_name_generator.rb.erb +19 -0
- data/lib/generators/answers/engine/templates/lib/tasks/answers/extension_plural_name.rake +13 -0
- data/lib/generators/answers/engine/templates/readme.md +10 -0
- data/lib/generators/answers/engine/templates/script/rails +10 -0
- data/lib/generators/answers/engine/templates/spec/features/answers/namespace/admin/plural_name_spec.rb.erb +200 -0
- data/lib/generators/answers/engine/templates/spec/models/answers/namespace/singular_name_spec.rb.erb +20 -0
- data/lib/generators/answers/engine/templates/spec/spec_helper.rb +31 -0
- data/lib/generators/answers/engine/templates/spec/support/factories/answers/plural_name.rb.erb +7 -0
- data/lib/generators/answers/engine/templates/tasks/rspec.rake +6 -0
- data/lib/generators/answers/engine/templates/tasks/testing.rake +8 -0
- data/lib/generators/answers/generator.rb +292 -0
- data/lib/markdownifier.rb +11 -0
- data/log/.gitkeep +0 -0
- data/log/development.log +12870 -0
- data/log/newrelic_agent.log +1339 -0
- data/log/test.log +233181 -0
- data/public/404.html +25 -0
- data/public/422.html +25 -0
- data/public/500.html +24 -0
- data/public/favicon.ico +0 -0
- data/public/robots.txt +5 -0
- data/script/delayed_job +5 -0
- data/spec/controllers/answers_controller_spec.rb +55 -0
- data/spec/controllers/api/v1/answers_controller_spec.rb +144 -0
- data/spec/controllers/api/v1/questions_controller_spec.rb +144 -0
- data/spec/controllers/api/v1/taggings_controller_spec.rb +126 -0
- data/spec/controllers/api/v1/tags_controller_spec.rb +126 -0
- data/spec/controllers/home_controller_spec.rb +60 -0
- data/spec/controllers/questions_controller_spec.rb +55 -0
- data/spec/controllers/tags_controller_spec.rb +42 -0
- data/spec/factories/answers.rb +10 -0
- data/spec/factories/questions.rb +8 -0
- data/spec/factories/tags.rb +8 -0
- data/spec/factories/user.rb +32 -0
- data/spec/features/admin_dashboard_spec.rb +53 -0
- data/spec/features/admin_user_spec.rb +61 -0
- data/spec/features/searches_spec.rb +101 -0
- data/spec/fixtures/Article/_before_validation/sets_access_count_if_nil.yml +223 -0
- data/spec/fixtures/Article/_delete_orphaned_keywords/updating_an_article/destroys_orphaned_keywords_associated.yml +223 -0
- data/spec/fixtures/Article/_delete_orphaned_keywords/when_deleting_an_article/destroys_all_keywords_associated.yml +223 -0
- data/spec/fixtures/Article/_find_by_friendly_id/when_an_article_does_not_exist/does_not_raise_an_exception.yml +223 -0
- data/spec/fixtures/Article/_find_by_friendly_id/when_an_article_exists/returns_the_corresponding_article.yml +223 -0
- data/spec/fixtures/Article/_find_by_type/excludes_articles_not_matching_specified_type.yml +223 -0
- data/spec/fixtures/Article/_find_by_type/returns_articles_matching_type.yml +223 -0
- data/spec/fixtures/Article/_hits/before_an_article_has_been_viewed/has_zero_hits.yml +223 -0
- data/spec/fixtures/Article/_hits/returns_number_of_views/has_seven_views.yml +223 -0
- data/spec/fixtures/Article/_indexable_/returns_false_if_article_is_not_published.yml +223 -0
- data/spec/fixtures/Article/_indexable_/returns_true_if_article_is_published.yml +223 -0
- data/spec/fixtures/Article/_legacy_/returns_true_if_render_markdown_is_false.yml +223 -0
- data/spec/fixtures/Article/_qm_after_create/creates_wordcounts_for_relevant_keywords.yml +223 -0
- data/spec/fixtures/Article/_record_hit/viewing_an_article/increases_hit_by_one.yml +223 -0
- data/spec/fixtures/Article/_related/has_no_related_articles/.yml +223 -0
- data/spec/fixtures/Article/_related/has_related_articles/.yml +223 -0
- data/spec/fixtures/Article/_remove_stop_words/removes_common_english_words_from_the_string.yml +223 -0
- data/spec/fixtures/Article/_search/_search_titles/query_is_present_in_the_title/.yml +223 -0
- data/spec/fixtures/Article/_search/_search_titles/returns_an_empty_array_when_the_search_term_is_present_in_an_article_but_not_the_title.yml +223 -0
- data/spec/fixtures/Article/_search/matches_articles_in_the_database.yml +223 -0
- data/spec/fixtures/Article/_search/query_does_not_match_anything_in_the_database/returns_an_empty_array.yml +223 -0
- data/spec/fixtures/Article/_search/query_is_a_single_space/.yml +223 -0
- data/spec/fixtures/Article/_search/query_is_an_empty_string/.yml +223 -0
- data/spec/fixtures/Article/_to_s/when_an_article_has_a_category/returns_a_string_containing_title_id_and_category.yml +223 -0
- data/spec/fixtures/Article/can_be_published/an_unpublished_article/is_published.yml +223 -0
- data/spec/fixtures/Article/can_be_published/an_unpublished_article/returns_status_Published.yml +223 -0
- data/spec/fixtures/Article/has_a_friendly_url.yml +223 -0
- data/spec/fixtures/Article/is_valid_with_a_title.yml +223 -0
- data/spec/fixtures/Searches/search_results/1_result_found/.yml +22047 -0
- data/spec/fixtures/Searches/search_results/no_results_found/.yml +393 -0
- data/spec/fixtures/Searches/search_results/several_results_found/should_contain_the_title_and_preview_of_both_articles.yml +223 -0
- data/spec/fixtures/Searches/search_results/several_results_found/show_the_query.yml +277 -0
- data/spec/fixtures/articles.yml +428 -0
- data/spec/fixtures/categories.yml +17 -0
- data/spec/fixtures/contacts.yml +11 -0
- data/spec/fixtures/dragon_keyword_cassette.yml +77 -0
- data/spec/fixtures/oakland_answers.yml +2379 -0
- data/spec/helpers/tags_helper_spec.rb +15 -0
- data/spec/lib/markdownifier_spec.rb +12 -0
- data/spec/models/ability_spec.rb +36 -0
- data/spec/models/answer_spec.rb +5 -0
- data/spec/models/question_spec.rb +70 -0
- data/spec/models/user_spec.rb +55 -0
- data/spec/routing/answers_routing_spec.rb +19 -0
- data/spec/routing/questions_routing_spec.rb +19 -0
- data/spec/routing/routes_spec.rb +13 -0
- data/spec/security/brakeman_spec.rb +37 -0
- data/spec/spec_helper.rb +61 -0
- data/spec/support/login_helpers.rb +10 -0
- data/spec/support/wait_for_ajax_helper.rb +7 -0
- data/spec/support/wait_for_dom_helper.rb +12 -0
- data/spec/views/questions/index.html.erb_spec.rb +16 -0
- data/spec/views/questions/show.html.erb_spec.rb +14 -0
- data/spec/views/tags/index.html.erb_spec.rb +5 -0
- data/spec/views/tags/show.html.erb_spec.rb +5 -0
- data/vendor/assets/javascripts/.gitkeep +0 -0
- data/vendor/assets/stylesheets/.gitkeep +0 -0
- data/vendor/assets/stylesheets/bootstrap.css +3990 -0
- data/vendor/crudgen/lib/generators/crudgen/install_generator.rb +23 -0
- data/vendor/plugins/.gitkeep +0 -0
- metadata +484 -0
@@ -0,0 +1,44 @@
|
|
1
|
+
require 'rails/generators/named_base'
|
2
|
+
require 'answers/extension_generation'
|
3
|
+
|
4
|
+
module Answers
|
5
|
+
class EngineGenerator < Rails::Generators::NamedBase
|
6
|
+
source_root Pathname.new(File.expand_path('../templates', __FILE__))
|
7
|
+
|
8
|
+
include Answers::ExtensionGeneration
|
9
|
+
|
10
|
+
class_option :skip_frontend,
|
11
|
+
:desc => 'Generate extension without frontend',
|
12
|
+
:type => :boolean,
|
13
|
+
:default => false,
|
14
|
+
:required => false
|
15
|
+
|
16
|
+
def skip_frontend?
|
17
|
+
options[:skip_frontend]
|
18
|
+
end
|
19
|
+
|
20
|
+
def generate
|
21
|
+
default_generate!
|
22
|
+
end
|
23
|
+
|
24
|
+
def backend_route
|
25
|
+
@backend_route ||= if namespacing.underscore != plural_name
|
26
|
+
%Q{"#\{Answers::Core.backend_route\}/#{namespacing.underscore}"}
|
27
|
+
else
|
28
|
+
"Answers::Core.backend_route"
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
protected
|
33
|
+
|
34
|
+
def generator_command
|
35
|
+
'rails generate answers:engine'
|
36
|
+
end
|
37
|
+
|
38
|
+
def reject_file_with_skip_frontend?(file)
|
39
|
+
(skip_frontend? && (file.to_s.include?('app') && file.to_s.scan(/admin|models|mailers/).empty?)) ||
|
40
|
+
reject_file_without_skip_frontend?(file)
|
41
|
+
end
|
42
|
+
alias_method_chain :reject_file?, :skip_frontend
|
43
|
+
end
|
44
|
+
end
|
@@ -0,0 +1,42 @@
|
|
1
|
+
source "http://rubygems.org"
|
2
|
+
|
3
|
+
gemspec
|
4
|
+
|
5
|
+
git 'git://github.com/answers/answers.git', :branch => 'master' do
|
6
|
+
gem 'answers'
|
7
|
+
|
8
|
+
group :development, :test do
|
9
|
+
gem 'answers-testing'
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
# Database Configuration
|
14
|
+
platforms :jruby do
|
15
|
+
gem 'activerecord-jdbcsqlite3-adapter'
|
16
|
+
gem 'activerecord-jdbcmysql-adapter'
|
17
|
+
gem 'activerecord-jdbcpostgresql-adapter'
|
18
|
+
gem 'jruby-openssl'
|
19
|
+
end
|
20
|
+
|
21
|
+
platforms :ruby do
|
22
|
+
gem 'sqlite3'
|
23
|
+
gem 'mysql2'
|
24
|
+
gem 'pg'
|
25
|
+
end
|
26
|
+
|
27
|
+
group :development, :test do
|
28
|
+
platforms :ruby do
|
29
|
+
require 'rbconfig'
|
30
|
+
if RbConfig::CONFIG['target_os'] =~ /linux/i
|
31
|
+
gem 'therubyracer', '~> 0.11.4'
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
# Gems used only for assets and not required
|
37
|
+
# in production environments by default.
|
38
|
+
group :assets do
|
39
|
+
gem 'sass-rails'
|
40
|
+
gem 'coffee-rails'
|
41
|
+
gem 'uglifier'
|
42
|
+
end
|
@@ -0,0 +1,19 @@
|
|
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
|
+
ENGINE_PATH = File.dirname(__FILE__)
|
9
|
+
APP_RAKEFILE = File.expand_path "../spec/dummy/Rakefile", __FILE__
|
10
|
+
|
11
|
+
if File.exists? APP_RAKEFILE
|
12
|
+
load 'rails/tasks/engine.rake'
|
13
|
+
end
|
14
|
+
|
15
|
+
require "answers-testing"
|
16
|
+
Answers::Testing::Railtie.load_dummy_tasks ENGINE_PATH
|
17
|
+
|
18
|
+
load File.expand_path('../tasks/testing.rake', __FILE__)
|
19
|
+
load File.expand_path('../tasks/rspec.rake', __FILE__)
|
@@ -0,0 +1,19 @@
|
|
1
|
+
# Encoding: UTF-8
|
2
|
+
|
3
|
+
Gem::Specification.new do |s|
|
4
|
+
s.platform = Gem::Platform::RUBY
|
5
|
+
s.name = 'answers-<%= extension_plural_name %>'
|
6
|
+
s.version = '1.0'
|
7
|
+
s.description = 'Ruby on Rails <%= extension_plural_name.titleize %> extension for Answers'
|
8
|
+
s.date = '<%= Time.now.strftime('%Y-%m-%d') %>'
|
9
|
+
s.summary = '<%= extension_plural_name.titleize %> extension for Answers'
|
10
|
+
s.require_paths = %w(lib)
|
11
|
+
s.files = Dir["{app,config,db,lib}/**/*"] + ["readme.md"]
|
12
|
+
|
13
|
+
# Runtime dependencies
|
14
|
+
s.add_dependency 'answers-core', '~> <%= Answers::Version %>'
|
15
|
+
s.add_dependency 'acts_as_indexed', '~> 0.8.0'
|
16
|
+
|
17
|
+
# Development dependencies (usually used for testing)
|
18
|
+
s.add_development_dependency 'answers-testing', '~> <%= Answers::Version %>'
|
19
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
module Answers
|
2
|
+
module <%= namespacing %>
|
3
|
+
module Admin
|
4
|
+
class <%= class_name.pluralize %>Controller < ::Answers::AdminController
|
5
|
+
|
6
|
+
crudify :'answers/<%= namespacing.underscore %>/<%= singular_name %>'<% if (title = attributes.detect { |a| a.type.to_s =~ /string|text/ }).present? and title.name != 'title' -%>,
|
7
|
+
:title_attribute => '<%= title.name %>'<% end -%><% if plural_name == singular_name -%>,
|
8
|
+
:redirect_to_url => :answers_<%= namespacing.underscore %>_admin_<%= singular_name %>_index_path<% end %>,
|
9
|
+
:xhr_paging => true
|
10
|
+
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
module Answers
|
2
|
+
module <%= namespacing %>
|
3
|
+
class <%= class_name.pluralize %>Controller < ::ApplicationController
|
4
|
+
|
5
|
+
before_filter :find_all_<%= plural_name %>
|
6
|
+
before_filter :find_page
|
7
|
+
|
8
|
+
def index
|
9
|
+
# you can use meta fields from your model instead (e.g. browser_title)
|
10
|
+
# by swapping @page for @<%= singular_name %> in the line below:
|
11
|
+
present(@page)
|
12
|
+
end
|
13
|
+
|
14
|
+
def show
|
15
|
+
@<%= singular_name %> = <%= class_name %>.find(params[:id])
|
16
|
+
|
17
|
+
# you can use meta fields from your model instead (e.g. browser_title)
|
18
|
+
# by swapping @page for @<%= singular_name %> in the line below:
|
19
|
+
present(@page)
|
20
|
+
end
|
21
|
+
|
22
|
+
protected
|
23
|
+
|
24
|
+
def find_all_<%= plural_name %>
|
25
|
+
@<%= "all_" if plural_name == singular_name %><%= plural_name %> = <%= class_name %>.order('position ASC')
|
26
|
+
end
|
27
|
+
|
28
|
+
def find_page
|
29
|
+
@page = ::Answers::Page.where(:link_url => "/<%= plural_name %>").first
|
30
|
+
end
|
31
|
+
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
data/lib/generators/answers/engine/templates/app/models/answers/namespace/singular_name.rb.erb
ADDED
@@ -0,0 +1,37 @@
|
|
1
|
+
module Answers
|
2
|
+
module <%= namespacing %>
|
3
|
+
class <%= class_name %> < Answers::Core::BaseModel
|
4
|
+
<% if table_name == namespacing.underscore.pluralize -%>
|
5
|
+
self.table_name = 'answers_<%= plural_name %>'
|
6
|
+
<% end %>
|
7
|
+
<% if localized? -%>
|
8
|
+
|
9
|
+
translates <%= localized_attributes.map { |a| ":#{a.name}" }.join(', ') %>
|
10
|
+
<% end -%>
|
11
|
+
<% if string_attributes.any? -%>
|
12
|
+
|
13
|
+
validates <%= string_attributes.first.name.to_sym.inspect %>, :presence => true, :uniqueness => true
|
14
|
+
<% else -%>
|
15
|
+
|
16
|
+
# def title was created automatically because you didn't specify a string field
|
17
|
+
# when you ran the answers:engine generator. <3 <3 Answers.
|
18
|
+
def title
|
19
|
+
"Override def title in vendor/extensions/<%= namespacing.underscore %>/app/models/answers/<%= namespacing.underscore %>/<%= singular_name %>.rb"
|
20
|
+
end
|
21
|
+
<% end -%>
|
22
|
+
<% image_attributes.each do |a| -%>
|
23
|
+
|
24
|
+
belongs_to :<%= a.name -%>, :class_name => '::Answers::Image'
|
25
|
+
<% end -%>
|
26
|
+
<% resource_attributes.each do |a| -%>
|
27
|
+
|
28
|
+
belongs_to :<%= a.name %>, :class_name => '::Answers::Resource'
|
29
|
+
<% end -%>
|
30
|
+
|
31
|
+
# To enable admin searching, add acts_as_indexed on searchable fields, for example:
|
32
|
+
#
|
33
|
+
# acts_as_indexed :fields => [:title]
|
34
|
+
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
<ul>
|
2
|
+
<%% if ::Answers::<%= namespacing %>::Admin::<%= class_name.pluralize %>Controller.searchable? %>
|
3
|
+
<li>
|
4
|
+
<%%= render '/answers/admin/search', :url => answers.<%= namespacing.underscore %>_admin_<%= plural_name %><%= "_index" if plural_name == singular_name%>_path %>
|
5
|
+
</li>
|
6
|
+
<%% end %>
|
7
|
+
<li>
|
8
|
+
<%%= link_to t('.create_new'), answers.new_<%= namespacing.underscore %>_admin_<%= singular_name %>_path,
|
9
|
+
:class => "add_icon" %>
|
10
|
+
</li>
|
11
|
+
<%% if !searching? && ::Answers::<%= namespacing %>::Admin::<%= class_name.pluralize %>Controller.sortable? && ::Answers::<%= namespacing %>::<%= class_name %>.many? %>
|
12
|
+
<li>
|
13
|
+
<%%= link_to t('.reorder', :what => "<%= singular_name.titleize.pluralize %>"),
|
14
|
+
answers.<%= namespacing.underscore %>_admin_<%= plural_name %><%= "_index" if plural_name == singular_name%>_path,
|
15
|
+
:id => "reorder_action",
|
16
|
+
:class => "reorder_icon" %>
|
17
|
+
|
18
|
+
<%%= link_to t('.reorder_done', :what => "<%= singular_name.titleize.pluralize %>"),
|
19
|
+
answers.<%= namespacing.underscore %>_admin_<%= plural_name %><%= "_index" if plural_name == singular_name%>_path,
|
20
|
+
:id => "reorder_action_done",
|
21
|
+
:style => "display: none;",
|
22
|
+
:class => "reorder_icon" %>
|
23
|
+
</li>
|
24
|
+
<%% end %>
|
25
|
+
</ul>
|
@@ -0,0 +1,65 @@
|
|
1
|
+
<%
|
2
|
+
text_areas = attributes.reject{|a| a.field_type.to_s != 'text_area'}
|
3
|
+
generated_text_areas = false
|
4
|
+
-%>
|
5
|
+
<%%= form_for [answers, :<%= namespacing.underscore %>_admin, @<%= singular_name %>] do |f| -%>
|
6
|
+
<%%= render '/answers/admin/error_messages',
|
7
|
+
:object => @<%= singular_name %>,
|
8
|
+
:include_object_name => true %>
|
9
|
+
|
10
|
+
<% if localized? -%>
|
11
|
+
<%%= render '/answers/admin/locale_picker',
|
12
|
+
:current_locale => Globalize.locale %>
|
13
|
+
<% end -%>
|
14
|
+
<% attributes.each_with_index do |attribute, index| -%>
|
15
|
+
<% if attribute.type.to_s == 'image' -%>
|
16
|
+
<div class='field'>
|
17
|
+
<%%= f.label :<%= attribute.name %> -%>
|
18
|
+
<%%= render '/answers/admin/image_picker',
|
19
|
+
:f => f,
|
20
|
+
:field => :<%= "#{attribute.name}_id".gsub("_id_id", "_id") %>,
|
21
|
+
:image => @<%= singular_name %>.<%= attribute.name.gsub("_id", "") %>,
|
22
|
+
:toggle_image_display => false -%>
|
23
|
+
</div>
|
24
|
+
|
25
|
+
<% elsif attribute.type.to_s == 'resource' -%>
|
26
|
+
<div class='field'>
|
27
|
+
<%%= f.label :<%= attribute.name %> -%>
|
28
|
+
<%%= render '/answers/admin/resource_picker',
|
29
|
+
:f => f,
|
30
|
+
:field => :<%= "#{attribute.name}_id".gsub("_id_id", "_id") %>,
|
31
|
+
:resource => @<%= singular_name %>.<%= attribute.name.gsub("_id", "") %> -%>
|
32
|
+
</div>
|
33
|
+
|
34
|
+
<% elsif attribute.field_type.to_s == "text_area" and !generated_text_areas -%>
|
35
|
+
<div class='field'>
|
36
|
+
<%%= render '/answers/admin/wysiwyg',
|
37
|
+
:f => f,
|
38
|
+
:fields => <%= text_areas.map{|t| t.name.to_sym}.inspect -%>,
|
39
|
+
:object => "<%= namespacing.underscore -%>/<%= singular_name -%>" -%>
|
40
|
+
</div>
|
41
|
+
|
42
|
+
<% generated_text_areas = true -%>
|
43
|
+
<% elsif attribute.field_type.to_s != 'text_area' -%>
|
44
|
+
<div class='field'>
|
45
|
+
<%%= f.label :<%= attribute.name %> -%>
|
46
|
+
<%%= f.<%= attribute.field_type -%> :<%= attribute.name -%><%= ", :class => 'larger widest'" if (index == 0 && attribute.field_type == :text_field) -%><%= ", :checked => @#{singular_name}[:#{attribute.name}]" if attribute.field_type == :check_box %> -%>
|
47
|
+
</div>
|
48
|
+
|
49
|
+
<% end -%>
|
50
|
+
<% end -%>
|
51
|
+
<%%= render '/answers/admin/form_actions', :f => f,
|
52
|
+
:continue_editing => false,
|
53
|
+
:delete_title => t('delete', :scope => 'answers.<%= plural_name %>.admin.<%= plural_name %>.<%= singular_name %>'),
|
54
|
+
:delete_confirmation => t('message', :scope => 'answers.admin.delete'<% if (title = attributes.detect { |a| a.type.to_s == "string" }).present? %>, :title => @<%= singular_name %>.<%= title.name %><% end %>) -%>
|
55
|
+
<%% end -%>
|
56
|
+
<% if text_areas.any? -%>
|
57
|
+
|
58
|
+
<%% content_for :javascripts do -%>
|
59
|
+
<script>
|
60
|
+
$(document).ready(function(){
|
61
|
+
page_options.init(false, '', '');
|
62
|
+
});
|
63
|
+
</script>
|
64
|
+
<%% end -%>
|
65
|
+
<% end -%>
|
@@ -0,0 +1,16 @@
|
|
1
|
+
<%%= render 'answers/admin/search_header', :url => answers.<%= namespacing.underscore %>_admin_<%= plural_name %>_path %>
|
2
|
+
<div class='pagination_container'>
|
3
|
+
<%% if @<%= plural_name %>.any? %>
|
4
|
+
<%%= render '<%= plural_name %>' %>
|
5
|
+
<%% else %>
|
6
|
+
<p>
|
7
|
+
<%% if searching? %>
|
8
|
+
<%%= t('no_results', :scope => 'answers.admin.search') %>
|
9
|
+
<%% else %>
|
10
|
+
<strong>
|
11
|
+
<%%= t('.no_items_yet') %>
|
12
|
+
</strong>
|
13
|
+
<%% end %>
|
14
|
+
</p>
|
15
|
+
<%% end %>
|
16
|
+
</div>
|
@@ -0,0 +1,33 @@
|
|
1
|
+
<% title_attribute = (title = attributes.detect { |a| a.type.to_s == "string" }).present? ? title.name : 'title' -%>
|
2
|
+
<li class='clearfix record <%%= cycle("on", "on-hover") %>' id="<%%= dom_id(<%= singular_name %>) -%>">
|
3
|
+
<span class='title'>
|
4
|
+
<%%= <%= singular_name %>.<%= title_attribute %> %>
|
5
|
+
<% if localized? %>
|
6
|
+
<%% if Answers::I18n.frontend_locales.many? %>
|
7
|
+
<span class='preview'>
|
8
|
+
<%% <%= singular_name %>.translations.each do |translation| %>
|
9
|
+
<%% if translation.<%= title_attribute %>.present? %>
|
10
|
+
<%%= link_to answers_icon_tag("flags/#{translation.locale}.png", :size => '16x11'),
|
11
|
+
answers.edit_<%= namespacing.underscore %>_admin_<%= singular_name %>_path(<%= singular_name %>, :switch_locale => translation.locale),
|
12
|
+
:class => 'locale' %>
|
13
|
+
<%% end %>
|
14
|
+
<%% end %>
|
15
|
+
</span>
|
16
|
+
<%% end %>
|
17
|
+
<% end %>
|
18
|
+
</span>
|
19
|
+
<span class='actions'>
|
20
|
+
<% unless skip_frontend? %>
|
21
|
+
<%%= link_to answers_icon_tag("application_go.png"), answers.<%= namespacing.underscore %>_<%= singular_name %>_path(<%= singular_name %>),
|
22
|
+
:title => t('.view_live_html'),
|
23
|
+
:target => "_blank" %>
|
24
|
+
<% end %>
|
25
|
+
<%%= link_to answers_icon_tag("application_edit.png"), answers.edit_<%= namespacing.underscore %>_admin_<%= singular_name %>_path(<%= singular_name %>),
|
26
|
+
:title => t('.edit') %>
|
27
|
+
<%%= link_to answers_icon_tag("delete.png"), answers.<%= namespacing.underscore %>_admin_<%= singular_name %>_path(<%= singular_name %>),
|
28
|
+
:class => "cancel confirm-delete",
|
29
|
+
:title => t('.delete'),
|
30
|
+
:data => {:confirm => t('message', :scope => 'answers.admin.delete', :title => <%= singular_name %>.<%= title_attribute %>)},
|
31
|
+
:method => :delete %>
|
32
|
+
</span>
|
33
|
+
</li>
|
@@ -0,0 +1,5 @@
|
|
1
|
+
<ul id='sortable_list'>
|
2
|
+
<%%= render :partial => '<%= singular_name %>', :collection => @<%= plural_name %> %>
|
3
|
+
</ul>
|
4
|
+
<%%= render '/answers/admin/sortable_list',
|
5
|
+
:continue_reordering => (local_assigns.keys.include?(:continue_reordering)) ? continue_reordering : true %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%%= render 'form' %>
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<section id='records'>
|
2
|
+
<%%= render 'records' %>
|
3
|
+
</section>
|
4
|
+
<aside id='actions'>
|
5
|
+
<%%= render 'actions' %>
|
6
|
+
</aside>
|
7
|
+
<%%= render '/answers/admin/make_sortable', options: {tree: false} if !searching? and ::Answers::<%= namespacing %>::Admin::<%= class_name.pluralize %>Controller.sortable? and ::Answers::<%= namespacing %>::<%= class_name %>.many? %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<%%= render 'form' %>
|
data/lib/generators/answers/engine/templates/app/views/answers/namespace/plural_name/index.html.erb
ADDED
@@ -0,0 +1,11 @@
|
|
1
|
+
<%% content_for :body do %>
|
2
|
+
<ul id="<%= plural_name %>">
|
3
|
+
<%% @<%= "all_" if plural_name == singular_name%><%= plural_name %>.each do |<%= singular_name %>| %>
|
4
|
+
<li>
|
5
|
+
<%%= link_to <%= singular_name %><% if (title = attributes.detect { |a| a.type.to_s == "string" }).present? %>.<%= title.name %><% end %>, answers.<%= namespacing.underscore %>_<%= singular_name %>_path(<%= singular_name %>) %>
|
6
|
+
</li>
|
7
|
+
<%% end %>
|
8
|
+
</ul>
|
9
|
+
<%% end %>
|
10
|
+
|
11
|
+
<%%= render '/answers/content_page' %>
|
data/lib/generators/answers/engine/templates/app/views/answers/namespace/plural_name/show.html.erb
ADDED
@@ -0,0 +1,39 @@
|
|
1
|
+
<%% content_for :body_content_title do %>
|
2
|
+
<%%= @<%= singular_name %><% if (title = attributes.detect { |a| a.type.to_s == "string" }).present? %>.<%= title.name %><% else %>.title<% end %> %>
|
3
|
+
<%% end %>
|
4
|
+
|
5
|
+
<%% content_for :body do %>
|
6
|
+
<% attributes.each do |attribute| -%>
|
7
|
+
<section>
|
8
|
+
<h1><%= attribute.name.titleize %></h1>
|
9
|
+
<p>
|
10
|
+
<% if attribute.type.to_s == 'image' -%>
|
11
|
+
<%%= image_fu @<%= singular_name %>.<%= attribute.name %>, nil %>
|
12
|
+
<% elsif attribute.type.to_s == 'resource' -%>
|
13
|
+
<%% if @<%= singular_name %>.<%= attribute.name %>.present? %>
|
14
|
+
<%%= link_to <%= "'#{attribute.name}'" %>, @<%= singular_name %>.<%= attribute.name %>.url %>
|
15
|
+
<%% else %>
|
16
|
+
<%= attribute.name %>
|
17
|
+
<%% end %>
|
18
|
+
<% else -%>
|
19
|
+
<%%=raw @<%= singular_name %>.<%= attribute.name %> %>
|
20
|
+
<% end -%>
|
21
|
+
</p>
|
22
|
+
</section>
|
23
|
+
<% end -%>
|
24
|
+
<%% end %>
|
25
|
+
|
26
|
+
<%% content_for :side_body do %>
|
27
|
+
<aside>
|
28
|
+
<h2><%%= t('.other') %></h2>
|
29
|
+
<ul id="<%= plural_name %>">
|
30
|
+
<%% @<%= "all_" if plural_name == singular_name%><%= plural_name %>.each do |<%= singular_name %>| %>
|
31
|
+
<li>
|
32
|
+
<%%= link_to <%= singular_name %><% if (title = attributes.detect { |a| a.type.to_s == "string" }).present? %>.<%= title.name %><% else %>.title<% end %>, answers.<%= namespacing.underscore %>_<%= singular_name %>_path(<%= singular_name %>) %>
|
33
|
+
</li>
|
34
|
+
<%% end %>
|
35
|
+
</ul>
|
36
|
+
</aside>
|
37
|
+
<%% end %>
|
38
|
+
|
39
|
+
<%%= render '/answers/content_page' %>
|