decidim-core 0.28.1 → 0.29.0.rc1
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 +3 -3
- 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/show.erb +5 -5
- 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/show.erb +1 -1
- 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/show.erb +2 -2
- 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/data_consent/category.erb +1 -1
- 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/nav_links/show.erb +2 -2
- 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/moderated.erb +12 -0
- 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 +14 -4
- 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/details.erb +1 -1
- 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/progress_bar_cell.rb +2 -0
- data/app/cells/decidim/public_participation/show.erb +1 -1
- data/app/cells/decidim/report_button/flag_modal.erb +6 -2
- data/app/cells/decidim/resource_types_filter/show.erb +3 -3
- 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/show.erb +2 -2
- 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/modal.erb +3 -4
- 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/force_authentication.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 +2 -2
- 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/gamification/badges_controller.rb +2 -0
- data/app/controllers/decidim/group_invites_controller.rb +36 -9
- data/app/controllers/decidim/links_controller.rb +15 -2
- 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 +3 -3
- 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 +2 -3
- 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 +44 -6
- 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 +60 -0
- data/app/packs/src/decidim/abide_form_validator_fixer.js +44 -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/direct_uploads/upload_modal.js +2 -6
- 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 +40 -6
- 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/_accordion.scss +2 -2
- data/app/packs/stylesheets/decidim/_cards.scss +2 -2
- 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 +16 -3
- data/app/packs/stylesheets/decidim/_modal.scss +1 -1
- data/app/packs/stylesheets/decidim/_modal_update.scss +2 -4
- 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 +2 -2
- 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/log/resource_presenter.rb +7 -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 +3 -3
- 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 +3 -3
- 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 +24 -10
- 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/endorsements/update_buttons_and_counters.js.erb +2 -1
- data/app/views/decidim/gamification/badges/index.html.erb +34 -33
- data/app/views/decidim/links/_modal.html.erb +1 -1
- data/app/views/decidim/links/new.html.erb +3 -1
- data/app/views/decidim/manifests/show.json.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/messaging/conversations/create.js.erb +1 -1
- 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/notifications_settings/show.html.erb +6 -6
- data/app/views/decidim/pages/_tabbed.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/_filters.html.erb +2 -2
- 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/_filters.html.erb +2 -2
- data/app/views/decidim/shared/_login_modal.html.erb +1 -1
- data/app/views/decidim/shared/_orders.html.erb +2 -2
- data/app/views/decidim/shared/filters/_collection.html.erb +5 -3
- data/app/views/decidim/shared/filters/_dropdown_label.html.erb +21 -19
- 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 -9
- 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 +7 -6
- 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_items.html.erb +2 -0
- 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/app/views/layouts/decidim/shared/_layout_user_profile.html.erb +2 -2
- 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 +3 -47
- data/config/locales/bg.yml +916 -41
- data/config/locales/ca.yml +67 -54
- data/config/locales/cs.yml +54 -56
- data/config/locales/de.yml +65 -52
- data/config/locales/el.yml +8 -30
- data/config/locales/en.yml +71 -58
- data/config/locales/es-MX.yml +73 -60
- data/config/locales/es-PY.yml +73 -60
- data/config/locales/es.yml +96 -83
- data/config/locales/eu.yml +71 -58
- data/config/locales/fi-plain.yml +69 -56
- data/config/locales/fi.yml +69 -56
- data/config/locales/fr-CA.yml +62 -55
- data/config/locales/fr.yml +57 -50
- data/config/locales/ga-IE.yml +7 -10
- data/config/locales/gl.yml +1 -18
- data/config/locales/hu.yml +37 -58
- data/config/locales/id-ID.yml +0 -14
- data/config/locales/is-IS.yml +0 -10
- data/config/locales/it.yml +7 -26
- data/config/locales/ja.yml +69 -56
- data/config/locales/kaa.yml +5 -0
- data/config/locales/lb.yml +7 -26
- data/config/locales/lt.yml +8 -50
- data/config/locales/lv.yml +8 -22
- data/config/locales/nl.yml +7 -25
- data/config/locales/no.yml +7 -26
- data/config/locales/pl.yml +99 -53
- data/config/locales/pt-BR.yml +4 -52
- data/config/locales/pt.yml +7 -26
- data/config/locales/ro-RO.yml +9 -28
- data/config/locales/ru.yml +8 -15
- data/config/locales/sk.yml +8 -22
- data/config/locales/sl.yml +8 -8
- data/config/locales/sv.yml +8 -34
- data/config/locales/tr-TR.yml +22 -28
- data/config/locales/uk.yml +10 -10
- data/config/locales/zh-CN.yml +0 -23
- data/config/locales/zh-TW.yml +8 -48
- 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 +121 -148
- 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 +157 -81
- 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 +2 -2
- 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 +30 -7
- 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 +23 -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 +15 -7
- 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 +208 -79
- 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,6 +3,7 @@
|
|
3
3
|
module Decidim
|
4
4
|
# View helpers related to the layout.
|
5
5
|
module LayoutHelper
|
6
|
+
include Decidim::OrganizationHelper
|
6
7
|
include Decidim::ModalHelper
|
7
8
|
include Decidim::TooltipHelper
|
8
9
|
|
@@ -129,28 +130,6 @@ module Decidim
|
|
129
130
|
}
|
130
131
|
end
|
131
132
|
|
132
|
-
# Renders a view with the customizable CSS variables in two flavours:
|
133
|
-
# 1. as a hexadecimal valid CSS color (ie: #ff0000)
|
134
|
-
# 2. as a disassembled RGB components (ie: 255 0 0)
|
135
|
-
#
|
136
|
-
# Example:
|
137
|
-
#
|
138
|
-
# --primary: #ff0000;
|
139
|
-
# --primary-rgb: 255 0 0
|
140
|
-
#
|
141
|
-
# Hexadecimal variables can be used as a normal CSS color:
|
142
|
-
#
|
143
|
-
# color: var(--primary)
|
144
|
-
#
|
145
|
-
# While the disassembled variant can be used where you need to manipulate
|
146
|
-
# the color somehow (ie: adding a background transparency):
|
147
|
-
#
|
148
|
-
# background-color: rgba(var(--primary-rgb), 0.5)
|
149
|
-
def organization_colors
|
150
|
-
css = current_organization.colors.each.map { |k, v| "--#{k}: #{v};--#{k}-rgb: #{v[1..2].hex} #{v[3..4].hex} #{v[5..6].hex};" }.join
|
151
|
-
render partial: "layouts/decidim/organization_colors", locals: { css: }
|
152
|
-
end
|
153
|
-
|
154
133
|
def current_user_unread_data
|
155
134
|
return {} if current_user.blank?
|
156
135
|
|
@@ -161,22 +140,8 @@ module Decidim
|
|
161
140
|
end
|
162
141
|
end
|
163
142
|
|
164
|
-
def organization_description_label
|
165
|
-
@organization_description_label ||= if empty_organization_description?
|
166
|
-
t("decidim.pages.home.footer_sub_hero.footer_sub_hero_body_html")
|
167
|
-
else
|
168
|
-
decidim_sanitize_admin(translated_attribute(current_organization.description))
|
169
|
-
end
|
170
|
-
end
|
171
|
-
|
172
143
|
private
|
173
144
|
|
174
|
-
def empty_organization_description?
|
175
|
-
organization_description = translated_attribute(current_organization.description)
|
176
|
-
|
177
|
-
organization_description.blank? || organization_description == "<p></p>"
|
178
|
-
end
|
179
|
-
|
180
145
|
def tag_builder
|
181
146
|
@tag_builder ||= ActionView::Helpers::TagHelper::TagBuilder.new(self)
|
182
147
|
end
|
@@ -21,7 +21,7 @@ module Decidim
|
|
21
21
|
# locales.
|
22
22
|
#
|
23
23
|
# collection - an Array of Strings. By default it uses all the available
|
24
|
-
# locales in Decidim, but you can
|
24
|
+
# locales in Decidim, but you can pass another collection of locales (for
|
25
25
|
# example, the available locales for an organization)
|
26
26
|
def localized_locales(collection = Decidim.available_locales)
|
27
27
|
klass = Class.new do
|
@@ -43,6 +43,14 @@ module Decidim
|
|
43
43
|
)
|
44
44
|
end
|
45
45
|
|
46
|
+
def mobile_breadcrumb_root_menu
|
47
|
+
@mobile_breadcrumb_root_menu ||= ::Decidim::BreadcrumbRootMenuPresenter.new(
|
48
|
+
:mobile_menu,
|
49
|
+
self,
|
50
|
+
container_options: { class: "menu-bar__main-dropdown__menu" }
|
51
|
+
)
|
52
|
+
end
|
53
|
+
|
46
54
|
def footer_menu
|
47
55
|
@footer_menu ||= ::Decidim::FooterMenuPresenter.new(
|
48
56
|
:menu,
|
@@ -3,13 +3,13 @@
|
|
3
3
|
module Decidim
|
4
4
|
# Helper that provides convenient methods to deal with the page meta tags.
|
5
5
|
module MetaTagsHelper
|
6
|
-
#
|
6
|
+
# Sets the given metatags for the page. It is a wrapper for the individual
|
7
7
|
# methods, so that you can set multiple values with a single call. See the docs for
|
8
8
|
# the other methods to see how they work.
|
9
9
|
#
|
10
|
-
# tags - A Hash containing the meta tag name as keys and its content as values.
|
10
|
+
# @param [Hash] tags - A Hash containing the meta tag name as keys and its content as values.
|
11
11
|
#
|
12
|
-
#
|
12
|
+
# @return [nil]
|
13
13
|
def add_decidim_meta_tags(tags)
|
14
14
|
add_decidim_page_title(tags[:title])
|
15
15
|
add_decidim_meta_description(tags[:description])
|
@@ -18,9 +18,11 @@ module Decidim
|
|
18
18
|
add_decidim_meta_image_url(add_base_url_to(tags[:image_url]))
|
19
19
|
end
|
20
20
|
|
21
|
-
#
|
22
|
-
#
|
23
|
-
#
|
21
|
+
# Add base url to path if path does not include host.
|
22
|
+
#
|
23
|
+
# @parma [String] path - A String containing path (e.g. "/proposals/1" )
|
24
|
+
#
|
25
|
+
# @return [String] - a String of URL including base URL and path, or path if it is blank.
|
24
26
|
def add_base_url_to(path)
|
25
27
|
return path if path.blank?
|
26
28
|
return path if URI.parse(path).host.present?
|
@@ -28,8 +30,9 @@ module Decidim
|
|
28
30
|
"#{resolve_base_url}#{path}"
|
29
31
|
end
|
30
32
|
|
31
|
-
#
|
32
|
-
#
|
33
|
+
# Resolve base url (example: https://www.decidim.org) without url params
|
34
|
+
#
|
35
|
+
# @return [String] - a String of base URL
|
33
36
|
def resolve_base_url
|
34
37
|
return request.base_url if respond_to?(:request) && request&.base_url.present?
|
35
38
|
|
@@ -41,20 +44,20 @@ module Decidim
|
|
41
44
|
end
|
42
45
|
end
|
43
46
|
|
44
|
-
#
|
45
|
-
# are rendered inside-out, `title` is appended to an array. This way the
|
47
|
+
# Accumulates the given `title` so that they can be chained. Since Rails views
|
48
|
+
# are rendered inside-out, `title` is appended to an array. This way the beginning of
|
46
49
|
# the title will be the most specific one. Use the `decidim_page_title` method to
|
47
50
|
# render the title whenever you need to (most surely, in the `<title>` tag in the HTML
|
48
51
|
# head and in some `title` metatags).
|
49
52
|
#
|
50
|
-
#
|
53
|
+
# @example
|
51
54
|
# add_decidim_page_title("My Process")
|
52
55
|
# add_decidim_page_title("My Organization")
|
53
56
|
# decidim_page_title # => "My Process - My Organization"
|
54
57
|
#
|
55
|
-
# title - A String to be added to the title
|
58
|
+
# @param [String] title - A String to be added to the title
|
56
59
|
#
|
57
|
-
#
|
60
|
+
# @return [Array<String>]
|
58
61
|
def add_decidim_page_title(title)
|
59
62
|
@decidim_page_title ||= []
|
60
63
|
return @decidim_page_title if title.blank?
|
@@ -62,11 +65,11 @@ module Decidim
|
|
62
65
|
@decidim_page_title << title
|
63
66
|
end
|
64
67
|
|
65
|
-
#
|
68
|
+
# Renders the title for a page. Use the `add_decidim_page_title` method to
|
66
69
|
# accumulate elements for the title. Basically, it joins the elements of the title
|
67
70
|
# array with `" - "`.
|
68
71
|
#
|
69
|
-
#
|
72
|
+
# @return [String]
|
70
73
|
def decidim_page_title
|
71
74
|
(@decidim_page_title || []).join(" - ")
|
72
75
|
end
|
@@ -80,9 +83,9 @@ module Decidim
|
|
80
83
|
# is the last one to be rendered. You can put there a basic content and override it
|
81
84
|
# in other layers.
|
82
85
|
#
|
83
|
-
# description - The String to be set as description
|
86
|
+
# @param [String] description - The String to be set as description
|
84
87
|
#
|
85
|
-
#
|
88
|
+
# @return [nil]
|
86
89
|
def add_decidim_meta_description(description)
|
87
90
|
@decidim_meta_description ||= strip_tags(description)
|
88
91
|
end
|
@@ -93,9 +96,9 @@ module Decidim
|
|
93
96
|
# is the last one to be rendered. You can put there a basic content and override it
|
94
97
|
# in other layers.
|
95
98
|
#
|
96
|
-
# twitter_handler - The String to be set as Twitter handler
|
99
|
+
# @param [String] twitter_handler - The String to be set as Twitter handler
|
97
100
|
#
|
98
|
-
#
|
101
|
+
# @return [nil]
|
99
102
|
def add_decidim_meta_twitter_handler(twitter_handler)
|
100
103
|
@decidim_meta_twitter_handler ||= twitter_handler
|
101
104
|
end
|
@@ -106,9 +109,9 @@ module Decidim
|
|
106
109
|
# is the last one to be rendered. You can put there a basic content and override it
|
107
110
|
# in other layers.
|
108
111
|
#
|
109
|
-
# url - The String to be set as URL
|
112
|
+
# @param [String] url - The String to be set as URL
|
110
113
|
#
|
111
|
-
#
|
114
|
+
# @return [nil]
|
112
115
|
def add_decidim_meta_url(url)
|
113
116
|
@decidim_meta_url ||= url
|
114
117
|
end
|
@@ -119,9 +122,9 @@ module Decidim
|
|
119
122
|
# is the last one to be rendered. You can put there a basic content and override it
|
120
123
|
# in other layers.
|
121
124
|
#
|
122
|
-
# image_url - The String to be set as image URL
|
125
|
+
# @param [String] image_url - The String to be set as image URL
|
123
126
|
#
|
124
|
-
#
|
127
|
+
# @return [nil]
|
125
128
|
def add_decidim_meta_image_url(image_url)
|
126
129
|
@decidim_meta_image_url ||= image_url
|
127
130
|
end
|
@@ -8,7 +8,7 @@ module Decidim
|
|
8
8
|
# you also can add your custom close button through data-dialog-close="<seed>"
|
9
9
|
#
|
10
10
|
# Options available:
|
11
|
-
# - id: String. Unique
|
11
|
+
# - id: String. Unique identifier for the dialog, if the page has distinct modal windows (default: "")
|
12
12
|
# - class: String. CSS classes for the modal content.
|
13
13
|
# - closable: Boolean. Whether the modal can be closed or not (default: true)
|
14
14
|
module ModalHelper
|
@@ -7,7 +7,7 @@ module Decidim
|
|
7
7
|
# (Note) This method requires the javascript 'decidim/orders' to be
|
8
8
|
# present in the page.
|
9
9
|
#
|
10
|
-
# orders - An array of order
|
10
|
+
# orders - An array of order criteria
|
11
11
|
# options - An optional hash of options
|
12
12
|
# * i18n_scope - The scope of the i18n translations
|
13
13
|
def order_selector(orders, options = {})
|
@@ -0,0 +1,55 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
# View helpers related to the organization.
|
5
|
+
|
6
|
+
module OrganizationHelper
|
7
|
+
include Decidim::TranslatableAttributes
|
8
|
+
|
9
|
+
# Renders a view with the customizable CSS variables in two flavours:
|
10
|
+
# 1. as a hexadecimal valid CSS color (ie: #ff0000)
|
11
|
+
# 2. as a disassembled RGB components (ie: 255 0 0)
|
12
|
+
#
|
13
|
+
# Example:
|
14
|
+
#
|
15
|
+
# --primary: #ff0000;
|
16
|
+
# --primary-rgb: 255 0 0
|
17
|
+
#
|
18
|
+
# Hexadecimal variables can be used as a normal CSS color:
|
19
|
+
#
|
20
|
+
# color: var(--primary)
|
21
|
+
#
|
22
|
+
# While the disassembled variant can be used where you need to manipulate
|
23
|
+
# the color somehow (ie: adding a background transparency):
|
24
|
+
#
|
25
|
+
# background-color: rgba(var(--primary-rgb), 0.5)
|
26
|
+
def organization_colors
|
27
|
+
css = current_organization.colors.each.map { |k, v| "--#{k}: #{v};--#{k}-rgb: #{v[1..2].hex} #{v[3..4].hex} #{v[5..6].hex};" }.join
|
28
|
+
render partial: "layouts/decidim/organization_colors", locals: { css: }
|
29
|
+
end
|
30
|
+
|
31
|
+
def organization_description_label
|
32
|
+
@organization_description_label ||= if empty_organization_description?
|
33
|
+
t("decidim.pages.home.footer_sub_hero.footer_sub_hero_body_html")
|
34
|
+
else
|
35
|
+
decidim_sanitize_admin(translated_attribute(current_organization.description))
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
def organization_name(organization = current_organization)
|
40
|
+
translated_attribute(organization.name, organization)
|
41
|
+
end
|
42
|
+
|
43
|
+
def current_organization_name
|
44
|
+
organization_name(current_organization)
|
45
|
+
end
|
46
|
+
|
47
|
+
private
|
48
|
+
|
49
|
+
def empty_organization_description?
|
50
|
+
organization_description = translated_attribute(current_organization.description)
|
51
|
+
|
52
|
+
organization_description.blank? || organization_description == "<p></p>"
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
@@ -13,7 +13,7 @@ module Decidim
|
|
13
13
|
|
14
14
|
content_tag :div, class: "flex flex-col-reverse md:flex-row items-center justify-between gap-1 py-8 md:py-16", data: { pagination: "" } do
|
15
15
|
template = ""
|
16
|
-
template += render
|
16
|
+
template += render(partial: "decidim/shared/results_per_page", formats: [:html]) if collection.total_pages.positive?
|
17
17
|
template += paginate collection, window: 2, outer_window: 1, theme: "decidim", params: paginate_params
|
18
18
|
template.html_safe
|
19
19
|
end
|
@@ -47,12 +47,5 @@ module Decidim
|
|
47
47
|
|
48
48
|
::Decidim::ResourceLocatorPresenter.new(resource)
|
49
49
|
end
|
50
|
-
|
51
|
-
# Returns a descriptive title for the resource
|
52
|
-
def resource_title(resource)
|
53
|
-
title = resource.try(:title) || resource.try(:name) || resource.try(:subject) || "#{resource.model_name.human} ##{resource.id}"
|
54
|
-
title = translated_attribute(title) if title.is_a?(Hash)
|
55
|
-
title
|
56
|
-
end
|
57
50
|
end
|
58
51
|
end
|
@@ -9,7 +9,7 @@ module Decidim
|
|
9
9
|
Option = Struct.new(:id, :name)
|
10
10
|
|
11
11
|
# Checks if the resource should show its scope or not.
|
12
|
-
# resource - the resource to
|
12
|
+
# resource - the resource to analyze
|
13
13
|
#
|
14
14
|
# Returns boolean.
|
15
15
|
def has_visible_scopes?(resource)
|
@@ -54,10 +54,12 @@ module Decidim
|
|
54
54
|
#
|
55
55
|
# Returns nothing.
|
56
56
|
def scopes_select_field(form, name, root: false, options: {})
|
57
|
+
options = options.merge(include_blank: I18n.t("decidim.scopes.prompt")) unless options.has_key?(:include_blank)
|
58
|
+
|
57
59
|
form.select(
|
58
60
|
name,
|
59
61
|
ordered_scopes_descendants_for_select(root),
|
60
|
-
options
|
62
|
+
options
|
61
63
|
)
|
62
64
|
end
|
63
65
|
|
@@ -7,7 +7,7 @@ module Decidim
|
|
7
7
|
#
|
8
8
|
# klass_name - a String representing the class name of the resource to render
|
9
9
|
# count - (optional) the number of resources so that the I18n backend
|
10
|
-
# can decide to translate into
|
10
|
+
# can decide to translate into singular or plural form.
|
11
11
|
def searchable_resource_human_name(resource, count: 5)
|
12
12
|
resource = if resource.is_a?(String)
|
13
13
|
resource.constantize
|
@@ -15,14 +15,14 @@ module Decidim
|
|
15
15
|
# @option kwargs [Float] :params the URL query parameters that should be
|
16
16
|
# included in the URL where the short link redirects to
|
17
17
|
# @return [String] The short URL
|
18
|
-
def short_url(**
|
18
|
+
def short_url(**)
|
19
19
|
target = respond_to?(:current_component) && current_component
|
20
20
|
target ||= respond_to?(:current_participatory_space) && current_participatory_space
|
21
21
|
target ||= respond_to?(:current_organization) && current_organization
|
22
22
|
target ||= Rails.application
|
23
23
|
|
24
24
|
mounted_engine = target.try(:mounted_engine) || EngineResolver.new(_routes).mounted_name
|
25
|
-
ShortLink.to(target, mounted_engine, **
|
25
|
+
ShortLink.to(target, mounted_engine, **).short_url
|
26
26
|
end
|
27
27
|
end
|
28
28
|
end
|
@@ -14,10 +14,10 @@ module Decidim
|
|
14
14
|
# options - Any other option to delegate to the individual I18n.t calls
|
15
15
|
#
|
16
16
|
# Returns a Hash with the locales as keys and the translations as values.
|
17
|
-
def multi_translation(key, locales = Decidim.available_locales, **
|
17
|
+
def multi_translation(key, locales = Decidim.available_locales, **)
|
18
18
|
locales.each_with_object({}) do |locale, result|
|
19
19
|
I18n.with_locale(locale) do
|
20
|
-
result[locale.to_sym] = I18n.t(key, **
|
20
|
+
result[locale.to_sym] = I18n.t(key, **)
|
21
21
|
end
|
22
22
|
end
|
23
23
|
end
|
@@ -8,10 +8,10 @@ module Decidim
|
|
8
8
|
user = Decidim::User.find_by(id: user_id)
|
9
9
|
return if user.blank?
|
10
10
|
|
11
|
-
should_notify = force || NotificationsDigestSendingDecider.must_notify?(user, time
|
11
|
+
should_notify = force || NotificationsDigestSendingDecider.must_notify?(user, time)
|
12
12
|
return unless should_notify
|
13
13
|
|
14
|
-
notification_ids = user.notifications.try(frequency, time
|
14
|
+
notification_ids = user.notifications.try(frequency, time).pluck(:id)
|
15
15
|
return if notification_ids.blank?
|
16
16
|
|
17
17
|
NotificationsDigestMailer.digest_mail(user, notification_ids).deliver_later
|
@@ -6,24 +6,62 @@ module Decidim
|
|
6
6
|
class ApplicationMailer < ActionMailer::Base
|
7
7
|
include LocalisedMailer
|
8
8
|
include MultitenantAssetHost
|
9
|
+
include Decidim::SanitizeHelper
|
10
|
+
include Decidim::OrganizationHelper
|
11
|
+
helper_method :organization_name, :decidim_escape_translated, :decidim_sanitize_translated, :translated_attribute, :decidim_sanitize, :decidim_sanitize_newsletter
|
12
|
+
|
9
13
|
after_action :set_smtp
|
14
|
+
after_action :set_from
|
10
15
|
|
11
16
|
default from: Decidim.config.mailer_sender
|
12
17
|
layout "decidim/mailer"
|
13
18
|
|
14
19
|
private
|
15
20
|
|
21
|
+
attr_reader :organization
|
22
|
+
|
16
23
|
def set_smtp
|
17
|
-
return if
|
24
|
+
return if organization.nil? || organization.smtp_settings.blank? || organization.smtp_settings.except("from", "from_label", "from_email").all?(&:blank?)
|
18
25
|
|
19
|
-
mail.from = @organization.smtp_settings["from"].presence || mail.from
|
20
26
|
mail.reply_to = mail.reply_to || Decidim.config.mailer_reply
|
21
27
|
mail.delivery_method.settings.merge!(
|
22
|
-
address:
|
23
|
-
port:
|
24
|
-
user_name:
|
25
|
-
password: Decidim::AttributeEncryptor.decrypt(
|
28
|
+
address: organization.smtp_settings["address"],
|
29
|
+
port: organization.smtp_settings["port"],
|
30
|
+
user_name: organization.smtp_settings["user_name"],
|
31
|
+
password: Decidim::AttributeEncryptor.decrypt(organization.smtp_settings["encrypted_password"])
|
26
32
|
) { |_k, o, v| v.presence || o }.compact_blank!
|
27
33
|
end
|
34
|
+
|
35
|
+
def set_from
|
36
|
+
return if organization.nil?
|
37
|
+
return if already_defined_name_in_mail?(mail.from.first)
|
38
|
+
|
39
|
+
mail.from = sender
|
40
|
+
end
|
41
|
+
|
42
|
+
def sender
|
43
|
+
return Decidim.config.mailer_sender if return_mailer_sender?
|
44
|
+
return default_sender if organization.smtp_settings.blank?
|
45
|
+
return default_sender if organization.smtp_settings["from"].nil?
|
46
|
+
return default_sender if organization.smtp_settings["from"].empty?
|
47
|
+
|
48
|
+
smtp_settings_from = organization.smtp_settings["from"]
|
49
|
+
return smtp_settings_from if already_defined_name_in_mail?(smtp_settings_from)
|
50
|
+
|
51
|
+
email_address_with_name(smtp_settings_from, organization_name(organization))
|
52
|
+
end
|
53
|
+
|
54
|
+
def default_sender
|
55
|
+
email_address_with_name(Decidim.config.mailer_sender, organization_name(organization))
|
56
|
+
end
|
57
|
+
|
58
|
+
def already_defined_name_in_mail?(mail_address)
|
59
|
+
# if there is an space, there is already a name in the address
|
60
|
+
mail_address.match?(/ /)
|
61
|
+
end
|
62
|
+
|
63
|
+
def return_mailer_sender?
|
64
|
+
already_defined_name_in_mail?(Decidim.config.mailer_sender) && organization.smtp_settings.present?
|
65
|
+
end
|
28
66
|
end
|
29
67
|
end
|
@@ -5,6 +5,8 @@ module Decidim
|
|
5
5
|
# each role and use a localised version.
|
6
6
|
class DecidimDeviseMailer < ::Devise::Mailer
|
7
7
|
include LocalisedMailer
|
8
|
+
include Decidim::SanitizeHelper
|
9
|
+
helper_method :decidim_escape_translated, :decidim_sanitize_translated, :translated_attribute
|
8
10
|
|
9
11
|
layout "decidim/mailer"
|
10
12
|
|
@@ -19,7 +21,11 @@ module Decidim
|
|
19
21
|
@organization = user.organization
|
20
22
|
@opts = opts
|
21
23
|
|
22
|
-
|
24
|
+
if opts[:invitation_instructions]
|
25
|
+
opts[:subject] =
|
26
|
+
I18n.t("devise.mailer.#{opts[:invitation_instructions]}.subject",
|
27
|
+
organization: organization_name(user.organization))
|
28
|
+
end
|
23
29
|
end
|
24
30
|
|
25
31
|
devise_mail(user, opts[:invitation_instructions] || :invitation_instructions, opts)
|
@@ -2,16 +2,13 @@
|
|
2
2
|
|
3
3
|
module Decidim
|
4
4
|
class NewsletterMailer < ApplicationMailer
|
5
|
-
helper Decidim::SanitizeHelper
|
6
|
-
helper Decidim::TranslationsHelper
|
7
|
-
|
8
5
|
include Decidim::NewslettersHelper
|
9
6
|
|
10
7
|
layout "decidim/newsletter_base"
|
11
8
|
|
12
9
|
helper_method :cell
|
13
10
|
|
14
|
-
def newsletter(user, newsletter, preview
|
11
|
+
def newsletter(user, newsletter, preview = nil)
|
15
12
|
return if user.email.blank?
|
16
13
|
|
17
14
|
@organization = user.organization
|
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
module Decidim
|
4
4
|
# A custom mailer for Decidim so we can notify users to verify
|
5
|
-
# their own newsletter notifications settings. GDPR
|
5
|
+
# their own newsletter notifications settings. GDPR related
|
6
6
|
class NewslettersOptInMailer < ApplicationMailer
|
7
7
|
def notify(user, token)
|
8
8
|
with_user(user) do
|
@@ -10,7 +10,7 @@ module Decidim
|
|
10
10
|
@organization = user.organization
|
11
11
|
@token = token
|
12
12
|
|
13
|
-
mail(to: user.email, subject: I18n.t("decidim.newsletters_opt_in_mailer.notify.subject", organization_name: @organization
|
13
|
+
mail(to: user.email, subject: I18n.t("decidim.newsletters_opt_in_mailer.notify.subject", organization_name: organization_name(@organization)))
|
14
14
|
end
|
15
15
|
end
|
16
16
|
end
|
@@ -5,7 +5,6 @@ module Decidim
|
|
5
5
|
# a events are received.
|
6
6
|
class NotificationMailer < Decidim::ApplicationMailer
|
7
7
|
helper Decidim::ResourceHelper
|
8
|
-
helper Decidim::SanitizeHelper
|
9
8
|
|
10
9
|
def event_received(event, event_class_name, resource, user, user_role, extra) # rubocop:disable Metrics/ParameterLists
|
11
10
|
with_user(user) do
|
@@ -1,10 +1,9 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module Decidim
|
4
|
-
# A custom mailer for sending notifications to an admin when a report is created
|
4
|
+
# A custom mailer for sending notifications to an admin when a report is created.
|
5
5
|
class ReportedMailer < Decidim::ApplicationMailer
|
6
6
|
helper Decidim::ResourceHelper
|
7
|
-
helper Decidim::TranslationsHelper
|
8
7
|
|
9
8
|
helper_method :reported_content_url, :report_url, :manage_moderations_url, :author_profile_url, :reported_content_cell
|
10
9
|
|
@@ -38,6 +37,10 @@ module Decidim
|
|
38
37
|
@organization
|
39
38
|
end
|
40
39
|
|
40
|
+
def current_user
|
41
|
+
@user
|
42
|
+
end
|
43
|
+
|
41
44
|
private
|
42
45
|
|
43
46
|
def reported_content_url
|
@@ -63,7 +66,7 @@ module Decidim
|
|
63
66
|
end
|
64
67
|
|
65
68
|
# This is needed to be able to use a cell in an ActionMailer, which is not supported out of the box by cells-rails.
|
66
|
-
# We are
|
69
|
+
# We are passing the current object as if it was a controller.
|
67
70
|
# We also need to define a 'current_organization' method, which is expected by Decidim::ViewModel.
|
68
71
|
# A similar approach is used in Decidim::NewsletterMailer
|
69
72
|
def reported_content_cell
|
@@ -11,7 +11,7 @@ module Decidim
|
|
11
11
|
with_user(admin) do
|
12
12
|
mail(to: admin.email, subject: I18n.t(
|
13
13
|
"decidim.user_report_mailer.notify.subject",
|
14
|
-
organization_name: report.moderation.user.organization
|
14
|
+
organization_name: organization_name(report.moderation.user.organization),
|
15
15
|
reason: @report.reason
|
16
16
|
))
|
17
17
|
end
|
@@ -194,7 +194,7 @@ module Decidim
|
|
194
194
|
# as a regular object.
|
195
195
|
def participatory_space_lazy(cache: true)
|
196
196
|
return if participatory_space_id.blank? || participatory_space_type.blank?
|
197
|
-
return
|
197
|
+
return resource_lazy if participatory_space_id == resource_id && participatory_space_type == resource_type
|
198
198
|
|
199
199
|
self.class.lazy_relation(participatory_space_id, participatory_space_type, cache)
|
200
200
|
end
|
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
module Decidim
|
4
4
|
# Area types allows to use different types of areas in participatory space
|
5
|
-
# (
|
5
|
+
# (territorial, sectorial, etc.)
|
6
6
|
class AreaType < ApplicationRecord
|
7
7
|
include Decidim::TranslatableResource
|
8
8
|
include Decidim::Traceable
|