decidim-core 0.23.1 → 0.24.0.rc2
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of decidim-core might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/README.md +2 -2
- data/app/assets/images/decidim/icons.svg +1 -1
- data/app/assets/javascripts/decidim.js.es6 +1 -0
- data/app/assets/javascripts/decidim/core/bundle.js +1 -1
- data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
- data/app/assets/javascripts/decidim/editor.js.es6 +15 -4
- data/app/assets/javascripts/decidim/editor/history_override.js.es6 +117 -0
- data/app/assets/javascripts/decidim/editor/linebreak_module.js.es6 +83 -0
- data/app/assets/javascripts/decidim/editor/modified_backspace_offset1.js.es6 +98 -0
- data/app/assets/javascripts/decidim/editor/modified_backspace_offset_any.js.es6 +48 -0
- data/app/assets/javascripts/decidim/editor/modified_backspace_utils.js.es6 +31 -0
- data/app/assets/javascripts/decidim/editor/modified_enter.js.es6 +118 -0
- data/app/assets/javascripts/decidim/form_filter.component.js.es6 +25 -0
- data/app/assets/javascripts/decidim/geocoding/attach_input.js.es6 +41 -4
- data/app/assets/javascripts/decidim/input_character_counter.js.es6 +6 -1
- data/app/assets/javascripts/decidim/map/controller/markers.js.es6 +27 -9
- data/app/assets/javascripts/decidim/session_timeouter.js.es6 +78 -0
- data/app/assets/stylesheets/decidim/_variables.scss +9 -0
- data/app/assets/stylesheets/decidim/email.scss +14 -2
- data/app/assets/stylesheets/decidim/extras/_external-links.scss +0 -1
- data/app/assets/stylesheets/decidim/extras/_process_stats.scss +1 -1
- data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +1 -0
- data/app/assets/stylesheets/decidim/layouts/_home.scss +5 -0
- data/app/assets/stylesheets/decidim/modules/_author-avatar.scss +2 -2
- data/app/assets/stylesheets/decidim/modules/_buttons.scss +2 -2
- data/app/assets/stylesheets/decidim/modules/_cards.scss +18 -1
- data/app/assets/stylesheets/decidim/modules/_collapsible-list.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_comments.scss +5 -1
- data/app/assets/stylesheets/decidim/modules/_conference-speaker.scss +4 -3
- data/app/assets/stylesheets/decidim/modules/_data-picker.scss +7 -0
- data/app/assets/stylesheets/decidim/modules/_extra.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_forms.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_loading-spinner.scss +34 -0
- data/app/assets/stylesheets/decidim/modules/_modules.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_opinion-toggle.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_reveal.scss +6 -0
- data/app/assets/stylesheets/decidim/modules/_signup.scss +1 -0
- data/app/assets/stylesheets/decidim/modules/{_process-stats.scss → _space-stats.scss} +1 -1
- data/app/cells/decidim/activity/show.erb +1 -1
- data/app/cells/decidim/activity_cell.rb +17 -8
- data/app/cells/decidim/address/details.erb +5 -5
- data/app/cells/decidim/address_cell.rb +21 -0
- data/app/cells/decidim/announcement/show.erb +4 -4
- data/app/cells/decidim/announcement_cell.rb +22 -2
- data/app/cells/decidim/author/flag_user.erb +10 -0
- data/app/cells/decidim/author/profile_minicard.erb +1 -1
- data/app/cells/decidim/author_cell.rb +9 -1
- data/app/cells/decidim/card_m/top.erb +1 -1
- data/app/cells/decidim/card_m_cell.rb +1 -1
- data/app/cells/decidim/content_blocks/cta/show.erb +14 -0
- data/app/cells/decidim/content_blocks/cta_cell.rb +35 -0
- data/app/cells/decidim/content_blocks/cta_settings_form/show.erb +9 -0
- data/app/cells/decidim/content_blocks/cta_settings_form_cell.rb +13 -0
- data/app/cells/decidim/content_blocks/hero_cell.rb +14 -0
- data/app/cells/decidim/content_blocks/highlighted_elements/elements.erb +0 -0
- data/app/cells/decidim/content_blocks/highlighted_elements/heading.erb +0 -0
- data/app/cells/decidim/content_blocks/highlighted_elements/show.erb +4 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_cell.rb +51 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_settings_form/show.erb +3 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_settings_form_cell.rb +28 -0
- data/app/cells/decidim/content_blocks/last_activity_cell.rb +11 -0
- data/app/cells/decidim/content_blocks/metrics_cell.rb +0 -6
- data/app/cells/decidim/content_blocks/stats_cell.rb +0 -6
- data/app/cells/decidim/content_blocks/sub_hero/show.erb +3 -1
- data/app/cells/decidim/date/show.erb +31 -0
- data/app/cells/decidim/date_cell.rb +50 -0
- data/app/cells/decidim/endorsement_buttons_cell.rb +3 -3
- data/app/cells/decidim/flag_modal/flag_user.erb +24 -0
- data/app/cells/decidim/flag_modal/show.erb +24 -0
- data/app/cells/decidim/flag_modal_cell.rb +25 -0
- data/app/cells/decidim/profile/inaccessible.erb +9 -0
- data/app/cells/decidim/profile_cell.rb +9 -1
- data/app/cells/decidim/profile_sidebar/show.erb +10 -1
- data/app/cells/decidim/profile_sidebar_cell.rb +1 -0
- data/app/cells/decidim/reported_content/show.erb +5 -0
- data/app/cells/decidim/reported_content_cell.rb +44 -0
- data/app/cells/decidim/scopes_picker/scope_picker_prompt.erb +3 -0
- data/app/cells/decidim/scopes_picker/scope_picker_values.erb +5 -0
- data/app/cells/decidim/scopes_picker/show.erb +14 -0
- data/app/cells/decidim/scopes_picker_cell.rb +93 -0
- data/app/cells/decidim/tos_page/announcement.erb +1 -2
- data/app/cells/decidim/tos_page/form.erb +19 -0
- data/app/cells/decidim/tos_page_cell.rb +10 -8
- data/app/cells/decidim/translation_bar_cell.rb +1 -1
- data/app/cells/decidim/user_conversation/conversation_header.erb +1 -1
- data/app/cells/decidim/user_conversations_cell.rb +1 -1
- data/app/commands/decidim/attachment_methods.rb +8 -0
- data/app/commands/decidim/create_report.rb +11 -1
- data/app/commands/decidim/create_user_report.rb +67 -0
- data/app/commands/decidim/destroy_account.rb +2 -0
- data/app/commands/decidim/gallery_methods.rb +2 -2
- data/app/commands/decidim/multiple_attachments_methods.rb +14 -10
- data/app/commands/decidim/search.rb +5 -2
- data/app/commands/decidim/update_notifications_settings.rb +1 -0
- data/app/commands/decidim/update_user_group.rb +1 -0
- data/app/controllers/concerns/decidim/devise_controllers.rb +1 -0
- data/app/controllers/concerns/decidim/flaggable.rb +5 -1
- data/app/controllers/concerns/decidim/force_authentication.rb +11 -3
- data/app/controllers/concerns/decidim/locale_switcher.rb +5 -0
- data/app/controllers/concerns/decidim/needs_permission.rb +7 -1
- data/app/controllers/concerns/decidim/orderable.rb +3 -1
- data/app/controllers/concerns/decidim/user_blocked_checker.rb +26 -0
- data/app/controllers/decidim/application_controller.rb +22 -0
- data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +3 -1
- data/app/controllers/decidim/devise/sessions_controller.rb +10 -6
- data/app/controllers/decidim/errors_controller.rb +1 -1
- data/app/controllers/decidim/locales_controller.rb +1 -1
- data/app/controllers/decidim/profiles_controller.rb +6 -0
- data/app/controllers/decidim/report_users_controller.rb +42 -0
- data/app/controllers/decidim/scopes_controller.rb +19 -10
- data/app/controllers/decidim/timeouts_controller.rb +28 -0
- data/app/controllers/decidim/user_activities_controller.rb +5 -0
- data/app/controllers/decidim/user_timeline_controller.rb +1 -0
- data/app/events/decidim/demoted_membership_event.rb +2 -2
- data/app/events/decidim/invited_to_group_event.rb +2 -2
- data/app/events/decidim/join_request_accepted_event.rb +2 -2
- data/app/events/decidim/join_request_created_event.rb +2 -2
- data/app/events/decidim/join_request_rejected_event.rb +2 -2
- data/app/events/decidim/promoted_to_admin_event.rb +2 -2
- data/app/events/decidim/removed_from_group_event.rb +2 -2
- data/app/forms/decidim/account_form.rb +1 -1
- data/app/forms/decidim/attachment_form.rb +1 -0
- data/app/forms/decidim/invite_user_form.rb +2 -2
- data/app/forms/decidim/messaging/conversation_form.rb +1 -1
- data/app/forms/decidim/messaging/message_form.rb +1 -1
- data/app/forms/decidim/notifications_settings_form.rb +20 -0
- data/app/forms/url_validator.rb +20 -0
- data/app/helpers/decidim/action_authorization_helper.rb +2 -0
- data/app/helpers/decidim/application_helper.rb +1 -2
- data/app/helpers/decidim/cells_helper.rb +6 -0
- data/app/helpers/decidim/filters_helper.rb +10 -0
- data/app/helpers/decidim/messaging/conversation_helper.rb +11 -1
- data/app/helpers/decidim/newsletters_helper.rb +7 -9
- data/app/helpers/decidim/paginate_helper.rb +1 -10
- data/app/helpers/decidim/sanitize_helper.rb +8 -0
- data/app/helpers/decidim/scopes_helper.rb +2 -2
- data/app/jobs/decidim/block_user_job.rb +11 -0
- data/app/jobs/decidim/data_portability_export_job.rb +3 -3
- data/app/jobs/decidim/export_job.rb +2 -2
- data/app/jobs/decidim/find_and_update_descendants_job.rb +48 -0
- data/app/jobs/decidim/machine_translation_resource_job.rb +3 -0
- data/app/jobs/decidim/machine_translation_save_job.rb +29 -0
- data/app/jobs/decidim/open_data_job.rb +1 -1
- data/app/jobs/decidim/update_search_indexes_job.rb +11 -0
- data/app/jobs/decidim/user_report_job.rb +11 -0
- data/app/mailers/decidim/application_mailer.rb +1 -0
- data/app/mailers/decidim/block_user_mailer.rb +21 -0
- data/app/mailers/decidim/reported_mailer.rb +33 -3
- data/app/mailers/decidim/user_report_mailer.rb +21 -0
- data/app/models/decidim/area.rb +0 -1
- data/app/models/decidim/area_type.rb +1 -1
- data/app/models/decidim/attachment.rb +3 -2
- data/app/models/decidim/attachment_collection.rb +1 -1
- data/app/models/decidim/authorization.rb +4 -0
- data/app/models/decidim/category.rb +6 -1
- data/app/models/decidim/impersonation_log.rb +5 -7
- data/app/models/decidim/metric.rb +2 -2
- data/app/models/decidim/moderation.rb +12 -0
- data/app/models/decidim/organization.rb +6 -2
- data/app/models/decidim/scope.rb +5 -2
- data/app/models/decidim/scope_type.rb +1 -1
- data/app/models/decidim/share_token.rb +1 -1
- data/app/models/decidim/static_page.rb +11 -1
- data/app/models/decidim/static_page_topic.rb +4 -0
- data/app/models/decidim/user.rb +23 -4
- data/app/models/decidim/user_base_entity.rb +12 -12
- data/app/models/decidim/user_block.rb +10 -0
- data/app/models/decidim/user_group.rb +1 -0
- data/app/models/decidim/user_moderation.rb +22 -0
- data/app/models/decidim/user_report.rb +31 -0
- data/app/permissions/decidim/permissions.rb +1 -3
- data/app/permissions/decidim/report_user_permissions.rb +13 -0
- data/app/presenters/decidim/admin_log/component_presenter.rb +2 -2
- data/app/presenters/decidim/admin_log/impersonation_log_presenter.rb +39 -0
- data/app/presenters/decidim/admin_log/moderation_presenter.rb +2 -2
- data/app/presenters/decidim/admin_log/organization_presenter.rb +3 -4
- data/app/presenters/decidim/admin_log/user_moderation_presenter.rb +63 -0
- data/app/presenters/decidim/admin_log/user_presenter.rb +19 -10
- data/app/presenters/decidim/home_stats_presenter.rb +3 -3
- data/app/presenters/decidim/log/base_presenter.rb +9 -1
- data/app/presenters/decidim/log/diff_presenter.rb +4 -3
- data/app/presenters/decidim/log/resource_presenter.rb +4 -4
- data/app/presenters/decidim/log/user_presenter.rb +1 -1
- data/app/presenters/decidim/menu_presenter.rb +12 -7
- data/app/presenters/decidim/nil_presenter.rb +0 -2
- data/app/presenters/decidim/user_presenter.rb +1 -1
- data/app/queries/decidim/metrics/blocked_users_metric_manage.rb +26 -0
- data/app/queries/decidim/metrics/followers_metric_manage.rb +3 -0
- data/app/queries/decidim/metrics/participants_metric_manage.rb +3 -0
- data/app/queries/decidim/metrics/reported_users_metric_manage.rb +26 -0
- data/app/queries/decidim/metrics/user_reports_metric_manage.rb +26 -0
- data/app/scrubbers/decidim/newsletter_scrubber.rb +31 -0
- data/app/services/decidim/activity_search.rb +1 -3
- data/app/services/decidim/base_diff_renderer.rb +1 -1
- data/app/services/decidim/data_portability_exporter.rb +1 -0
- data/app/services/decidim/email_notification_generator.rb +2 -2
- data/app/services/decidim/events_manager.rb +1 -1
- data/app/services/decidim/open_data_exporter.rb +36 -7
- data/app/services/decidim/tokenizer.rb +38 -0
- data/app/services/decidim/traceability.rb +3 -0
- data/app/services/decidim/zip_stream/zip_stream_writer.rb +3 -3
- data/app/uploaders/decidim/application_uploader.rb +24 -0
- data/app/uploaders/decidim/attachment_uploader.rb +2 -4
- data/app/uploaders/decidim/downloader.rb +9 -0
- data/app/uploaders/decidim/image_uploader.rb +9 -21
- data/app/uploaders/decidim/open_data_uploader.rb +5 -0
- data/app/uploaders/decidim/record_image_uploader.rb +2 -2
- data/app/validators/etiquette_validator.rb +0 -7
- data/app/validators/uploader_content_type_validator.rb +4 -2
- data/app/views/decidim/block_user_mailer/notify.html.erb +7 -0
- data/app/views/decidim/devise/confirmations/new.html.erb +1 -1
- data/app/views/decidim/devise/registrations/edit.html.erb +1 -1
- data/app/views/decidim/devise/unlocks/new.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_conversation.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_messages.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_show.html.erb +4 -4
- data/app/views/decidim/newsletter_mailer/newsletter.html.erb +1 -1
- data/app/views/decidim/notifications_settings/show.html.erb +11 -0
- data/app/views/decidim/pages/_standalone.html.erb +3 -1
- data/app/views/decidim/pages/_tabbed.html.erb +1 -1
- data/app/views/decidim/reported_mailer/report.html.erb +8 -8
- data/app/views/decidim/searches/_filters_small_view.html.erb +1 -1
- data/app/views/decidim/shared/_check_boxes_tree.html.erb +3 -3
- data/app/views/decidim/shared/_component_announcement.html.erb +2 -2
- data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +1 -1
- data/app/views/decidim/user_report_mailer/notify.html.erb +7 -0
- data/app/views/decidim/widgets/_data_picker.html.erb +1 -1
- data/app/views/layouts/decidim/_application.html.erb +1 -0
- data/app/views/layouts/decidim/_js_configuration.html.erb +1 -1
- data/app/views/layouts/decidim/_main_footer.html.erb +6 -4
- data/app/views/layouts/decidim/_timeout_modal.html.erb +21 -0
- data/config/initializers/active_support.rb +7 -0
- data/config/initializers/devise.rb +1 -1
- data/config/initializers/omniauth.rb +1 -1
- data/config/locales/ar.yml +1 -9
- data/config/locales/bg.yml +1 -15
- data/config/locales/ca.yml +81 -16
- data/config/locales/cs.yml +102 -37
- data/config/locales/de.yml +217 -143
- data/config/locales/el.yml +1 -16
- data/config/locales/en.yml +79 -14
- data/config/locales/eo.yml +0 -1
- data/config/locales/es-MX.yml +78 -13
- data/config/locales/es-PY.yml +77 -12
- data/config/locales/es.yml +80 -15
- data/config/locales/eu.yml +10 -12
- data/config/locales/fi-plain.yml +80 -16
- data/config/locales/fi.yml +89 -25
- data/config/locales/fr-CA.yml +79 -14
- data/config/locales/fr.yml +80 -15
- data/config/locales/gl.yml +1 -9
- data/config/locales/hu.yml +1 -15
- data/config/locales/id-ID.yml +1 -9
- data/config/locales/is-IS.yml +7 -2
- data/config/locales/it.yml +70 -19
- data/config/locales/ja.yml +6 -21
- data/config/locales/lv.yml +3 -15
- data/config/locales/nl.yml +48 -25
- data/config/locales/no.yml +24 -18
- data/config/locales/pl.yml +100 -25
- data/config/locales/pt-BR.yml +1 -9
- data/config/locales/pt.yml +1 -16
- data/config/locales/ro-RO.yml +20 -16
- data/config/locales/ru.yml +5 -16
- data/config/locales/si-LK.yml +1 -0
- data/config/locales/sk.yml +2 -16
- data/config/locales/sr-CS.yml +0 -11
- data/config/locales/sv.yml +6 -17
- data/config/locales/sw-KE.yml +1 -0
- data/config/locales/tr-TR.yml +637 -246
- data/config/locales/uk.yml +5 -13
- data/config/locales/zh-CN.yml +1 -16
- data/config/routes.rb +9 -4
- data/db/migrate/20170713131206_add_admin_to_users.rb +1 -1
- data/db/migrate/20180206143340_fix_reference_for_all_resources.rb +2 -0
- data/db/migrate/20180314085339_rename_maximum_votes_per_proposal_to_threshold_per_proposal.rb +2 -2
- data/db/migrate/20200929171508_remove_show_statistics_from_organizations.rb +7 -0
- data/db/migrate/20201010124755_create_decidim_user_moderations.rb +12 -0
- data/db/migrate/20201010124756_create_decidim_user_reports.rb +16 -0
- data/db/migrate/20201010224433_add_suspension_fields_to_decidim_users.rb +8 -0
- data/db/migrate/20201011074641_create_decidim_user_suspensions.rb +14 -0
- data/db/migrate/20201011081626_add_current_suspension_id_to_decidim_users.rb +7 -0
- data/db/migrate/20201013071533_add_reported_content_to_moderations.rb +7 -0
- data/db/migrate/20201019074554_add_locale_to_moderation_reports.rb +7 -0
- data/db/migrate/20201127114444_encrypt_authorization_metadatas.rb +35 -0
- data/db/migrate/20201128130723_add_allow_public_access_to_static_pages.rb +17 -0
- data/db/migrate/20201218144706_update_table_block_user_functionality.rb +8 -0
- data/db/migrate/20201218145252_rename_decidim_user_fields_for_block_functionality.rb +9 -0
- data/db/migrate/20210208134328_add_email_on_moderations_to_users.rb +7 -0
- data/db/migrate/20210302150803_invalidate_all_sessions_for_deleted_users.rb +11 -0
- data/db/seeds.rb +18 -12
- data/lib/decidim/amendable.rb +3 -2
- data/{app/functions/decidim/core → lib/decidim/api/functions}/component_finder_base.rb +1 -1
- data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list.rb +4 -4
- data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list_base.rb +3 -1
- data/lib/decidim/api/functions/needs_api_default_order.rb +24 -0
- data/{app/functions/decidim/core → lib/decidim/api/functions}/needs_api_filter_and_order.rb +0 -0
- data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_finder_base.rb +2 -2
- data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_list_base.rb +3 -1
- data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_finder.rb +1 -4
- data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_list.rb +1 -3
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/base_input_filter.rb +0 -0
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/component_input_filter.rb +20 -22
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_hastaggable_input_filter.rb +1 -1
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_localized_input_filter.rb +3 -3
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_publishable_input_filter.rb +6 -6
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_timestamp_input_filter.rb +12 -12
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/participatory_space_input_filter.rb +0 -1
- data/lib/decidim/api/input_filters/user_entity_input_filter.rb +89 -0
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/base_input_sort.rb +3 -2
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/component_input_sort.rb +10 -11
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_endorsable_input_sort.rb +2 -4
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_localized_input_sort.rb +3 -3
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_publishable_input_sort.rb +1 -1
- data/lib/decidim/api/input_sorts/has_timestamp_input_sort.rb +12 -0
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/participatory_space_input_sort.rb +1 -1
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/user_entity_input_sort.rb +4 -4
- data/lib/decidim/api/{amendable_entity_interface.rb → interfaces/amendable_entity_interface.rb} +5 -5
- data/lib/decidim/api/interfaces/amendable_interface.rb +17 -0
- data/lib/decidim/api/{attachable_interface.rb → interfaces/attachable_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/author_interface.rb +32 -0
- data/lib/decidim/api/interfaces/authorable_interface.rb +23 -0
- data/lib/decidim/api/{categorizable_interface.rb → interfaces/categorizable_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/coauthorable_interface.rb +30 -0
- data/lib/decidim/api/interfaces/component_interface.rb +22 -0
- data/lib/decidim/api/interfaces/endorsable_interface.rb +19 -0
- data/lib/decidim/api/{fingerprint_interface.rb → interfaces/fingerprint_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/participatory_space_interface.rb +48 -0
- data/lib/decidim/api/interfaces/participatory_space_resourceable_interface.rb +25 -0
- data/lib/decidim/api/{scopable_interface.rb → interfaces/scopable_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/timestamps_interface.rb +15 -0
- data/lib/decidim/api/interfaces/traceable_interface.rb +14 -0
- data/lib/decidim/api/scalars/date_time_type.rb +17 -0
- data/lib/decidim/api/scalars/date_type.rb +17 -0
- data/lib/decidim/api/types/amendment_type.rb +19 -0
- data/lib/decidim/api/types/area_api_type.rb +16 -0
- data/lib/decidim/api/types/area_type_type.rb +13 -0
- data/lib/decidim/api/types/attachment_type.rb +13 -0
- data/lib/decidim/api/types/category_type.rb +14 -0
- data/{app/types/decidim/core → lib/decidim/api/types}/component_type.rb +2 -4
- data/lib/decidim/api/types/coordinates_type.rb +21 -0
- data/lib/decidim/api/types/decidim_type.rb +13 -0
- data/lib/decidim/api/types/fingerprint_type.rb +12 -0
- data/lib/decidim/api/types/hashtag_type.rb +13 -0
- data/lib/decidim/api/types/localized_string_type.rb +13 -0
- data/lib/decidim/api/types/metric_history_type.rb +18 -0
- data/lib/decidim/api/types/metric_type.rb +13 -0
- data/lib/decidim/api/types/organization_type.rb +17 -0
- data/lib/decidim/api/types/participatory_space_link_type.rb +22 -0
- data/lib/decidim/api/types/participatory_space_type.rb +10 -0
- data/lib/decidim/api/types/scope_api_type.rb +16 -0
- data/lib/decidim/api/types/session_type.rb +22 -0
- data/lib/decidim/api/types/statistic_type.rb +20 -0
- data/lib/decidim/api/types/trace_version_type.rb +21 -0
- data/lib/decidim/api/types/translated_field_type.rb +36 -0
- data/lib/decidim/api/types/user_group_type.rb +64 -0
- data/lib/decidim/api/types/user_type.rb +67 -0
- data/lib/decidim/attachment_attributes.rb +57 -0
- data/lib/decidim/attribute_encryptor.rb +9 -1
- data/lib/decidim/attributes.rb +1 -0
- data/lib/decidim/attributes/clean_string.rb +37 -0
- data/lib/decidim/coauthorable.rb +3 -3
- data/lib/decidim/component_manifest.rb +17 -0
- data/lib/decidim/content_block_manifest.rb +1 -1
- data/lib/decidim/content_parsers/hashtag_parser.rb +3 -6
- data/lib/decidim/content_parsers/user_group_parser.rb +2 -5
- data/lib/decidim/content_parsers/user_parser.rb +2 -5
- data/lib/decidim/content_processor.rb +1 -1
- data/lib/decidim/content_renderers/hashtag_renderer.rb +3 -6
- data/lib/decidim/core.rb +11 -3
- data/lib/decidim/core/api.rb +71 -16
- data/lib/decidim/core/engine.rb +40 -6
- data/lib/decidim/core/test.rb +4 -0
- data/lib/decidim/core/test/factories.rb +53 -15
- data/lib/decidim/core/test/shared_examples/admin_log_presenter_examples.rb +34 -0
- data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/amendment_accepted_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/amendment_promoted_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/amendment_rejected_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/comments_examples.rb +11 -9
- data/lib/decidim/core/test/shared_examples/component_type.rb +1 -1
- data/lib/decidim/core/test/shared_examples/controller_render_views.rb +28 -0
- data/lib/decidim/core/test/shared_examples/counts_commentators_as_newsletter_participants.rb +31 -0
- data/lib/decidim/core/test/shared_examples/follows_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/logo_email.rb +1 -1
- data/lib/decidim/core/test/shared_examples/map_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/process_announcements_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/reportable.rb +8 -0
- data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/searchable_participatory_space_examples.rb +2 -3
- data/lib/decidim/core/test/shared_examples/searchable_results_examples.rb +46 -0
- data/lib/decidim/core/test/shared_examples/static_pages_examples.rb +43 -0
- data/lib/decidim/core/version.rb +1 -1
- data/lib/decidim/diffy_extension.rb +2 -2
- data/lib/decidim/exporters/csv.rb +3 -2
- data/lib/decidim/exporters/export_data.rb +1 -1
- data/lib/decidim/faker/internet.rb +17 -0
- data/lib/decidim/faker/localized.rb +43 -20
- data/lib/decidim/file_validator_humanizer.rb +6 -4
- data/lib/decidim/form_builder.rb +36 -24
- data/lib/decidim/gamification/badge_scorer.rb +3 -2
- data/lib/decidim/gamification/base_event.rb +2 -2
- data/lib/decidim/geocodable.rb +2 -0
- data/lib/decidim/has_category.rb +1 -1
- data/lib/decidim/has_private_users.rb +2 -2
- data/lib/decidim/importers/import_manifest.rb +36 -0
- data/lib/decidim/map/autocomplete.rb +11 -1
- data/lib/decidim/metric_operation.rb +5 -6
- data/lib/decidim/newsletter_participant.rb +2 -4
- data/lib/decidim/paddable.rb +11 -4
- data/lib/decidim/participatory_space_resourceable.rb +1 -3
- data/lib/decidim/query_extensions.rb +90 -69
- data/lib/decidim/randomable.rb +6 -1
- data/lib/decidim/record_encryptor.rb +149 -0
- data/lib/decidim/reportable.rb +26 -0
- data/lib/decidim/resource_manifest.rb +3 -0
- data/lib/decidim/resourceable.rb +6 -6
- data/lib/decidim/scopable.rb +1 -1
- data/lib/decidim/search_resource_fields_mapper.rb +1 -1
- data/lib/decidim/searchable.rb +9 -0
- data/lib/decidim/settings_manifest.rb +2 -1
- data/lib/decidim/shareable_with_token.rb +0 -1
- data/lib/decidim/translatable_attributes.rb +2 -1
- data/lib/decidim/translatable_resource.rb +10 -0
- data/lib/decidim/user_reportable.rb +33 -0
- data/lib/decidim/view_model.rb +26 -0
- data/lib/premailer/adapter/decidim.rb +33 -0
- data/lib/tasks/decidim_data_portability_tasks.rake +4 -4
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.ko.js +18 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.vi.js +14 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-CN.js +14 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-TW.js +14 -0
- metadata +204 -105
- data/app/cells/decidim/tos_page/sticky_form.erb +0 -29
- data/app/functions/decidim/core/participatory_space_finder.rb +0 -11
- data/app/functions/decidim/core/participatory_space_list.rb +0 -11
- data/app/types/decidim/core/amendment_type.rb +0 -26
- data/app/types/decidim/core/area_api_type.rb +0 -16
- data/app/types/decidim/core/area_type_type.rb +0 -14
- data/app/types/decidim/core/attachment_type.rb +0 -14
- data/app/types/decidim/core/category_type.rb +0 -16
- data/app/types/decidim/core/coordinates_type.rb +0 -19
- data/app/types/decidim/core/date_time_type.rb +0 -12
- data/app/types/decidim/core/date_type.rb +0 -13
- data/app/types/decidim/core/decidim_type.rb +0 -19
- data/app/types/decidim/core/fingerprint_type.rb +0 -15
- data/app/types/decidim/core/has_timestamp_input_sort.rb +0 -12
- data/app/types/decidim/core/hashtag_type.rb +0 -13
- data/app/types/decidim/core/localized_string_type.rb +0 -14
- data/app/types/decidim/core/metric_history_type.rb +0 -17
- data/app/types/decidim/core/metric_type.rb +0 -14
- data/app/types/decidim/core/organization_type.rb +0 -20
- data/app/types/decidim/core/participatory_space_link_type.rb +0 -24
- data/app/types/decidim/core/participatory_space_type.rb +0 -12
- data/app/types/decidim/core/scope_api_type.rb +0 -16
- data/app/types/decidim/core/session_type.rb +0 -19
- data/app/types/decidim/core/statistic_type.rb +0 -22
- data/app/types/decidim/core/trace_version_type.rb +0 -29
- data/app/types/decidim/core/translated_field_type.rb +0 -45
- data/app/types/decidim/core/user_entity_input_filter.rb +0 -81
- data/app/types/decidim/core/user_group_type.rb +0 -51
- data/app/types/decidim/core/user_type.rb +0 -52
- data/app/views/decidim/shared/_announcement.html.erb +0 -1
- data/app/views/decidim/shared/_flag_modal.html.erb +0 -20
- data/lib/decidim/api/amendable_interface.rb +0 -18
- data/lib/decidim/api/author_interface.rb +0 -29
- data/lib/decidim/api/authorable_interface.rb +0 -22
- data/lib/decidim/api/coauthorable_interface.rb +0 -29
- data/lib/decidim/api/component_interface.rb +0 -20
- data/lib/decidim/api/endorsable_interface.rb +0 -22
- data/lib/decidim/api/participatory_space_interface.rb +0 -47
- data/lib/decidim/api/participatory_space_resourceable_interface.rb +0 -21
- data/lib/decidim/api/timestamps_interface.rb +0 -21
- data/lib/decidim/api/traceable_interface.rb +0 -14
@@ -0,0 +1,38 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "openssl"
|
4
|
+
|
5
|
+
module Decidim
|
6
|
+
# This class is used to generate secure tokens
|
7
|
+
class Tokenizer
|
8
|
+
#
|
9
|
+
# Initializes the Tokenizer.
|
10
|
+
#
|
11
|
+
# salt - The salt fr the encryption (it should be at leas 30 chars long)
|
12
|
+
# length - How long the key generated should be (in bytes)
|
13
|
+
#
|
14
|
+
def initialize(salt: nil, length: 32)
|
15
|
+
@salt = salt.presence || Tokenizer.random_salt
|
16
|
+
@length = length
|
17
|
+
end
|
18
|
+
|
19
|
+
def self.random_salt
|
20
|
+
SecureRandom.hex(32)
|
21
|
+
end
|
22
|
+
|
23
|
+
attr_reader :salt, :length
|
24
|
+
|
25
|
+
# returns a securely generated string of bytes
|
26
|
+
def digest(string)
|
27
|
+
OpenSSL::PKCS5.pbkdf2_hmac(string.to_s, salt, 20_000, length, "sha256")
|
28
|
+
end
|
29
|
+
|
30
|
+
def int_digest(string)
|
31
|
+
digest(string.to_s).bytes.inject { |a, b| (a << 8) + b }
|
32
|
+
end
|
33
|
+
|
34
|
+
def hex_digest(string)
|
35
|
+
digest(string.to_s).bytes.map { |c| c.ord.to_s(16) }.join
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -115,6 +115,9 @@ module Decidim
|
|
115
115
|
|
116
116
|
def log(action, user, resource, extra_log_info = {})
|
117
117
|
return unless user.is_a?(Decidim::User)
|
118
|
+
# If the record is not valid, it may not yet have an ID causing an
|
119
|
+
# exception when trying to save the log record.
|
120
|
+
return unless resource.valid?
|
118
121
|
|
119
122
|
Decidim::ActionLogger.log(
|
120
123
|
action,
|
@@ -24,10 +24,10 @@ module Decidim
|
|
24
24
|
attachment_block.last.each do |attachment_uploader|
|
25
25
|
next if attachment_uploader.file.nil?
|
26
26
|
|
27
|
-
case attachment_uploader.
|
28
|
-
when "
|
27
|
+
case attachment_uploader.provider
|
28
|
+
when "file" # file system
|
29
29
|
next unless File.exist?(attachment_uploader.file.file)
|
30
|
-
when "
|
30
|
+
when "aws"
|
31
31
|
cache_attachment_from_aws(attachment_uploader)
|
32
32
|
else
|
33
33
|
Rails.logger.info "Carrierwave fog_provider not supported by DataPortabilityExporter for attachment: #{attachment_uploader}"
|
@@ -5,6 +5,8 @@ module Decidim
|
|
5
5
|
# hold the uploads configuration, so you should inherit from this class and
|
6
6
|
# then tweak any configuration you need.
|
7
7
|
class ApplicationUploader < CarrierWave::Uploader::Base
|
8
|
+
include CarrierWave::MiniMagick
|
9
|
+
|
8
10
|
process :validate_inside_organization
|
9
11
|
|
10
12
|
# Override the directory where uploaded files will be stored.
|
@@ -17,6 +19,28 @@ module Decidim
|
|
17
19
|
default_path
|
18
20
|
end
|
19
21
|
|
22
|
+
# When the uploaded content can't be processed, we want to make sure
|
23
|
+
# not to expose internal tools errors to the users.
|
24
|
+
# We'll show a generic error instead.
|
25
|
+
def manipulate!
|
26
|
+
super
|
27
|
+
rescue CarrierWave::ProcessingError => e
|
28
|
+
Rails.logger.error(e)
|
29
|
+
raise CarrierWave::ProcessingError, I18n.t("carrierwave.errors.general")
|
30
|
+
end
|
31
|
+
|
32
|
+
# As of Carrierwave 2.0 fog_provider method has been deprecated, and is throwing RuntimeError
|
33
|
+
# RuntimeError: Carrierwave fog_provider not supported: DEPRECATION WARNING: #fog_provider is deprecated...
|
34
|
+
# We are attempting to fetch the provider from credentials, if not we consider to be file
|
35
|
+
def provider
|
36
|
+
fog_credentials.fetch(:provider, "file").downcase
|
37
|
+
end
|
38
|
+
|
39
|
+
# We overwrite the downloader to be able to fetch some elements from URL.
|
40
|
+
def downloader
|
41
|
+
Decidim::Downloader
|
42
|
+
end
|
43
|
+
|
20
44
|
protected
|
21
45
|
|
22
46
|
# Validates that the associated model is always within an organization in
|
@@ -3,8 +3,6 @@
|
|
3
3
|
module Decidim
|
4
4
|
# This class deals with uploading attachments to a participatory space.
|
5
5
|
class AttachmentUploader < ApplicationUploader
|
6
|
-
include CarrierWave::MiniMagick
|
7
|
-
|
8
6
|
process :set_content_type_and_size_in_model
|
9
7
|
process :validate_dimensions
|
10
8
|
process :strip
|
@@ -17,7 +15,7 @@ module Decidim
|
|
17
15
|
process resize_to_limit: [nil, 1000]
|
18
16
|
end
|
19
17
|
|
20
|
-
def
|
18
|
+
def extension_allowlist
|
21
19
|
case upload_context
|
22
20
|
when :admin
|
23
21
|
Decidim.organization_settings(model).upload_allowed_file_extensions_admin
|
@@ -28,7 +26,7 @@ module Decidim
|
|
28
26
|
|
29
27
|
# CarrierWave automatically calls this method and validates the content
|
30
28
|
# type fo the temp file to match against any of these options.
|
31
|
-
def
|
29
|
+
def content_type_allowlist
|
32
30
|
case upload_context
|
33
31
|
when :admin
|
34
32
|
Decidim.organization_settings(model).upload_allowed_content_types_admin
|
@@ -3,15 +3,13 @@
|
|
3
3
|
module Decidim
|
4
4
|
# This class deals with uploading hero images to ParticipatoryProcesses.
|
5
5
|
class ImageUploader < ApplicationUploader
|
6
|
-
include CarrierWave::MiniMagick
|
7
|
-
|
8
6
|
process :validate_size, :validate_dimensions, :strip
|
9
7
|
process quality: Decidim.image_uploader_quality
|
10
8
|
|
11
9
|
# CarrierWave automatically calls this method and validates the content
|
12
10
|
# type fo the temp file to match against any of these options.
|
13
|
-
def
|
14
|
-
|
11
|
+
def content_type_allowlist
|
12
|
+
extension_allowlist.map { |ext| "image/#{ext}" }
|
15
13
|
end
|
16
14
|
|
17
15
|
# Strips out all embedded information from the image
|
@@ -25,15 +23,12 @@ module Decidim
|
|
25
23
|
# Fetches info about different versions, their processors and dimensions
|
26
24
|
def dimensions_info
|
27
25
|
if versions.any?
|
28
|
-
versions.
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
}
|
35
|
-
]
|
36
|
-
end.to_h
|
26
|
+
versions.transform_values do |info|
|
27
|
+
{
|
28
|
+
processor: info.processors[0][0],
|
29
|
+
dimensions: info.processors[0][1]
|
30
|
+
}
|
31
|
+
end
|
37
32
|
else
|
38
33
|
processors.map do |info|
|
39
34
|
[:default, { processor: info[0], dimensions: info[1] }]
|
@@ -43,7 +38,7 @@ module Decidim
|
|
43
38
|
|
44
39
|
# Add a white list of extensions which are allowed to be uploaded.
|
45
40
|
# For images you might use something like this:
|
46
|
-
def
|
41
|
+
def extension_allowlist
|
47
42
|
Decidim.organization_settings(model).upload_allowed_file_extensions_image
|
48
43
|
end
|
49
44
|
|
@@ -69,13 +64,6 @@ module Decidim
|
|
69
64
|
3840
|
70
65
|
end
|
71
66
|
|
72
|
-
def manipulate!
|
73
|
-
super
|
74
|
-
rescue CarrierWave::ProcessingError => e
|
75
|
-
Rails.logger.error(e)
|
76
|
-
raise CarrierWave::ProcessingError, I18n.t("carrierwave.errors.general")
|
77
|
-
end
|
78
|
-
|
79
67
|
private
|
80
68
|
|
81
69
|
def validation_error!(text)
|
@@ -4,11 +4,11 @@ module Decidim
|
|
4
4
|
# This class deals with uploading record specific images that have more
|
5
5
|
# limited content types than the defaults.
|
6
6
|
class RecordImageUploader < ImageUploader
|
7
|
-
def
|
7
|
+
def content_type_allowlist
|
8
8
|
%w(image/jpeg image/png)
|
9
9
|
end
|
10
10
|
|
11
|
-
def
|
11
|
+
def extension_allowlist
|
12
12
|
%w(jpeg jpg png)
|
13
13
|
end
|
14
14
|
end
|
@@ -9,7 +9,6 @@ class EtiquetteValidator < ActiveModel::EachValidator
|
|
9
9
|
validate_caps(record, attribute, value)
|
10
10
|
validate_marks(record, attribute, value)
|
11
11
|
validate_caps_first(record, attribute, value)
|
12
|
-
validate_length(record, attribute, value)
|
13
12
|
end
|
14
13
|
|
15
14
|
private
|
@@ -31,10 +30,4 @@ class EtiquetteValidator < ActiveModel::EachValidator
|
|
31
30
|
|
32
31
|
record.errors.add(attribute, options[:message] || :must_start_with_caps)
|
33
32
|
end
|
34
|
-
|
35
|
-
def validate_length(record, attribute, value)
|
36
|
-
return if value.length > 15
|
37
|
-
|
38
|
-
record.errors.add(attribute, options[:message] || :too_short)
|
39
|
-
end
|
40
33
|
end
|
@@ -4,6 +4,7 @@
|
|
4
4
|
# content types. This prevents CarrierWave from uploading the records before
|
5
5
|
# they pass the content type validations.
|
6
6
|
class UploaderContentTypeValidator < ActiveModel::Validations::FileContentTypeValidator
|
7
|
+
# rubocop: disable Metrics/CyclomaticComplexity
|
7
8
|
def validate_each(record, attribute, value)
|
8
9
|
begin
|
9
10
|
values = parse_values(value)
|
@@ -19,8 +20,8 @@ class UploaderContentTypeValidator < ActiveModel::Validations::FileContentTypeVa
|
|
19
20
|
return unless uploader.is_a?(Decidim::ApplicationUploader)
|
20
21
|
|
21
22
|
mode = option_value(record, :mode)
|
22
|
-
allowed_types = uploader.
|
23
|
-
forbidden_types = uploader.
|
23
|
+
allowed_types = uploader.content_type_allowlist || []
|
24
|
+
forbidden_types = uploader.content_type_denylist || []
|
24
25
|
|
25
26
|
values.each do |val|
|
26
27
|
val_mode = mode
|
@@ -39,6 +40,7 @@ class UploaderContentTypeValidator < ActiveModel::Validations::FileContentTypeVa
|
|
39
40
|
validate_blacklist(record, attribute, content_type, forbidden_types)
|
40
41
|
end
|
41
42
|
end
|
43
|
+
# rubocop: enable Metrics/CyclomaticComplexity
|
42
44
|
|
43
45
|
def check_validity!; end
|
44
46
|
end
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<p><%= t ".hello" %></p>
|
2
|
+
|
3
|
+
<p><%= t ".body_1", organization_name: h(@organization.name) %></p>
|
4
|
+
|
5
|
+
<p><%= t ".body_2", justification: h(@justification) %></p>
|
6
|
+
|
7
|
+
<p><%= t(".greetings", organization_name: h(@organization.name), organization_url: decidim.root_url(host: @organization.host)).html_safe %></p>
|
@@ -13,7 +13,7 @@
|
|
13
13
|
<div class="card">
|
14
14
|
<div class="card__content">
|
15
15
|
<%= decidim_form_for(resource, namespace: "confirmation", as: resource_name, url: confirmation_path(resource_name), html: { method: :post, class: "register-form new_user" }) do |f| %>
|
16
|
-
<%=
|
16
|
+
<%= render "devise/shared/error_messages", resource: resource %>
|
17
17
|
|
18
18
|
<div class="field">
|
19
19
|
<%= f.email_field :email, autofocus: true, value: (resource.pending_reconfirmation? ? resource.unconfirmed_email : resource.email) %>
|
@@ -1,7 +1,7 @@
|
|
1
1
|
<h2><%= t("devise.registrations.edit.title", resource: resource_class.model_name.human) %></h2>
|
2
2
|
|
3
3
|
<%= decidim_form_for(resource, namespace: "registration", as: resource_name, url: registration_path(resource_name), html: { method: :put }) do |f| %>
|
4
|
-
<%=
|
4
|
+
<%= render "devise/shared/error_messages", resource: resource %>
|
5
5
|
<%= form_required_explanation %>
|
6
6
|
<%= invisible_captcha %>
|
7
7
|
|
@@ -13,7 +13,7 @@
|
|
13
13
|
<div class="card">
|
14
14
|
<div class="card__content">
|
15
15
|
<%= decidim_form_for(resource, namespace: "unlock", as: resource_name, url: unlock_path(resource_name), html: { method: :post, class: "register-form new_user" }) do |f| %>
|
16
|
-
<%=
|
16
|
+
<%= render "devise/shared/error_messages", resource: resource %>
|
17
17
|
|
18
18
|
<div class="field">
|
19
19
|
<%= f.email_field :email, autofocus: true, autocomplete: "email" %>
|
@@ -17,7 +17,7 @@
|
|
17
17
|
<% if conversation.interlocutors(current_user).count == 1 %>
|
18
18
|
<%= t("from", scope: "decidim.messaging.conversations.index") %>: <strong><%= conversation.interlocutors(current_user).first.name %> <span class="muted">@<%= conversation.interlocutors(current_user).first.nickname %></span></strong>
|
19
19
|
<% else %>
|
20
|
-
<%= t("from", scope: "decidim.messaging.conversations.index") %>: <strong><%= username_list(conversation.interlocutors(current_user), true) %></strong>
|
20
|
+
<%= t("from", scope: "decidim.messaging.conversations.index") %>: <strong><%= username_list(conversation.interlocutors(current_user), shorten: true) %></strong>
|
21
21
|
<% end %>
|
22
22
|
<br>
|
23
23
|
<span class="muted">
|
@@ -1,5 +1,5 @@
|
|
1
1
|
<div class="conversation-chat<%= " conversation-chat--offset" if sender_is_user?(sender) %>">
|
2
|
-
<%= link_to sender.
|
2
|
+
<%= link_to profile_path(sender.nickname) do %>
|
3
3
|
<%= image_tag sender.avatar_url, alt: t("decidim.author.avatar") %>
|
4
4
|
<% end %>
|
5
5
|
<div>
|
@@ -15,12 +15,12 @@
|
|
15
15
|
<%= icon "chevron-left", role: "img", aria_label: t(".back") %>
|
16
16
|
<% end %>
|
17
17
|
</div>
|
18
|
-
|
19
|
-
|
18
|
+
<% if participants.count == 1 %>
|
19
|
+
<%= link_to profile_path(participants.first.nickname) do %>
|
20
20
|
<%= image_tag participants.first.avatar_url, alt: t("decidim.author.avatar") %>
|
21
|
-
<% else %>
|
22
|
-
<%= image_tag current_user.avatar.default_multiuser_url, alt: t("decidim.author.avatar") %>
|
23
21
|
<% end %>
|
22
|
+
<% else %>
|
23
|
+
<%= image_tag current_user.avatar.default_multiuser_url, alt: t("decidim.author.avatar") %>
|
24
24
|
<% end %>
|
25
25
|
|
26
26
|
<div class="ml-s">
|
@@ -46,6 +46,17 @@
|
|
46
46
|
</label>
|
47
47
|
</div>
|
48
48
|
|
49
|
+
<% if @notifications_settings.user_is_moderator?(current_user) %>
|
50
|
+
<p><strong><%= t(".administrators") %></strong></p>
|
51
|
+
<div class="switch tiny switch-with-label email_on_moderations">
|
52
|
+
<label>
|
53
|
+
<%= f.check_box :email_on_moderations, label: false, class: "switch-input" %>
|
54
|
+
<span class="switch-paddle"></span>
|
55
|
+
<span class="switch-label"><%= t(".email_on_moderations") %></span>
|
56
|
+
</label>
|
57
|
+
</div>
|
58
|
+
<% end %>
|
59
|
+
|
49
60
|
<%= f.submit t(".update_notifications_settings") %>
|
50
61
|
<% end %>
|
51
62
|
</div>
|
@@ -10,7 +10,7 @@
|
|
10
10
|
<p><%= l @report.created_at, format: :short %></p>
|
11
11
|
|
12
12
|
<p><b><%= t(".participatory_space") %></b></p>
|
13
|
-
<p><%= translated_attribute
|
13
|
+
<p><%= link_to translated_attribute(@participatory_space.title), resource_locator(@participatory_space).url %></p>
|
14
14
|
|
15
15
|
<p><b><%= t(".reason") %></b></p>
|
16
16
|
<p><%= t(@report.reason, organization_name: @participatory_space.organization.name, scope: "decidim.shared.flag_modal") %></p>
|
@@ -22,14 +22,14 @@
|
|
22
22
|
</blockquote>
|
23
23
|
<% end %>
|
24
24
|
|
25
|
-
<% if @
|
26
|
-
<p><b><%= t(".
|
27
|
-
<
|
28
|
-
<h5><%= translated_attribute @content[:title] %></h5>
|
29
|
-
<p><%= translated_attribute @content[:body] %></p>
|
30
|
-
</blockquote>
|
25
|
+
<% if @original_language.present? %>
|
26
|
+
<p><b><%= t(".content_original_language") %></b></p>
|
27
|
+
<p><%= I18n.t("locale.name", locale: @original_language) %></p>
|
31
28
|
<% end %>
|
32
29
|
|
30
|
+
<p><b><%= t(".content") %></b> (<%= t(".id") %>: <%= @reportable.id %>)</p>
|
31
|
+
<%= reported_content_cell %>
|
32
|
+
|
33
33
|
<% if @author.present? %>
|
34
34
|
<p><b><%= t(".authors") %></b></p>
|
35
35
|
<% if author_profile_url.present? %>
|
@@ -46,7 +46,7 @@
|
|
46
46
|
<table>
|
47
47
|
<tr>
|
48
48
|
<td>
|
49
|
-
<%= link_to t(".
|
49
|
+
<%= link_to t(".see_report"), report_url, class: "button", target: "_blank" %>
|
50
50
|
</td>
|
51
51
|
</tr>
|
52
52
|
</table>
|