decidim-core 0.23.5 → 0.24.2
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 +2 -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 +90 -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 +123 -0
- data/app/assets/javascripts/decidim/form_filter.component.js.es6 +25 -0
- data/app/assets/javascripts/decidim/gallery.js.es6 +5 -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 +40 -10
- 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/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_cell.rb +11 -8
- data/app/cells/decidim/announcement/show.erb +4 -4
- data/app/cells/decidim/announcement_cell.rb +43 -8
- 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/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 -1
- data/app/cells/decidim/tos_page/form.erb +15 -13
- 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/create_report.rb +11 -1
- data/app/commands/decidim/create_user_report.rb +67 -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 +2 -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/paginable.rb +8 -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 +2 -2
- 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 +2 -2
- data/app/helpers/decidim/cache_helper.rb +14 -0
- data/app/helpers/decidim/cells_helper.rb +6 -0
- data/app/helpers/decidim/filters_helper.rb +9 -0
- data/app/helpers/decidim/messaging/conversation_helper.rb +11 -1
- data/app/helpers/decidim/newsletters_helper.rb +7 -9
- data/app/helpers/decidim/scopes_helper.rb +1 -1
- data/app/jobs/decidim/block_user_job.rb +11 -0
- 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/update_search_indexes_job.rb +11 -0
- data/app/jobs/decidim/user_report_job.rb +11 -0
- data/app/mailers/concerns/decidim/localised_mailer.rb +4 -2
- data/app/mailers/decidim/block_user_mailer.rb +21 -0
- data/app/mailers/decidim/notification_mailer.rb +0 -2
- 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/follow.rb +1 -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 +5 -1
- 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 +19 -2
- data/app/models/decidim/user_base_entity.rb +13 -13
- data/app/models/decidim/user_block.rb +10 -0
- data/app/models/decidim/user_group.rb +5 -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/impersonation_log_presenter.rb +39 -0
- data/app/presenters/decidim/admin_log/organization_presenter.rb +1 -2
- data/app/presenters/decidim/admin_log/user_moderation_presenter.rb +63 -0
- data/app/presenters/decidim/admin_log/user_presenter.rb +18 -9
- data/app/presenters/decidim/home_stats_presenter.rb +3 -3
- 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/queries/decidim/user_groups/accepted_memberships.rb +1 -1
- data/app/queries/decidim/user_groups/admin_memberships.rb +1 -1
- data/app/queries/decidim/user_groups/member_memberships.rb +1 -1
- 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/zip_stream/zip_stream_writer.rb +3 -3
- data/app/uploaders/decidim/application_uploader.rb +22 -2
- 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/application/_document.html.erb +1 -1
- 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/notifications_settings/show.html.erb +11 -0
- data/app/views/decidim/pages/_standalone.html.erb +3 -1
- data/app/views/decidim/reported_mailer/report.html.erb +17 -9
- 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 +79 -14
- data/config/locales/cs.yml +83 -18
- data/config/locales/de.yml +78 -17
- data/config/locales/el.yml +1 -20
- data/config/locales/en.yml +81 -16
- data/config/locales/eo.yml +0 -1
- data/config/locales/es-MX.yml +79 -14
- data/config/locales/es-PY.yml +79 -14
- data/config/locales/es.yml +79 -14
- data/config/locales/eu.yml +1 -9
- data/config/locales/fi-plain.yml +78 -14
- data/config/locales/fi.yml +78 -14
- data/config/locales/fr-CA.yml +79 -18
- data/config/locales/fr.yml +76 -15
- data/config/locales/gl.yml +5 -17
- data/config/locales/hu.yml +1 -14
- data/config/locales/id-ID.yml +1 -9
- data/config/locales/is-IS.yml +0 -2
- data/config/locales/it.yml +65 -18
- data/config/locales/ja.yml +1 -19
- data/config/locales/lv.yml +1 -14
- data/config/locales/nl.yml +40 -17
- data/config/locales/no.yml +7 -20
- data/config/locales/pl.yml +78 -19
- data/config/locales/pt-BR.yml +1 -9
- data/config/locales/pt.yml +1 -20
- data/config/locales/ro-RO.yml +64 -18
- data/config/locales/ru.yml +1 -10
- data/config/locales/sk.yml +1 -14
- data/config/locales/sr-CS.yml +0 -9
- data/config/locales/sv.yml +67 -14
- data/config/locales/tr-TR.yml +62 -17
- data/config/locales/uk.yml +1 -7
- data/config/locales/zh-CN.yml +1 -19
- 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/20210310120640_add_followable_counter_cache_to_users.rb +16 -0
- data/db/seeds.rb +14 -13
- 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 +35 -6
- data/lib/decidim/core/test.rb +2 -1
- data/lib/decidim/core/test/factories.rb +53 -15
- 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 +33 -0
- data/lib/decidim/core/test/shared_examples/follows_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/localised_email.rb +8 -0
- 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 +4 -3
- 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/followable.rb +6 -1
- data/lib/decidim/form_builder.rb +33 -22
- 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 +1 -1
- 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/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 +4 -4
- 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 +193 -100
- 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
- data/lib/decidim/core/test/shared_examples/user_localised_email_examples.rb +0 -25
@@ -59,7 +59,7 @@ shared_examples "admin manages resource gallery" do
|
|
59
59
|
let!(:image1) { create(:attachment, :with_image, attached_to: resource) }
|
60
60
|
let!(:image2) { create(:attachment, :with_image, attached_to: resource) }
|
61
61
|
let(:uploaded_photos) { [] }
|
62
|
-
let(:current_photos) { [image1
|
62
|
+
let(:current_photos) { [image1] }
|
63
63
|
|
64
64
|
it "to decrease the number of photos in the gallery" do
|
65
65
|
expect(resource.attachments.count).to eq(2)
|
@@ -37,7 +37,7 @@ shared_examples "amendment accepted event" do
|
|
37
37
|
describe "notification_title" do
|
38
38
|
it "is generated correctly" do
|
39
39
|
expect(subject.notification_title)
|
40
|
-
.to eq("The <a href=\"#{emendation_path}\">amendment</a> created by <a href=\"#{emendation_author_path}\">#{emendation_author_nickname}</a> has been accepted for <a href=\"#{amendable_path}\">#{amendable_title}</a>.") # rubocop:disable
|
40
|
+
.to eq("The <a href=\"#{emendation_path}\">amendment</a> created by <a href=\"#{emendation_author_path}\">#{emendation_author_nickname}</a> has been accepted for <a href=\"#{amendable_path}\">#{amendable_title}</a>.") # rubocop:disable Layout/LineLength
|
41
41
|
end
|
42
42
|
end
|
43
43
|
end
|
@@ -37,7 +37,7 @@ shared_examples "amendment promoted event" do
|
|
37
37
|
describe "notification_title" do
|
38
38
|
it "is generated correctly" do
|
39
39
|
expect(subject.notification_title)
|
40
|
-
.to eq("A <a href=\"#{emendation_path}\">rejected amendment</a> for <a href=\"#{amendable_path}\">#{amendable_title}</a> has been published as a new #{amendable_type} by <a href=\"#{emendation_author_path}\">#{emendation_author_nickname}</a>.") # rubocop:disable
|
40
|
+
.to eq("A <a href=\"#{emendation_path}\">rejected amendment</a> for <a href=\"#{amendable_path}\">#{amendable_title}</a> has been published as a new #{amendable_type} by <a href=\"#{emendation_author_path}\">#{emendation_author_nickname}</a>.") # rubocop:disable Layout/LineLength
|
41
41
|
end
|
42
42
|
end
|
43
43
|
end
|
@@ -37,7 +37,7 @@ shared_examples "amendment rejected event" do
|
|
37
37
|
describe "notification_title" do
|
38
38
|
it "is generated correctly" do
|
39
39
|
expect(subject.notification_title)
|
40
|
-
.to eq("The <a href=\"#{emendation_path}\">amendment</a> created by <a href=\"#{emendation_author_path}\">#{emendation_author_nickname}</a> has been rejected for <a href=\"#{amendable_path}\">#{amendable_title}</a>.") # rubocop:disable
|
40
|
+
.to eq("The <a href=\"#{emendation_path}\">amendment</a> created by <a href=\"#{emendation_author_path}\">#{emendation_author_nickname}</a> has been rejected for <a href=\"#{amendable_path}\">#{amendable_title}</a>.") # rubocop:disable Layout/LineLength
|
41
41
|
end
|
42
42
|
end
|
43
43
|
end
|
@@ -97,13 +97,14 @@ shared_examples "comments" do
|
|
97
97
|
context "when user adds a new comment" do
|
98
98
|
before do
|
99
99
|
within ".add-comment form" do
|
100
|
-
fill_in "add-comment-#{commentable.commentable_type}-#{commentable.id}", with: "This is a new comment"
|
100
|
+
fill_in "add-comment-#{commentable.commentable_type.demodulize}-#{commentable.id}", with: "This is a new comment"
|
101
101
|
click_button "Send"
|
102
102
|
end
|
103
103
|
end
|
104
104
|
|
105
|
-
it "shows comment to the user" do
|
105
|
+
it "shows comment to the user and updates the comments counter" do
|
106
106
|
expect(page).to have_comment_from(user, "This is a new comment", wait: 20)
|
107
|
+
expect(page).to have_selector("span.comments-count", text: "#{commentable.comments.count} COMMENTS")
|
107
108
|
end
|
108
109
|
end
|
109
110
|
|
@@ -120,7 +121,7 @@ shared_examples "comments" do
|
|
120
121
|
expect(page).to have_selector(".add-comment form")
|
121
122
|
|
122
123
|
within ".add-comment form" do
|
123
|
-
fill_in "add-comment-#{commentable.commentable_type}-#{commentable.id}", with: "This is a new comment"
|
124
|
+
fill_in "add-comment-#{commentable.commentable_type.demodulize}-#{commentable.id}", with: "This is a new comment"
|
124
125
|
select user_group.name, from: "Comment as"
|
125
126
|
click_button "Send"
|
126
127
|
end
|
@@ -144,7 +145,7 @@ shared_examples "comments" do
|
|
144
145
|
end
|
145
146
|
|
146
147
|
expect(page).to have_selector("#comment_#{comment.id} .add-comment")
|
147
|
-
fill_in "add-comment-
|
148
|
+
fill_in "add-comment-Comment-#{comment.id}", with: "This is a reply"
|
148
149
|
within ".comment-thread .add-comment" do
|
149
150
|
click_button "Send"
|
150
151
|
end
|
@@ -152,6 +153,7 @@ shared_examples "comments" do
|
|
152
153
|
expect(page).to have_selector(".comment-thread .comment--nested", wait: 20)
|
153
154
|
expect(page).to have_selector(".comment__additionalreply")
|
154
155
|
expect(page).to have_reply_to(comment, "This is a reply")
|
156
|
+
expect(page).to have_selector("span.comments-count", text: "#{commentable.comments.count} COMMENTS")
|
155
157
|
end
|
156
158
|
end
|
157
159
|
|
@@ -184,7 +186,7 @@ shared_examples "comments" do
|
|
184
186
|
page.find(".opinion-toggle--ok").click
|
185
187
|
|
186
188
|
within ".add-comment form" do
|
187
|
-
fill_in "add-comment-#{commentable.commentable_type}-#{commentable.id}", with: "I am in favor about this!"
|
189
|
+
fill_in "add-comment-#{commentable.commentable_type.demodulize}-#{commentable.id}", with: "I am in favor about this!"
|
188
190
|
click_button "Send"
|
189
191
|
end
|
190
192
|
|
@@ -237,7 +239,7 @@ shared_examples "comments" do
|
|
237
239
|
visit resource_path
|
238
240
|
|
239
241
|
within ".add-comment form" do
|
240
|
-
fill_in "add-comment-#{commentable.commentable_type}-#{commentable.id}", with: content
|
242
|
+
fill_in "add-comment-#{commentable.commentable_type.demodulize}-#{commentable.id}", with: content
|
241
243
|
end
|
242
244
|
end
|
243
245
|
|
@@ -284,7 +286,7 @@ shared_examples "comments" do
|
|
284
286
|
visit resource_path
|
285
287
|
|
286
288
|
within ".add-comment form" do
|
287
|
-
fill_in "add-comment-#{commentable.commentable_type}-#{commentable.id}", with: content
|
289
|
+
fill_in "add-comment-#{commentable.commentable_type.demodulize.demodulize}-#{commentable.id}", with: content
|
288
290
|
click_button "Send"
|
289
291
|
end
|
290
292
|
end
|
@@ -296,7 +298,7 @@ shared_examples "comments" do
|
|
296
298
|
|
297
299
|
it "replaces the mention with a link to the user's profile" do
|
298
300
|
expect(page).to have_comment_from(user, "A valid user mention: @#{mentioned_user.nickname}", wait: 20)
|
299
|
-
expect(page).to have_link "@#{mentioned_user.nickname}", href: "/profiles/#{mentioned_user.nickname}"
|
301
|
+
expect(page).to have_link "@#{mentioned_user.nickname}", href: "http://#{mentioned_user.organization.host}/profiles/#{mentioned_user.nickname}"
|
300
302
|
end
|
301
303
|
end
|
302
304
|
|
@@ -327,7 +329,7 @@ shared_examples "comments" do
|
|
327
329
|
visit resource_path
|
328
330
|
|
329
331
|
within ".add-comment form" do
|
330
|
-
fill_in "add-comment-#{commentable.commentable_type}-#{commentable.id}", with: content
|
332
|
+
fill_in "add-comment-#{commentable.commentable_type.demodulize}-#{commentable.id}", with: content
|
331
333
|
click_button "Send"
|
332
334
|
end
|
333
335
|
end
|
@@ -0,0 +1,33 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
shared_context "with controller rendering the view" do
|
4
|
+
# Fix "No route matches" errors with the view.
|
5
|
+
before do
|
6
|
+
controller.view_context_class.class_eval do
|
7
|
+
# Needed for the form_for to work (through decidim_form_for)
|
8
|
+
# The path shouldn't matter in the controller specs.
|
9
|
+
def polymorphic_path(_record, _options)
|
10
|
+
"/"
|
11
|
+
end
|
12
|
+
|
13
|
+
# Needed for the head and link_to helpers to work
|
14
|
+
# The URL shouldn't matter in the controller specs.
|
15
|
+
def url_for(_options)
|
16
|
+
"/"
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
after do
|
22
|
+
# Ensure that the customized view context class is not being kept in the
|
23
|
+
# cache variable. Otherwise we might mess up the following specs using the
|
24
|
+
# same controller in the same run.
|
25
|
+
controller.class.remove_instance_variable(:@view_context_class)
|
26
|
+
end
|
27
|
+
|
28
|
+
# Rendering of the view is necessary to see the view renders correctly
|
29
|
+
# when there are errors on the form. This is hard to test with a
|
30
|
+
# system test because there is some JS blocking us to submit the form
|
31
|
+
# with errors (e.g. too short title).
|
32
|
+
render_views
|
33
|
+
end
|
@@ -44,7 +44,7 @@ shared_examples "follows" do
|
|
44
44
|
it "makes the user follow the followable" do
|
45
45
|
visit followable_path
|
46
46
|
expect do
|
47
|
-
click_button "
|
47
|
+
click_button "Following #{translated(followable.participatory_space.title)}"
|
48
48
|
expect(page).to have_content "Stop following"
|
49
49
|
end.to change(Decidim::Follow, :count).by(1)
|
50
50
|
end
|
@@ -22,4 +22,12 @@ shared_examples "localised email" do
|
|
22
22
|
expect(mail.body.encoded).to match(default_body)
|
23
23
|
end
|
24
24
|
end
|
25
|
+
|
26
|
+
context "when the user doesn't have an email" do
|
27
|
+
let(:user) { create(:user, :deleted) }
|
28
|
+
|
29
|
+
it "does nothing" do
|
30
|
+
expect(mail.deliver_now).to be_nil
|
31
|
+
end
|
32
|
+
end
|
25
33
|
end
|
@@ -14,7 +14,7 @@ shared_examples "email with logo" do
|
|
14
14
|
|
15
15
|
it "includes organization logo with full link" do
|
16
16
|
expect(mail.body).to include("alt=\"#{organization.name}\"")
|
17
|
-
expect(mail.body).to match(%r{
|
17
|
+
expect(mail.body).to match(%r{https{0,1}://#{organization.host}#{organization.logo.medium.url}})
|
18
18
|
end
|
19
19
|
end
|
20
20
|
end
|
@@ -26,7 +26,7 @@ shared_context "with frontend map builder" do
|
|
26
26
|
let(:organization) { create(:organization) }
|
27
27
|
let(:template) { template_class.new }
|
28
28
|
let(:options) { {} }
|
29
|
-
let(:js_options) { options.
|
29
|
+
let(:js_options) { options.transform_keys { |k| k.to_s.camelize(:lower) }.to_h }
|
30
30
|
|
31
31
|
before do
|
32
32
|
allow(template).to receive(:current_organization).and_return(organization)
|
@@ -3,7 +3,7 @@
|
|
3
3
|
shared_examples "manage processes announcements" do
|
4
4
|
let!(:participatory_process) { create(:participatory_process, organization: organization) }
|
5
5
|
|
6
|
-
it "customize
|
6
|
+
it "can customize a general announcement for the process" do
|
7
7
|
click_link translated(participatory_process.title)
|
8
8
|
|
9
9
|
fill_in_i18n_editor(
|
@@ -29,6 +29,10 @@ shared_examples_for "reportable" do
|
|
29
29
|
context "when the resource has been hidden" do
|
30
30
|
let(:moderation) { create(:moderation, reportable: subject, participatory_space: participatory_space, report_count: 1, hidden_at: Time.current) }
|
31
31
|
|
32
|
+
before do
|
33
|
+
subject.reload
|
34
|
+
end
|
35
|
+
|
32
36
|
it { expect(subject).to be_hidden }
|
33
37
|
end
|
34
38
|
end
|
@@ -42,6 +46,10 @@ shared_examples_for "reportable" do
|
|
42
46
|
end
|
43
47
|
|
44
48
|
context "when the report count is greater than 0" do
|
49
|
+
before do
|
50
|
+
subject.reload
|
51
|
+
end
|
52
|
+
|
45
53
|
it { expect(subject).to be_reported }
|
46
54
|
end
|
47
55
|
end
|
@@ -9,7 +9,7 @@ shared_examples "having a rich text editor" do |css, toolbar|
|
|
9
9
|
end
|
10
10
|
|
11
11
|
shared_context "with rich text editor content" do
|
12
|
-
let(:content) { "<p
|
12
|
+
let(:content) { "<p>#{safe_tags}</p>#{script}" }
|
13
13
|
let(:safe_tags) { em + u + strong }
|
14
14
|
let(:em) { "<em>em</em>" }
|
15
15
|
let(:u) { "<u>u</u>" }
|
@@ -36,7 +36,7 @@ shared_examples "global search of participatory spaces" do
|
|
36
36
|
it "updates the associated SearchableResource after published ParticipatorySpace update" do
|
37
37
|
searchable = ::Decidim::SearchableResource.find_by(resource_type: participatory_space.class.name, resource_id: participatory_space.id)
|
38
38
|
created_at = searchable.created_at
|
39
|
-
updated_title = { "en" => "Brand new title" }
|
39
|
+
updated_title = { "en" => "Brand new title", "machine_translations" => {} }
|
40
40
|
participatory_space.update(title: updated_title)
|
41
41
|
|
42
42
|
participatory_space.save!
|
@@ -130,7 +130,7 @@ shared_examples "global search of participatory spaces" do
|
|
130
130
|
end
|
131
131
|
|
132
132
|
def expected_searchable_resource_attrs(space, locale)
|
133
|
-
|
133
|
+
{
|
134
134
|
"locale" => locale,
|
135
135
|
"decidim_organization_id" => space.organization.id,
|
136
136
|
"decidim_participatory_space_id" => space.id,
|
@@ -139,6 +139,5 @@ shared_examples "global search of participatory spaces" do
|
|
139
139
|
"resource_id" => space.id,
|
140
140
|
"resource_type" => space.class.name
|
141
141
|
}.merge(searchable_resource_attrs_mapper.call(space, locale))
|
142
|
-
h
|
143
142
|
end
|
144
143
|
end
|
@@ -36,5 +36,51 @@ shared_examples "searchable results" do
|
|
36
36
|
end
|
37
37
|
end
|
38
38
|
end
|
39
|
+
|
40
|
+
context "when participatory space is not visible" do
|
41
|
+
shared_examples_for "no searchs found" do
|
42
|
+
it "not contains these searchables" do
|
43
|
+
expect(searchables).not_to be_empty
|
44
|
+
expect(term).not_to be_empty
|
45
|
+
|
46
|
+
fill_in "term", with: term
|
47
|
+
find("input#term").native.send_keys :enter
|
48
|
+
|
49
|
+
expect(page).to have_current_path decidim.search_path, ignore_query: true
|
50
|
+
expect(page).to have_content(/results for the search: "#{term}"/i)
|
51
|
+
expect(page).to have_selector(".filters__section")
|
52
|
+
expect(page.find("#search-count .section-heading").text.to_i).not_to be_positive
|
53
|
+
end
|
54
|
+
|
55
|
+
it "doesn't find content by hashtag" do
|
56
|
+
if respond_to?(:hashtag)
|
57
|
+
fill_in "term", with: hashtag
|
58
|
+
find("input#term").native.send_keys :enter
|
59
|
+
|
60
|
+
expect(page.find("#search-count .section-heading").text.to_i).not_to be_positive
|
61
|
+
|
62
|
+
within "#results" do
|
63
|
+
expect(page).not_to have_content(hashtag)
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
68
|
+
|
69
|
+
context "when participatory space is unpublished" do
|
70
|
+
before do
|
71
|
+
perform_enqueued_jobs { participatory_space.update!(published_at: nil) }
|
72
|
+
end
|
73
|
+
|
74
|
+
it_behaves_like "no searchs found"
|
75
|
+
end
|
76
|
+
|
77
|
+
context "when participatory space is private" do
|
78
|
+
before do
|
79
|
+
perform_enqueued_jobs { participatory_space.update!(private_space: true) }
|
80
|
+
end
|
81
|
+
|
82
|
+
it_behaves_like "no searchs found"
|
83
|
+
end
|
84
|
+
end
|
39
85
|
end
|
40
86
|
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "spec_helper"
|
4
|
+
|
5
|
+
shared_examples "accessible static pages" do
|
6
|
+
let(:organization) do
|
7
|
+
create(
|
8
|
+
:organization,
|
9
|
+
create_static_pages: false,
|
10
|
+
force_users_to_authenticate_before_access_organization: true
|
11
|
+
)
|
12
|
+
end
|
13
|
+
let!(:public_pages) { create_list(:static_page, 5, organization: organization, allow_public_access: true) }
|
14
|
+
let!(:private_pages) { create_list(:static_page, 5, organization: organization) }
|
15
|
+
let(:actual_page_ids) { [] }
|
16
|
+
|
17
|
+
def expect_correct_accessible_static_pages
|
18
|
+
expect(actual_page_ids).to match_array(expected_page_ids)
|
19
|
+
end
|
20
|
+
|
21
|
+
context "with a user" do
|
22
|
+
let(:user) { create(:user, organization: organization) }
|
23
|
+
let(:expected_page_ids) { public_pages.pluck(:id) + private_pages.pluck(:id) }
|
24
|
+
|
25
|
+
it { expect_correct_accessible_static_pages }
|
26
|
+
end
|
27
|
+
|
28
|
+
context "without a user" do
|
29
|
+
let(:user) { nil }
|
30
|
+
let(:expected_page_ids) { public_pages.pluck(:id) }
|
31
|
+
|
32
|
+
it { expect_correct_accessible_static_pages }
|
33
|
+
|
34
|
+
context "when the organization does not force users to authenticate" do
|
35
|
+
let(:organization) { create(:organization, create_static_pages: false) }
|
36
|
+
let(:expected_page_ids) do
|
37
|
+
public_pages.pluck(:id) + private_pages.pluck(:id)
|
38
|
+
end
|
39
|
+
|
40
|
+
it { expect_correct_accessible_static_pages }
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
data/lib/decidim/core/version.rb
CHANGED
@@ -36,11 +36,11 @@ module Decidim
|
|
36
36
|
end
|
37
37
|
|
38
38
|
def unescaped_split_left
|
39
|
-
@diff.gsub(%r{<li class="ins">([\s\S]*?)
|
39
|
+
@diff.gsub(%r{<li class="ins">([\s\S]*?)</li>}, "")
|
40
40
|
end
|
41
41
|
|
42
42
|
def unescaped_split_right
|
43
|
-
@diff.gsub(%r{<li class="del">([\s\S]*?)
|
43
|
+
@diff.gsub(%r{<li class="del">([\s\S]*?)</li>}, "")
|
44
44
|
end
|
45
45
|
end
|
46
46
|
end
|
@@ -43,7 +43,7 @@ module Decidim
|
|
43
43
|
def headers
|
44
44
|
return [] if processed_collection.empty?
|
45
45
|
|
46
|
-
processed_collection.
|
46
|
+
processed_collection.inject([]) { |keys, resource| keys | resource.keys }
|
47
47
|
end
|
48
48
|
|
49
49
|
def processed_collection
|
@@ -53,12 +53,13 @@ module Decidim
|
|
53
53
|
end
|
54
54
|
|
55
55
|
def flatten(object, key = nil)
|
56
|
-
|
56
|
+
case object
|
57
|
+
when Hash
|
57
58
|
object.inject({}) do |result, (subkey, value)|
|
58
59
|
new_key = key ? "#{key}/#{subkey}" : subkey.to_s
|
59
60
|
result.merge(flatten(value, new_key))
|
60
61
|
end
|
61
|
-
|
62
|
+
when Array
|
62
63
|
{ key.to_s => object.compact.map(&:to_s).join(", ") }
|
63
64
|
else
|
64
65
|
{ key.to_s => object }
|
@@ -28,7 +28,7 @@ module Decidim
|
|
28
28
|
# Returns a String with the filename of the export.
|
29
29
|
def filename(prefix = "export", options = {})
|
30
30
|
options[:extension] = !options[:extension].nil? ? options[:extension] : true
|
31
|
-
result = "#{prefix}-#{I18n.
|
31
|
+
result = "#{prefix}-#{I18n.l(Time.zone.today, format: :default)}-#{Time.now.seconds_since_midnight.to_i}"
|
32
32
|
result += ".#{extension}" if options[:extension]
|
33
33
|
result
|
34
34
|
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "faker"
|
4
|
+
|
5
|
+
module Decidim
|
6
|
+
module Faker
|
7
|
+
# A Custom Faker wrapper to modify Faker::Internet#slug
|
8
|
+
class Internet < ::Faker::Internet
|
9
|
+
# Fakes a slug, using EN locale to allow ASCII only
|
10
|
+
def self.slug(...)
|
11
|
+
with_locale(:en) do
|
12
|
+
::Faker::Internet.slug(...)
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|