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
@@ -116,7 +116,7 @@ module Decidim
|
|
116
116
|
return content if content.blank?
|
117
117
|
|
118
118
|
Decidim.content_processors.reduce(content) do |result, type|
|
119
|
-
renderer_klass(type).constantize.new(result).render(options)
|
119
|
+
renderer_klass(type).constantize.new(result).render(**options)
|
120
120
|
end
|
121
121
|
end
|
122
122
|
|
@@ -10,7 +10,7 @@ module Decidim
|
|
10
10
|
# @see BaseRenderer Examples of how to use a content renderer
|
11
11
|
class HashtagRenderer < BaseRenderer
|
12
12
|
# Matches a global id representing a Decidim::Hashtag
|
13
|
-
GLOBAL_ID_REGEX = %r{gid
|
13
|
+
GLOBAL_ID_REGEX = %r{gid://[\w-]*/Decidim::Hashtag/(\d+)/?(_?)([[:alnum:]](?:[[:alnum:]]|_)*)?\b}.freeze
|
14
14
|
|
15
15
|
# Replaces found Global IDs matching an existing hashtag with
|
16
16
|
# a link to their detail page. The Global IDs representing an
|
@@ -47,11 +47,8 @@ module Decidim
|
|
47
47
|
private
|
48
48
|
|
49
49
|
def hashtags
|
50
|
-
@hashtags ||=
|
51
|
-
existing_hashtags.
|
52
|
-
[hashtag.id, hashtag]
|
53
|
-
end
|
54
|
-
]
|
50
|
+
@hashtags ||=
|
51
|
+
existing_hashtags.index_by(&:id)
|
55
52
|
end
|
56
53
|
|
57
54
|
def existing_hashtags
|
data/lib/decidim/core.rb
CHANGED
@@ -20,6 +20,7 @@ module Decidim
|
|
20
20
|
autoload :Traceable, "decidim/traceable"
|
21
21
|
autoload :Loggable, "decidim/loggable"
|
22
22
|
autoload :Reportable, "decidim/reportable"
|
23
|
+
autoload :UserReportable, "decidim/user_reportable"
|
23
24
|
autoload :Authorable, "decidim/authorable"
|
24
25
|
autoload :Coauthorable, "decidim/coauthorable"
|
25
26
|
autoload :Participable, "decidim/participable"
|
@@ -92,6 +93,8 @@ module Decidim
|
|
92
93
|
autoload :HasUploadValidations, "decidim/has_upload_validations"
|
93
94
|
autoload :FileValidatorHumanizer, "decidim/file_validator_humanizer"
|
94
95
|
autoload :ShareableWithToken, "decidim/shareable_with_token"
|
96
|
+
autoload :RecordEncryptor, "decidim/record_encryptor"
|
97
|
+
autoload :AttachmentAttributes, "decidim/attachment_attributes"
|
95
98
|
|
96
99
|
include ActiveSupport::Configurable
|
97
100
|
# Loads seeds from all engines.
|
@@ -115,7 +118,7 @@ module Decidim
|
|
115
118
|
organization,
|
116
119
|
manifest.name,
|
117
120
|
Decidim::Faker::Localized.wrapped("<p>", "</p>") do
|
118
|
-
Decidim::Faker::Localized.sentence(15)
|
121
|
+
Decidim::Faker::Localized.sentence(word_count: 15)
|
119
122
|
end
|
120
123
|
)
|
121
124
|
end
|
@@ -149,7 +152,7 @@ module Decidim
|
|
149
152
|
|
150
153
|
# Exposes a configuration option: The application available locales.
|
151
154
|
config_accessor :available_locales do
|
152
|
-
%w(en bg ar ca cs da de el eo es es-MX es-PY et eu fi-pl fi fr fr-CA ga gl hr hu id is it ja lt lv mt nl no pl pt pt-BR ro ru sk sl sr sv tr uk)
|
155
|
+
%w(en bg ar ca cs da de el eo es es-MX es-PY et eu fi-pl fi fr fr-CA ga gl hr hu id is it ja ko lt lv mt nl no pl pt pt-BR ro ru sk sl sr sv tr uk vi zh-CN zh-TW)
|
153
156
|
end
|
154
157
|
|
155
158
|
# Exposes a configuration option: The application default locale.
|
@@ -357,6 +360,11 @@ module Decidim
|
|
357
360
|
"decidim-cc"
|
358
361
|
end
|
359
362
|
|
363
|
+
# Defines how often session_timeouter.js checks time between current moment and last request
|
364
|
+
config_accessor :session_timeouter_interval do
|
365
|
+
10_000
|
366
|
+
end
|
367
|
+
|
360
368
|
# Public: Registers a global engine. This method is intended to be used
|
361
369
|
# by component engines that also offer unscoped functionality
|
362
370
|
#
|
@@ -556,7 +564,7 @@ module Decidim
|
|
556
564
|
organization = begin
|
557
565
|
if model.is_a?(Decidim::Organization)
|
558
566
|
model
|
559
|
-
elsif model.respond_to?(:organization)
|
567
|
+
elsif model.respond_to?(:organization) && model.organization.present?
|
560
568
|
model.organization
|
561
569
|
end
|
562
570
|
end
|
data/lib/decidim/core/api.rb
CHANGED
@@ -2,21 +2,76 @@
|
|
2
2
|
|
3
3
|
module Decidim
|
4
4
|
module Core
|
5
|
-
autoload :
|
6
|
-
autoload :
|
7
|
-
autoload :
|
8
|
-
autoload :
|
9
|
-
autoload :
|
10
|
-
autoload :
|
11
|
-
autoload :
|
12
|
-
autoload :
|
13
|
-
autoload :
|
14
|
-
|
15
|
-
autoload :
|
16
|
-
autoload :
|
17
|
-
autoload :
|
18
|
-
autoload :
|
19
|
-
autoload :
|
20
|
-
autoload :
|
5
|
+
autoload :ComponentFinderBase, "decidim/api/functions/component_finder_base"
|
6
|
+
autoload :ComponentList, "decidim/api/functions/component_list"
|
7
|
+
autoload :ComponentListBase, "decidim/api/functions/component_list_base"
|
8
|
+
autoload :NeedsApiFilterAndOrder, "decidim/api/functions/needs_api_filter_and_order"
|
9
|
+
autoload :NeedsApiDefaultOrder, "decidim/api/functions/needs_api_default_order"
|
10
|
+
autoload :ParticipatorySpaceFinderBase, "decidim/api/functions/participatory_space_finder_base"
|
11
|
+
autoload :ParticipatorySpaceListBase, "decidim/api/functions/participatory_space_list_base"
|
12
|
+
autoload :UserEntityFinder, "decidim/api/functions/user_entity_finder"
|
13
|
+
autoload :UserEntityList, "decidim/api/functions/user_entity_list"
|
14
|
+
|
15
|
+
autoload :AmendmentType, "decidim/api/types/amendment_type"
|
16
|
+
autoload :AreaApiType, "decidim/api/types/area_api_type"
|
17
|
+
autoload :AreaTypeType, "decidim/api/types/area_type_type"
|
18
|
+
autoload :AttachmentType, "decidim/api/types/attachment_type"
|
19
|
+
autoload :CategoryType, "decidim/api/types/category_type"
|
20
|
+
autoload :ComponentType, "decidim/api/types/component_type"
|
21
|
+
autoload :CoordinatesType, "decidim/api/types/coordinates_type"
|
22
|
+
autoload :DecidimType, "decidim/api/types/decidim_type"
|
23
|
+
autoload :FingerprintType, "decidim/api/types/fingerprint_type"
|
24
|
+
autoload :HashtagType, "decidim/api/types/hashtag_type"
|
25
|
+
autoload :LocalizedStringType, "decidim/api/types/localized_string_type"
|
26
|
+
autoload :MetricHistoryType, "decidim/api/types/metric_history_type"
|
27
|
+
autoload :MetricType, "decidim/api/types/metric_type"
|
28
|
+
autoload :OrganizationType, "decidim/api/types/organization_type"
|
29
|
+
autoload :ParticipatorySpaceType, "decidim/api/types/participatory_space_type"
|
30
|
+
autoload :ParticipatorySpaceLinkType, "decidim/api/types/participatory_space_link_type"
|
31
|
+
autoload :ScopeApiType, "decidim/api/types/scope_api_type"
|
32
|
+
autoload :SessionType, "decidim/api/types/session_type"
|
33
|
+
autoload :StatisticType, "decidim/api/types/statistic_type"
|
34
|
+
autoload :TraceVersionType, "decidim/api/types/trace_version_type"
|
35
|
+
autoload :TranslatedFieldType, "decidim/api/types/translated_field_type"
|
36
|
+
autoload :UserGroupType, "decidim/api/types/user_group_type"
|
37
|
+
autoload :UserType, "decidim/api/types/user_type"
|
38
|
+
|
39
|
+
autoload :BaseInputFilter, "decidim/api/input_filters/base_input_filter"
|
40
|
+
autoload :ComponentInputFilter, "decidim/api/input_filters/component_input_filter"
|
41
|
+
autoload :HasHastaggableInputFilter, "decidim/api/input_filters/has_hastaggable_input_filter"
|
42
|
+
autoload :HasLocalizedInputFilter, "decidim/api/input_filters/has_localized_input_filter"
|
43
|
+
autoload :HasPublishableInputFilter, "decidim/api/input_filters/has_publishable_input_filter"
|
44
|
+
autoload :HasTimestampInputFilter, "decidim/api/input_filters/has_timestamp_input_filter"
|
45
|
+
autoload :ParticipatorySpaceInputFilter, "decidim/api/input_filters/participatory_space_input_filter"
|
46
|
+
autoload :UserEntityInputFilter, "decidim/api/input_filters/user_entity_input_filter"
|
47
|
+
|
48
|
+
autoload :BaseInputSort, "decidim/api/input_sorts/base_input_sort"
|
49
|
+
autoload :ComponentInputSort, "decidim/api/input_sorts/component_input_sort"
|
50
|
+
autoload :HasEndorsableInputSort, "decidim/api/input_sorts/has_endorsable_input_sort"
|
51
|
+
autoload :HasLocalizedInputSort, "decidim/api/input_sorts/has_localized_input_sort"
|
52
|
+
autoload :HasPublishableInputSort, "decidim/api/input_sorts/has_publishable_input_sort"
|
53
|
+
autoload :HasTimestampInputSort, "decidim/api/input_sorts/has_timestamp_input_sort"
|
54
|
+
autoload :ParticipatorySpaceInputSort, "decidim/api/input_sorts/participatory_space_input_sort"
|
55
|
+
autoload :UserEntityInputSort, "decidim/api/input_sorts/user_entity_input_sort"
|
56
|
+
|
57
|
+
autoload :ParticipatorySpaceInterface, "decidim/api/interfaces/participatory_space_interface"
|
58
|
+
autoload :ComponentInterface, "decidim/api/interfaces/component_interface"
|
59
|
+
autoload :AuthorInterface, "decidim/api/interfaces/author_interface"
|
60
|
+
autoload :AuthorableInterface, "decidim/api/interfaces/authorable_interface"
|
61
|
+
autoload :CoauthorableInterface, "decidim/api/interfaces/coauthorable_interface"
|
62
|
+
autoload :CategorizableInterface, "decidim/api/interfaces/categorizable_interface"
|
63
|
+
autoload :ScopableInterface, "decidim/api/interfaces/scopable_interface"
|
64
|
+
autoload :AttachableInterface, "decidim/api/interfaces/attachable_interface"
|
65
|
+
autoload :HashtagInterface, "decidim/api/interfaces/hashtag_interface"
|
66
|
+
autoload :ParticipatorySpaceResourceableInterface, "decidim/api/interfaces/participatory_space_resourceable_interface"
|
67
|
+
autoload :FingerprintInterface, "decidim/api/interfaces/fingerprint_interface"
|
68
|
+
autoload :AmendableInterface, "decidim/api/interfaces/amendable_interface"
|
69
|
+
autoload :AmendableEntityInterface, "decidim/api/interfaces/amendable_entity_interface"
|
70
|
+
autoload :TraceableInterface, "decidim/api/interfaces/traceable_interface"
|
71
|
+
autoload :TimestampsInterface, "decidim/api/interfaces/timestamps_interface"
|
72
|
+
autoload :EndorsableInterface, "decidim/api/interfaces/endorsable_interface"
|
73
|
+
|
74
|
+
autoload :DateTimeType, "decidim/api/scalars/date_time_type"
|
75
|
+
autoload :DateType, "decidim/api/scalars/date_type"
|
21
76
|
end
|
22
77
|
end
|
data/lib/decidim/core/engine.rb
CHANGED
@@ -28,6 +28,7 @@ require "omniauth-twitter"
|
|
28
28
|
require "omniauth-google-oauth2"
|
29
29
|
require "invisible_captcha"
|
30
30
|
require "premailer/rails"
|
31
|
+
require "premailer/adapter/decidim"
|
31
32
|
require "geocoder"
|
32
33
|
require "paper_trail"
|
33
34
|
require "cells/rails"
|
@@ -36,7 +37,6 @@ require "kaminari"
|
|
36
37
|
require "doorkeeper"
|
37
38
|
require "doorkeeper-i18n"
|
38
39
|
require "nobspw"
|
39
|
-
require "kaminari"
|
40
40
|
require "batch-loader"
|
41
41
|
require "etherpad-lite"
|
42
42
|
require "diffy"
|
@@ -88,9 +88,9 @@ module Decidim
|
|
88
88
|
end
|
89
89
|
|
90
90
|
initializer "decidim.graphql_api" do
|
91
|
-
|
92
|
-
|
93
|
-
|
91
|
+
# Enable them method `!` everywhere for compatibility, this line will be removed when upgrading to GraphQL 2.0
|
92
|
+
GraphQL::DeprecatedDSL.activate
|
93
|
+
Decidim::Api::QueryType.include Decidim::QueryExtensions
|
94
94
|
|
95
95
|
Decidim::Api.add_orphan_type Decidim::Core::UserType
|
96
96
|
Decidim::Api.add_orphan_type Decidim::Core::UserGroupType
|
@@ -109,7 +109,7 @@ module Decidim
|
|
109
109
|
# that may be using the `geocoded_by` or `reverse_geocoded_by` class
|
110
110
|
# methods injected by the Geocoder gem.
|
111
111
|
ActiveSupport.on_load :active_record do
|
112
|
-
ActiveRecord::Base.
|
112
|
+
ActiveRecord::Base.include Decidim::Geocodable
|
113
113
|
end
|
114
114
|
end
|
115
115
|
|
@@ -334,6 +334,36 @@ module Decidim
|
|
334
334
|
end
|
335
335
|
end
|
336
336
|
|
337
|
+
Decidim.metrics_registry.register(:blocked_users) do |metric_registry|
|
338
|
+
metric_registry.manager_class = "Decidim::Metrics::BlockedUsersMetricManage"
|
339
|
+
|
340
|
+
metric_registry.settings do |settings|
|
341
|
+
settings.attribute :highlighted, type: :boolean, default: false
|
342
|
+
settings.attribute :scopes, type: :array, default: %w(home)
|
343
|
+
settings.attribute :weight, type: :integer, default: 1
|
344
|
+
end
|
345
|
+
end
|
346
|
+
|
347
|
+
Decidim.metrics_registry.register(:user_reports) do |metric_registry|
|
348
|
+
metric_registry.manager_class = "Decidim::Metrics::UserReportsMetricManage"
|
349
|
+
|
350
|
+
metric_registry.settings do |settings|
|
351
|
+
settings.attribute :highlighted, type: :boolean, default: false
|
352
|
+
settings.attribute :scopes, type: :array, default: %w(home)
|
353
|
+
settings.attribute :weight, type: :integer, default: 1
|
354
|
+
end
|
355
|
+
end
|
356
|
+
|
357
|
+
Decidim.metrics_registry.register(:reported_users) do |metric_registry|
|
358
|
+
metric_registry.manager_class = "Decidim::Metrics::ReportedUsersMetricManage"
|
359
|
+
|
360
|
+
metric_registry.settings do |settings|
|
361
|
+
settings.attribute :highlighted, type: :boolean, default: false
|
362
|
+
settings.attribute :scopes, type: :array, default: %w(home)
|
363
|
+
settings.attribute :weight, type: :integer, default: 1
|
364
|
+
end
|
365
|
+
end
|
366
|
+
|
337
367
|
Decidim.metrics_registry.register(:participants) do |metric_registry|
|
338
368
|
metric_registry.manager_class = "Decidim::Metrics::ParticipantsMetricManage"
|
339
369
|
|
@@ -507,8 +537,12 @@ module Decidim
|
|
507
537
|
NOBSPW.configuration.use_ruby_grep = true
|
508
538
|
end
|
509
539
|
|
540
|
+
initializer "decidim.premailer" do
|
541
|
+
Premailer::Adapter.use = :decidim
|
542
|
+
end
|
543
|
+
|
510
544
|
config.to_prepare do
|
511
|
-
FoundationRailsHelper::FlashHelper.
|
545
|
+
FoundationRailsHelper::FlashHelper.include Decidim::FlashHelperExtensions
|
512
546
|
end
|
513
547
|
end
|
514
548
|
end
|
data/lib/decidim/core/test.rb
CHANGED
@@ -1,6 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require "decidim/core/test/shared_examples/acts_as_author_examples"
|
4
|
+
require "decidim/core/test/shared_examples/admin_log_presenter_examples"
|
4
5
|
require "decidim/core/test/shared_examples/authorable"
|
5
6
|
require "decidim/core/test/shared_examples/coauthorable"
|
6
7
|
require "decidim/core/test/shared_examples/publicable"
|
@@ -13,6 +14,7 @@ require "decidim/core/test/shared_examples/has_scope"
|
|
13
14
|
require "decidim/core/test/shared_examples/has_category"
|
14
15
|
require "decidim/core/test/shared_examples/has_reference"
|
15
16
|
require "decidim/core/test/shared_examples/comments_examples"
|
17
|
+
require "decidim/core/test/shared_examples/counts_commentators_as_newsletter_participants"
|
16
18
|
require "decidim/core/test/shared_examples/announcements_examples"
|
17
19
|
require "decidim/core/test/shared_examples/process_announcements_examples"
|
18
20
|
require "decidim/core/test/shared_examples/reportable"
|
@@ -61,3 +63,5 @@ require "decidim/core/test/shared_examples/manage_component_share_tokens"
|
|
61
63
|
require "decidim/core/test/shared_examples/metric_manage_shared_context"
|
62
64
|
require "decidim/core/test/shared_examples/embed_resource_examples"
|
63
65
|
require "decidim/core/test/shared_examples/resource_search_examples"
|
66
|
+
require "decidim/core/test/shared_examples/static_pages_examples"
|
67
|
+
require "decidim/core/test/shared_examples/controller_render_views"
|
@@ -1,6 +1,7 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require "decidim/faker/localized"
|
4
|
+
require "decidim/faker/internet"
|
4
5
|
require "decidim/dev"
|
5
6
|
|
6
7
|
require "decidim/participatory_processes/test/factories"
|
@@ -13,7 +14,7 @@ end
|
|
13
14
|
|
14
15
|
FactoryBot.define do
|
15
16
|
sequence(:title) do |n|
|
16
|
-
"#{Faker::Lorem.sentence(3)} #{n}".delete("'")
|
17
|
+
"#{Faker::Lorem.sentence(word_count: 3)} #{n}".delete("'")
|
17
18
|
end
|
18
19
|
|
19
20
|
sequence(:name) do |n|
|
@@ -21,11 +22,11 @@ FactoryBot.define do
|
|
21
22
|
end
|
22
23
|
|
23
24
|
sequence(:nickname) do |n|
|
24
|
-
"#{Faker::Lorem.characters(rand(1..10))}_#{n}".gsub("'", "_")
|
25
|
+
"#{Faker::Lorem.characters(number: rand(1..10))}_#{n}".gsub("'", "_")
|
25
26
|
end
|
26
27
|
|
27
28
|
sequence(:hashtag_name) do |n|
|
28
|
-
"#{Faker::Lorem.characters(rand(1..10))}_#{n}".gsub("'", "_")
|
29
|
+
"#{Faker::Lorem.characters(number: rand(1..10))}_#{n}".gsub("'", "_")
|
29
30
|
end
|
30
31
|
|
31
32
|
sequence(:email) do |n|
|
@@ -37,19 +38,19 @@ FactoryBot.define do
|
|
37
38
|
end
|
38
39
|
|
39
40
|
sequence(:slug) do |n|
|
40
|
-
"#{Faker::Internet.slug(nil, "-")}-#{n}".gsub("'", "_")
|
41
|
+
"#{Decidim::Faker::Internet.slug(words: nil, glue: "-")}-#{n}".gsub("'", "_")
|
41
42
|
end
|
42
43
|
|
43
44
|
sequence(:scope_name) do |n|
|
44
|
-
"#{Faker::Lorem.sentence(1, true, 3)} #{n}".gsub("s", "z").gsub("S", "Z")
|
45
|
+
"#{Faker::Lorem.sentence(word_count: 1, supplemental: true, random_words_to_add: 3)} #{n}".gsub("s", "z").gsub("S", "Z")
|
45
46
|
end
|
46
47
|
|
47
48
|
sequence(:scope_code) do |n|
|
48
|
-
"#{Faker::Lorem.characters(4).upcase}-#{n}"
|
49
|
+
"#{Faker::Lorem.characters(number: 4).upcase}-#{n}"
|
49
50
|
end
|
50
51
|
|
51
52
|
sequence(:area_name) do |n|
|
52
|
-
"#{Faker::Lorem.sentence(1, true, 3)} #{n}"
|
53
|
+
"#{Faker::Lorem.sentence(word_count: 1, supplemental: true, random_words_to_add: 3)} #{n}"
|
53
54
|
end
|
54
55
|
|
55
56
|
factory :category, class: "Decidim::Category" do
|
@@ -67,6 +68,10 @@ FactoryBot.define do
|
|
67
68
|
end
|
68
69
|
|
69
70
|
factory :organization, class: "Decidim::Organization" do
|
71
|
+
transient do
|
72
|
+
create_static_pages { true }
|
73
|
+
end
|
74
|
+
|
70
75
|
name { Faker::Company.unique.name }
|
71
76
|
reference_prefix { Faker::Name.suffix }
|
72
77
|
time_zone { "UTC" }
|
@@ -104,9 +109,15 @@ FactoryBot.define do
|
|
104
109
|
end
|
105
110
|
file_upload_settings { Decidim::OrganizationSettings.default(:upload) }
|
106
111
|
|
107
|
-
|
108
|
-
|
109
|
-
|
112
|
+
trait :secure_context do
|
113
|
+
host { "localhost" }
|
114
|
+
end
|
115
|
+
|
116
|
+
after(:create) do |organization, evaluator|
|
117
|
+
if evaluator.create_static_pages
|
118
|
+
tos_page = Decidim::StaticPage.find_by(slug: "terms-and-conditions", organization: organization)
|
119
|
+
create(:static_page, :tos, organization: organization) if tos_page.nil?
|
120
|
+
end
|
110
121
|
end
|
111
122
|
end
|
112
123
|
|
@@ -121,15 +132,23 @@ FactoryBot.define do
|
|
121
132
|
tos_agreement { "1" }
|
122
133
|
avatar { Decidim::Dev.test_file("avatar.jpg", "image/jpeg") }
|
123
134
|
personal_url { Faker::Internet.url }
|
124
|
-
about { "<script>alert(\"ABOUT\");</script
|
135
|
+
about { "<script>alert(\"ABOUT\");</script>#{Faker::Lorem.paragraph(sentence_count: 2)}" }
|
125
136
|
confirmation_sent_at { Time.current }
|
126
137
|
accepted_tos_version { organization.tos_version }
|
127
138
|
email_on_notification { true }
|
139
|
+
email_on_moderations { true }
|
128
140
|
|
129
141
|
trait :confirmed do
|
130
142
|
confirmed_at { Time.current }
|
131
143
|
end
|
132
144
|
|
145
|
+
trait :blocked do
|
146
|
+
blocked { true }
|
147
|
+
blocked_at { Time.current }
|
148
|
+
extended_data { { "user_name": generate(:name) } }
|
149
|
+
name { "Blocked user" }
|
150
|
+
end
|
151
|
+
|
133
152
|
trait :deleted do
|
134
153
|
email { "" }
|
135
154
|
deleted_at { Time.current }
|
@@ -175,7 +194,7 @@ FactoryBot.define do
|
|
175
194
|
|
176
195
|
factory :user_group, class: "Decidim::UserGroup" do
|
177
196
|
transient do
|
178
|
-
document_number { Faker::Number.number(8)
|
197
|
+
document_number { "#{Faker::Number.number(digits: 8)}X" }
|
179
198
|
phone { Faker::PhoneNumber.phone_number }
|
180
199
|
rejected_at { nil }
|
181
200
|
verified_at { nil }
|
@@ -184,7 +203,7 @@ FactoryBot.define do
|
|
184
203
|
sequence(:name) { |n| "#{Faker::Company.name} #{n}" }
|
185
204
|
email { generate(:user_group_email) }
|
186
205
|
nickname { generate(:nickname) }
|
187
|
-
about { "<script>alert(\"ABOUT\");</script
|
206
|
+
about { "<script>alert(\"ABOUT\");</script>#{Faker::Lorem.paragraph(sentence_count: 2)}" }
|
188
207
|
organization
|
189
208
|
avatar { Decidim::Dev.test_file("avatar.jpg", "image/jpeg") } # Keep after organization
|
190
209
|
|
@@ -259,6 +278,7 @@ FactoryBot.define do
|
|
259
278
|
title { generate_localized_title }
|
260
279
|
content { Decidim::Faker::Localized.wrapped("<p>", "</p>") { generate_localized_title } }
|
261
280
|
organization { build(:organization) }
|
281
|
+
allow_public_access { false }
|
262
282
|
|
263
283
|
trait :default do
|
264
284
|
slug { Decidim::StaticPage::DEFAULT_PAGES.sample }
|
@@ -290,7 +310,7 @@ FactoryBot.define do
|
|
290
310
|
factory :attachment_collection, class: "Decidim::AttachmentCollection" do
|
291
311
|
name { generate_localized_title }
|
292
312
|
description { generate_localized_title }
|
293
|
-
weight { Faker::Number.number(1) }
|
313
|
+
weight { Faker::Number.number(digits: 1) }
|
294
314
|
|
295
315
|
association :collection_for, factory: :participatory_process
|
296
316
|
end
|
@@ -298,7 +318,7 @@ FactoryBot.define do
|
|
298
318
|
factory :attachment, class: "Decidim::Attachment" do
|
299
319
|
title { generate_localized_title }
|
300
320
|
description { Decidim::Faker::Localized.wrapped("<p>", "</p>") { generate_localized_title } }
|
301
|
-
weight { Faker::Number.number(1) }
|
321
|
+
weight { Faker::Number.number(digits: 1) }
|
302
322
|
attached_to { build(:participatory_process) }
|
303
323
|
content_type { "image/jpeg" }
|
304
324
|
file { Decidim::Dev.test_file("city.jpeg", "image/jpeg") } # Keep after attached_to
|
@@ -402,6 +422,14 @@ FactoryBot.define do
|
|
402
422
|
}
|
403
423
|
end
|
404
424
|
end
|
425
|
+
|
426
|
+
trait :with_comments_disabled do
|
427
|
+
settings do
|
428
|
+
{
|
429
|
+
comments_enabled: false
|
430
|
+
}
|
431
|
+
end
|
432
|
+
end
|
405
433
|
end
|
406
434
|
|
407
435
|
factory :scope_type, class: "Decidim::ScopeType" do
|
@@ -681,6 +709,16 @@ FactoryBot.define do
|
|
681
709
|
end
|
682
710
|
end
|
683
711
|
|
712
|
+
factory :user_report, class: "Decidim::UserReport" do
|
713
|
+
reason { "spam" }
|
714
|
+
moderation { build(:user_moderation) }
|
715
|
+
user { build(:user, organization: moderation.organization) }
|
716
|
+
end
|
717
|
+
|
718
|
+
factory :user_moderation, class: "Decidim::UserModeration" do
|
719
|
+
user { build(:user) }
|
720
|
+
end
|
721
|
+
|
684
722
|
factory :endorsement, class: "Decidim::Endorsement" do
|
685
723
|
resource { build(:dummy_resource) }
|
686
724
|
author { resource.try(:creator_author) || resource.try(:author) || build(:user, organization: resource.organization) }
|