decidim-core 0.28.2 → 0.29.0.rc2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +1 -1
- data/app/cells/decidim/activities_cell.rb +0 -1
- data/app/cells/decidim/activity_cell.rb +5 -7
- data/app/cells/decidim/address_cell.rb +3 -5
- data/app/cells/decidim/amendable/amend_button_card_cell.rb +0 -2
- data/app/cells/decidim/amendable/amendments_cell.rb +0 -2
- data/app/cells/decidim/amendable/announcement_cell.rb +10 -14
- data/app/cells/decidim/amendable/emendation_actions_cell.rb +0 -2
- data/app/cells/decidim/amendable/promote_button_card_cell.rb +0 -2
- data/app/cells/decidim/amendable/wizard_step_form_cell.rb +6 -19
- data/app/cells/decidim/announcement/show.erb +1 -1
- data/app/cells/decidim/announcement_cell.rb +6 -2
- data/app/cells/decidim/attachments_file_tab/show.erb +3 -0
- data/app/cells/decidim/attachments_file_tab_cell.rb +11 -0
- data/app/cells/decidim/attachments_link_tab/show.erb +12 -0
- data/app/cells/decidim/attachments_link_tab_cell.rb +21 -0
- data/app/cells/decidim/author/flag.erb +2 -2
- data/app/cells/decidim/author_cell.rb +0 -2
- data/app/cells/decidim/authorization_modal_cell.rb +0 -3
- data/app/cells/decidim/badge_cell.rb +0 -4
- data/app/cells/decidim/badges_cell.rb +0 -2
- data/app/cells/decidim/button_cell.rb +0 -3
- data/app/cells/decidim/card_cell.rb +1 -5
- data/app/cells/decidim/card_g_cell.rb +2 -2
- data/app/cells/decidim/card_l/space.erb +1 -1
- data/app/cells/decidim/card_l_cell.rb +1 -3
- data/app/cells/decidim/card_metadata_cell.rb +1 -5
- data/app/cells/decidim/card_s_cell.rb +1 -4
- data/app/cells/decidim/coauthorships_cell.rb +0 -2
- data/app/cells/decidim/comments_button_cell.rb +0 -2
- data/app/cells/decidim/content_blocks/footer_sub_hero/show.erb +1 -1
- data/app/cells/decidim/content_blocks/footer_sub_hero_cell.rb +0 -3
- data/app/cells/decidim/content_blocks/hero/show.erb +1 -1
- data/app/cells/decidim/content_blocks/hero_cell.rb +0 -1
- data/app/cells/decidim/content_blocks/highlighted_content_banner_cell.rb +0 -2
- data/app/cells/decidim/content_blocks/how_to_participate/show.erb +1 -1
- data/app/cells/decidim/content_blocks/how_to_participate_cell.rb +0 -1
- data/app/cells/decidim/content_blocks/participatory_space_documents/content.erb +1 -1
- data/app/cells/decidim/content_blocks/participatory_space_documents_cell.rb +17 -1
- data/app/cells/decidim/content_blocks/participatory_space_hero_cell.rb +0 -2
- data/app/cells/decidim/content_blocks/participatory_space_last_activity_cell.rb +1 -3
- data/app/cells/decidim/content_blocks/stats/show.erb +1 -1
- data/app/cells/decidim/content_blocks/sub_hero_cell.rb +0 -3
- data/app/cells/decidim/date_range/show.erb +10 -10
- data/app/cells/decidim/date_range_cell.rb +0 -2
- data/app/cells/decidim/diff_cell.rb +0 -1
- data/app/cells/decidim/documents_panel/show.erb +4 -0
- data/app/cells/decidim/documents_panel_cell.rb +9 -1
- data/app/cells/decidim/endorsement_buttons_cell.rb +5 -13
- data/app/cells/decidim/flag_modal/flag_user.erb +3 -3
- data/app/cells/decidim/followers_cell.rb +0 -1
- data/app/cells/decidim/following_cell.rb +0 -1
- data/app/cells/decidim/footer_topics/show.erb +8 -0
- data/app/cells/decidim/footer_topics_cell.rb +39 -0
- data/app/cells/decidim/groups_cell.rb +0 -3
- data/app/cells/decidim/linked_resources_for_cell.rb +0 -3
- data/app/cells/decidim/members_cell.rb +0 -1
- data/app/cells/decidim/navbar_admin_link_cell.rb +0 -2
- data/app/cells/decidim/newsletter_templates/base_cell.rb +0 -1
- data/app/cells/decidim/newsletter_templates/basic_only_text/show.erb +2 -2
- data/app/cells/decidim/newsletter_templates/image_text_cta/show.erb +2 -2
- data/app/cells/decidim/notification/show.erb +5 -0
- data/app/cells/decidim/notification_actions/base_cell.rb +13 -0
- data/app/cells/decidim/notification_actions/buttons/show.erb +5 -0
- data/app/cells/decidim/notification_actions/buttons_cell.rb +41 -0
- data/app/cells/decidim/notification_cell.rb +9 -3
- data/app/cells/decidim/notifications_cell.rb +0 -1
- data/app/cells/decidim/pad_iframe/show.erb +2 -2
- data/app/cells/decidim/pad_iframe_cell.rb +0 -1
- data/app/cells/decidim/participatory_space_dropdown_metadata_cell.rb +1 -2
- data/app/cells/decidim/photo_cell.rb +1 -5
- data/app/cells/decidim/photos_list_cell.rb +0 -2
- data/app/cells/decidim/profile_cell.rb +0 -2
- data/app/cells/decidim/profile_sidebar/show.erb +20 -20
- data/app/cells/decidim/profile_sidebar_cell.rb +1 -10
- data/app/cells/decidim/progress_bar/show.erb +8 -6
- data/app/cells/decidim/public_participation/show.erb +1 -1
- data/app/cells/decidim/report_button/flag_modal.erb +1 -1
- data/app/cells/decidim/resource_types_filter_cell.rb +0 -2
- data/app/cells/decidim/scopes_picker/show.erb +1 -1
- data/app/cells/decidim/scopes_picker_cell.rb +0 -1
- data/app/cells/decidim/search_results_cell.rb +1 -1
- data/app/cells/decidim/statistic_cell.rb +0 -2
- data/app/cells/decidim/tab_panels/show.erb +1 -1
- data/app/cells/decidim/tab_panels_cell.rb +12 -2
- data/app/cells/decidim/tags_cell.rb +0 -2
- data/app/cells/decidim/tos_page_cell.rb +0 -3
- data/app/cells/decidim/translation_bar/show.erb +1 -1
- data/app/cells/decidim/translation_bar_cell.rb +0 -2
- data/app/cells/decidim/upload_modal/files.erb +1 -1
- data/app/cells/decidim/upload_modal_cell.rb +1 -3
- data/app/cells/decidim/user_conversation/new.erb +1 -1
- data/app/cells/decidim/user_conversation/show.erb +1 -1
- data/app/cells/decidim/user_conversation_cell.rb +0 -1
- data/app/cells/decidim/user_conversations/show.erb +1 -1
- data/app/cells/decidim/user_conversations_cell.rb +0 -1
- data/app/cells/decidim/user_group_pending_invitations_list_cell.rb +0 -1
- data/app/cells/decidim/user_group_pending_requests_list_cell.rb +0 -1
- data/app/cells/decidim/user_timeline/show.erb +1 -1
- data/app/cells/decidim/version_cell.rb +3 -5
- data/app/cells/decidim/versions_list_cell.rb +1 -3
- data/app/cells/decidim/versions_list_item_cell.rb +2 -4
- data/app/cells/decidim/wizard_step_form/wizard_aside.erb +2 -2
- data/app/cells/decidim/wizard_step_form/wizard_header.erb +2 -3
- data/app/cells/decidim/wizard_step_form_cell.rb +0 -8
- data/app/commands/decidim/amendable/create_draft.rb +4 -3
- data/app/commands/decidim/amendable/promote.rb +3 -2
- data/app/commands/decidim/amendable/publish_draft.rb +3 -2
- data/app/commands/decidim/amendable/update_draft.rb +4 -3
- data/app/commands/decidim/amendable/withdraw.rb +1 -1
- data/app/commands/decidim/create_follow.rb +4 -4
- data/app/commands/decidim/create_report.rb +3 -3
- data/app/commands/decidim/create_user_report.rb +5 -5
- data/app/commands/decidim/delete_follow.rb +4 -4
- data/app/commands/decidim/demote_membership.rb +2 -2
- data/app/commands/decidim/destroy_account.rb +21 -19
- data/app/commands/decidim/endorse_resource.rb +1 -1
- data/app/commands/decidim/invite_user_to_group.rb +5 -4
- data/app/commands/decidim/update_account.rb +24 -22
- data/app/commands/decidim/update_notifications_settings.rb +13 -11
- data/app/commands/decidim/update_password.rb +7 -7
- data/app/commands/decidim/update_user_interests.rb +9 -7
- data/app/controllers/concerns/decidim/devise_controllers.rb +2 -0
- data/app/controllers/concerns/decidim/filter_resource.rb +1 -1
- data/app/controllers/concerns/decidim/needs_rtl_direction.rb +23 -0
- data/app/controllers/concerns/decidim/participatory_space_context.rb +1 -23
- data/app/controllers/concerns/decidim/payload_info.rb +2 -1
- data/app/controllers/concerns/decidim/registers_permissions.rb +4 -4
- data/app/controllers/concerns/decidim/use_organization_time_zone.rb +1 -1
- data/app/controllers/concerns/decidim/withdrawable.rb +1 -1
- data/app/controllers/decidim/account_controller.rb +2 -2
- data/app/controllers/{concerns/decidim → decidim}/amendments_controller.rb +3 -16
- data/app/controllers/decidim/application_controller.rb +1 -0
- data/app/controllers/decidim/components/base_controller.rb +1 -1
- data/app/controllers/decidim/devise/invitations_controller.rb +1 -1
- data/app/controllers/decidim/devise/passwords_controller.rb +2 -2
- data/app/controllers/decidim/endorsements_controller.rb +1 -1
- data/app/controllers/decidim/favicon_controller.rb +1 -1
- data/app/controllers/decidim/follows_controller.rb +2 -2
- data/app/controllers/decidim/group_invites_controller.rb +36 -9
- data/app/controllers/decidim/newsletters_opt_in_controller.rb +1 -1
- data/app/controllers/decidim/notifications_settings_controller.rb +1 -1
- data/app/controllers/decidim/report_users_controller.rb +1 -1
- data/app/controllers/decidim/reports_controller.rb +1 -1
- data/app/controllers/decidim/user_interests_controller.rb +1 -1
- data/app/events/decidim/change_nickname_event.rb +0 -1
- data/app/events/decidim/invited_to_group_event.rb +29 -0
- data/app/events/decidim/welcome_notification_event.rb +2 -4
- data/app/forms/decidim/form.rb +4 -0
- data/app/forms/decidim/omniauth_registration_form.rb +1 -1
- data/app/forms/decidim/upload_validation_form.rb +1 -1
- data/app/helpers/concerns/decidim/flash_helper_extensions.rb +1 -1
- data/app/helpers/decidim/amendments_helper.rb +4 -14
- data/app/helpers/decidim/application_helper.rb +8 -0
- data/app/helpers/decidim/authorization_form_helper.rb +2 -2
- data/app/helpers/decidim/breadcrumb_helper.rb +1 -1
- data/app/helpers/decidim/cells_helper.rb +1 -1
- data/app/helpers/decidim/check_boxes_tree_helper.rb +1 -1
- data/app/helpers/decidim/datalist_select_helper.rb +1 -1
- data/app/helpers/decidim/decidim_form_helper.rb +3 -3
- data/app/helpers/decidim/filters_helper.rb +1 -1
- data/app/helpers/decidim/layout_helper.rb +1 -36
- data/app/helpers/decidim/localized_locales_helper.rb +1 -1
- data/app/helpers/decidim/menu_helper.rb +8 -0
- data/app/helpers/decidim/meta_tags_helper.rb +26 -23
- data/app/helpers/decidim/modal_helper.rb +1 -1
- data/app/helpers/decidim/orders_helper.rb +1 -1
- data/app/helpers/decidim/organization_helper.rb +55 -0
- data/app/helpers/decidim/paginate_helper.rb +1 -1
- data/app/helpers/decidim/resource_helper.rb +0 -7
- data/app/helpers/decidim/scopes_helper.rb +4 -2
- data/app/helpers/decidim/searches_helper.rb +1 -1
- data/app/helpers/decidim/short_link_helper.rb +2 -2
- data/app/helpers/decidim/translations_helper.rb +2 -2
- data/app/helpers/decidim/twitter_search_helper.rb +1 -1
- data/app/helpers/decidim/user_profile_helper.rb +0 -1
- data/app/jobs/decidim/email_notifications_digest_generator_job.rb +2 -2
- data/app/mailers/decidim/application_mailer.rb +6 -2
- data/app/mailers/decidim/block_user_mailer.rb +1 -1
- data/app/mailers/decidim/decidim_devise_mailer.rb +7 -1
- data/app/mailers/decidim/newsletter_mailer.rb +1 -4
- data/app/mailers/decidim/newsletters_opt_in_mailer.rb +2 -2
- data/app/mailers/decidim/notification_mailer.rb +0 -1
- data/app/mailers/decidim/notifications_digest_mailer.rb +0 -1
- data/app/mailers/decidim/reported_mailer.rb +6 -3
- data/app/mailers/decidim/user_report_mailer.rb +1 -1
- data/app/models/decidim/action_log.rb +1 -1
- data/app/models/decidim/area_type.rb +1 -1
- data/app/models/decidim/attachment.rb +26 -2
- data/app/models/decidim/authorization.rb +1 -1
- data/app/models/decidim/authorization_transfer.rb +1 -0
- data/app/models/decidim/component.rb +2 -2
- data/app/models/decidim/content_block.rb +1 -1
- data/app/models/decidim/messaging/message.rb +2 -2
- data/app/models/decidim/newsletter.rb +9 -9
- data/app/models/decidim/notification.rb +2 -2
- data/app/models/decidim/organization.rb +23 -2
- data/app/models/decidim/push_notification_message.rb +1 -1
- data/app/models/decidim/resource_link.rb +1 -1
- data/app/models/decidim/user.rb +2 -2
- data/app/models/decidim/user_group.rb +2 -2
- data/app/packs/src/decidim/a11y.js +46 -0
- data/app/packs/src/decidim/attachments/file_or_link_tabs.js +55 -0
- data/app/packs/src/decidim/attachments/index.js +1 -0
- data/app/packs/src/decidim/back_to_list.js +1 -1
- data/app/packs/src/decidim/check_boxes_tree.js +1 -1
- data/app/packs/src/decidim/data_consent/consent_manager.js +1 -1
- data/app/packs/src/decidim/data_consent/consent_manager.test.js +6 -6
- data/app/packs/src/decidim/data_consent/index.js +1 -1
- data/app/packs/src/decidim/datepicker/datepicker_functions.js +243 -0
- data/app/packs/src/decidim/datepicker/datepicker_listeners.js +78 -0
- data/app/packs/src/decidim/datepicker/form_datepicker.js +91 -0
- data/app/packs/src/decidim/datepicker/generate_datepicker.js +148 -0
- data/app/packs/src/decidim/datepicker/generate_timepicker.js +298 -0
- data/app/packs/src/decidim/datepicker/test/date.test.js +118 -0
- data/app/packs/src/decidim/datepicker/test/time.test.js +227 -0
- data/app/packs/src/decidim/editor/extensions/indent/index.js +1 -1
- data/app/packs/src/decidim/editor/extensions/video_embed/index.js +4 -4
- data/app/packs/src/decidim/editor/test/extensions/decidim_kit.test.js +0 -15
- data/app/packs/src/decidim/editor/test/extensions/indent.test.js +1 -1
- data/app/packs/src/decidim/editor/test/fixtures/upload_templates.js +1 -1
- data/app/packs/src/decidim/editor/test/helpers.js +1 -14
- data/app/packs/src/decidim/editor/utilities/paste_transform.js +2 -2
- data/app/packs/src/decidim/external_domain_warning.js +2 -2
- data/app/packs/src/decidim/external_domain_warning.test.js +4 -4
- data/app/packs/src/decidim/form_filter.js +4 -4
- data/app/packs/src/decidim/impersonation.js +1 -1
- data/app/packs/src/decidim/index.js +11 -5
- data/app/packs/src/decidim/input_character_counter.js +1 -1
- data/app/packs/src/decidim/input_emoji.js +171 -72
- data/app/packs/src/decidim/input_hashtags.js +1 -1
- data/app/packs/src/decidim/input_mentions.js +1 -1
- data/app/packs/src/decidim/notifications_actions.js +40 -0
- data/app/packs/src/decidim/sticky_header.js +87 -0
- data/app/packs/src/decidim/sw/sw.js +8 -6
- data/app/packs/src/decidim/tooltips.js +1 -1
- data/app/packs/stylesheets/decidim/_datepicker.scss +193 -0
- data/app/packs/stylesheets/decidim/_dropdown.scss +36 -0
- data/app/packs/stylesheets/decidim/_emoji.scss +36 -0
- data/app/packs/stylesheets/decidim/_filters.scss +4 -2
- data/app/packs/stylesheets/decidim/_flash.scss +2 -2
- data/app/packs/stylesheets/decidim/_footer.scss +1 -3
- data/app/packs/stylesheets/decidim/_forms.scss +9 -1
- data/app/packs/stylesheets/decidim/_header.scss +70 -50
- data/app/packs/stylesheets/decidim/_home.scss +1 -1
- data/app/packs/stylesheets/decidim/_layout.scss +13 -0
- data/app/packs/stylesheets/decidim/_modal.scss +1 -1
- data/app/packs/stylesheets/decidim/_modal_update.scss +1 -1
- data/app/packs/stylesheets/decidim/_notifications.scss +4 -0
- data/app/packs/stylesheets/decidim/_tabs_x.scss +5 -1
- data/app/packs/stylesheets/decidim/application.scss +4 -0
- data/app/packs/stylesheets/decidim/legacy/leaflet.scss +1 -1
- data/app/packs/stylesheets/decidim/vendor/_datepicker_light.scss +228 -0
- data/app/permissions/decidim/default_permissions.rb +2 -2
- data/app/presenters/decidim/admin_log/organization_presenter.rb +1 -1
- data/app/presenters/decidim/admin_log/static_page_presenter.rb +1 -1
- data/app/presenters/decidim/authorization_transfer_presenter.rb +1 -1
- data/app/presenters/decidim/component_attachment_collection_presenter.rb +81 -0
- data/app/presenters/decidim/footer_menu_presenter.rb +1 -1
- data/app/presenters/decidim/home_stats_presenter.rb +1 -1
- data/app/presenters/decidim/organization_presenter.rb +1 -1
- data/app/queries/decidim/metric_measure.rb +1 -1
- data/app/queries/decidim/public_activities.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/action_logger.rb +3 -3
- data/app/services/decidim/log/diff_changeset_calculator.rb +2 -2
- data/app/services/decidim/notifications_digest_sending_decider.rb +1 -1
- data/app/uploaders/decidim/organization_favicon_uploader.rb +1 -1
- data/app/uploaders/decidim/record_image_uploader.rb +2 -2
- data/app/validators/organization_present_validator.rb +1 -1
- data/app/validators/passthru_validator.rb +1 -1
- data/app/validators/uploader_image_dimensions_validator.rb +2 -2
- data/app/views/decidim/account/show.html.erb +1 -1
- data/app/views/decidim/amendments/_wizard_header.html.erb +1 -2
- data/app/views/decidim/application/_collection.html.erb +3 -1
- data/app/views/decidim/application/_component_documents.html.erb +4 -0
- data/app/views/decidim/application/_document.html.erb +23 -9
- data/app/views/decidim/block_user_mailer/notify.html.erb +2 -2
- data/app/views/decidim/devise/invitations/edit.html.erb +2 -2
- data/app/views/decidim/devise/omniauth_registrations/new.html.erb +1 -1
- data/app/views/decidim/devise/registrations/new.html.erb +1 -1
- data/app/views/decidim/devise/shared/_login_boxes.html.erb +1 -1
- data/app/views/decidim/doorkeeper/authorizations/new.html.erb +1 -1
- data/app/views/decidim/endorsements/_identity.html.erb +1 -1
- data/app/views/decidim/gamification/badges/index.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_add_conversation_users.html.erb +2 -2
- data/app/views/decidim/messaging/conversations/_error_modal.html.erb +5 -5
- data/app/views/decidim/newsletter_mailer/newsletter.html.erb +1 -1
- data/app/views/decidim/newsletters/show.html.erb +1 -1
- data/app/views/decidim/newsletters_opt_in_mailer/notify.html.erb +2 -2
- data/app/views/decidim/pages/index.html.erb +1 -2
- data/app/views/decidim/reported_mailer/report.html.erb +4 -2
- data/app/views/decidim/scopes/picker.html.erb +5 -5
- data/app/views/decidim/searches/_resources_filter_block.html.erb +6 -6
- data/app/views/decidim/shared/_extended_navigation_bar.html.erb +8 -8
- data/app/views/decidim/shared/_login_modal.html.erb +1 -1
- data/app/views/decidim/user_interests/_areas.html.erb +2 -2
- data/app/views/decidim/user_report_mailer/notify.html.erb +2 -2
- data/app/views/decidim/user_update_mailer/notify.html.erb +1 -1
- data/app/views/decidim/widgets/_data_picker.html.erb +1 -1
- data/app/views/devise/mailer/invitation_instructions.html.erb +1 -1
- data/app/views/devise/mailer/invitation_instructions.text.erb +1 -1
- data/app/views/devise/mailer/invite_admin.html.erb +2 -2
- data/app/views/devise/mailer/invite_admin.text.erb +2 -2
- data/app/views/devise/mailer/invite_collaborator.html.erb +2 -2
- data/app/views/devise/mailer/invite_collaborator.text.erb +2 -2
- data/app/views/devise/mailer/invite_private_user.html.erb +2 -2
- data/app/views/devise/mailer/invite_private_user.text.erb +2 -2
- data/app/views/devise/mailer/organization_admin_invitation_instructions.html.erb +1 -1
- data/app/views/devise/mailer/organization_admin_invitation_instructions.text.erb +1 -1
- data/app/views/layouts/decidim/_application.html.erb +3 -6
- data/app/views/layouts/decidim/_data_consent_warning.html.erb +2 -2
- data/app/views/layouts/decidim/_decidim_javascript.html.erb +1 -1
- data/app/views/layouts/decidim/_head_extra.html.erb +2 -2
- data/app/views/layouts/decidim/_impersonation_warning.html.erb +1 -1
- data/app/views/layouts/decidim/_js_configuration.html.erb +7 -2
- data/app/views/layouts/decidim/_logo.html.erb +2 -2
- data/app/views/layouts/decidim/_logo_mobile.html.erb +11 -0
- data/app/views/layouts/decidim/_mailer_logo.html.erb +2 -2
- data/app/views/layouts/decidim/_meta_tags_config.html.erb +1 -1
- data/app/views/layouts/decidim/_wrapper.html.erb +16 -9
- data/app/views/layouts/decidim/footer/_main.html.erb +2 -3
- data/app/views/layouts/decidim/footer/_main_intro.html.erb +2 -2
- data/app/views/layouts/decidim/footer/_main_legal.html.erb +2 -3
- data/app/views/layouts/decidim/footer/_main_links.html.erb +13 -11
- data/app/views/layouts/decidim/footer/_main_social_media_links.html.erb +8 -8
- data/app/views/layouts/decidim/header/_main.html.erb +9 -22
- data/app/views/layouts/decidim/header/_main_links_desktop.html.erb +3 -4
- data/app/views/layouts/decidim/header/_main_links_mobile_account.html.erb +10 -3
- data/app/views/layouts/decidim/header/_main_links_mobile_item_account.html.erb +24 -0
- data/app/views/layouts/decidim/header/_main_links_mobile_search.html.erb +0 -21
- data/app/views/layouts/decidim/header/_main_menu_mobile.html.erb +12 -0
- data/app/views/layouts/decidim/header/_menu_breadcrumb_desktop.html.erb +1 -1
- data/app/views/layouts/decidim/header/_menu_breadcrumb_main_dropdown_mobile.html.erb +17 -0
- data/app/views/layouts/decidim/header/_menu_breadcrumb_main_dropdown_top_left.html.erb +1 -1
- data/app/views/layouts/decidim/header/_menu_breadcrumb_mobile_tablet.html.erb +1 -1
- data/app/views/layouts/decidim/header/_menu_form_search_mobile.html.erb +16 -0
- data/app/views/layouts/decidim/header/_mobile_language_choose.html.erb +25 -0
- data/app/views/layouts/decidim/mailer.html.erb +2 -2
- data/app/views/layouts/decidim/shared/_layout_center.html.erb +1 -1
- data/app/views/layouts/decidim/shared/_layout_item.html.erb +0 -14
- data/config/initializers/active_storage.rb +3 -0
- data/config/initializers/devise.rb +1 -1
- data/config/initializers/new_framework_defaults_7_0.rb +145 -0
- data/config/locales/ar.yml +2 -42
- data/config/locales/bg.yml +55 -57
- data/config/locales/ca.yml +65 -54
- data/config/locales/cs.yml +53 -55
- data/config/locales/de.yml +63 -52
- data/config/locales/el.yml +0 -29
- data/config/locales/en.yml +68 -57
- data/config/locales/es-MX.yml +67 -56
- data/config/locales/es-PY.yml +67 -56
- data/config/locales/es.yml +66 -55
- data/config/locales/eu.yml +67 -56
- data/config/locales/fi-plain.yml +66 -55
- data/config/locales/fi.yml +65 -54
- data/config/locales/fr-CA.yml +60 -55
- data/config/locales/fr.yml +55 -50
- data/config/locales/ga-IE.yml +0 -11
- data/config/locales/gl.yml +0 -18
- data/config/locales/hu.yml +36 -56
- data/config/locales/id-ID.yml +0 -14
- data/config/locales/is-IS.yml +0 -10
- data/config/locales/it.yml +0 -25
- data/config/locales/ja.yml +67 -56
- data/config/locales/lb.yml +0 -25
- data/config/locales/lt.yml +0 -48
- data/config/locales/lv.yml +0 -21
- data/config/locales/nl.yml +0 -24
- data/config/locales/no.yml +0 -25
- data/config/locales/pl.yml +67 -56
- data/config/locales/pt-BR.yml +4 -51
- data/config/locales/pt.yml +0 -25
- data/config/locales/ro-RO.yml +1 -28
- data/config/locales/ru.yml +0 -15
- data/config/locales/sk.yml +0 -21
- data/config/locales/sl.yml +0 -8
- data/config/locales/sv.yml +0 -33
- data/config/locales/tr-TR.yml +4 -27
- data/config/locales/uk.yml +0 -10
- data/config/locales/zh-CN.yml +0 -22
- data/config/locales/zh-TW.yml +0 -47
- data/config/routes.rb +0 -1
- data/db/migrate/20170128112958_change_user_groups_verified_to_timestamp.rb +1 -1
- data/db/migrate/20240110150230_rename_external_domain_whitelist_to_external_domain_allowlist.rb +7 -0
- data/db/migrate/20240326104215_remove_show_in_footer_in_static_pages.rb +7 -0
- data/db/migrate/20240401192628_change_name_on_decidim_organizations.rb +31 -0
- data/db/seeds/avatars/001.jpg +0 -0
- data/db/seeds/avatars/002.jpg +0 -0
- data/db/seeds/avatars/003.jpg +0 -0
- data/db/seeds/avatars/004.jpg +0 -0
- data/db/seeds/avatars/005.jpg +0 -0
- data/db/seeds/avatars/006.jpg +0 -0
- data/db/seeds/avatars/007.jpg +0 -0
- data/db/seeds/avatars/008.jpg +0 -0
- data/db/seeds/avatars/009.jpg +0 -0
- data/db/seeds/avatars/010.jpg +0 -0
- data/db/seeds/avatars/011.jpg +0 -0
- data/db/seeds/avatars/012.jpg +0 -0
- data/db/seeds/avatars/013.jpg +0 -0
- data/db/seeds/avatars/014.jpg +0 -0
- data/db/seeds/avatars/015.jpg +0 -0
- data/db/seeds/avatars/016.jpg +0 -0
- data/db/seeds/avatars/017.jpg +0 -0
- data/db/seeds/avatars/018.jpg +0 -0
- data/db/seeds/avatars/019.jpg +0 -0
- data/db/seeds/avatars/020.jpg +0 -0
- data/db/seeds/avatars/021.jpg +0 -0
- data/db/seeds/avatars/022.jpg +0 -0
- data/db/seeds/avatars/023.jpg +0 -0
- data/db/seeds/avatars/024.jpg +0 -0
- data/db/seeds/avatars/025.jpg +0 -0
- data/db/seeds/avatars/026.jpg +0 -0
- data/db/seeds/avatars/027.jpg +0 -0
- data/db/seeds/avatars/028.jpg +0 -0
- data/db/seeds/avatars/029.jpg +0 -0
- data/db/seeds/avatars/030.jpg +0 -0
- data/db/seeds/avatars/031.jpg +0 -0
- data/db/seeds/avatars/032.jpg +0 -0
- data/db/seeds/avatars/033.jpg +0 -0
- data/db/seeds/avatars/034.jpg +0 -0
- data/db/seeds/avatars/035.jpg +0 -0
- data/db/seeds/avatars/036.jpg +0 -0
- data/db/seeds/avatars/037.jpg +0 -0
- data/db/seeds/avatars/038.jpg +0 -0
- data/db/seeds/avatars/039.jpg +0 -0
- data/db/seeds/avatars/040.jpg +0 -0
- data/db/seeds/avatars/041.jpg +0 -0
- data/db/seeds/avatars/042.jpg +0 -0
- data/db/seeds/avatars/043.jpg +0 -0
- data/db/seeds/avatars/044.jpg +0 -0
- data/db/seeds/avatars/045.jpg +0 -0
- data/db/seeds/avatars/046.jpg +0 -0
- data/db/seeds/avatars/047.jpg +0 -0
- data/db/seeds/avatars/048.jpg +0 -0
- data/db/seeds/avatars/049.jpg +0 -0
- data/db/seeds/avatars/050.jpg +0 -0
- data/db/seeds/avatars/051.jpg +0 -0
- data/db/seeds/avatars/052.jpg +0 -0
- data/db/seeds/avatars/053.jpg +0 -0
- data/db/seeds/avatars/054.jpg +0 -0
- data/db/seeds/avatars/055.jpg +0 -0
- data/db/seeds/avatars/056.jpg +0 -0
- data/db/seeds/avatars/057.jpg +0 -0
- data/db/seeds/avatars/058.jpg +0 -0
- data/db/seeds/avatars/059.jpg +0 -0
- data/db/seeds/avatars/060.jpg +0 -0
- data/db/seeds/avatars/061.jpg +0 -0
- data/db/seeds/avatars/062.jpg +0 -0
- data/db/seeds/avatars/063.jpg +0 -0
- data/db/seeds/avatars/064.jpg +0 -0
- data/db/seeds/avatars/065.jpg +0 -0
- data/db/seeds/avatars/066.jpg +0 -0
- data/db/seeds/avatars/067.jpg +0 -0
- data/db/seeds/avatars/068.jpg +0 -0
- data/db/seeds/avatars/069.jpg +0 -0
- data/db/seeds/avatars/070.jpg +0 -0
- data/db/seeds/avatars/071.jpg +0 -0
- data/db/seeds/avatars/072.jpg +0 -0
- data/db/seeds/avatars/073.jpg +0 -0
- data/db/seeds/avatars/074.jpg +0 -0
- data/db/seeds/avatars/075.jpg +0 -0
- data/db/seeds/avatars/076.jpg +0 -0
- data/db/seeds/avatars/077.jpg +0 -0
- data/db/seeds/avatars/078.jpg +0 -0
- data/db/seeds/avatars/079.jpg +0 -0
- data/db/seeds/avatars/080.jpg +0 -0
- data/db/seeds/avatars/081.jpg +0 -0
- data/db/seeds/avatars/082.jpg +0 -0
- data/db/seeds/avatars/083.jpg +0 -0
- data/db/seeds/avatars/084.jpg +0 -0
- data/db/seeds/avatars/085.jpg +0 -0
- data/db/seeds/avatars/086.jpg +0 -0
- data/db/seeds/avatars/087.jpg +0 -0
- data/db/seeds/avatars/088.jpg +0 -0
- data/db/seeds/avatars/089.jpg +0 -0
- data/db/seeds/avatars/090.jpg +0 -0
- data/db/seeds/avatars/091.jpg +0 -0
- data/db/seeds/avatars/092.jpg +0 -0
- data/db/seeds/avatars/093.jpg +0 -0
- data/db/seeds/avatars/094.jpg +0 -0
- data/db/seeds/avatars/095.jpg +0 -0
- data/db/seeds/avatars/096.jpg +0 -0
- data/db/seeds/avatars/097.jpg +0 -0
- data/db/seeds/avatars/098.jpg +0 -0
- data/db/seeds/avatars/099.jpg +0 -0
- data/db/seeds/avatars/100.jpg +0 -0
- data/db/seeds/avatars/CREDITS.md +114 -0
- data/db/seeds/avatars/README.md +25 -0
- data/decidim-core.gemspec +6 -5
- data/lib/decidim/acts_as_author.rb +1 -1
- data/lib/decidim/admin_filter.rb +44 -0
- data/lib/decidim/admin_filters_registry.rb +55 -0
- data/lib/decidim/amendable.rb +1 -2
- data/lib/decidim/api/functions/component_finder_base.rb +1 -1
- data/lib/decidim/api/functions/needs_api_filter_and_order.rb +3 -3
- data/lib/decidim/api/functions/participatory_space_finder_base.rb +1 -1
- data/lib/decidim/api/functions/participatory_space_list_base.rb +1 -1
- data/lib/decidim/api/input_filters/user_entity_input_filter.rb +3 -3
- data/lib/decidim/api/interfaces/author_interface.rb +1 -1
- data/lib/decidim/api/types/organization_type.rb +1 -1
- data/lib/decidim/api/types/user_group_type.rb +1 -1
- data/lib/decidim/api/types/user_type.rb +1 -1
- data/lib/decidim/asset_router/pipeline.rb +2 -2
- data/lib/decidim/assets/tailwind/instance.rb +1 -1
- data/lib/decidim/assets/tailwind/tailwind.config.js.erb +8 -3
- data/lib/decidim/attribute_object/model.rb +2 -2
- data/lib/decidim/attribute_object/type_resolver.rb +1 -3
- data/lib/decidim/attribute_object.rb +2 -2
- data/lib/decidim/attributes.rb +0 -4
- data/lib/decidim/authorable.rb +5 -0
- data/lib/decidim/command.rb +2 -2
- data/lib/decidim/commands/create_resource.rb +63 -0
- data/lib/decidim/commands/destroy_resource.rb +74 -0
- data/lib/decidim/commands/hook_error.rb +8 -0
- data/lib/decidim/commands/resource_handler.rb +85 -0
- data/lib/decidim/commands/update_resource.rb +64 -0
- data/lib/decidim/component_manifest.rb +3 -1
- data/lib/decidim/component_validator.rb +1 -1
- data/lib/decidim/content_blocks/has_related_components.rb +1 -1
- data/lib/decidim/content_parsers/resource_parser.rb +2 -2
- data/lib/decidim/content_processor.rb +1 -1
- data/lib/decidim/content_security_policy.rb +1 -1
- data/lib/decidim/core/engine.rb +12 -15
- data/lib/decidim/core/menu.rb +13 -3
- data/lib/decidim/core/seeds.rb +120 -147
- data/lib/decidim/core/test/factories.rb +24 -3
- data/lib/decidim/core/test/shared_examples/acts_as_author_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/withdraw_amendment_examples.rb +2 -2
- data/lib/decidim/core/test/shared_examples/announcements_examples.rb +3 -3
- data/lib/decidim/core/test/shared_examples/assembly_announcements_examples.rb +4 -4
- data/lib/decidim/core/test/shared_examples/comments_examples.rb +88 -82
- data/lib/decidim/core/test/shared_examples/comments_reports_examples.rb +4 -4
- data/lib/decidim/core/test/shared_examples/digest_mail_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/edit_link_shared_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/editor_shared_examples.rb +7 -7
- data/lib/decidim/core/test/shared_examples/fingerprint_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/follows_examples.rb +3 -3
- data/lib/decidim/core/test/shared_examples/has_attachment_collections.rb +4 -2
- data/lib/decidim/core/test/shared_examples/has_attachments.rb +3 -2
- data/lib/decidim/core/test/shared_examples/has_contextual_help.rb +4 -4
- data/lib/decidim/core/test/shared_examples/has_reference.rb +1 -1
- data/lib/decidim/core/test/shared_examples/logo_email.rb +1 -1
- data/lib/decidim/core/test/shared_examples/manage_component_share_tokens.rb +9 -9
- data/lib/decidim/core/test/shared_examples/map_examples.rb +5 -5
- data/lib/decidim/core/test/shared_examples/paginated_resource_examples.rb +2 -2
- data/lib/decidim/core/test/shared_examples/participatory_space_dropdown_metadata_cell_examples.rb +3 -3
- data/lib/decidim/core/test/shared_examples/preview_component_with_share_token_examples.rb +3 -3
- data/lib/decidim/core/test/shared_examples/process_announcements_examples.rb +4 -4
- data/lib/decidim/core/test/shared_examples/reports_examples.rb +5 -5
- data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +10 -10
- data/lib/decidim/core/test/shared_examples/searchable_participatory_space_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/searchable_results_examples.rb +8 -8
- data/lib/decidim/core/test/shared_examples/share_link_examples.rb +2 -2
- data/lib/decidim/core/test/shared_examples/simple_event.rb +1 -1
- data/lib/decidim/core/test/shared_examples/space_cell_changes_button_text_cta.rb +3 -3
- data/lib/decidim/core/test/shared_examples/system_endorse_resource_examples.rb +11 -11
- data/lib/decidim/core/test/shared_examples/translated_event_examples.rb +2 -2
- data/lib/decidim/core/test/shared_examples/uncommentable_component_examples.rb +2 -2
- data/lib/decidim/core/test/shared_examples/with_endorsable_permissions_examples.rb +1 -1
- data/lib/decidim/core/version.rb +1 -1
- data/lib/decidim/core.rb +24 -6
- data/lib/decidim/dependency_resolver.rb +3 -3
- data/lib/decidim/diffy_extension.rb +1 -1
- data/lib/decidim/download_your_data_serializers/download_your_data_user_serializer.rb +2 -1
- data/lib/decidim/engine_router.rb +2 -2
- data/lib/decidim/events/base_event.rb +19 -0
- data/lib/decidim/events/simple_event.rb +1 -0
- data/lib/decidim/exporters/export_manifest.rb +1 -1
- data/lib/decidim/faker/localized.rb +3 -3
- data/lib/decidim/form_builder.rb +4 -4
- data/lib/decidim/hashtag.rb +1 -1
- data/lib/decidim/jsonb_attributes.rb +4 -4
- data/lib/decidim/manifest_messages.rb +2 -2
- data/lib/decidim/organization_settings.rb +5 -5
- data/lib/decidim/paddable.rb +1 -1
- data/lib/decidim/participable.rb +1 -1
- data/lib/decidim/participatory_space_manifest.rb +1 -1
- data/lib/decidim/resourceable.rb +1 -1
- data/lib/decidim/search_resource_fields_mapper.rb +2 -2
- data/lib/decidim/searchable.rb +3 -3
- data/lib/decidim/seeds.rb +62 -0
- data/lib/decidim/stats_registry.rb +2 -2
- data/lib/decidim/translatable_attributes.rb +3 -3
- data/lib/decidim/translatable_resource.rb +1 -1
- data/lib/decidim/view_hooks.rb +1 -1
- data/lib/decidim/view_model.rb +4 -0
- data/lib/decidim/webpacker/esbuild.config.js +14 -0
- data/lib/decidim/webpacker/shakapacker.yml +2 -2
- data/lib/decidim/webpacker/tsconfig.json +11 -0
- data/lib/decidim/webpacker/webpack/custom.js +13 -35
- data/lib/devise/models/decidim_newsletterable.rb +1 -1
- data/lib/tasks/decidim_download_your_data_tasks.rake +2 -2
- data/lib/tasks/decidim_locales_tasks.rake +1 -1
- data/lib/tasks/decidim_mailers_tasks.rake +2 -2
- data/lib/tasks/decidim_metrics_tasks.rake +6 -6
- data/lib/tasks/decidim_procfile.rake +9 -3
- data/lib/tasks/decidim_tasks.rake +5 -4
- data/lib/tasks/decidim_webpacker_tasks.rake +126 -117
- data/lib/tasks/upgrade/decidim_active_storage_migration_tasks.rake +80 -0
- data/lib/tasks/upgrade/decidim_content_blocks_tasks.rake +50 -0
- data/lib/tasks/upgrade/decidim_deduplicate_endorsements.rake +1 -1
- data/lib/tasks/upgrade/decidim_fix_categorization.rake +1 -1
- data/lib/tasks/upgrade/decidim_fix_nickname_uniqueness.rake +1 -1
- data/lib/tasks/upgrade/decidim_fix_short_url_resolver.rake +1 -1
- data/lib/tasks/upgrade/decidim_moderation_tasks.rake +1 -1
- data/lib/tasks/upgrade/decidim_user_moderation.rake +1 -1
- metadata +202 -75
- data/app/cells/decidim/content_blocks/cta/show.erb +0 -12
- data/app/cells/decidim/content_blocks/cta_cell.rb +0 -31
- data/app/cells/decidim/footer_pages/pages.erb +0 -3
- data/app/cells/decidim/footer_pages/topics.erb +0 -12
- data/app/cells/decidim/footer_pages_cell.rb +0 -68
- data/app/packs/src/decidim/vendor/modernizr.js +0 -5
- data/app/queries/decidim/similar_emendations.rb +0 -56
- data/app/uploaders/decidim/cw/application_uploader.rb +0 -77
- data/app/uploaders/decidim/cw/attachment_uploader.rb +0 -56
- data/app/uploaders/decidim/cw/avatar_uploader.rb +0 -24
- data/app/uploaders/decidim/cw/banner_image_uploader.rb +0 -7
- data/app/uploaders/decidim/cw/download_your_data_uploader.rb +0 -15
- data/app/uploaders/decidim/cw/downloader.rb +0 -9
- data/app/uploaders/decidim/cw/hero_image_uploader.rb +0 -10
- data/app/uploaders/decidim/cw/homepage_image_uploader.rb +0 -14
- data/app/uploaders/decidim/cw/image_uploader.rb +0 -78
- data/app/uploaders/decidim/cw/newsletter_template_image_uploader.rb +0 -38
- data/app/uploaders/decidim/cw/oauth_application_logo_uploader.rb +0 -10
- data/app/uploaders/decidim/cw/official_image_footer_uploader.rb +0 -10
- data/app/uploaders/decidim/cw/official_image_header_uploader.rb +0 -10
- data/app/uploaders/decidim/cw/open_data_uploader.rb +0 -23
- data/app/uploaders/decidim/cw/organization_favicon_uploader.rb +0 -18
- data/app/uploaders/decidim/cw/organization_logo_uploader.rb +0 -10
- data/app/uploaders/decidim/cw/record_image_uploader.rb +0 -15
- data/app/uploaders/decidim/downloader.rb +0 -9
- data/app/views/decidim/amendments/compare_draft.html.erb +0 -18
- data/app/views/layouts/decidim/_edit_link.html.erb +0 -0
- data/app/views/layouts/decidim/header/_main_links_mobile.html.erb +0 -36
- data/config/initializers/carrierwave.rb +0 -15
- data/lib/decidim/carrier_wave_migrator_service.rb +0 -287
- data/lib/tasks/decidim_active_storage_migration_tasks.rake +0 -114
- data/lib/tasks/decidim_content_blocks_tasks.rake +0 -48
- /data/app/views/layouts/decidim/header/{_menu_breadcrumb_main_dropdown.html.erb → _menu_breadcrumb_main_dropdown_desktop.html.erb} +0 -0
@@ -3,12 +3,12 @@
|
|
3
3
|
module Decidim
|
4
4
|
# This command destroys the user's account.
|
5
5
|
class DestroyAccount < Decidim::Command
|
6
|
+
delegate :current_user, to: :form
|
7
|
+
|
6
8
|
# Destroy a user's account.
|
7
9
|
#
|
8
|
-
# user - The user to be updated.
|
9
10
|
# form - The form with the data.
|
10
|
-
def initialize(
|
11
|
-
@user = user
|
11
|
+
def initialize(form)
|
12
12
|
@form = form
|
13
13
|
end
|
14
14
|
|
@@ -29,40 +29,42 @@ module Decidim
|
|
29
29
|
|
30
30
|
private
|
31
31
|
|
32
|
+
attr_reader :form
|
33
|
+
|
32
34
|
def destroy_user_account!
|
33
|
-
|
35
|
+
current_user.invalidate_all_sessions!
|
34
36
|
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
37
|
+
current_user.name = ""
|
38
|
+
current_user.nickname = ""
|
39
|
+
current_user.email = ""
|
40
|
+
current_user.delete_reason = @form.delete_reason
|
41
|
+
current_user.admin = false if current_user.admin?
|
42
|
+
current_user.deleted_at = Time.current
|
43
|
+
current_user.skip_reconfirmation!
|
44
|
+
current_user.avatar.purge
|
45
|
+
current_user.save!
|
44
46
|
end
|
45
47
|
|
46
48
|
def destroy_user_identities
|
47
|
-
|
49
|
+
current_user.identities.destroy_all
|
48
50
|
end
|
49
51
|
|
50
52
|
def destroy_user_group_memberships
|
51
|
-
Decidim::UserGroupMembership.where(user:
|
53
|
+
Decidim::UserGroupMembership.where(user: current_user).destroy_all
|
52
54
|
end
|
53
55
|
|
54
56
|
def destroy_follows
|
55
|
-
Decidim::Follow.where(followable:
|
56
|
-
Decidim::Follow.where(user:
|
57
|
+
Decidim::Follow.where(followable: current_user).destroy_all
|
58
|
+
Decidim::Follow.where(user: current_user).destroy_all
|
57
59
|
end
|
58
60
|
|
59
61
|
def destroy_participatory_space_private_user
|
60
|
-
Decidim::ParticipatorySpacePrivateUser.where(user:
|
62
|
+
Decidim::ParticipatorySpacePrivateUser.where(user: current_user).destroy_all
|
61
63
|
end
|
62
64
|
|
63
65
|
def delegate_destroy_to_participatory_spaces
|
64
66
|
Decidim.participatory_space_manifests.each do |space_manifest|
|
65
|
-
space_manifest.invoke_on_destroy_account(
|
67
|
+
space_manifest.invoke_on_destroy_account(current_user)
|
66
68
|
end
|
67
69
|
end
|
68
70
|
end
|
@@ -8,7 +8,7 @@ module Decidim
|
|
8
8
|
#
|
9
9
|
# resource - An instance of Decidim::Endorsable.
|
10
10
|
# current_user - The current user.
|
11
|
-
# current_group_id- (optional) The
|
11
|
+
# current_group_id- (optional) The current_group that is endorsing the Resource.
|
12
12
|
def initialize(resource, current_user, current_group_id = nil)
|
13
13
|
@resource = resource
|
14
14
|
@current_user = current_user
|
@@ -23,16 +23,16 @@ module Decidim
|
|
23
23
|
return broadcast(:ok) if user_belongs_to_group?
|
24
24
|
|
25
25
|
transaction do
|
26
|
-
invite_user
|
26
|
+
@invitation = invite_user
|
27
27
|
send_notification
|
28
28
|
end
|
29
29
|
|
30
30
|
broadcast(:ok)
|
31
31
|
end
|
32
32
|
|
33
|
-
|
33
|
+
attr_reader :form, :user_group, :invitation
|
34
34
|
|
35
|
-
|
35
|
+
private
|
36
36
|
|
37
37
|
def invite_user
|
38
38
|
Decidim::UserGroupMembership.create!(
|
@@ -50,7 +50,8 @@ module Decidim
|
|
50
50
|
affected_users: [form.user],
|
51
51
|
extra: {
|
52
52
|
user_group_name: user_group.name,
|
53
|
-
user_group_nickname: user_group.nickname
|
53
|
+
user_group_nickname: user_group.nickname,
|
54
|
+
membership_id: invitation.id
|
54
55
|
}
|
55
56
|
)
|
56
57
|
end
|
@@ -3,12 +3,12 @@
|
|
3
3
|
module Decidim
|
4
4
|
# This command updates the user's account.
|
5
5
|
class UpdateAccount < Decidim::Command
|
6
|
+
delegate :current_user, to: :form
|
7
|
+
|
6
8
|
# Updates a user's account.
|
7
9
|
#
|
8
|
-
# user - The user to be updated.
|
9
10
|
# form - The form with the data.
|
10
|
-
def initialize(
|
11
|
-
@user = user
|
11
|
+
def initialize(form)
|
12
12
|
@form = form
|
13
13
|
end
|
14
14
|
|
@@ -19,15 +19,15 @@ module Decidim
|
|
19
19
|
update_avatar
|
20
20
|
update_password
|
21
21
|
|
22
|
-
if
|
23
|
-
changes =
|
24
|
-
|
22
|
+
if current_user.valid?
|
23
|
+
changes = current_user.changed
|
24
|
+
current_user.save!
|
25
25
|
notify_followers
|
26
26
|
send_update_summary!(changes)
|
27
|
-
broadcast(:ok,
|
27
|
+
broadcast(:ok, current_user.unconfirmed_email.present?)
|
28
28
|
else
|
29
29
|
[:avatar, :password].each do |key|
|
30
|
-
@form.errors.add key,
|
30
|
+
@form.errors.add key, current_user.errors[key] if current_user.errors.has_key? key
|
31
31
|
end
|
32
32
|
broadcast(:invalid, @form.password)
|
33
33
|
end
|
@@ -35,38 +35,40 @@ module Decidim
|
|
35
35
|
|
36
36
|
private
|
37
37
|
|
38
|
+
attr_reader :form
|
39
|
+
|
38
40
|
def update_personal_data
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
41
|
+
current_user.locale = @form.locale
|
42
|
+
current_user.name = @form.name
|
43
|
+
current_user.nickname = @form.nickname
|
44
|
+
current_user.email = @form.email
|
45
|
+
current_user.personal_url = @form.personal_url
|
46
|
+
current_user.about = @form.about
|
45
47
|
end
|
46
48
|
|
47
49
|
def update_avatar
|
48
50
|
if @form.avatar.present?
|
49
|
-
|
51
|
+
current_user.avatar.attach(@form.avatar)
|
50
52
|
elsif @form.remove_avatar
|
51
|
-
|
53
|
+
current_user.avatar = nil
|
52
54
|
end
|
53
55
|
end
|
54
56
|
|
55
57
|
def update_password
|
56
58
|
return if @form.password.blank?
|
57
59
|
|
58
|
-
|
59
|
-
|
60
|
+
current_user.password = @form.password
|
61
|
+
current_user.password_updated_at = Time.current
|
60
62
|
end
|
61
63
|
|
62
64
|
def notify_followers
|
63
|
-
return unless
|
65
|
+
return unless current_user.previous_changes.keys.intersect?(%w(about personal_url))
|
64
66
|
|
65
67
|
Decidim::EventsManager.publish(
|
66
68
|
event: "decidim.events.users.profile_updated",
|
67
69
|
event_class: Decidim::ProfileUpdatedEvent,
|
68
|
-
resource:
|
69
|
-
followers:
|
70
|
+
resource: current_user,
|
71
|
+
followers: current_user.followers
|
70
72
|
)
|
71
73
|
end
|
72
74
|
|
@@ -78,7 +80,7 @@ module Decidim
|
|
78
80
|
|
79
81
|
I18n.t("activemodel.attributes.user.#{attr}")
|
80
82
|
end
|
81
|
-
UserUpdateMailer.notify(
|
83
|
+
UserUpdateMailer.notify(current_user, updates).deliver_later
|
82
84
|
end
|
83
85
|
|
84
86
|
def attr_set
|
@@ -3,12 +3,12 @@
|
|
3
3
|
module Decidim
|
4
4
|
# This command updates the user's notifications settings.
|
5
5
|
class UpdateNotificationsSettings < Decidim::Command
|
6
|
+
delegate :current_user, to: :form
|
7
|
+
|
6
8
|
# Updates a user's notifications settings.
|
7
9
|
#
|
8
|
-
# user - The user to be updated.
|
9
10
|
# form - The form with the data.
|
10
|
-
def initialize(
|
11
|
-
@user = user
|
11
|
+
def initialize(form)
|
12
12
|
@form = form
|
13
13
|
end
|
14
14
|
|
@@ -16,20 +16,22 @@ module Decidim
|
|
16
16
|
return broadcast(:invalid) unless @form.valid?
|
17
17
|
|
18
18
|
update_notifications_settings
|
19
|
-
|
19
|
+
current_user.save!
|
20
20
|
|
21
|
-
broadcast(:ok,
|
21
|
+
broadcast(:ok, current_user)
|
22
22
|
end
|
23
23
|
|
24
24
|
private
|
25
25
|
|
26
|
+
attr_reader :form
|
27
|
+
|
26
28
|
def update_notifications_settings
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
29
|
+
current_user.newsletter_notifications_at = @form.newsletter_notifications_at
|
30
|
+
current_user.notification_types = @form.notification_types
|
31
|
+
current_user.direct_message_types = @form.direct_message_types
|
32
|
+
current_user.email_on_moderations = @form.email_on_moderations
|
33
|
+
current_user.notification_settings = current_user.notification_settings.merge(@form.notification_settings)
|
34
|
+
current_user.notifications_sending_frequency = @form.notifications_sending_frequency
|
33
35
|
end
|
34
36
|
end
|
35
37
|
end
|
@@ -3,22 +3,22 @@
|
|
3
3
|
module Decidim
|
4
4
|
# Decidim command updates user's password
|
5
5
|
class UpdatePassword < Decidim::Command
|
6
|
+
delegate :current_user, to: :form
|
7
|
+
|
6
8
|
# Updates a user's password.
|
7
9
|
#
|
8
|
-
# user - The user to be updated.
|
9
10
|
# form - The form with the data.
|
10
|
-
def initialize(
|
11
|
-
@user = user
|
11
|
+
def initialize(form)
|
12
12
|
@form = form
|
13
13
|
end
|
14
14
|
|
15
15
|
def call
|
16
16
|
return broadcast(:invalid) if form.invalid?
|
17
17
|
|
18
|
-
|
19
|
-
|
18
|
+
current_user.password = form.password
|
19
|
+
current_user.password_updated_at = Time.current
|
20
20
|
|
21
|
-
if
|
21
|
+
if current_user.save
|
22
22
|
broadcast(:ok)
|
23
23
|
else
|
24
24
|
broadcast(:invalid)
|
@@ -27,6 +27,6 @@ module Decidim
|
|
27
27
|
|
28
28
|
private
|
29
29
|
|
30
|
-
attr_reader :form
|
30
|
+
attr_reader :form
|
31
31
|
end
|
32
32
|
end
|
@@ -3,12 +3,12 @@
|
|
3
3
|
module Decidim
|
4
4
|
# This command updates the user's interests.
|
5
5
|
class UpdateUserInterests < Decidim::Command
|
6
|
-
|
6
|
+
delegate :current_user, to: :form
|
7
|
+
|
8
|
+
# Updates a user's interests.
|
7
9
|
#
|
8
|
-
# user - The user to be updated.
|
9
10
|
# form - The form with the data.
|
10
|
-
def initialize(
|
11
|
-
@user = user
|
11
|
+
def initialize(form)
|
12
12
|
@form = form
|
13
13
|
end
|
14
14
|
|
@@ -16,16 +16,18 @@ module Decidim
|
|
16
16
|
return broadcast(:invalid) unless @form.valid?
|
17
17
|
|
18
18
|
update_interests
|
19
|
-
|
19
|
+
current_user.save!
|
20
20
|
|
21
21
|
broadcast(:ok)
|
22
22
|
end
|
23
23
|
|
24
24
|
private
|
25
25
|
|
26
|
+
attr_reader :form
|
27
|
+
|
26
28
|
def update_interests
|
27
|
-
|
28
|
-
|
29
|
+
current_user.extended_data ||= {}
|
30
|
+
current_user.extended_data["interested_scopes"] = selected_scopes_ids
|
29
31
|
end
|
30
32
|
|
31
33
|
def selected_scopes_ids
|
@@ -16,6 +16,7 @@ module Decidim
|
|
16
16
|
include Decidim::NeedsOrganization
|
17
17
|
include Decidim::LocaleSwitcher
|
18
18
|
include ImpersonateUsers
|
19
|
+
include NeedsRtlDirection
|
19
20
|
include NeedsPermission
|
20
21
|
include Decidim::SafeRedirect
|
21
22
|
include NeedsSnippets
|
@@ -33,6 +34,7 @@ module Decidim
|
|
33
34
|
helper Decidim::CacheHelper
|
34
35
|
helper Decidim::SocialShareButtonHelper
|
35
36
|
helper Decidim::SanitizeHelper
|
37
|
+
helper Decidim::ApplicationHelper
|
36
38
|
|
37
39
|
layout "layouts/decidim/application"
|
38
40
|
|
@@ -0,0 +1,23 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
module NeedsRtlDirection
|
5
|
+
extend ActiveSupport::Concern
|
6
|
+
|
7
|
+
included do
|
8
|
+
helper_method :rtl_direction
|
9
|
+
|
10
|
+
def rtl_direction
|
11
|
+
return "rtl" if rtl_languages_codes.include?(I18n.locale.to_s)
|
12
|
+
|
13
|
+
"ltr"
|
14
|
+
end
|
15
|
+
|
16
|
+
private
|
17
|
+
|
18
|
+
def rtl_languages_codes
|
19
|
+
%w(ar ar-BH ar-EG ar-SA ar-YE dv he fa ks ks-PK ug ur-IN ur-PK ydd)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
@@ -7,21 +7,6 @@ module Decidim
|
|
7
7
|
module ParticipatorySpaceContext
|
8
8
|
extend ActiveSupport::Concern
|
9
9
|
|
10
|
-
class_methods do
|
11
|
-
# Public: Called on a controller, it sets up all the surrounding methods to render a
|
12
|
-
# participatory space's template. It expects the method `current_participatory_space` to be
|
13
|
-
# defined, from which it will extract the participatory manifest.
|
14
|
-
#
|
15
|
-
# options - A hash used to modify the behavior of the layout. :only: - An array of actions on
|
16
|
-
# which the layout will be applied.
|
17
|
-
#
|
18
|
-
# Returns nothing.
|
19
|
-
def participatory_space_layout(options = {})
|
20
|
-
layout :layout, **options
|
21
|
-
before_action :authorize_participatory_space, **options
|
22
|
-
end
|
23
|
-
end
|
24
|
-
|
25
10
|
included do
|
26
11
|
include Decidim::NeedsOrganization
|
27
12
|
|
@@ -91,7 +76,7 @@ module Decidim
|
|
91
76
|
current_participatory_space_manifest.context(current_participatory_space_context).layout
|
92
77
|
end
|
93
78
|
|
94
|
-
# Method for current user can visit the space (assembly or
|
79
|
+
# Method for current user can visit the space (assembly or process)
|
95
80
|
def current_user_can_visit_space?
|
96
81
|
return true unless current_participatory_space.try(:private_space?) &&
|
97
82
|
!current_participatory_space.try(:is_transparent?)
|
@@ -100,13 +85,6 @@ module Decidim
|
|
100
85
|
current_user.admin || current_participatory_space.users.include?(current_user)
|
101
86
|
end
|
102
87
|
|
103
|
-
def check_current_user_can_visit_space
|
104
|
-
return if current_user_can_visit_space?
|
105
|
-
|
106
|
-
flash[:alert] = I18n.t("participatory_space_private_users.not_allowed", scope: "decidim")
|
107
|
-
redirect_to action: "index"
|
108
|
-
end
|
109
|
-
|
110
88
|
def help_section
|
111
89
|
@help_section ||= Decidim::ContextualHelpSection.find_content(
|
112
90
|
current_organization,
|
@@ -5,13 +5,14 @@ require "active_support/concern"
|
|
5
5
|
module Decidim
|
6
6
|
module PayloadInfo
|
7
7
|
extend ActiveSupport::Concern
|
8
|
+
include Decidim::TranslatableAttributes
|
8
9
|
|
9
10
|
included do
|
10
11
|
def append_info_to_payload(payload)
|
11
12
|
super
|
12
13
|
payload[:user_id] = try(:current_user).try(:id)
|
13
14
|
payload[:organization_id] = try(:current_organization).try(:id)
|
14
|
-
payload[:app] = try(:current_organization).try(:name)
|
15
|
+
payload[:app] = translated_attribute(try(:current_organization).try(:name))
|
15
16
|
payload[:remote_ip] = request.remote_ip
|
16
17
|
payload[:referer] = request.referer.to_s
|
17
18
|
payload[:request_id] = request.uuid
|
@@ -10,8 +10,8 @@ module Decidim
|
|
10
10
|
module RegistersPermissions
|
11
11
|
extend ActiveSupport::Concern
|
12
12
|
|
13
|
-
def self.register_permissions(artifact, *
|
14
|
-
::Decidim.permissions_registry.register_permissions(artifact, *
|
13
|
+
def self.register_permissions(artifact, *)
|
14
|
+
::Decidim.permissions_registry.register_permissions(artifact, *)
|
15
15
|
end
|
16
16
|
|
17
17
|
class_methods do
|
@@ -19,8 +19,8 @@ module Decidim
|
|
19
19
|
#
|
20
20
|
# +artifact+ is expected to be the class or module that declares `NeedsPermission.permission_class_chain`.
|
21
21
|
# +permission_classes+ are subclasses of `DefaultPermissions` or at least should quack as one.
|
22
|
-
def register_permissions(artifact, *
|
23
|
-
RegistersPermissions.register_permissions(artifact, *
|
22
|
+
def register_permissions(artifact, *)
|
23
|
+
RegistersPermissions.register_permissions(artifact, *)
|
24
24
|
end
|
25
25
|
end
|
26
26
|
end
|
@@ -12,7 +12,7 @@ module Decidim
|
|
12
12
|
around_action :use_organization_time_zone
|
13
13
|
helper_method :organization_time_zone
|
14
14
|
|
15
|
-
# Executes a block of code in the context of the
|
15
|
+
# Executes a block of code in the context of the organization's time zone
|
16
16
|
#
|
17
17
|
# &action - a block of code to be wrapped around the time zone
|
18
18
|
#
|
@@ -3,7 +3,7 @@
|
|
3
3
|
require "active_support/concern"
|
4
4
|
|
5
5
|
module Decidim
|
6
|
-
# A controller concern to enable
|
6
|
+
# A controller concern to enable withdrawing the controller resources. Only
|
7
7
|
# affects the UI, so the actual logic to withdraw the resource will still need
|
8
8
|
# to be implemented.
|
9
9
|
module Withdrawable
|
@@ -16,7 +16,7 @@ module Decidim
|
|
16
16
|
def update
|
17
17
|
enforce_permission_to(:update, :user, current_user:)
|
18
18
|
@account = form(AccountForm).from_params(account_params)
|
19
|
-
UpdateAccount.call(
|
19
|
+
UpdateAccount.call(@account) do
|
20
20
|
on(:ok) do |email_is_unconfirmed|
|
21
21
|
flash[:notice] = if email_is_unconfirmed
|
22
22
|
t("account.update.success_with_email_confirmation", scope: "decidim")
|
@@ -45,7 +45,7 @@ module Decidim
|
|
45
45
|
enforce_permission_to(:delete, :user, current_user:)
|
46
46
|
@form = form(DeleteAccountForm).from_params(params)
|
47
47
|
|
48
|
-
DestroyAccount.call(
|
48
|
+
DestroyAccount.call(@form) do
|
49
49
|
on(:ok) do
|
50
50
|
sign_out(current_user)
|
51
51
|
flash[:notice] = t("account.destroy.success", scope: "decidim")
|
@@ -9,8 +9,8 @@ module Decidim
|
|
9
9
|
helper UserGroupHelper
|
10
10
|
|
11
11
|
before_action :authenticate_user!
|
12
|
-
helper_method :amendment, :amendable, :emendation
|
13
|
-
before_action :ensure_is_draft_from_user, only: [:
|
12
|
+
helper_method :amendment, :amendable, :emendation
|
13
|
+
before_action :ensure_is_draft_from_user, only: [:edit_draft, :update_draft, :destroy_draft, :preview_draft, :publish_draft]
|
14
14
|
|
15
15
|
def new
|
16
16
|
raise ActionController::RoutingError, "Not Found" unless amendable
|
@@ -34,7 +34,7 @@ module Decidim
|
|
34
34
|
Decidim::Amendable::CreateDraft.call(@form) do
|
35
35
|
on(:ok) do |amendment|
|
36
36
|
flash[:notice] = t("created.success", scope: "decidim.amendments")
|
37
|
-
redirect_to
|
37
|
+
redirect_to preview_draft_amend_path(amendment)
|
38
38
|
end
|
39
39
|
|
40
40
|
on(:invalid) do
|
@@ -44,15 +44,6 @@ module Decidim
|
|
44
44
|
end
|
45
45
|
end
|
46
46
|
|
47
|
-
def compare_draft
|
48
|
-
enforce_permission_to :create, :amendment, current_component: amendable.component
|
49
|
-
|
50
|
-
if similar_emendations.empty?
|
51
|
-
flash[:notice] = t("no_similars_found", scope: "decidim.amendments.compare_draft")
|
52
|
-
redirect_to edit_draft_amend_path(amendment)
|
53
|
-
end
|
54
|
-
end
|
55
|
-
|
56
47
|
def edit_draft
|
57
48
|
enforce_permission_to :create, :amendment, current_component: amendable.component
|
58
49
|
|
@@ -219,10 +210,6 @@ module Decidim
|
|
219
210
|
raise ActionController::RoutingError, "Not Found" unless amendment.draft? && amender == current_user
|
220
211
|
end
|
221
212
|
|
222
|
-
def similar_emendations
|
223
|
-
@similar_emendations ||= Decidim::SimilarEmendations.for(amendment)
|
224
|
-
end
|
225
|
-
|
226
213
|
def breadcrumb_item
|
227
214
|
{
|
228
215
|
label: t("decidim.amendments.name"),
|
@@ -3,7 +3,7 @@
|
|
3
3
|
module Decidim
|
4
4
|
module Components
|
5
5
|
# Controller from which all component engines inherit from. It is in charge of
|
6
|
-
# setting the
|
6
|
+
# setting the appropriate layout, including necessary helpers, and overall
|
7
7
|
# fooling the engine into thinking it is isolated.
|
8
8
|
class BaseController < Decidim::ApplicationController
|
9
9
|
include Settings
|
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
module Decidim
|
4
4
|
module Devise
|
5
|
-
# This controller customizes the behaviour of Devise::
|
5
|
+
# This controller customizes the behaviour of Devise::Invitable.
|
6
6
|
class InvitationsController < ::Devise::InvitationsController
|
7
7
|
include Decidim::DeviseControllers
|
8
8
|
include NeedsTosAccepted
|
@@ -25,8 +25,8 @@ module Decidim
|
|
25
25
|
self.resource = current_user
|
26
26
|
@send_path = apply_password_path
|
27
27
|
|
28
|
-
@form = Decidim::PasswordForm.from_params(params["user"])
|
29
|
-
Decidim::UpdatePassword.call(
|
28
|
+
@form = Decidim::PasswordForm.from_params(params["user"]).with_context(current_user:)
|
29
|
+
Decidim::UpdatePassword.call(@form) do
|
30
30
|
on(:ok) do
|
31
31
|
flash[:notice] = t("passwords.update.success", scope: "decidim")
|
32
32
|
bypass_sign_in(current_user)
|
@@ -48,7 +48,7 @@ module Decidim
|
|
48
48
|
render :identities, layout: false
|
49
49
|
end
|
50
50
|
|
51
|
-
# should be pubic in order to be
|
51
|
+
# should be pubic in order to be visible in NeedsPermission#permissions_context
|
52
52
|
def current_component
|
53
53
|
resource.component
|
54
54
|
end
|
@@ -4,7 +4,7 @@ module Decidim
|
|
4
4
|
# We serve a custom /favicon.ico route for Decidim in order to show the
|
5
5
|
# correct favicons also when browsing e.g. PDF documents originating from the
|
6
6
|
# same domain displayed inline in the browser. For those special files
|
7
|
-
# displayed in the browser, the favicon could be otherwise incorrectly
|
7
|
+
# displayed in the browser, the favicon could be otherwise incorrectly shown
|
8
8
|
# or cached.
|
9
9
|
#
|
10
10
|
# This custom route ensures that the favicons are always correctly served for
|
@@ -10,7 +10,7 @@ module Decidim
|
|
10
10
|
@form = form(Decidim::FollowForm).from_params(params)
|
11
11
|
enforce_permission_to :delete, :follow, follow: @form.follow
|
12
12
|
|
13
|
-
DeleteFollow.call(@form
|
13
|
+
DeleteFollow.call(@form) do
|
14
14
|
on(:ok) do
|
15
15
|
render :update_button
|
16
16
|
end
|
@@ -25,7 +25,7 @@ module Decidim
|
|
25
25
|
@form = form(Decidim::FollowForm).from_params(params)
|
26
26
|
enforce_permission_to :create, :follow
|
27
27
|
|
28
|
-
CreateFollow.call(@form
|
28
|
+
CreateFollow.call(@form) do
|
29
29
|
on(:ok) do
|
30
30
|
render :update_button
|
31
31
|
end
|