decidim 0.0.2 → 0.0.3
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/.travis.yml +12 -0
- data/Dockerfile +2 -0
- data/Gemfile.lock +80 -54
- data/README.md +15 -2
- data/decidim-admin/app/assets/javascripts/decidim/admin/application.js.es6 +3 -2
- data/decidim-admin/app/assets/javascripts/decidim/admin/tab_focus.js.es6 +1 -1
- data/decidim-admin/app/assets/stylesheets/decidim/admin/_foundation_and_overrides.scss +1 -1
- data/decidim-admin/app/commands/decidim/admin/{create_participatory_process_attachment.rb → create_attachment.rb} +6 -7
- data/decidim-admin/app/commands/decidim/admin/create_participatory_process.rb +12 -3
- data/decidim-admin/app/commands/decidim/admin/{update_participatory_process_attachment.rb → update_attachment.rb} +7 -6
- data/decidim-admin/app/commands/decidim/admin/update_feature.rb +2 -1
- data/decidim-admin/app/commands/decidim/admin/update_organization.rb +1 -0
- data/decidim-admin/app/commands/decidim/admin/update_participatory_process.rb +16 -4
- data/decidim-admin/app/constraints/decidim/admin/organization_dashboard_constraint.rb +1 -1
- data/decidim-admin/app/controllers/decidim/admin/application_controller.rb +2 -2
- data/decidim-admin/app/controllers/decidim/admin/concerns/has_attachments.rb +116 -0
- data/decidim-admin/app/controllers/decidim/admin/participatory_process_attachments_controller.rb +5 -67
- data/decidim-admin/app/controllers/decidim/admin/users_controller.rb +5 -5
- data/decidim-admin/app/forms/decidim/admin/{participatory_process_attachment_form.rb → attachment_form.rb} +2 -2
- data/decidim-admin/app/forms/decidim/admin/feature_form.rb +1 -0
- data/decidim-admin/app/forms/decidim/admin/organization_form.rb +1 -0
- data/decidim-admin/app/forms/decidim/admin/participatory_process_form.rb +8 -1
- data/decidim-admin/app/helpers/decidim/admin/application_helper.rb +1 -0
- data/decidim-admin/app/helpers/decidim/admin/feature_settings_helper.rb +29 -0
- data/decidim-admin/app/models/decidim/admin/abilities/admin_user.rb +4 -4
- data/decidim-admin/app/models/decidim/admin/abilities/base.rb +3 -3
- data/decidim-admin/app/models/decidim/admin/abilities/participatory_process_admin.rb +15 -7
- data/decidim-admin/app/views/decidim/admin/{participatory_process_attachments → attachments}/_form.html.erb +0 -0
- data/decidim-admin/app/views/decidim/admin/attachments/edit.html.erb +9 -0
- data/decidim-admin/app/views/decidim/admin/attachments/index.html.erb +37 -0
- data/decidim-admin/app/views/decidim/admin/attachments/new.html.erb +9 -0
- data/decidim-admin/app/views/decidim/admin/attachments/show.html.erb +25 -0
- data/decidim-admin/app/views/decidim/admin/features/_form.html.erb +1 -0
- data/decidim-admin/app/views/decidim/admin/features/_settings_fields.html.erb +6 -3
- data/decidim-admin/app/views/decidim/admin/organization/_form.html.erb +4 -0
- data/decidim-admin/app/views/decidim/admin/participatory_processes/_form.html.erb +16 -0
- data/decidim-admin/app/views/decidim/admin/participatory_processes/show.html.erb +11 -1
- data/decidim-admin/app/views/layouts/decidim/admin/_header.html.erb +2 -2
- data/decidim-admin/app/views/layouts/decidim/admin/_sidebar.html.erb +1 -1
- data/decidim-admin/app/views/layouts/decidim/admin/participatory_process.html.erb +2 -2
- data/decidim-admin/config/locales/ca.yml +29 -27
- data/decidim-admin/config/locales/en.yml +29 -27
- data/decidim-admin/config/locales/es.yml +29 -27
- data/decidim-admin/config/routes.rb +1 -1
- data/decidim-admin/db/migrate/20170128112958_change_user_groups_verified_to_timestamp.rb +9 -0
- data/decidim-admin/decidim-admin.gemspec +0 -1
- data/decidim-admin/lib/decidim/admin/engine.rb +2 -2
- data/decidim-admin/lib/decidim/admin/test/manage_attachments_examples.rb +103 -0
- data/decidim-admin/spec/commands/create_category_spec.rb +1 -1
- data/decidim-admin/spec/commands/create_feature_spec.rb +1 -1
- data/decidim-admin/spec/commands/create_participatory_process_spec.rb +32 -2
- data/decidim-admin/spec/commands/create_static_page_spec.rb +1 -1
- data/decidim-admin/spec/commands/destroy_category_spec.rb +1 -1
- data/decidim-admin/spec/commands/destroy_feature_spec.rb +2 -2
- data/decidim-admin/spec/commands/destroy_participatory_process_step_spec.rb +1 -1
- data/decidim-admin/spec/commands/update_category_spec.rb +1 -1
- data/decidim-admin/spec/commands/update_feature_spec.rb +3 -1
- data/decidim-admin/spec/commands/update_organization_spec.rb +12 -2
- data/decidim-admin/spec/commands/update_static_page_spec.rb +1 -1
- data/decidim-admin/spec/features/admin_manages_organization_admins_spec.rb +1 -1
- data/decidim-admin/spec/features/admin_manages_organization_scopes_spec.rb +1 -1
- data/decidim-admin/spec/features/admin_manages_participatory_processes_spec.rb +1 -1
- data/decidim-admin/spec/features/static_pages_spec.rb +1 -1
- data/decidim-admin/spec/forms/participatory_process_form_spec.rb +32 -2
- data/decidim-admin/spec/forms/participatory_process_step_form_spec.rb +3 -3
- data/decidim-admin/spec/forms/scope_form_spec.rb +2 -2
- data/decidim-admin/spec/forms/static_page_form_spec.rb +2 -2
- data/decidim-admin/spec/helpers/feature_settings_helper_spec.rb +56 -0
- data/decidim-admin/spec/models/abilities/admin_user_spec.rb +7 -6
- data/decidim-admin/spec/models/abilities/participatory_process_admin_spec.rb +5 -8
- data/decidim-admin/spec/shared/manage_process_admins_examples.rb +1 -1
- data/decidim-admin/spec/shared/manage_process_attachments_examples.rb +4 -94
- data/decidim-admin/spec/shared/manage_process_categories_examples.rb +2 -1
- data/decidim-admin/spec/shared/manage_process_steps_examples.rb +1 -1
- data/decidim-admin/spec/shared/manage_processes_examples.rb +4 -3
- data/decidim-admin/spec/views/decidim/static_pages/_form.html.erb_spec.rb +2 -2
- data/decidim-api/app/views/layouts/decidim/api/documentation.html.erb +1 -1
- data/decidim-api/decidim-api.gemspec +1 -1
- data/decidim-api/lib/decidim/api.rb +1 -0
- data/decidim-api/lib/decidim/api/schema.rb +5 -0
- data/decidim-api/lib/decidim/api/test/type_context.rb +1 -0
- data/decidim-api/lib/decidim/api/types/author_interface.rb +13 -0
- data/decidim-api/spec/types/query_type_spec.rb +1 -1
- data/decidim-api/spec/types/translated_field_type_spec.rb +1 -1
- data/decidim-budgets/.gitignore +7 -0
- data/decidim-budgets/README.md +23 -0
- data/decidim-budgets/Rakefile +2 -0
- data/decidim-budgets/app/assets/config/decidim_budgets_manifest.js +1 -0
- data/decidim-budgets/app/assets/images/decidim/budgets/icon.svg +4 -0
- data/decidim-budgets/app/assets/javascripts/decidim/budgets/projects.js.es6 +28 -0
- data/decidim-budgets/app/assets/stylesheets/decidim/budgets/_budgets.scss +1 -0
- data/decidim-budgets/app/assets/stylesheets/decidim/budgets/budget/_budget-list.scss +32 -0
- data/decidim-budgets/app/assets/stylesheets/decidim/budgets/budget/_budget-meter.scss +78 -0
- data/decidim-budgets/app/assets/stylesheets/decidim/budgets/budget/_progress.scss +17 -0
- data/decidim-budgets/app/commands/decidim/budgets/add_line_item.rb +43 -0
- data/decidim-budgets/app/commands/decidim/budgets/admin/create_project.rb +52 -0
- data/decidim-budgets/app/commands/decidim/budgets/admin/update_project.rb +56 -0
- data/decidim-budgets/app/commands/decidim/budgets/cancel_order.rb +36 -0
- data/decidim-budgets/app/commands/decidim/budgets/checkout.rb +34 -0
- data/decidim-budgets/app/commands/decidim/budgets/remove_line_item.rb +35 -0
- data/decidim-budgets/app/controllers/concerns/decidim/budgets/needs_current_order.rb +27 -0
- data/decidim-budgets/app/controllers/decidim/budgets/admin/application_controller.rb +14 -0
- data/decidim-budgets/app/controllers/decidim/budgets/admin/projects_controller.rb +69 -0
- data/decidim-budgets/app/controllers/decidim/budgets/application_controller.rb +13 -0
- data/decidim-budgets/app/controllers/decidim/budgets/line_items_controller.rb +43 -0
- data/decidim-budgets/app/controllers/decidim/budgets/orders_controller.rb +38 -0
- data/decidim-budgets/app/controllers/decidim/budgets/projects_controller.rb +44 -0
- data/decidim-budgets/app/forms/decidim/budgets/admin/project_form.rb +44 -0
- data/decidim-budgets/app/helpers/decidim/budgets/application_helper.rb +12 -0
- data/decidim-budgets/app/helpers/decidim/budgets/projects_helper.rb +29 -0
- data/decidim-budgets/app/models/decidim/budgets/application_record.rb +9 -0
- data/decidim-budgets/app/models/decidim/budgets/line_item.rb +20 -0
- data/decidim-budgets/app/models/decidim/budgets/order.rb +52 -0
- data/decidim-budgets/app/models/decidim/budgets/project.rb +15 -0
- data/decidim-budgets/app/services/decidim/budgets/project_search.rb +58 -0
- data/decidim-budgets/app/views/decidim/budgets/admin/projects/_form.html.erb +31 -0
- data/decidim-budgets/app/views/decidim/budgets/admin/projects/edit.html.erb +9 -0
- data/decidim-budgets/app/views/decidim/budgets/admin/projects/index.html.erb +27 -0
- data/{decidim-admin/app/views/decidim/admin/participatory_process_attachments → decidim-budgets/app/views/decidim/budgets/admin/projects}/new.html.erb +0 -0
- data/decidim-budgets/app/views/decidim/budgets/line_items/update_budget.js.erb +21 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_budget_confirm.html.erb +30 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_budget_excess.html.erb +14 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_budget_summary.html.erb +46 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_count.html.erb +1 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_filters.html.erb +24 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_linked_projects.html.erb +12 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_order_progress.html.erb +34 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_order_selected_projects.html.erb +25 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_order_total_budget.html.erb +1 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_project.html.erb +40 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_project_budget_button.html.erb +9 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_projects.html.erb +8 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/_tags.html.erb +10 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/index.html.erb +26 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/index.js.erb +2 -0
- data/decidim-budgets/app/views/decidim/budgets/projects/show.html.erb +48 -0
- data/decidim-budgets/bin/rails +14 -0
- data/decidim-budgets/config/i18n-tasks.yml +4 -0
- data/decidim-budgets/config/locales/ca.yml +84 -0
- data/decidim-budgets/config/locales/en.yml +95 -0
- data/decidim-budgets/config/locales/es.yml +84 -0
- data/decidim-budgets/db/migrate/20170127114122_create_projects.rb +15 -0
- data/decidim-budgets/db/migrate/20170130095615_create_orders.rb +13 -0
- data/decidim-budgets/db/migrate/20170130101825_create_line_items.rb +10 -0
- data/decidim-budgets/decidim-budgets.gemspec +24 -0
- data/decidim-budgets/lib/decidim/budgets.rb +11 -0
- data/decidim-budgets/lib/decidim/budgets/admin.rb +9 -0
- data/decidim-budgets/lib/decidim/budgets/admin_engine.rb +22 -0
- data/decidim-budgets/lib/decidim/budgets/feature.rb +59 -0
- data/decidim-budgets/lib/decidim/budgets/list_engine.rb +30 -0
- data/decidim-budgets/lib/decidim/budgets/test/factories.rb +43 -0
- data/decidim-budgets/spec/commands/add_line_item_spec.rb +48 -0
- data/decidim-budgets/spec/commands/cancel_order_spec.rb +42 -0
- data/decidim-budgets/spec/commands/checkout_spec.rb +45 -0
- data/decidim-budgets/spec/commands/create_project_spec.rb +72 -0
- data/decidim-budgets/spec/commands/remove_line_item_spec.rb +31 -0
- data/decidim-budgets/spec/commands/update_project_spec.rb +65 -0
- data/decidim-budgets/spec/factories.rb +4 -0
- data/decidim-budgets/spec/features/admin_manages_projects_spec.rb +16 -0
- data/decidim-budgets/spec/features/orders_spec.rb +149 -0
- data/decidim-budgets/spec/features/process_admin_manages_projects_spec.rb +17 -0
- data/decidim-budgets/spec/forms/project_form_spec.rb +115 -0
- data/decidim-budgets/spec/models/line_item_spec.rb +35 -0
- data/decidim-budgets/spec/models/order_spec.rb +45 -0
- data/decidim-budgets/spec/models/project_spec.rb +30 -0
- data/decidim-budgets/spec/services/project_search_spec.rb +97 -0
- data/decidim-budgets/spec/shared/admin_shared_context.rb +11 -0
- data/decidim-budgets/spec/shared/manage_projects_examples.rb +104 -0
- data/decidim-budgets/spec/spec_helper.rb +2 -0
- data/decidim-comments/app/assets/javascripts/decidim/comments/bundle.js +0 -0
- data/decidim-comments/app/commands/decidim/comments/create_comment.rb +2 -1
- data/decidim-comments/app/forms/decidim/comments/comment_form.rb +1 -0
- data/decidim-comments/app/frontend/application/apollo_client.js +1 -1
- data/decidim-comments/app/frontend/application/application.component.jsx +1 -1
- data/decidim-comments/app/frontend/comments/add_comment_form.component.jsx +76 -20
- data/decidim-comments/app/frontend/comments/add_comment_form.component.test.jsx +77 -22
- data/decidim-comments/app/frontend/comments/add_comment_form.fragment.graphql +6 -0
- data/decidim-comments/app/frontend/comments/add_comment_form.mutation.graphql +2 -2
- data/decidim-comments/app/frontend/comments/comment.component.jsx +15 -15
- data/decidim-comments/app/frontend/comments/comment.component.test.jsx +42 -41
- data/decidim-comments/app/frontend/comments/comment_order_selector.component.jsx +1 -1
- data/decidim-comments/app/frontend/comments/comment_thread.component.jsx +7 -7
- data/decidim-comments/app/frontend/comments/comment_thread.component.test.jsx +21 -19
- data/decidim-comments/app/frontend/comments/comments.component.jsx +21 -17
- data/decidim-comments/app/frontend/comments/comments.component.test.jsx +47 -32
- data/decidim-comments/app/frontend/comments/comments.query.graphql +6 -3
- data/decidim-comments/app/frontend/comments/down_vote_button.component.jsx +21 -10
- data/decidim-comments/app/frontend/comments/up_vote_button.component.jsx +23 -12
- data/decidim-comments/app/frontend/comments/vote_button.component.jsx +15 -7
- data/decidim-comments/app/frontend/comments/vote_button_component.test.jsx +7 -2
- data/decidim-comments/app/frontend/entry.js +1 -8
- data/decidim-comments/app/frontend/support/generate_user_data.js +13 -0
- data/decidim-comments/app/frontend/support/generate_user_group_data.js +14 -0
- data/decidim-comments/app/helpers/decidim/comments/comments_helper.rb +10 -15
- data/decidim-comments/app/models/decidim/comments/comment.rb +5 -7
- data/decidim-comments/app/types/decidim/comments/comment_type.rb +5 -1
- data/decidim-comments/config/locales/ca.yml +5 -1
- data/decidim-comments/config/locales/en.yml +4 -1
- data/decidim-comments/config/locales/es.yml +5 -1
- data/decidim-comments/db/migrate/20170123102043_add_user_group_id_to_comments.rb +5 -0
- data/decidim-comments/decidim-comments.gemspec +0 -1
- data/decidim-comments/lib/decidim/comments/engine.rb +0 -1
- data/decidim-comments/lib/decidim/comments/mutation_extensions.rb +2 -1
- data/decidim-comments/spec/commands/create_comment_spec.rb +6 -3
- data/decidim-comments/spec/commands/vote_comment_spec.rb +4 -4
- data/decidim-comments/spec/features/comments_spec.rb +27 -3
- data/decidim-comments/spec/forms/comment_form_spec.rb +6 -3
- data/decidim-comments/spec/models/comment_spec.rb +25 -32
- data/decidim-comments/spec/queries/comments_with_replies_spec.rb +2 -2
- data/decidim-comments/spec/types/comment_type_spec.rb +2 -2
- data/decidim-comments/spec/types/query_type_spec.rb +5 -5
- data/decidim-dev/app/views/decidim/dummy_resource/_linked_dummys.html.erb +5 -0
- data/decidim-dev/config/locales/en.yml +5 -0
- data/decidim-dev/decidim-dev.gemspec +3 -3
- data/decidim-dev/lib/decidim/dev/assets/avatar.jpg +0 -0
- data/decidim-dev/lib/decidim/dev/assets/icon.png +0 -0
- data/decidim-dev/lib/decidim/dev/test/base_spec_helper.rb +1 -0
- data/decidim-dev/lib/decidim/dev/test/rspec_support/action_mailer.rb +1 -1
- data/decidim-dev/lib/decidim/dev/test/rspec_support/engine_routes.rb +9 -5
- data/decidim-dev/lib/decidim/dev/test/rspec_support/feature.rb +24 -0
- data/decidim-meetings/app/assets/config/decidim_meetings_manifest.js +2 -0
- data/decidim-meetings/app/assets/javascripts/decidim/meetings/map.js.es6.erb +92 -0
- data/decidim-meetings/app/assets/stylesheets/decidim/meetings/map.css +1 -0
- data/decidim-meetings/app/commands/decidim/meetings/admin/close_meeting.rb +53 -0
- data/decidim-meetings/app/commands/decidim/meetings/admin/create_meeting.rb +15 -3
- data/decidim-meetings/app/commands/decidim/meetings/admin/update_meeting.rb +15 -3
- data/decidim-meetings/app/controllers/decidim/meetings/admin/application_controller.rb +9 -0
- data/decidim-meetings/app/controllers/decidim/meetings/admin/attachments_controller.rb +29 -0
- data/decidim-meetings/app/controllers/decidim/meetings/admin/meeting_closes_controller.rb +38 -0
- data/decidim-meetings/app/controllers/decidim/meetings/admin/meetings_controller.rb +0 -12
- data/decidim-meetings/app/controllers/decidim/meetings/meetings_controller.rb +11 -9
- data/decidim-meetings/app/forms/decidim/meetings/admin/close_meeting_form.rb +31 -0
- data/decidim-meetings/app/forms/decidim/meetings/admin/meeting_form.rb +0 -2
- data/decidim-meetings/app/helpers/decidim/meetings/admin/application_helper.rb +12 -0
- data/decidim-meetings/app/helpers/decidim/meetings/application_helper.rb +1 -0
- data/decidim-meetings/app/helpers/decidim/meetings/map_helper.rb +46 -0
- data/decidim-meetings/app/models/decidim/meetings/meeting.rb +11 -15
- data/decidim-meetings/app/services/decidim/meetings/meeting_search.rb +0 -1
- data/decidim-meetings/app/services/decidim/meetings/static_map_generator.rb +50 -0
- data/decidim-meetings/app/views/decidim/meetings/admin/meeting_closes/_form.html.erb +23 -0
- data/decidim-meetings/app/views/decidim/meetings/admin/meeting_closes/edit.html.erb +9 -0
- data/decidim-meetings/app/views/decidim/meetings/admin/meetings/_form.html.erb +2 -6
- data/decidim-meetings/app/views/decidim/meetings/admin/meetings/index.html.erb +14 -0
- data/decidim-meetings/app/views/decidim/meetings/meetings/_datetime.html.erb +8 -0
- data/decidim-meetings/app/views/decidim/meetings/meetings/_filters.html.erb +2 -2
- data/decidim-meetings/app/views/decidim/meetings/meetings/_filters_small_view.html.erb +18 -0
- data/decidim-meetings/app/views/decidim/meetings/meetings/_linked_meetings.html.erb +22 -0
- data/decidim-meetings/app/views/decidim/meetings/meetings/_meetings.html.erb +3 -10
- data/decidim-meetings/app/views/decidim/meetings/meetings/index.html.erb +42 -0
- data/decidim-meetings/app/views/decidim/meetings/meetings/index.js.erb +6 -0
- data/decidim-meetings/app/views/decidim/meetings/meetings/show.html.erb +33 -7
- data/decidim-meetings/bin/rails +1 -1
- data/decidim-meetings/config/i18n-tasks.yml +2 -0
- data/decidim-meetings/config/locales/ca.yml +37 -4
- data/decidim-meetings/config/locales/en.yml +34 -1
- data/decidim-meetings/config/locales/es.yml +36 -3
- data/decidim-meetings/db/migrate/20170110142105_close_a_meeting.rb +9 -0
- data/decidim-meetings/db/migrate/20170123151650_add_latitude_and_longitude_to_meetings.rb +6 -0
- data/decidim-meetings/db/migrate/20170129153716_remove_short_description_from_meetings.rb +5 -0
- data/decidim-meetings/decidim-meetings.gemspec +7 -0
- data/decidim-meetings/lib/decidim/meetings/admin_engine.rb +31 -1
- data/decidim-meetings/lib/decidim/meetings/feature.rb +20 -6
- data/decidim-meetings/lib/decidim/meetings/list_engine.rb +10 -1
- data/decidim-meetings/lib/decidim/meetings/seeds/Exampledocument.pdf +0 -0
- data/decidim-meetings/lib/decidim/meetings/seeds/city.jpeg +0 -0
- data/decidim-meetings/lib/decidim/meetings/test/factories.rb +23 -0
- data/decidim-meetings/spec/commands/close_meeting_spec.rb +78 -0
- data/decidim-meetings/spec/commands/create_meeting_spec.rb +22 -3
- data/decidim-meetings/spec/commands/update_meeting_spec.rb +32 -3
- data/decidim-meetings/spec/controllers/meetings_controller_spec.rb +41 -0
- data/decidim-meetings/spec/factories.rb +3 -13
- data/decidim-meetings/spec/features/admin_manages_meetings_attachments_spec.rb +10 -0
- data/decidim-meetings/spec/features/explore_meetings_spec.rb +55 -1
- data/decidim-meetings/spec/features/process_admin_manages_meetings_attachments_spec.rb +12 -0
- data/decidim-meetings/spec/forms/close_meeting_form_spec.rb +90 -0
- data/decidim-meetings/spec/forms/meeting_form_spec.rb +1 -7
- data/decidim-meetings/spec/models/meeting_spec.rb +42 -24
- data/decidim-meetings/spec/services/meeting_search_spec.rb +1 -17
- data/decidim-meetings/spec/services/static_map_generator_spec.rb +33 -0
- data/decidim-meetings/spec/shared/manage_attachments_examples.rb +17 -0
- data/decidim-meetings/spec/shared/manage_meetings_examples.rb +58 -8
- data/decidim-meetings/spec/spec_helper.rb +5 -0
- data/decidim-meetings/spec/support/geocoder.rb +7 -0
- data/decidim-meetings/vendor/assets/javascripts/leaflet-svg-icon.js +179 -0
- data/decidim-meetings/vendor/assets/javascripts/leaflet-tilelayer-here.js +166 -0
- data/decidim-meetings/vendor/assets/javascripts/leaflet.js +9 -0
- data/decidim-meetings/vendor/assets/stylesheets/leaflet.css +624 -0
- data/decidim-pages/app/models/decidim/pages/page.rb +10 -1
- data/decidim-pages/app/views/decidim/pages/application/show.html.erb +2 -1
- data/decidim-pages/spec/commands/create_page_spec.rb +2 -2
- data/decidim-pages/spec/commands/destroy_page_spec.rb +1 -1
- data/decidim-pages/spec/commands/update_page_spec.rb +1 -1
- data/decidim-pages/spec/factories.rb +1 -1
- data/decidim-pages/spec/features/admin_spec.rb +1 -0
- data/decidim-pages/spec/models/page_spec.rb +15 -0
- data/decidim-proposals/app/assets/stylesheets/decidim/proposals/social_share.css.scss +5 -0
- data/decidim-proposals/app/commands/decidim/proposals/admin/answer_proposal.rb +43 -0
- data/decidim-proposals/app/commands/decidim/proposals/create_proposal.rb +1 -0
- data/decidim-proposals/app/controllers/decidim/proposals/admin/proposal_answers_controller.rb +37 -0
- data/decidim-proposals/app/controllers/decidim/proposals/admin/proposals_controller.rb +1 -0
- data/decidim-proposals/app/controllers/decidim/proposals/proposal_votes_controller.rb +18 -7
- data/decidim-proposals/app/controllers/decidim/proposals/proposals_controller.rb +8 -7
- data/decidim-proposals/app/forms/decidim/proposals/admin/proposal_answer_form.rb +18 -0
- data/decidim-proposals/app/forms/decidim/proposals/proposal_form.rb +1 -0
- data/decidim-proposals/app/helpers/decidim/proposals/application_helper.rb +17 -0
- data/decidim-proposals/app/helpers/decidim/proposals/proposal_votes_helper.rb +19 -0
- data/decidim-proposals/app/models/decidim/proposals/abilities/current_user.rb +59 -0
- data/decidim-proposals/app/models/decidim/proposals/proposal.rb +30 -33
- data/decidim-proposals/app/models/decidim/proposals/proposal_vote.rb +2 -0
- data/decidim-proposals/app/services/decidim/proposals/proposal_search.rb +11 -0
- data/decidim-proposals/app/views/decidim/proposals/admin/proposal_answers/edit.html.erb +15 -0
- data/decidim-proposals/app/views/decidim/proposals/admin/proposals/index.html.erb +8 -0
- data/decidim-proposals/app/views/decidim/proposals/proposal_votes/update_buttons_and_counters.js.erb +20 -0
- data/decidim-proposals/app/views/decidim/proposals/proposals/_filters.html.erb +3 -1
- data/decidim-proposals/app/views/decidim/proposals/proposals/_filters_small_view.html.erb +18 -0
- data/decidim-proposals/app/views/decidim/proposals/proposals/_linked_proposals.html.erb +27 -0
- data/decidim-proposals/app/views/decidim/proposals/proposals/_proposal.html.erb +3 -2
- data/decidim-proposals/app/views/decidim/proposals/proposals/_proposal_badge.html.erb +3 -0
- data/decidim-proposals/app/views/decidim/proposals/proposals/_remaining_votes_count.html.erb +1 -0
- data/decidim-proposals/app/views/decidim/proposals/proposals/_share.html.erb +1 -1
- data/decidim-proposals/app/views/decidim/proposals/proposals/_vote_button.html.erb +16 -4
- data/decidim-proposals/app/views/decidim/proposals/proposals/_votes_limit.html.erb +23 -0
- data/decidim-proposals/app/views/decidim/proposals/proposals/index.html.erb +13 -3
- data/decidim-proposals/app/views/decidim/proposals/proposals/new.html.erb +6 -0
- data/decidim-proposals/app/views/decidim/proposals/proposals/show.html.erb +15 -2
- data/decidim-proposals/config/i18n-tasks.yml +3 -0
- data/decidim-proposals/config/locales/ca.yml +54 -1
- data/decidim-proposals/config/locales/en.yml +54 -0
- data/decidim-proposals/config/locales/es.yml +54 -1
- data/decidim-proposals/db/migrate/20170120151202_add_user_group_id_to_proposals.rb +5 -0
- data/decidim-proposals/db/migrate/20170131092413_add_answers_to_proposals.rb +7 -0
- data/decidim-proposals/decidim-proposals.gemspec +3 -0
- data/decidim-proposals/lib/decidim/proposals/admin_engine.rb +3 -1
- data/decidim-proposals/lib/decidim/proposals/engine.rb +7 -1
- data/decidim-proposals/lib/decidim/proposals/feature.rb +28 -1
- data/decidim-proposals/lib/decidim/proposals/test/factories.rb +83 -0
- data/decidim-proposals/spec/commands/decidim/proposals/admin_create_proposal_spec.rb +14 -0
- data/decidim-proposals/spec/commands/decidim/proposals/answer_proposal_spec.rb +53 -0
- data/decidim-proposals/spec/commands/decidim/proposals/create_proposal_spec.rb +3 -56
- data/decidim-proposals/spec/controllers/decidim/admin/proposal_answers_controller_spec.rb +45 -0
- data/decidim-proposals/spec/controllers/decidim/proposal_votes_controller_spec.rb +113 -0
- data/decidim-proposals/spec/controllers/decidim/proposals_controller_spec.rb +53 -0
- data/decidim-proposals/spec/factories.rb +1 -23
- data/decidim-proposals/spec/features/proposals_spec.rb +201 -38
- data/decidim-proposals/spec/features/vote_proposal_spec.rb +83 -11
- data/decidim-proposals/spec/forms/decidim/proposals/admin_proposal_form_spec.rb +13 -0
- data/decidim-proposals/spec/forms/decidim/proposals/proposal_answer_form_spec.rb +50 -0
- data/decidim-proposals/spec/forms/decidim/proposals/proposal_form_spec.rb +5 -93
- data/decidim-proposals/spec/helpers/application_helper_spec.rb +33 -0
- data/decidim-proposals/spec/helpers/proposal_votes_helper_spec.rb +53 -0
- data/decidim-proposals/spec/lib/decidim/proposals/feature_spec.rb +1 -1
- data/decidim-proposals/spec/models/decidim/proposals/proposal_spec.rb +21 -19
- data/decidim-proposals/spec/models/decidim/proposals/proposal_vote_spec.rb +19 -1
- data/decidim-proposals/spec/services/decidim/proposals/proposal_search_spec.rb +66 -25
- data/decidim-proposals/spec/shared/create_proposal_examples.rb +69 -0
- data/decidim-proposals/spec/shared/manage_proposals_examples.rb +49 -0
- data/decidim-proposals/spec/shared/proposal_form_examples.rb +100 -0
- data/decidim-results/.gitignore +7 -0
- data/decidim-results/README.md +23 -0
- data/decidim-results/Rakefile +2 -0
- data/decidim-results/app/assets/images/decidim/results/icon.svg +1 -0
- data/decidim-results/app/commands/decidim/results/admin/create_result.rb +65 -0
- data/decidim-results/app/commands/decidim/results/admin/update_result.rb +69 -0
- data/decidim-results/app/controllers/decidim/results/admin/application_controller.rb +14 -0
- data/decidim-results/app/controllers/decidim/results/admin/results_controller.rb +69 -0
- data/decidim-results/app/controllers/decidim/results/application_controller.rb +13 -0
- data/decidim-results/app/controllers/decidim/results/results_controller.rb +42 -0
- data/decidim-results/app/forms/decidim/results/admin/result_form.rb +40 -0
- data/decidim-results/app/helpers/decidim/results/application_helper.rb +11 -0
- data/decidim-results/app/models/decidim/results/application_record.rb +9 -0
- data/decidim-results/app/models/decidim/results/result.rb +15 -0
- data/decidim-results/app/services/decidim/results/result_search.rb +44 -0
- data/decidim-results/app/services/decidim/results/result_stats_calculator.rb +51 -0
- data/decidim-results/app/views/decidim/results/admin/results/_form.html.erb +23 -0
- data/decidim-results/app/views/decidim/results/admin/results/edit.html.erb +9 -0
- data/decidim-results/app/views/decidim/results/admin/results/index.html.erb +27 -0
- data/decidim-results/app/views/decidim/results/admin/results/new.html.erb +9 -0
- data/decidim-results/app/views/decidim/results/results/_count.html.erb +1 -0
- data/decidim-results/app/views/decidim/results/results/_filters.html.erb +22 -0
- data/decidim-results/app/views/decidim/results/results/_linked_results.html.erb +12 -0
- data/decidim-results/app/views/decidim/results/results/_results.html.erb +16 -0
- data/decidim-results/app/views/decidim/results/results/_tags.html.erb +10 -0
- data/decidim-results/app/views/decidim/results/results/index.html.erb +22 -0
- data/decidim-results/app/views/decidim/results/results/index.js.erb +2 -0
- data/decidim-results/app/views/decidim/results/results/show.html.erb +52 -0
- data/decidim-results/bin/rails +14 -0
- data/decidim-results/config/i18n-tasks.yml +5 -0
- data/decidim-results/config/locales/ca.yml +61 -0
- data/decidim-results/config/locales/en.yml +62 -0
- data/decidim-results/config/locales/es.yml +61 -0
- data/decidim-results/db/migrate/20170116104125_create_results.rb +14 -0
- data/decidim-results/db/migrate/20170129164553_remove_short_description_from_results.rb +5 -0
- data/decidim-results/decidim-results.gemspec +26 -0
- data/decidim-results/lib/decidim/results.rb +11 -0
- data/decidim-results/lib/decidim/results/admin.rb +9 -0
- data/decidim-results/lib/decidim/results/admin_engine.rb +22 -0
- data/decidim-results/lib/decidim/results/feature.rb +52 -0
- data/decidim-results/lib/decidim/results/list_engine.rb +19 -0
- data/decidim-results/lib/decidim/results/test/factories.rb +11 -0
- data/decidim-results/spec/commands/create_result_spec.rb +90 -0
- data/decidim-results/spec/commands/update_result_spec.rb +83 -0
- data/decidim-results/spec/factories.rb +6 -0
- data/decidim-results/spec/features/admin_manages_results_spec.rb +16 -0
- data/decidim-results/spec/features/explore_results_spec.rb +186 -0
- data/decidim-results/spec/features/process_admin_manages_results_spec.rb +17 -0
- data/decidim-results/spec/forms/result_form_spec.rb +91 -0
- data/decidim-results/spec/models/result_spec.rb +18 -0
- data/decidim-results/spec/services/result_search_spec.rb +97 -0
- data/decidim-results/spec/services/result_stats_calculator_spec.rb +93 -0
- data/decidim-results/spec/shared/admin_shared_context.rb +11 -0
- data/decidim-results/spec/shared/manage_results_examples.rb +96 -0
- data/decidim-results/spec/spec_helper.rb +2 -0
- data/decidim-system/app/assets/javascripts/decidim/system/application.js.es6 +1 -3
- data/decidim-system/app/views/layouts/decidim/system/_header.html.erb +2 -2
- data/decidim-system/decidim-system.gemspec +0 -1
- data/decidim-system/lib/decidim/system/engine.rb +0 -1
- data/decidim-system/spec/features/manage_admins_spec.rb +1 -1
- data/decidim-system/spec/features/organizations_spec.rb +1 -1
- data/decidim.gemspec +2 -0
- data/docs/how_to_create_a_plugin.md +0 -2
- data/lib/decidim.rb +2 -0
- data/lib/generators/decidim/install_generator.rb +1 -0
- data/lib/generators/decidim/templates/Gemfile.erb +10 -1
- data/lib/generators/decidim/templates/initializer.rb +9 -0
- data/lib/generators/decidim/templates/secrets.yml.erb +3 -0
- data/lib/generators/decidim/templates/social_share_button.rb +1 -1
- data/package.json +2 -3
- data/yarn.lock +10 -8
- metadata +265 -32
- data/decidim-admin/app/helpers/decidim/admin/aria_selected_link_to_helper.rb +0 -28
- data/decidim-admin/app/views/decidim/admin/participatory_process_attachments/edit.html.erb +0 -9
- data/decidim-admin/app/views/decidim/admin/participatory_process_attachments/index.html.erb +0 -37
- data/decidim-admin/app/views/decidim/admin/participatory_process_attachments/show.html.erb +0 -25
- data/decidim-comments/app/frontend/support/generate_current_user_data.js +0 -13
- data/decidim-comments/app/types/decidim/comments/author_type.rb +0 -15
- data/decidim-comments/spec/types/author_type_spec.rb +0 -21
- data/decidim-dev/lib/decidim/dev/assets/avatar.svg +0 -14
- data/decidim-proposals/app/views/decidim/proposals/proposal_votes/create.js.erb +0 -5
@@ -0,0 +1,30 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "spec_helper"
|
4
|
+
|
5
|
+
describe Decidim::Budgets::Project do
|
6
|
+
let(:project) { build :project }
|
7
|
+
subject { project }
|
8
|
+
|
9
|
+
it { is_expected.to be_valid }
|
10
|
+
|
11
|
+
context "without a feature" do
|
12
|
+
let(:project) { build :project, feature: nil }
|
13
|
+
|
14
|
+
it { is_expected.not_to be_valid }
|
15
|
+
end
|
16
|
+
|
17
|
+
context "when the scope is from another organization" do
|
18
|
+
let(:scope) { create :scope }
|
19
|
+
let(:project) { build :project, scope: scope }
|
20
|
+
|
21
|
+
it { is_expected.not_to be_valid }
|
22
|
+
end
|
23
|
+
|
24
|
+
context "when the category is from another organization" do
|
25
|
+
let(:category) { create :category }
|
26
|
+
let(:project) { build :project, category: category }
|
27
|
+
|
28
|
+
it { is_expected.not_to be_valid }
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,97 @@
|
|
1
|
+
require "spec_helper"
|
2
|
+
|
3
|
+
describe Decidim::Budgets::ProjectSearch do
|
4
|
+
let(:current_feature) { create :budget_feature }
|
5
|
+
let(:scope1) { create :scope, organization: current_feature.organization }
|
6
|
+
let(:scope2) { create :scope, organization: current_feature.organization }
|
7
|
+
let(:parent_category) { create :category, participatory_process: current_feature.participatory_process }
|
8
|
+
let(:subcategory) { create :subcategory, parent: parent_category }
|
9
|
+
let!(:project1) do
|
10
|
+
create(
|
11
|
+
:project,
|
12
|
+
feature: current_feature,
|
13
|
+
category: parent_category,
|
14
|
+
scope: scope1
|
15
|
+
)
|
16
|
+
end
|
17
|
+
let!(:project2) do
|
18
|
+
create(
|
19
|
+
:project,
|
20
|
+
feature: current_feature,
|
21
|
+
category: subcategory,
|
22
|
+
scope: scope2
|
23
|
+
)
|
24
|
+
end
|
25
|
+
let(:external_project) { create :project }
|
26
|
+
let(:feature_id) { current_feature.id }
|
27
|
+
let(:organization_id) { current_feature.organization.id }
|
28
|
+
let(:default_params) { { feature: current_feature } }
|
29
|
+
let(:params) { default_params }
|
30
|
+
|
31
|
+
subject { described_class.new(params) }
|
32
|
+
|
33
|
+
describe "base query" do
|
34
|
+
context "when no feature is passed" do
|
35
|
+
let(:default_params) { { feature: nil } }
|
36
|
+
|
37
|
+
it "raises an error" do
|
38
|
+
expect{ subject.results }.to raise_error(StandardError, "Missing feature")
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
describe "filters" do
|
44
|
+
context "feature_id" do
|
45
|
+
it "only returns projects from the given feature" do
|
46
|
+
external_project = create(:project)
|
47
|
+
|
48
|
+
expect(subject.results).not_to include(external_project)
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
context "scope_id" do
|
53
|
+
context "when a single id is being sent" do
|
54
|
+
let(:params) { default_params.merge(scope_id: scope1.id) }
|
55
|
+
|
56
|
+
it "filters projects by scope" do
|
57
|
+
expect(subject.results).to eq [project1]
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
context "when multiple ids are sent" do
|
62
|
+
let(:params) { default_params.merge(scope_id: [scope2.id, scope1.id]) }
|
63
|
+
|
64
|
+
it "filters projects by scope" do
|
65
|
+
expect(subject.results).to match_array [project1,project2]
|
66
|
+
end
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
70
|
+
context "category_id" do
|
71
|
+
context "when the given category has no subcategories" do
|
72
|
+
let(:params) { default_params.merge(category_id: subcategory.id) }
|
73
|
+
|
74
|
+
it "returns only projects from the given category" do
|
75
|
+
expect(subject.results).to eq [project2]
|
76
|
+
end
|
77
|
+
end
|
78
|
+
|
79
|
+
context "when the given category has some subcategories" do
|
80
|
+
let(:params) { default_params.merge(category_id: parent_category.id) }
|
81
|
+
|
82
|
+
it "returns projects from this category and its children's" do
|
83
|
+
expect(subject.results).to match_array [project2, project1]
|
84
|
+
end
|
85
|
+
end
|
86
|
+
|
87
|
+
context "when the category does not belong to the current feature" do
|
88
|
+
let(:external_category) { create :category }
|
89
|
+
let(:params) { default_params.merge(category_id: external_category.id) }
|
90
|
+
|
91
|
+
it "returns an empty array" do
|
92
|
+
expect(subject.results).to eq []
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
RSpec.shared_context "admin" do
|
2
|
+
let(:organization) { create(:organization) }
|
3
|
+
let!(:user) { create(:user, :admin, :confirmed, organization: organization, email: "admin@decidim.org") }
|
4
|
+
let(:participatory_process) { create(:participatory_process, organization: organization) }
|
5
|
+
let(:process_admin) { create :user, :confirmed, organization: organization }
|
6
|
+
let!(:user_role) { create :participatory_process_user_role, user: process_admin, participatory_process: participatory_process }
|
7
|
+
let(:current_feature) { create :feature, participatory_process: participatory_process, manifest_name: "budgets" }
|
8
|
+
let(:scope) { create :scope, organization: organization }
|
9
|
+
let!(:category) { create :category, participatory_process: participatory_process }
|
10
|
+
let!(:project) { create :project, scope: scope, feature: current_feature }
|
11
|
+
end
|
@@ -0,0 +1,104 @@
|
|
1
|
+
# -*- coding: utf-8 -*-
|
2
|
+
# frozen_string_literal: true
|
3
|
+
RSpec.shared_examples "manage projects" do
|
4
|
+
it "updates a project" do
|
5
|
+
within find("tr", text: translated(project.title)) do
|
6
|
+
click_link "Edit"
|
7
|
+
end
|
8
|
+
|
9
|
+
within ".edit_project" do
|
10
|
+
fill_in_i18n(
|
11
|
+
:project_title,
|
12
|
+
"#title-tabs",
|
13
|
+
en: "My new title",
|
14
|
+
es: "Mi nuevo título",
|
15
|
+
ca: "El meu nou títol"
|
16
|
+
)
|
17
|
+
|
18
|
+
find("*[type=submit]").click
|
19
|
+
end
|
20
|
+
|
21
|
+
within ".flash" do
|
22
|
+
expect(page).to have_content("successfully")
|
23
|
+
end
|
24
|
+
|
25
|
+
within "table" do
|
26
|
+
expect(page).to have_content("My new title")
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
context "previewing projects" do
|
31
|
+
it "allows the user to preview the project" do
|
32
|
+
new_window = window_opened_by { click_link translated(project.title) }
|
33
|
+
|
34
|
+
within_window new_window do
|
35
|
+
expect(current_path).to eq decidim_budgets.project_path(id: project.id, participatory_process_id: participatory_process.id, feature_id: current_feature.id)
|
36
|
+
expect(page).to have_content(translated(project.title))
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
it "creates a new project" do
|
42
|
+
find(".actions .new").click
|
43
|
+
|
44
|
+
within ".new_project" do
|
45
|
+
fill_in_i18n(
|
46
|
+
:project_title,
|
47
|
+
"#title-tabs",
|
48
|
+
en: "My project",
|
49
|
+
es: "Mi proyecto",
|
50
|
+
ca: "El meu projecte"
|
51
|
+
)
|
52
|
+
fill_in_i18n_editor(
|
53
|
+
:project_short_description,
|
54
|
+
"#short_description-tabs",
|
55
|
+
en: "Short description",
|
56
|
+
es: "Descripción corta",
|
57
|
+
ca: "Descripció curta"
|
58
|
+
)
|
59
|
+
fill_in_i18n_editor(
|
60
|
+
:project_description,
|
61
|
+
"#description-tabs",
|
62
|
+
en: "A longer description",
|
63
|
+
es: "Descripción más larga",
|
64
|
+
ca: "Descripció més llarga"
|
65
|
+
)
|
66
|
+
fill_in :project_budget, with: 22_000_000
|
67
|
+
|
68
|
+
select scope.name, from: :project_decidim_scope_id
|
69
|
+
select translated(category.name), from: :project_decidim_category_id
|
70
|
+
|
71
|
+
find("*[type=submit]").click
|
72
|
+
end
|
73
|
+
|
74
|
+
within ".flash" do
|
75
|
+
expect(page).to have_content("successfully")
|
76
|
+
end
|
77
|
+
|
78
|
+
within "table" do
|
79
|
+
expect(page).to have_content("My project")
|
80
|
+
end
|
81
|
+
end
|
82
|
+
|
83
|
+
context "deleting a project" do
|
84
|
+
let!(:project2) { create(:project, feature: current_feature) }
|
85
|
+
|
86
|
+
before do
|
87
|
+
visit current_path
|
88
|
+
end
|
89
|
+
|
90
|
+
it "deletes a project" do
|
91
|
+
within find("tr", text: translated(project2.title)) do
|
92
|
+
click_link "Delete"
|
93
|
+
end
|
94
|
+
|
95
|
+
within ".flash" do
|
96
|
+
expect(page).to have_content("successfully")
|
97
|
+
end
|
98
|
+
|
99
|
+
within "table" do
|
100
|
+
expect(page).to_not have_content(translated(project2.title))
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
104
|
+
end
|
Binary file
|
@@ -2,7 +2,7 @@ import ApolloClient, { createNetworkInterface } from 'apollo-client';
|
|
2
2
|
|
3
3
|
// Create a custom network interface for Apollo since our
|
4
4
|
// API endpoint is not the default.
|
5
|
-
const networkInterface = createNetworkInterface({
|
5
|
+
const networkInterface = createNetworkInterface({
|
6
6
|
uri: '/api',
|
7
7
|
opts: {
|
8
8
|
credentials: 'same-origin'
|
@@ -14,6 +14,7 @@ import commentFragment from './comment.fragment.graphql';
|
|
14
14
|
import commentDataFragment from './comment_data.fragment.graphql';
|
15
15
|
import upVoteFragment from './up_vote.fragment.graphql';
|
16
16
|
import downVoteFragment from './down_vote.fragment.graphql';
|
17
|
+
import addCommentFormFragment from './add_comment_form.fragment.graphql';
|
17
18
|
|
18
19
|
/**
|
19
20
|
* Renders a form to create new comments.
|
@@ -33,20 +34,23 @@ export class AddCommentForm extends Component {
|
|
33
34
|
render() {
|
34
35
|
const { submitButtonClassName, commentableType, commentableId } = this.props;
|
35
36
|
const { disabled } = this.state;
|
36
|
-
|
37
|
+
|
37
38
|
return (
|
38
39
|
<div className="add-comment">
|
39
40
|
{this._renderHeading()}
|
40
41
|
{this._renderOpinionButtons()}
|
41
42
|
<form onSubmit={(evt) => this._addComment(evt)}>
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
43
|
+
{this._renderCommentAs()}
|
44
|
+
<div className="field">
|
45
|
+
<label className="show-for-sr" htmlFor={`add-comment-${commentableType}-${commentableId}`}>{ I18n.t("components.add_comment_form.form.body.label") }</label>
|
46
|
+
{this._renderTextArea()}
|
47
|
+
<input
|
48
|
+
type="submit"
|
49
|
+
className={submitButtonClassName}
|
50
|
+
value={I18n.t("components.add_comment_form.form.submit")}
|
51
|
+
disabled={disabled}
|
52
|
+
/>
|
53
|
+
</div>
|
50
54
|
</form>
|
51
55
|
</div>
|
52
56
|
);
|
@@ -94,7 +98,7 @@ export class AddCommentForm extends Component {
|
|
94
98
|
<textarea {...textAreaProps} />
|
95
99
|
);
|
96
100
|
}
|
97
|
-
|
101
|
+
|
98
102
|
/**
|
99
103
|
* Render opinion buttons or not based on the arguable prop
|
100
104
|
* @private
|
@@ -117,7 +121,7 @@ export class AddCommentForm extends Component {
|
|
117
121
|
if (arguable) {
|
118
122
|
return (
|
119
123
|
<div className="opinion-toggle button-group">
|
120
|
-
<button
|
124
|
+
<button
|
121
125
|
className={okButtonClassName}
|
122
126
|
onClick={() => this.setState({ alignment: 1 })}
|
123
127
|
>
|
@@ -143,7 +147,40 @@ export class AddCommentForm extends Component {
|
|
143
147
|
|
144
148
|
return null;
|
145
149
|
}
|
146
|
-
|
150
|
+
|
151
|
+
/**
|
152
|
+
* Render a select with an option for each user's verified group
|
153
|
+
* @private
|
154
|
+
* @returns {Void|DOMElement} - Returns nothing or a form field.
|
155
|
+
*/
|
156
|
+
_renderCommentAs() {
|
157
|
+
const { session, commentableType, commentableId } = this.props;
|
158
|
+
const { user, verifiedUserGroups } = session;
|
159
|
+
|
160
|
+
if (verifiedUserGroups.length > 0) {
|
161
|
+
return (
|
162
|
+
<div className="field">
|
163
|
+
<label htmlFor={`add-comment-${commentableType}-${commentableId}-user-group-id`}>
|
164
|
+
{ I18n.t('components.add_comment_form.form.user_group_id.label') }
|
165
|
+
</label>
|
166
|
+
<select
|
167
|
+
ref={(select) => {this.userGroupIdSelect = select}}
|
168
|
+
id={`add-comment-${commentableType}-${commentableId}-user-group-id`}
|
169
|
+
>
|
170
|
+
<option value="">{ user.name }</option>
|
171
|
+
{
|
172
|
+
verifiedUserGroups.map((userGroup) => (
|
173
|
+
<option key={userGroup.id} value={userGroup.id}>{userGroup.name}</option>
|
174
|
+
))
|
175
|
+
}
|
176
|
+
</select>
|
177
|
+
</div>
|
178
|
+
);
|
179
|
+
}
|
180
|
+
|
181
|
+
return null;
|
182
|
+
}
|
183
|
+
|
147
184
|
/**
|
148
185
|
* Check comment's body and disable form if it's empty
|
149
186
|
* @private
|
@@ -164,10 +201,15 @@ export class AddCommentForm extends Component {
|
|
164
201
|
_addComment(evt) {
|
165
202
|
const { alignment } = this.state;
|
166
203
|
const { addComment, onCommentAdded } = this.props;
|
204
|
+
let addCommentParams = { body: this.bodyTextArea.value, alignment };
|
167
205
|
|
168
206
|
evt.preventDefault();
|
169
207
|
|
170
|
-
|
208
|
+
if (this.userGroupIdSelect && this.userGroupIdSelect.value !== '') {
|
209
|
+
addCommentParams.userGroupId = this.userGroupIdSelect.value;
|
210
|
+
}
|
211
|
+
|
212
|
+
addComment(addCommentParams);
|
171
213
|
|
172
214
|
this.bodyTextArea.value = '';
|
173
215
|
this.setState({ alignment: 0 });
|
@@ -185,8 +227,15 @@ AddCommentForm.defaultProps = {
|
|
185
227
|
|
186
228
|
AddCommentForm.propTypes = {
|
187
229
|
addComment: PropTypes.func.isRequired,
|
188
|
-
|
189
|
-
|
230
|
+
session: PropTypes.shape({
|
231
|
+
user: PropTypes.shape({
|
232
|
+
name: PropTypes.string.isRequired
|
233
|
+
}),
|
234
|
+
verifiedUserGroups: PropTypes.arrayOf(
|
235
|
+
PropTypes.shape({
|
236
|
+
name: PropTypes.string.isRequired
|
237
|
+
})
|
238
|
+
).isRequired
|
190
239
|
}).isRequired,
|
191
240
|
commentableId: PropTypes.string.isRequired,
|
192
241
|
commentableType: PropTypes.string.isRequired,
|
@@ -197,6 +246,12 @@ AddCommentForm.propTypes = {
|
|
197
246
|
autoFocus: PropTypes.bool
|
198
247
|
};
|
199
248
|
|
249
|
+
AddCommentForm.fragments = {
|
250
|
+
user: gql`
|
251
|
+
${addCommentFormFragment}
|
252
|
+
`
|
253
|
+
};
|
254
|
+
|
200
255
|
const AddCommentFormWithMutation = graphql(gql`
|
201
256
|
${addCommentMutation}
|
202
257
|
${commentThreadFragment}
|
@@ -206,12 +261,13 @@ const AddCommentFormWithMutation = graphql(gql`
|
|
206
261
|
${downVoteFragment}
|
207
262
|
`, {
|
208
263
|
props: ({ ownProps, mutate }) => ({
|
209
|
-
addComment: ({ body, alignment }) => mutate({
|
210
|
-
variables: {
|
264
|
+
addComment: ({ body, alignment, userGroupId }) => mutate({
|
265
|
+
variables: {
|
211
266
|
commentableId: ownProps.commentableId,
|
212
267
|
commentableType: ownProps.commentableType,
|
213
268
|
body,
|
214
|
-
alignment
|
269
|
+
alignment,
|
270
|
+
userGroupId
|
215
271
|
},
|
216
272
|
optimisticResponse: {
|
217
273
|
__typename: 'Mutation',
|
@@ -223,8 +279,8 @@ const AddCommentFormWithMutation = graphql(gql`
|
|
223
279
|
alignment: alignment,
|
224
280
|
author: {
|
225
281
|
__typename: 'Author',
|
226
|
-
name: ownProps.
|
227
|
-
avatarUrl: ownProps.
|
282
|
+
name: ownProps.session.user.name,
|
283
|
+
avatarUrl: ownProps.session.user.avatarUrl
|
228
284
|
},
|
229
285
|
replies: [],
|
230
286
|
hasReplies: false,
|