decidim 0.2.0 → 0.3.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of decidim might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/.circleci/config.yml +3 -1
- data/.codeclimate.yml +2 -3
- data/.rubocop.yml +1 -48
- data/.travis.yml +1 -0
- data/Dockerfile +1 -0
- data/Gemfile +1 -0
- data/Gemfile.lock +119 -115
- data/README.md +24 -9
- data/Rakefile +14 -10
- data/decidim-admin/app/assets/javascripts/decidim/admin/application.js.es6 +21 -9
- data/decidim-admin/app/assets/javascripts/decidim/admin/sort_list.component.js.es6 +35 -0
- data/decidim-admin/app/assets/stylesheets/decidim/admin/extra/_language-chooser.scss +4 -0
- data/decidim-admin/app/assets/stylesheets/decidim/admin/extra/_sort.scss +12 -0
- data/decidim-admin/app/controllers/decidim/admin/application_controller.rb +1 -0
- data/decidim-admin/app/controllers/decidim/admin/participatory_process_attachments_controller.rb +4 -0
- data/decidim-admin/app/helpers/decidim/admin/menu_helper.rb +0 -1
- data/decidim-admin/app/models/decidim/admin/participatory_process_user_role.rb +2 -2
- data/decidim-admin/app/views/decidim/admin/categories/index.html.erb +7 -1
- data/decidim-admin/app/views/decidim/admin/exports/_dropdown.html.erb +1 -1
- data/decidim-admin/app/views/decidim/admin/moderations/index.html.erb +6 -2
- data/decidim-admin/app/views/decidim/admin/participatory_process_steps/index.html.erb +1 -0
- data/decidim-admin/app/views/layouts/decidim/admin/_title_bar.html.erb +10 -0
- data/decidim-admin/bin/rails +3 -3
- data/decidim-admin/config/locales/ca.yml +3 -1
- data/decidim-admin/config/locales/en.yml +3 -1
- data/decidim-admin/config/locales/es.yml +3 -1
- data/decidim-admin/config/locales/eu.yml +0 -1
- data/decidim-admin/config/locales/fi.yml +0 -1
- data/decidim-admin/config/locales/fr.yml +0 -1
- data/decidim-admin/config/locales/it.yml +490 -0
- data/decidim-admin/db/migrate/20161102144648_add_admin_participatory_process_user_roles.rb +5 -3
- data/decidim-admin/db/migrate/20170128112958_change_user_groups_verified_to_timestamp.rb +2 -0
- data/decidim-admin/decidim-admin.gemspec +2 -1
- data/decidim-admin/lib/decidim/admin/engine.rb +1 -1
- data/decidim-admin/lib/decidim/admin/test/manage_attachments_examples.rb +3 -3
- data/decidim-admin/spec/commands/reject_user_group_spec.rb +2 -2
- data/decidim-admin/spec/features/admin_copy_participatory_process_spec.rb +2 -2
- data/decidim-admin/spec/features/admin_invite_spec.rb +1 -1
- data/decidim-admin/spec/features/admin_manages_features_spec.rb +2 -2
- data/decidim-admin/spec/features/admin_manages_newsletters_spec.rb +4 -4
- data/decidim-admin/spec/features/admin_manages_organization_spec.rb +6 -6
- data/decidim-admin/spec/features/admin_manages_participatory_process_groups_spec.rb +4 -4
- data/decidim-admin/spec/features/admin_manages_participatory_processes_spec.rb +4 -4
- data/decidim-admin/spec/features/static_pages_spec.rb +4 -4
- data/decidim-admin/spec/forms/organization_form_spec.rb +1 -1
- data/decidim-admin/spec/shared/manage_process_categories_examples.rb +44 -29
- data/decidim-admin/spec/shared/manage_process_steps_examples.rb +3 -3
- data/decidim-admin/spec/shared/manage_processes_examples.rb +1 -1
- data/decidim-admin/spec/shared/participatory_admin_shared_context.rb +3 -3
- data/decidim-admin/spec/spec_helper.rb +3 -2
- data/decidim-api/bin/rails +3 -3
- data/decidim-api/decidim-api.gemspec +2 -1
- data/decidim-api/lib/decidim/api/engine.rb +1 -1
- data/decidim-api/spec/spec_helper.rb +3 -2
- data/decidim-budgets/app/controllers/decidim/budgets/application_controller.rb +1 -1
- data/decidim-budgets/app/models/decidim/budgets/line_item.rb +1 -2
- data/decidim-budgets/app/models/decidim/budgets/order.rb +2 -2
- data/decidim-budgets/app/views/decidim/budgets/projects/_linked_projects.html.erb +1 -1
- data/decidim-budgets/bin/rails +3 -3
- data/decidim-budgets/config/locales/it.yml +126 -0
- data/decidim-budgets/db/migrate/20170127114122_create_projects.rb +2 -0
- data/decidim-budgets/db/migrate/20170130095615_create_orders.rb +2 -0
- data/decidim-budgets/db/migrate/20170130101825_create_line_items.rb +2 -0
- data/decidim-budgets/db/migrate/20170207101750_remove_short_description_from_decidim_projects.rb +2 -0
- data/decidim-budgets/db/migrate/20170215132708_add_reference_to_projects.rb +2 -0
- data/decidim-budgets/db/migrate/20170410074214_remove_not_null_reference_budgets.rb +2 -0
- data/decidim-budgets/db/migrate/20170612101846_migrate_projects_category.rb +15 -0
- data/decidim-budgets/decidim-budgets.gemspec +3 -1
- data/decidim-budgets/lib/decidim/budgets/feature.rb +2 -2
- data/decidim-budgets/spec/features/admin_manages_project_attachments_spec.rb +5 -3
- data/decidim-budgets/spec/features/admin_manages_projects_spec.rb +5 -7
- data/decidim-budgets/spec/features/process_admin_manages_project_attachments_spec.rb +4 -4
- data/decidim-budgets/spec/features/process_admin_manages_projects_spec.rb +5 -8
- data/decidim-budgets/spec/shared/manage_attachments_examples.rb +0 -4
- data/decidim-budgets/spec/shared/manage_projects_examples.rb +3 -3
- data/decidim-budgets/spec/spec_helper.rb +2 -1
- data/decidim-comments/app/assets/javascripts/decidim/comments/bundle.js +0 -0
- data/decidim-comments/app/commands/decidim/comments/create_comment.rb +2 -2
- data/decidim-comments/app/frontend/comments/add_comment_form.component.tsx +1 -0
- data/decidim-comments/app/frontend/comments/comment.component.test.tsx +12 -1
- data/decidim-comments/app/frontend/comments/comment.component.tsx +42 -4
- data/decidim-comments/app/frontend/comments/comment_thread.component.test.tsx +11 -0
- data/decidim-comments/app/frontend/comments/comment_thread.component.tsx +5 -1
- data/decidim-comments/app/frontend/fragments/comment_data.fragment.graphql +3 -0
- data/decidim-comments/app/frontend/support/generate_comments_data.ts +3 -0
- data/decidim-comments/app/frontend/support/schema.ts +18 -12
- data/decidim-comments/app/mailers/decidim/comments/comment_notification_mailer.rb +6 -4
- data/decidim-comments/app/models/decidim/comments/comment.rb +6 -4
- data/decidim-comments/app/models/decidim/comments/comment_vote.rb +1 -2
- data/decidim-comments/app/models/decidim/comments/seed.rb +5 -2
- data/decidim-comments/app/resolvers/decidim/comments/vote_comment_resolver.rb +3 -0
- data/decidim-comments/app/types/decidim/comments/commentable_interface.rb +3 -3
- data/decidim-comments/app/views/decidim/comments/comment_notification_mailer/comment_created.html.erb +1 -1
- data/decidim-comments/app/views/decidim/comments/comment_notification_mailer/reply_created.html.erb +1 -1
- data/decidim-comments/bin/rails +3 -3
- data/decidim-comments/config/locales/ca.yml +5 -0
- data/decidim-comments/config/locales/en.yml +5 -0
- data/decidim-comments/config/locales/es.yml +5 -0
- data/decidim-comments/config/locales/it.yml +65 -0
- data/decidim-comments/db/migrate/20161130143508_create_comments.rb +2 -0
- data/decidim-comments/db/migrate/20161214082645_add_depth_to_comments.rb +2 -0
- data/decidim-comments/db/migrate/20161216102820_add_alignment_to_comments.rb +2 -0
- data/decidim-comments/db/migrate/20161219150806_create_comment_votes.rb +3 -1
- data/decidim-comments/db/migrate/20170123102043_add_user_group_id_to_comments.rb +2 -0
- data/decidim-comments/db/migrate/20170504085413_add_root_commentable_to_comments.rb +2 -0
- data/decidim-comments/db/migrate/20170510091348_update_root_commentable_for_comments.rb +3 -2
- data/decidim-comments/db/migrate/20170510091409_set_root_commentable_null_constraints.rb +2 -0
- data/decidim-comments/decidim-comments.gemspec +2 -1
- data/decidim-comments/lib/decidim/comments/comment_serializer.rb +1 -1
- data/decidim-comments/lib/decidim/comments/commentable.rb +4 -4
- data/decidim-comments/spec/commands/create_comment_spec.rb +2 -2
- data/decidim-comments/spec/features/admin_manages_comments_spec.rb +4 -9
- data/decidim-comments/spec/features/process_admin_manages_comments_spec.rb +5 -11
- data/decidim-comments/spec/mailers/comment_notification_mailer_spec.rb +12 -7
- data/decidim-comments/spec/shared/author_localised_email.rb +26 -0
- data/decidim-comments/spec/spec_helper.rb +1 -1
- data/decidim-dev/config/locales/it.yml +9 -0
- data/decidim-dev/decidim-dev.gemspec +8 -3
- data/decidim-dev/lib/decidim/dev.rb +1 -8
- data/decidim-dev/lib/decidim/dev/railtie.rb +1 -1
- data/decidim-dev/lib/decidim/dev/test/base_spec_helper.rb +6 -4
- data/decidim-dev/lib/decidim/dev/test/rspec_support/capybara.rb +2 -2
- data/decidim-dev/lib/decidim/dev/test/rspec_support/feature.rb +4 -2
- data/decidim-dev/lib/decidim/dev/test/rspec_support/feature_context.rb +28 -8
- data/decidim-dev/lib/decidim/dev/test/rspec_support/translation_helpers.rb +7 -2
- data/decidim-dev/lib/decidim/dev/test/spec_helper.rb +2 -2
- data/decidim-dev/lib/generators/decidim/dummy_generator.rb +1 -1
- data/decidim-meetings/README.md +1 -1
- data/decidim-meetings/app/controllers/decidim/meetings/application_controller.rb +1 -1
- data/decidim-meetings/app/views/decidim/meetings/meetings/_linked_meetings.html.erb +1 -1
- data/decidim-meetings/bin/rails +3 -3
- data/decidim-meetings/config/locales/it.yml +87 -0
- data/decidim-meetings/db/migrate/20161130121354_create_meetings.rb +2 -0
- data/decidim-meetings/db/migrate/20170110142105_close_a_meeting.rb +2 -0
- data/decidim-meetings/db/migrate/20170123151650_add_latitude_and_longitude_to_meetings.rb +2 -0
- data/decidim-meetings/db/migrate/20170129153716_remove_short_description_from_meetings.rb +2 -0
- data/decidim-meetings/db/migrate/20170215132546_add_reference_to_meetings.rb +2 -0
- data/decidim-meetings/db/migrate/20170410074252_remove_not_null_reference_meetings.rb +2 -0
- data/decidim-meetings/db/migrate/20170612101925_migrate_meetings_category.rb +15 -0
- data/decidim-meetings/decidim-meetings.gemspec +3 -1
- data/decidim-meetings/lib/decidim/meetings/feature.rb +2 -2
- data/decidim-meetings/spec/features/admin_manages_meetings_attachments_spec.rb +5 -1
- data/decidim-meetings/spec/features/admin_manages_meetings_spec.rb +5 -7
- data/decidim-meetings/spec/features/explore_meetings_spec.rb +32 -6
- data/decidim-meetings/spec/features/process_admin_manages_meetings_attachments_spec.rb +4 -2
- data/decidim-meetings/spec/features/process_admin_manages_meetings_spec.rb +5 -8
- data/decidim-meetings/spec/shared/manage_attachments_examples.rb +0 -3
- data/decidim-meetings/spec/shared/manage_meetings_examples.rb +11 -11
- data/decidim-meetings/spec/spec_helper.rb +2 -1
- data/decidim-pages/bin/rails +3 -3
- data/decidim-pages/config/locales/it.yml +22 -0
- data/decidim-pages/db/migrate/20161116121353_create_decidim_pages.rb +2 -0
- data/decidim-pages/db/migrate/20161214150429_add_commentable_to_pages.rb +2 -0
- data/decidim-pages/db/migrate/20170110145040_remove_commentable_flag_from_pages.rb +2 -0
- data/decidim-pages/db/migrate/20170220091402_remove_page_feature_titles.rb +2 -0
- data/decidim-pages/decidim-pages.gemspec +3 -1
- data/decidim-pages/spec/features/admin_spec.rb +1 -1
- data/decidim-pages/spec/spec_helper.rb +2 -3
- data/decidim-proposals/app/commands/decidim/proposals/unvote_proposal.rb +34 -0
- data/decidim-proposals/app/commands/decidim/proposals/vote_proposal.rb +39 -0
- data/decidim-proposals/app/controllers/concerns/decidim/proposals/orderable.rb +7 -3
- data/decidim-proposals/app/controllers/decidim/proposals/proposal_votes_controller.rb +18 -8
- data/decidim-proposals/app/models/decidim/proposals/proposal.rb +3 -3
- data/decidim-proposals/app/models/decidim/proposals/proposal_vote.rb +0 -1
- data/decidim-proposals/app/views/decidim/proposals/proposals/_author.html.erb +23 -0
- data/decidim-proposals/app/views/decidim/proposals/proposals/_linked_proposals.html.erb +2 -2
- data/decidim-proposals/app/views/decidim/proposals/proposals/_proposal.html.erb +1 -9
- data/decidim-proposals/app/views/decidim/proposals/proposals/_vote_button.html.erb +2 -6
- data/decidim-proposals/app/views/decidim/proposals/proposals/new.html.erb +1 -1
- data/decidim-proposals/app/views/decidim/proposals/proposals/show.html.erb +1 -11
- data/decidim-proposals/bin/rails +3 -3
- data/decidim-proposals/config/locales/ca.yml +6 -0
- data/decidim-proposals/config/locales/en.yml +6 -0
- data/decidim-proposals/config/locales/es.yml +6 -0
- data/decidim-proposals/config/locales/eu.yml +0 -2
- data/decidim-proposals/config/locales/fi.yml +0 -2
- data/decidim-proposals/config/locales/fr.yml +0 -2
- data/decidim-proposals/config/locales/it.yml +147 -0
- data/decidim-proposals/db/migrate/20161212110850_create_decidim_proposals.rb +2 -0
- data/decidim-proposals/db/migrate/20170112115253_create_proposal_votes.rb +3 -1
- data/decidim-proposals/db/migrate/20170113114245_add_text_search_indexes.rb +2 -0
- data/decidim-proposals/db/migrate/20170118120151_add_counter_cache_votes_to_proposals.rb +2 -0
- data/decidim-proposals/db/migrate/20170120151202_add_user_group_id_to_proposals.rb +2 -0
- data/decidim-proposals/db/migrate/20170131092413_add_answers_to_proposals.rb +2 -0
- data/decidim-proposals/db/migrate/20170205082832_add_index_to_decidim_proposals_proposals_proposal_votes_count.rb +2 -0
- data/decidim-proposals/db/migrate/20170215113152_create_proposal_reports.rb +2 -0
- data/decidim-proposals/db/migrate/20170215131720_add_report_count_to_proposals.rb +2 -0
- data/decidim-proposals/db/migrate/20170215132030_add_reference_to_proposals.rb +2 -0
- data/decidim-proposals/db/migrate/20170220152416_add_hidden_at_to_proposals.rb +2 -0
- data/decidim-proposals/db/migrate/20170228105156_add_geolocalization_fields_to_proposals.rb +2 -0
- data/decidim-proposals/db/migrate/20170307085300_migrate_proposal_reports_data_to_reports.rb +8 -10
- data/decidim-proposals/db/migrate/20170410073742_remove_not_null_reference_proposals.rb +2 -0
- data/decidim-proposals/db/migrate/20170612101809_migrate_proposals_category.rb +15 -0
- data/decidim-proposals/decidim-proposals.gemspec +4 -2
- data/decidim-proposals/lib/decidim/proposals/feature.rb +5 -1
- data/decidim-proposals/lib/decidim/proposals/proposal_serializer.rb +1 -6
- data/decidim-proposals/spec/commands/decidim/proposals/unvote_proposal_spec.rb +26 -0
- data/decidim-proposals/spec/commands/decidim/proposals/vote_proposal_spec.rb +47 -0
- data/decidim-proposals/spec/features/admin_manages_proposals_spec.rb +6 -11
- data/decidim-proposals/spec/features/process_admin_manages_proposals_spec.rb +6 -12
- data/decidim-proposals/spec/features/proposals_spec.rb +38 -12
- data/decidim-proposals/spec/shared/manage_proposals_examples.rb +3 -6
- data/decidim-proposals/spec/spec_helper.rb +2 -1
- data/decidim-results/app/controllers/decidim/results/application_controller.rb +1 -1
- data/decidim-results/app/views/decidim/results/results/_linked_results.html.erb +1 -1
- data/decidim-results/bin/rails +3 -3
- data/decidim-results/config/locales/it.yml +78 -0
- data/decidim-results/db/migrate/20170116104125_create_results.rb +2 -0
- data/decidim-results/db/migrate/20170129164553_remove_short_description_from_results.rb +2 -0
- data/decidim-results/db/migrate/20170215132624_add_reference_to_results.rb +2 -0
- data/decidim-results/db/migrate/20170410074358_remove_not_null_reference_results.rb +2 -0
- data/decidim-results/db/migrate/20170612101951_migrate_results_category.rb +15 -0
- data/decidim-results/decidim-results.gemspec +3 -1
- data/decidim-results/spec/features/admin_manages_results_spec.rb +5 -7
- data/decidim-results/spec/features/process_admin_manages_results_spec.rb +5 -8
- data/decidim-results/spec/shared/manage_results_examples.rb +3 -3
- data/decidim-results/spec/spec_helper.rb +2 -1
- data/decidim-surveys/README.md +24 -0
- data/decidim-surveys/Rakefile +3 -0
- data/decidim-surveys/app/assets/config/admin/decidim_surveys_manifest.js +1 -0
- data/decidim-surveys/app/assets/images/decidim/surveys/icon.svg +1 -0
- data/decidim-surveys/app/assets/javascripts/decidim/surveys/admin/auto_label_by_position.component.js.es6 +33 -0
- data/decidim-surveys/app/assets/javascripts/decidim/surveys/admin/dynamic_fields.component.js.es6 +95 -0
- data/decidim-surveys/app/assets/javascripts/decidim/surveys/admin/surveys.js.es6 +85 -0
- data/decidim-surveys/app/assets/stylesheets/decidim/surveys/surveys.scss +9 -0
- data/decidim-surveys/app/commands/decidim/surveys/admin/update_survey.rb +65 -0
- data/decidim-surveys/app/commands/decidim/surveys/answer_survey.rb +43 -0
- data/decidim-surveys/app/commands/decidim/surveys/create_survey.rb +19 -0
- data/decidim-surveys/app/controllers/decidim/surveys/admin/application_controller.rb +15 -0
- data/decidim-surveys/app/controllers/decidim/surveys/admin/surveys_controller.rb +55 -0
- data/decidim-surveys/app/controllers/decidim/surveys/application_controller.rb +13 -0
- data/decidim-surveys/app/controllers/decidim/surveys/surveys_controller.rb +39 -0
- data/decidim-surveys/app/forms/decidim/surveys/admin/survey_form.rb +19 -0
- data/decidim-surveys/app/forms/decidim/surveys/admin/survey_question_answer_option_form.rb +15 -0
- data/decidim-surveys/app/forms/decidim/surveys/admin/survey_question_form.rb +24 -0
- data/decidim-surveys/app/forms/decidim/surveys/survey_answer_form.rb +36 -0
- data/decidim-surveys/app/forms/decidim/surveys/survey_form.rb +22 -0
- data/decidim-surveys/app/helpers/decidim/surveys/admin/application_helper.rb +39 -0
- data/decidim-surveys/app/models/decidim/surveys/abilities/admin_user.rb +34 -0
- data/decidim-surveys/app/models/decidim/surveys/abilities/current_user.rb +47 -0
- data/decidim-surveys/app/models/decidim/surveys/abilities/process_admin_user.rb +44 -0
- data/decidim-surveys/app/models/decidim/surveys/application_record.rb +10 -0
- data/decidim-surveys/app/models/decidim/surveys/survey.rb +25 -0
- data/decidim-surveys/app/models/decidim/surveys/survey_answer.rb +27 -0
- data/decidim-surveys/app/models/decidim/surveys/survey_question.rb +18 -0
- data/decidim-surveys/app/queries/decidim/surveys/survey_user_answers.rb +28 -0
- data/decidim-surveys/app/views/decidim/surveys/admin/surveys/_answer_option.html.erb +23 -0
- data/decidim-surveys/app/views/decidim/surveys/admin/surveys/_form.html.erb +47 -0
- data/decidim-surveys/app/views/decidim/surveys/admin/surveys/_question.html.erb +57 -0
- data/decidim-surveys/app/views/decidim/surveys/admin/surveys/edit.html.erb +7 -0
- data/decidim-surveys/app/views/decidim/surveys/surveys/show.html.erb +102 -0
- data/decidim-surveys/bin/rails +15 -0
- data/decidim-surveys/config/i18n-tasks.yml +11 -0
- data/decidim-surveys/config/locales/ca.yml +69 -0
- data/decidim-surveys/config/locales/en.yml +73 -0
- data/decidim-surveys/config/locales/es.yml +69 -0
- data/decidim-surveys/config/locales/eu.yml +5 -0
- data/decidim-surveys/config/locales/fi.yml +5 -0
- data/decidim-surveys/config/locales/fr.yml +5 -0
- data/decidim-surveys/config/locales/it.yml +5 -0
- data/decidim-surveys/config/locales/nl.yml +5 -0
- data/decidim-surveys/db/migrate/20170511092231_create_decidim_surveys.rb +15 -0
- data/decidim-surveys/db/migrate/20170515090916_create_decidim_survey_questions.rb +12 -0
- data/decidim-surveys/db/migrate/20170515144119_create_decidim_survey_answers.rb +14 -0
- data/decidim-surveys/db/migrate/20170518085302_add_position_to_surveys_questions.rb +7 -0
- data/decidim-surveys/db/migrate/20170522075938_add_mandatory_to_surveys_questions.rb +7 -0
- data/decidim-surveys/db/migrate/20170524122229_add_question_type_to_surveys_questions.rb +7 -0
- data/decidim-surveys/db/migrate/20170525132233_add_answer_options_to_surveys_questions.rb +7 -0
- data/decidim-surveys/decidim-surveys.gemspec +22 -0
- data/decidim-surveys/lib/decidim/surveys.rb +14 -0
- data/decidim-surveys/lib/decidim/surveys/admin.rb +10 -0
- data/decidim-surveys/lib/decidim/surveys/admin_engine.rb +34 -0
- data/decidim-surveys/lib/decidim/surveys/engine.rb +25 -0
- data/decidim-surveys/lib/decidim/surveys/feature.rb +85 -0
- data/decidim-surveys/lib/decidim/surveys/survey_user_answers_serializer.rb +23 -0
- data/decidim-surveys/lib/decidim/surveys/test/factories.rb +39 -0
- data/decidim-surveys/spec/commands/decidim/surveys/admin/update_survey_spec.rb +147 -0
- data/decidim-surveys/spec/commands/decidim/surveys/answer_survey_spec.rb +71 -0
- data/decidim-surveys/spec/commands/decidim/surveys/create_survey_spec.rb +44 -0
- data/decidim-surveys/spec/factories.rb +3 -0
- data/decidim-surveys/spec/features/admin_manages_surveys_spec.rb +13 -0
- data/decidim-surveys/spec/features/process_admin_manages_surveys_spec.rb +13 -0
- data/decidim-surveys/spec/features/survey_spec.rb +235 -0
- data/decidim-surveys/spec/forms/decidim/surveys/admin/survey_form_spec.rb +64 -0
- data/decidim-surveys/spec/forms/decidim/surveys/admin/survey_question_form_spec.rb +36 -0
- data/decidim-surveys/spec/forms/decidim/surveys/survey_answer_form_spec.rb +36 -0
- data/decidim-surveys/spec/forms/decidim/surveys/survey_form_spec.rb +32 -0
- data/decidim-surveys/spec/models/decidim/surveys/abilities/admin_user_spec.rb +22 -0
- data/decidim-surveys/spec/models/decidim/surveys/abilities/current_user_spec.rb +19 -0
- data/decidim-surveys/spec/models/decidim/surveys/abilities/process_admin_user_spec.rb +23 -0
- data/decidim-surveys/spec/models/decidim/surveys/survey_answer_spec.rb +55 -0
- data/decidim-surveys/spec/models/decidim/surveys/survey_question_spec.rb +19 -0
- data/decidim-surveys/spec/models/decidim/surveys/survey_spec.rb +65 -0
- data/decidim-surveys/spec/queries/decidim/surveys/survey_user_answers_spec.rb +21 -0
- data/decidim-surveys/spec/services/decidim/surveys/surveys/survey_user_answer_serializer_spec.rb +34 -0
- data/decidim-surveys/spec/shared/edit_survey_examples.rb +213 -0
- data/decidim-surveys/spec/shared/export_survey_user_answers_examples.rb +47 -0
- data/decidim-surveys/spec/spec_helper.rb +4 -0
- data/decidim-system/app/controllers/decidim/system/devise/passwords_controller.rb +2 -0
- data/decidim-system/app/helpers/decidim/system/menu_helper.rb +0 -1
- data/decidim-system/bin/rails +3 -3
- data/decidim-system/config/locales/it.yml +66 -0
- data/decidim-system/db/migrate/20160919105637_devise_create_decidim_admins.rb +2 -0
- data/decidim-system/decidim-system.gemspec +2 -1
- data/decidim-system/spec/spec_helper.rb +3 -2
- data/decidim.gemspec +5 -4
- data/docs/geocoding.md +2 -2
- data/docs/how_to_create_a_plugin.md +11 -11
- data/lib/decidim.rb +1 -0
- data/lib/generators/decidim/app_generator.rb +3 -2
- data/lib/generators/decidim/demo_generator.rb +1 -1
- data/lib/generators/decidim/docker_generator.rb +2 -2
- data/lib/generators/decidim/install_generator.rb +3 -6
- data/lib/generators/decidim/templates/initializer.rb +2 -2
- metadata +130 -47
- data/decidim-admin/app/assets/javascripts/decidim/admin/sort_steps.js.es6 +0 -30
- data/decidim-budgets/spec/shared/admin_shared_context.rb +0 -13
- data/decidim-comments/spec/shared/admin_shared_context.rb +0 -13
- data/decidim-meetings/spec/shared/admin_shared_context.rb +0 -13
- data/decidim-proposals/spec/shared/admin_shared_context.rb +0 -13
- data/decidim-results/spec/shared/admin_shared_context.rb +0 -13
@@ -3,13 +3,10 @@
|
|
3
3
|
require "spec_helper"
|
4
4
|
|
5
5
|
describe "Process admin manages results", type: :feature do
|
6
|
-
|
7
|
-
let(:
|
8
|
-
|
6
|
+
let(:manifest_name) { "results" }
|
7
|
+
let!(:result) { create :result, scope: scope, feature: current_feature }
|
8
|
+
|
9
|
+
include_context "feature process admin"
|
9
10
|
|
10
|
-
|
11
|
-
switch_to_host(organization.host)
|
12
|
-
login_as user, scope: :user
|
13
|
-
visit decidim_admin.manage_feature_path(participatory_process_id: participatory_process, feature_id: current_feature)
|
14
|
-
end
|
11
|
+
it_behaves_like "manage results"
|
15
12
|
end
|
@@ -10,7 +10,7 @@ RSpec.shared_examples "manage results" do
|
|
10
10
|
within ".edit_result" do
|
11
11
|
fill_in_i18n(
|
12
12
|
:result_title,
|
13
|
-
"#title-tabs",
|
13
|
+
"#result-title-tabs",
|
14
14
|
en: "My new title",
|
15
15
|
es: "Mi nuevo título",
|
16
16
|
ca: "El meu nou títol"
|
@@ -47,14 +47,14 @@ RSpec.shared_examples "manage results" do
|
|
47
47
|
within ".new_result" do
|
48
48
|
fill_in_i18n(
|
49
49
|
:result_title,
|
50
|
-
"#title-tabs",
|
50
|
+
"#result-title-tabs",
|
51
51
|
en: "My result",
|
52
52
|
es: "Mi result",
|
53
53
|
ca: "El meu result"
|
54
54
|
)
|
55
55
|
fill_in_i18n_editor(
|
56
56
|
:result_description,
|
57
|
-
"#description-tabs",
|
57
|
+
"#result-description-tabs",
|
58
58
|
en: "A longer description",
|
59
59
|
es: "Descripción más larga",
|
60
60
|
ca: "Descripció més llarga"
|
@@ -0,0 +1,24 @@
|
|
1
|
+
# Decidim::Surveys
|
2
|
+
|
3
|
+
The Surveys module adds one of the main features of Decidim: allows admins to contribute to a participatory process by creating surveys. Users can participate in the surveys answering their questions from the public page.
|
4
|
+
|
5
|
+
## Usage
|
6
|
+
Surveys will be available as a Feature for a Participatory Process.
|
7
|
+
|
8
|
+
## Installation
|
9
|
+
Add this line to your application's Gemfile:
|
10
|
+
|
11
|
+
```ruby
|
12
|
+
gem 'decidim-surveys'
|
13
|
+
```
|
14
|
+
|
15
|
+
And then execute:
|
16
|
+
```bash
|
17
|
+
$ bundle
|
18
|
+
```
|
19
|
+
|
20
|
+
## Contributing
|
21
|
+
See [Decidim](https://github.com/decidim/decidim).
|
22
|
+
|
23
|
+
## License
|
24
|
+
See [Decidim](https://github.com/decidim/decidim).
|
@@ -0,0 +1 @@
|
|
1
|
+
//= link decidim/surveys/admin/surveys.js
|
@@ -0,0 +1 @@
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 36.02 36.02"><path d="M373,545.54a18,18,0,1,1,18-18A18,18,0,0,1,373,545.54Zm0-34a16,16,0,1,0,16,16A16,16,0,0,0,373,511.53Z" transform="translate(-354.99 -509.53)"/><path d="M377.73,536.41h-9.46a1,1,0,1,1,0-2h9.46A1,1,0,0,1,377.73,536.41Z" transform="translate(-354.99 -509.53)"/><path d="M375,525.54h-6.73a1,1,0,1,1,0-2H375A1,1,0,1,1,375,525.54Z" transform="translate(-354.99 -509.53)"/><path d="M375,535.41a1,1,0,0,1-1-1v-9.87a1,1,0,1,1,2,0v9.87A1,1,0,0,1,375,535.41Z" transform="translate(-354.99 -509.53)"/><path d="M373,523a3,3,0,1,1,3-3A3,3,0,0,1,373,523Zm0-4a1,1,0,1,0,1,1A1,1,0,0,0,373,519Z" transform="translate(-354.99 -509.53)"/><path d="M371,535.41a1,1,0,0,1-1-1v-9.87a1,1,0,1,1,2,0v9.87A1,1,0,0,1,371,535.41Z" transform="translate(-354.99 -509.53)"/></svg>
|
@@ -0,0 +1,33 @@
|
|
1
|
+
((exports) => {
|
2
|
+
class AutoLabelByPositionComponent {
|
3
|
+
constructor(options = {}) {
|
4
|
+
this.listSelector = options.listSelector;
|
5
|
+
this.labelSelector = options.labelSelector;
|
6
|
+
this.onPositionComputed = options.onPositionComputed;
|
7
|
+
|
8
|
+
this.run();
|
9
|
+
}
|
10
|
+
|
11
|
+
run() {
|
12
|
+
const $list = $(this.listSelector);
|
13
|
+
|
14
|
+
$list.each((idx, el) => {
|
15
|
+
const $label = $(el).find(this.labelSelector);
|
16
|
+
const labelContent = $label.html();
|
17
|
+
|
18
|
+
if (labelContent.match(/#(\d+)/)) {
|
19
|
+
$label.html(labelContent.replace(/#(\d+)/, `#${idx + 1}`));
|
20
|
+
} else {
|
21
|
+
$label.html(`${labelContent} #${idx + 1}`);
|
22
|
+
}
|
23
|
+
|
24
|
+
if (this.onPositionComputed) {
|
25
|
+
this.onPositionComputed(el, idx);
|
26
|
+
}
|
27
|
+
});
|
28
|
+
}
|
29
|
+
}
|
30
|
+
|
31
|
+
exports.DecidimAdmin = exports.DecidimAdmin || {};
|
32
|
+
exports.DecidimAdmin.AutoLabelByPositionComponent = AutoLabelByPositionComponent;
|
33
|
+
})(window);
|
data/decidim-surveys/app/assets/javascripts/decidim/surveys/admin/dynamic_fields.component.js.es6
ADDED
@@ -0,0 +1,95 @@
|
|
1
|
+
((exports) => {
|
2
|
+
class DynamicFieldsComponent {
|
3
|
+
constructor(options = {}) {
|
4
|
+
this.templateId = options.templateId;
|
5
|
+
this.wrapperSelector = options.wrapperSelector;
|
6
|
+
this.containerSelector = options.containerSelector;
|
7
|
+
this.fieldSelector = options.fieldSelector;
|
8
|
+
this.addFieldButtonSelector = options.addFieldButtonSelector;
|
9
|
+
this.removeFieldButtonSelector = options.removeFieldButtonSelector;
|
10
|
+
this.onAddField = options.onAddField;
|
11
|
+
this.onRemoveField = options.onRemoveField;
|
12
|
+
this.tabsPrefix = options.tabsPrefix;
|
13
|
+
this._compileTemplate();
|
14
|
+
this._bindEvents();
|
15
|
+
}
|
16
|
+
|
17
|
+
_compileTemplate() {
|
18
|
+
$.template(this.templateId, $(`#${this.templateId}`).html());
|
19
|
+
}
|
20
|
+
|
21
|
+
_bindEvents() {
|
22
|
+
$(this.wrapperSelector).on('click', this.addFieldButtonSelector, (event) =>
|
23
|
+
this._bindSafeEvent(event, () => this._addField())
|
24
|
+
);
|
25
|
+
|
26
|
+
$(this.wrapperSelector).on('click', this.removeFieldButtonSelector, (event) =>
|
27
|
+
this._bindSafeEvent(event, (target) => this._removeField(target))
|
28
|
+
);
|
29
|
+
}
|
30
|
+
|
31
|
+
_bindSafeEvent(event, cb) {
|
32
|
+
event.preventDefault();
|
33
|
+
event.stopPropagation();
|
34
|
+
|
35
|
+
try {
|
36
|
+
return cb(event.target);
|
37
|
+
} catch (error) {
|
38
|
+
console.error(error); // eslint-disable-line no-console
|
39
|
+
return error;
|
40
|
+
}
|
41
|
+
}
|
42
|
+
|
43
|
+
_addField() {
|
44
|
+
const $container = $(this.wrapperSelector).find(this.containerSelector);
|
45
|
+
const uid = this._getUID();
|
46
|
+
const tabsId = `${this.tabsPrefix}-${uid}`;
|
47
|
+
|
48
|
+
const $newField = $.tmpl(this.templateId, { tabsId });
|
49
|
+
|
50
|
+
$newField.attr('id', `${tabsId}-field`);
|
51
|
+
$newField.find('[disabled]').attr('disabled', false);
|
52
|
+
$newField.find('ul.tabs').attr('data-tabs', true);
|
53
|
+
|
54
|
+
$newField.appendTo($container);
|
55
|
+
$newField.foundation();
|
56
|
+
|
57
|
+
if (this.onAddField) {
|
58
|
+
this.onAddField($newField);
|
59
|
+
}
|
60
|
+
}
|
61
|
+
|
62
|
+
_removeField(target) {
|
63
|
+
const $target = $(target);
|
64
|
+
const $removedField = $target.parents(this.fieldSelector);
|
65
|
+
const idInput = $removedField.find('input').filter((idx, input) => input.name.match(/id/));
|
66
|
+
|
67
|
+
if (idInput.length > 0) {
|
68
|
+
const deletedInput = $removedField.find('input').filter((idx, input) => input.name.match(/delete/));
|
69
|
+
|
70
|
+
if (deletedInput.length > 0) {
|
71
|
+
$(deletedInput[0]).val(true);
|
72
|
+
}
|
73
|
+
|
74
|
+
$removedField.addClass('hidden');
|
75
|
+
$removedField.hide();
|
76
|
+
} else {
|
77
|
+
$removedField.remove();
|
78
|
+
}
|
79
|
+
|
80
|
+
if (this.onRemoveField) {
|
81
|
+
this.onRemoveField($removedField);
|
82
|
+
}
|
83
|
+
}
|
84
|
+
|
85
|
+
_getUID() {
|
86
|
+
return `${new Date().getTime()}-${Math.floor(Math.random() * 1000000)}`;
|
87
|
+
}
|
88
|
+
}
|
89
|
+
|
90
|
+
exports.DecidimAdmin = exports.DecidimAdmin || {};
|
91
|
+
exports.DecidimAdmin.DynamicFieldsComponent = DynamicFieldsComponent;
|
92
|
+
exports.DecidimAdmin.createDynamicFields = (options) => {
|
93
|
+
return new DynamicFieldsComponent(options);
|
94
|
+
};
|
95
|
+
})(window);
|
@@ -0,0 +1,85 @@
|
|
1
|
+
// = require jquery-tmpl
|
2
|
+
// = require ./auto_label_by_position.component
|
3
|
+
// = require ./dynamic_fields.component
|
4
|
+
|
5
|
+
((exports) => {
|
6
|
+
const { AutoLabelByPositionComponent, createDynamicFields, createSortList } = exports.DecidimAdmin;
|
7
|
+
|
8
|
+
const wrapperSelector = '.survey-questions';
|
9
|
+
const fieldSelector = '.survey-question';
|
10
|
+
const questionTypeSelector = '[name="survey[questions][][question_type]"]';
|
11
|
+
const answerOptionsWrapperSelector = '.survey-question-answer-options';
|
12
|
+
|
13
|
+
const autoLabelByPosition = new AutoLabelByPositionComponent({
|
14
|
+
listSelector: '.survey-question:not(.hidden)',
|
15
|
+
labelSelector: '.card-title span:first',
|
16
|
+
onPositionComputed: (el, idx) => {
|
17
|
+
$(el).find('input[name="survey[questions][][position]"]').val(idx);
|
18
|
+
}
|
19
|
+
});
|
20
|
+
|
21
|
+
const createSortableList = () => {
|
22
|
+
createSortList('.survey-questions-list:not(.published)', {
|
23
|
+
handle: '.question-divider',
|
24
|
+
placeholder: '<div style="border-style: dashed; border-color: #000"></div>',
|
25
|
+
forcePlaceholderSize: true,
|
26
|
+
onSortUpdate: () => { autoLabelByPosition.run() }
|
27
|
+
});
|
28
|
+
};
|
29
|
+
|
30
|
+
const createDynamicFieldsForAnswerOptions = (fieldId) => {
|
31
|
+
createDynamicFields({
|
32
|
+
templateId: `survey-question-answer-option-tmpl`,
|
33
|
+
tabsPrefix: `survey-question-answer-option`,
|
34
|
+
wrapperSelector: `#${fieldId} ${answerOptionsWrapperSelector}`,
|
35
|
+
containerSelector: `.survey-question-answer-options-list`,
|
36
|
+
fieldSelector: `.survey-question-answer-option`,
|
37
|
+
addFieldButtonSelector: `.add-answer-option`,
|
38
|
+
removeFieldButtonSelector: `.remove-answer-option`
|
39
|
+
});
|
40
|
+
};
|
41
|
+
|
42
|
+
const setAnswerOptionsWrapperVisibility = ($target) => {
|
43
|
+
const $answerOptionsWrapper = $target.parents(fieldSelector).find(answerOptionsWrapperSelector);
|
44
|
+
const value = $target.val();
|
45
|
+
|
46
|
+
$answerOptionsWrapper.hide();
|
47
|
+
|
48
|
+
if (value === 'single_option' || value === 'multiple_option') {
|
49
|
+
$answerOptionsWrapper.show();
|
50
|
+
}
|
51
|
+
};
|
52
|
+
|
53
|
+
createDynamicFields({
|
54
|
+
templateId: 'survey-question-tmpl',
|
55
|
+
tabsPrefix: 'survey-question',
|
56
|
+
wrapperSelector: wrapperSelector,
|
57
|
+
containerSelector: '.survey-questions-list',
|
58
|
+
fieldSelector: fieldSelector,
|
59
|
+
addFieldButtonSelector: '.add-question',
|
60
|
+
removeFieldButtonSelector: '.remove-question',
|
61
|
+
onAddField: ($field) => {
|
62
|
+
const fieldId = $field.attr('id');
|
63
|
+
|
64
|
+
createSortableList();
|
65
|
+
autoLabelByPosition.run();
|
66
|
+
createDynamicFieldsForAnswerOptions(fieldId);
|
67
|
+
setAnswerOptionsWrapperVisibility($field.find(questionTypeSelector));
|
68
|
+
},
|
69
|
+
onRemoveField: () => {
|
70
|
+
autoLabelByPosition.run();
|
71
|
+
}
|
72
|
+
});
|
73
|
+
|
74
|
+
createSortableList();
|
75
|
+
|
76
|
+
$(fieldSelector).each((idx, el) => {
|
77
|
+
createDynamicFieldsForAnswerOptions($(el).attr('id'));
|
78
|
+
setAnswerOptionsWrapperVisibility($(el).find(questionTypeSelector));
|
79
|
+
});
|
80
|
+
|
81
|
+
$(wrapperSelector).on('change', questionTypeSelector, (ev) => {
|
82
|
+
const $target = $(ev.target);
|
83
|
+
setAnswerOptionsWrapperVisibility($target);
|
84
|
+
});
|
85
|
+
})(window);
|
@@ -0,0 +1,65 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
module Surveys
|
5
|
+
module Admin
|
6
|
+
# This command is executed when the user changes a Survey from the admin
|
7
|
+
# panel.
|
8
|
+
class UpdateSurvey < Rectify::Command
|
9
|
+
# Initializes a UpdateSurvey Command.
|
10
|
+
#
|
11
|
+
# form - The form from which to get the data.
|
12
|
+
# survey - The current instance of the survey to be updated.
|
13
|
+
def initialize(form, survey)
|
14
|
+
@form = form
|
15
|
+
@survey = survey
|
16
|
+
end
|
17
|
+
|
18
|
+
# Updates the survey if valid.
|
19
|
+
#
|
20
|
+
# Broadcasts :ok if successful, :invalid otherwise.
|
21
|
+
def call
|
22
|
+
return broadcast(:invalid) if @form.invalid?
|
23
|
+
|
24
|
+
Survey.transaction do
|
25
|
+
update_survey_questions if @survey.questions_editable?
|
26
|
+
update_survey
|
27
|
+
end
|
28
|
+
|
29
|
+
broadcast(:ok)
|
30
|
+
end
|
31
|
+
|
32
|
+
private
|
33
|
+
|
34
|
+
def update_survey_questions
|
35
|
+
@form.questions.each do |form_question|
|
36
|
+
question_attributes = {
|
37
|
+
body: form_question.body,
|
38
|
+
position: form_question.position,
|
39
|
+
mandatory: form_question.mandatory,
|
40
|
+
question_type: form_question.question_type,
|
41
|
+
answer_options: form_question.answer_options.map { |answer| { "body" => answer.body } }
|
42
|
+
}
|
43
|
+
|
44
|
+
if form_question.id.present?
|
45
|
+
question = @survey.questions.where(id: form_question.id).first
|
46
|
+
if form_question.deleted?
|
47
|
+
question.destroy!
|
48
|
+
else
|
49
|
+
question.update_attributes!(question_attributes)
|
50
|
+
end
|
51
|
+
else
|
52
|
+
@survey.questions.create!(question_attributes)
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
def update_survey
|
58
|
+
@survey.update_attributes!(title: @form.title,
|
59
|
+
description: @form.description,
|
60
|
+
tos: @form.tos)
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
module Surveys
|
5
|
+
# This command is executed when the user answers a Survey.
|
6
|
+
class AnswerSurvey < Rectify::Command
|
7
|
+
# Initializes a AnswerSurvey Command.
|
8
|
+
#
|
9
|
+
# form - The form from which to get the data.
|
10
|
+
# survey - The current instance of the survey to be answered.
|
11
|
+
def initialize(form, current_user, survey)
|
12
|
+
@form = form
|
13
|
+
@current_user = current_user
|
14
|
+
@survey = survey
|
15
|
+
end
|
16
|
+
|
17
|
+
# Answers a survey if it is valid
|
18
|
+
#
|
19
|
+
# Broadcasts :ok if successful, :invalid otherwise.
|
20
|
+
def call
|
21
|
+
return broadcast(:invalid) if @form.invalid?
|
22
|
+
|
23
|
+
answer_survey
|
24
|
+
broadcast(:ok)
|
25
|
+
end
|
26
|
+
|
27
|
+
private
|
28
|
+
|
29
|
+
def answer_survey
|
30
|
+
SurveyAnswer.transaction do
|
31
|
+
@form.answers.each do |form_answer|
|
32
|
+
SurveyAnswer.create!(
|
33
|
+
user: @current_user,
|
34
|
+
survey: @survey,
|
35
|
+
question: form_answer.question,
|
36
|
+
body: form_answer.body
|
37
|
+
)
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
module Surveys
|
5
|
+
# Command that gets called whenever a feature's survey has to be created. It
|
6
|
+
# usually happens as a callback when the feature itself is created.
|
7
|
+
class CreateSurvey < Rectify::Command
|
8
|
+
def initialize(feature)
|
9
|
+
@feature = feature
|
10
|
+
end
|
11
|
+
|
12
|
+
def call
|
13
|
+
@survey = Survey.new(feature: @feature)
|
14
|
+
|
15
|
+
@survey.save ? broadcast(:ok) : broadcast(:invalid)
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|