decidim-core 0.21.0 → 0.22.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of decidim-core might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/app/assets/config/decidim_core_manifest.js +3 -0
- data/app/assets/fonts/decidim/Roboto-Regular.svg +1 -10520
- data/app/assets/fonts/decidim/Source_Sans_Pro_400.svg +1 -345
- data/app/assets/fonts/decidim/Source_Sans_Pro_600.svg +1 -339
- data/app/assets/fonts/decidim/Source_Sans_Pro_900.svg +1 -342
- data/app/assets/images/decidim/avatar-multiuser.png +0 -0
- data/app/assets/images/decidim/brands/google.svg +1 -1
- data/app/assets/images/decidim/decidim-logo.svg +1 -71
- data/app/assets/images/decidim/default-avatar.svg +1 -14
- data/app/assets/images/decidim/gamification/badges/followers.svg +1 -115
- data/app/assets/images/decidim/gamification/badges/invitations.svg +1 -117
- data/app/assets/images/decidim/icons.svg +1 -259
- data/app/assets/images/decidim/placeholder.jpg +0 -0
- data/app/assets/javascripts/decidim.js.es6 +23 -1
- data/app/assets/javascripts/decidim/ajax_modals.js.es6 +3 -0
- data/app/assets/javascripts/decidim/assets.js.erb +5 -0
- data/app/assets/javascripts/decidim/callout.js.es6 +18 -0
- data/app/assets/javascripts/decidim/configuration.js.es6 +23 -0
- data/app/assets/javascripts/decidim/confirm.js.es6 +178 -0
- data/app/assets/javascripts/decidim/conversations.js.es6 +17 -0
- data/app/assets/javascripts/decidim/core/bundle.js +1 -1
- data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
- data/app/assets/javascripts/decidim/core/extrapoly.js +6 -0
- data/app/assets/javascripts/decidim/data_picker.js.es6 +128 -50
- data/app/assets/javascripts/decidim/diff_mode_dropdown.js.es6 +5 -7
- data/app/assets/javascripts/decidim/dropdowns_menus.js.es6 +32 -0
- data/app/assets/javascripts/decidim/external_link.js.es6 +69 -0
- data/app/assets/javascripts/decidim/floating_help.js.es6 +7 -0
- data/app/assets/javascripts/decidim/form_filter.component.js.es6 +1 -1
- data/app/assets/javascripts/decidim/form_filter.component.test.js +4 -4
- data/app/assets/javascripts/decidim/form_validator.es6 +61 -0
- data/app/assets/javascripts/decidim/foundation.js.es6 +28 -28
- data/app/assets/javascripts/decidim/icon.js.es6 +42 -0
- data/app/assets/javascripts/decidim/identity_selector_dialog.js.es6 +61 -0
- data/app/assets/javascripts/decidim/input_character_counter.js.es6 +115 -0
- data/app/assets/javascripts/decidim/input_mentions.js.es6 +34 -9
- data/app/assets/javascripts/decidim/input_multiple_mentions.js.es6 +195 -0
- data/app/assets/javascripts/decidim/map.js.es6 +40 -3
- data/app/assets/javascripts/decidim/orders.js.es6 +9 -28
- data/app/assets/javascripts/decidim/responsive_horizontal_tabs.js.es6 +12 -0
- data/app/assets/javascripts/decidim/results_listing.js.es6 +44 -0
- data/app/assets/javascripts/decidim/start_conversation_dialog.js +13 -0
- data/app/assets/javascripts/decidim/vizzs.js.es6 +1 -0
- data/app/assets/stylesheets/decidim/_decidim-settings.scss +5 -0
- data/app/assets/stylesheets/decidim/_decidim.scss +13 -11
- data/app/assets/stylesheets/decidim/_properties.scss +25 -0
- data/app/assets/stylesheets/decidim/_variables.scss +6 -24
- data/app/assets/stylesheets/decidim/application.scss.erb +2 -2
- data/app/assets/stylesheets/decidim/editor.scss +2 -2
- data/app/assets/stylesheets/decidim/email.scss +1771 -0
- data/app/assets/stylesheets/decidim/extras/_external-links.scss +29 -0
- data/app/assets/stylesheets/decidim/extras/_extras.scss +17 -0
- data/app/assets/stylesheets/decidim/extras/_label-required.scss +9 -0
- data/app/assets/stylesheets/decidim/extras/_process_stats.scss +1 -1
- data/app/assets/stylesheets/decidim/extras/_quill.scss +5 -0
- data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +8 -0
- data/app/assets/stylesheets/decidim/layouts/_home.scss +31 -7
- data/app/assets/stylesheets/decidim/layouts/_layouts.scss +5 -0
- data/app/assets/stylesheets/decidim/layouts/_logo.scss +26 -0
- data/app/assets/stylesheets/decidim/layouts/_user.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_author-avatar.scss +9 -13
- data/app/assets/stylesheets/decidim/modules/_buttons.scss +198 -26
- data/app/assets/stylesheets/decidim/modules/_cards.scss +174 -23
- data/app/assets/stylesheets/decidim/modules/_collapsible-list.scss +21 -0
- data/app/assets/stylesheets/decidim/modules/_comments.scss +25 -1
- data/app/assets/stylesheets/decidim/modules/_conference-programme.scss +0 -1
- data/app/assets/stylesheets/decidim/modules/_confirm.scss +5 -0
- data/app/assets/stylesheets/decidim/modules/_conversation.scss +50 -0
- data/app/assets/stylesheets/decidim/modules/_data-picker.scss +9 -11
- data/app/assets/stylesheets/decidim/modules/_definition-data.scss +6 -1
- data/app/assets/stylesheets/decidim/modules/_docs-manager.scss +0 -1
- data/app/assets/stylesheets/decidim/modules/_extra.scss +0 -2
- data/app/assets/stylesheets/decidim/modules/_filters.scss +25 -1
- data/app/assets/stylesheets/decidim/modules/_floating-helper.scss +20 -8
- data/app/assets/stylesheets/decidim/modules/_footer.scss +8 -4
- data/app/assets/stylesheets/decidim/modules/_forms.scss +63 -4
- data/app/assets/stylesheets/decidim/modules/_horizontal-tabs.scss +64 -1
- data/app/assets/stylesheets/decidim/modules/_inline-filters.scss +6 -3
- data/app/assets/stylesheets/decidim/modules/_input-gallery.scss +10 -0
- data/app/assets/stylesheets/decidim/modules/_input-mentions.scss +25 -7
- data/app/assets/stylesheets/decidim/modules/_input-multiple-mentions.scss +5 -0
- data/app/assets/stylesheets/decidim/modules/_map.scss +11 -0
- data/app/assets/stylesheets/decidim/modules/_margins.scss +8 -7
- data/app/assets/stylesheets/decidim/modules/_messages.scss +18 -18
- data/app/assets/stylesheets/decidim/modules/_modules.scss +75 -72
- data/app/assets/stylesheets/decidim/modules/_navbar.scss +176 -26
- data/app/assets/stylesheets/decidim/modules/_notification.scss +5 -0
- data/app/assets/stylesheets/decidim/modules/_order-by.scss +5 -0
- data/app/assets/stylesheets/decidim/modules/_process-nav.scss +5 -2
- data/app/assets/stylesheets/decidim/modules/_process-phase.scss +2 -4
- data/app/assets/stylesheets/decidim/modules/_process-stats.scss +2 -2
- data/app/assets/stylesheets/decidim/modules/_progress-bar.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_reveal.scss +6 -0
- data/app/assets/stylesheets/decidim/modules/_signup.scss +6 -5
- data/app/assets/stylesheets/decidim/modules/_static-pages.scss +0 -1
- data/app/assets/stylesheets/decidim/modules/_sticky.scss +5 -0
- data/app/assets/stylesheets/decidim/modules/_tags.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_timeline.scss +1 -2
- data/app/assets/stylesheets/decidim/modules/_typography.scss +47 -8
- data/app/assets/stylesheets/decidim/modules/_versions.scss +0 -1
- data/app/assets/stylesheets/decidim/utils/_helpers.scss +8 -0
- data/app/assets/stylesheets/decidim/utils/_mixins.scss +86 -7
- data/app/assets/stylesheets/decidim/utils/_settings.scss +81 -69
- data/app/assets/stylesheets/decidim/vizzs.scss +8 -0
- data/app/assets/stylesheets/decidim/vizzs/_areachart.scss +0 -1
- data/app/assets/stylesheets/decidim/vizzs/_linechart.scss +0 -1
- data/app/assets/stylesheets/decidim/vizzs/_rowchart.scss +0 -1
- data/app/assets/stylesheets/decidim/vizzs/_vizzs.scss +5 -0
- data/app/assets/stylesheets/foundation-overrides/components/_button-group.scss +319 -0
- data/app/cells/decidim/activity/show.erb +24 -21
- data/app/cells/decidim/activity_cell.rb +2 -0
- data/app/cells/decidim/address_cell.rb +1 -1
- data/app/cells/decidim/amendable/amend_button_card_cell.rb +1 -5
- data/app/cells/decidim/amendable/promote_button_card_cell.rb +1 -1
- data/app/cells/decidim/announcement/show.erb +1 -1
- data/app/cells/decidim/author/comments.erb +1 -1
- data/app/cells/decidim/author/endorsements.erb +6 -0
- data/app/cells/decidim/author/flag.erb +5 -2
- data/app/cells/decidim/author/profile_inline.erb +0 -1
- data/app/cells/decidim/author/show.erb +2 -0
- data/app/cells/decidim/author/withdraw.erb +2 -2
- data/app/cells/decidim/author_cell.rb +9 -13
- data/app/cells/decidim/badge/show.erb +6 -6
- data/app/cells/decidim/badge/small.erb +2 -1
- data/app/cells/decidim/card/show.erb +4 -4
- data/app/cells/decidim/card_m/comments_counter.erb +1 -1
- data/app/cells/decidim/card_m/header.erb +4 -4
- data/app/cells/decidim/card_m/image.erb +1 -1
- data/app/cells/decidim/card_m/show.erb +2 -2
- data/app/cells/decidim/card_m_cell.rb +3 -2
- data/app/cells/decidim/collapsible_list/show.erb +3 -3
- data/app/cells/decidim/content_blocks/footer_sub_hero/show.erb +4 -4
- data/app/cells/decidim/content_blocks/hero_settings_form/show.erb +2 -2
- data/app/cells/decidim/content_blocks/how_to_participate/show.erb +8 -8
- data/app/cells/decidim/content_blocks/last_activity_cell.rb +1 -1
- data/app/cells/decidim/content_blocks/stats/show.erb +1 -1
- data/app/cells/decidim/content_blocks/sub_hero/show.erb +3 -3
- data/app/cells/decidim/diff/attribute.erb +10 -10
- data/app/cells/decidim/diff_cell.rb +11 -1
- data/app/cells/decidim/endorsement_buttons/select_identity_button.erb +10 -0
- data/app/cells/decidim/endorsement_buttons/show.erb +4 -0
- data/app/cells/decidim/endorsement_buttons_cell.rb +208 -0
- data/app/cells/decidim/endorsers_list/show.erb +16 -0
- data/app/cells/decidim/endorsers_list_cell.rb +29 -0
- data/app/cells/decidim/fingerprint_cell.rb +1 -0
- data/app/cells/decidim/follow_button/show.erb +13 -5
- data/app/cells/decidim/follow_button_cell.rb +29 -5
- data/app/cells/decidim/navbar_admin_link/show.erb +1 -1
- data/app/cells/decidim/navbar_admin_link_cell.rb +6 -0
- data/app/cells/decidim/newsletter_templates/base_cell.rb +30 -0
- data/app/cells/decidim/newsletter_templates/base_settings_form_cell.rb +13 -0
- data/app/cells/decidim/newsletter_templates/basic_only_text/show.erb +86 -0
- data/app/cells/decidim/newsletter_templates/basic_only_text_cell.rb +21 -0
- data/app/cells/decidim/newsletter_templates/basic_only_text_settings_form/show.erb +7 -0
- data/app/cells/decidim/newsletter_templates/basic_only_text_settings_form_cell.rb +8 -0
- data/app/cells/decidim/newsletter_templates/image_text_cta/show.erb +125 -0
- data/app/cells/decidim/newsletter_templates/image_text_cta_cell.rb +61 -0
- data/app/cells/decidim/newsletter_templates/image_text_cta_settings_form/show.erb +17 -0
- data/app/cells/decidim/newsletter_templates/image_text_cta_settings_form_cell.rb +8 -0
- data/app/cells/decidim/notifications/show.erb +1 -1
- data/app/cells/decidim/profile/show.erb +2 -2
- data/app/cells/decidim/profile/user_group_tabs.erb +10 -5
- data/app/cells/decidim/profile/user_tabs.erb +16 -14
- data/app/cells/decidim/profile_cell.rb +18 -0
- data/app/cells/decidim/profile_sidebar/show.erb +16 -16
- data/app/cells/decidim/profile_sidebar_cell.rb +1 -0
- data/app/cells/decidim/search_results_section/show.erb +1 -1
- data/app/cells/decidim/tags_cell.rb +32 -2
- data/app/cells/decidim/user_activity/show.erb +19 -1
- data/app/cells/decidim/user_activity_cell.rb +6 -0
- data/app/cells/decidim/user_conversation/conversation_header.erb +14 -0
- data/app/cells/decidim/user_conversation/messages.erb +15 -0
- data/app/cells/decidim/user_conversation/new.erb +15 -0
- data/app/cells/decidim/user_conversation/reply.erb +17 -0
- data/app/cells/decidim/user_conversation/show.erb +20 -0
- data/app/cells/decidim/user_conversation_cell.rb +75 -0
- data/app/cells/decidim/user_conversations/add_conversation_users.erb +25 -0
- data/app/cells/decidim/user_conversations/conversation_item.erb +38 -0
- data/app/cells/decidim/user_conversations/show.erb +58 -0
- data/app/cells/decidim/user_conversations_cell.rb +40 -0
- data/app/cells/decidim/user_group_admin_membership_profile/footer.erb +3 -3
- data/app/cells/decidim/user_profile/footer.erb +1 -1
- data/app/cells/decidim/user_profile/unlinked_user_data.erb +16 -0
- data/app/cells/decidim/user_profile/user_data.erb +1 -1
- data/app/cells/decidim/user_profile_cell.rb +7 -1
- data/app/cells/decidim/user_timeline_cell.rb +4 -0
- data/app/cells/decidim/version/show.erb +31 -0
- data/app/{views/decidim/shared/_version_author.html.erb → cells/decidim/version_author/show.erb} +1 -1
- data/app/cells/decidim/version_author_cell.rb +9 -0
- data/app/cells/decidim/version_cell.rb +83 -0
- data/app/cells/decidim/versions_list/show.erb +32 -0
- data/app/cells/decidim/versions_list_cell.rb +64 -0
- data/app/cells/decidim/versions_list_item/show.erb +20 -0
- data/app/cells/decidim/versions_list_item_cell.rb +51 -0
- data/app/cells/decidim/wizard_step_form/wizard_aside.erb +1 -1
- data/app/cells/decidim/wizard_step_form/wizard_header.erb +2 -2
- data/app/cells/decidim/wizard_step_form_cell.rb +4 -1
- data/app/commands/decidim/attachment_methods.rb +40 -0
- data/app/commands/decidim/create_registration.rb +2 -1
- data/app/commands/decidim/create_user_group.rb +12 -0
- data/app/commands/decidim/destroy_account.rb +12 -0
- data/app/commands/decidim/endorse_resource.rb +64 -0
- data/app/commands/decidim/gallery_methods.rb +64 -0
- data/app/commands/decidim/invite_user_again.rb +2 -4
- data/app/commands/decidim/messaging/reply_to_conversation.rb +34 -3
- data/app/commands/decidim/messaging/start_conversation.rb +36 -5
- data/app/commands/decidim/unendorse_resource.rb +38 -0
- data/app/commands/decidim/update_notifications_settings.rb +1 -0
- data/app/commands/decidim/update_user_group.rb +14 -1
- data/app/controllers/concerns/decidim/impersonate_users.rb +13 -0
- data/app/controllers/concerns/decidim/resource_versions_concern.rb +28 -0
- data/app/controllers/decidim/devise/registrations_controller.rb +2 -4
- data/app/controllers/decidim/devise/sessions_controller.rb +5 -0
- data/app/controllers/decidim/endorsements_controller.rb +71 -0
- data/app/controllers/decidim/messaging/conversations_controller.rb +52 -12
- data/app/controllers/decidim/newsletters_controller.rb +2 -2
- data/app/controllers/decidim/profiles_controller.rb +6 -0
- data/app/controllers/decidim/scopes_controller.rb +1 -0
- data/app/controllers/decidim/user_activities_controller.rb +19 -2
- data/app/controllers/decidim/user_conversations_controller.rb +142 -0
- data/app/controllers/decidim/user_timeline_controller.rb +19 -2
- data/app/events/decidim/resource_endorsed_event.rb +35 -0
- data/app/events/decidim/user_group_admin_event.rb +37 -0
- data/app/events/decidim/user_group_created_event.rb +6 -0
- data/app/events/decidim/user_group_updated_event.rb +6 -0
- data/app/forms/decidim/attachment_form.rb +1 -0
- data/app/forms/decidim/messaging/conversation_form.rb +10 -4
- data/app/forms/decidim/notifications_settings_form.rb +6 -0
- data/app/forms/decidim/registration_form.rb +1 -0
- data/app/functions/decidim/core/component_finder_base.rb +10 -3
- data/app/functions/decidim/core/component_list_base.rb +8 -2
- data/app/functions/decidim/core/user_entity_finder.rb +33 -0
- data/app/functions/decidim/core/user_entity_list.rb +31 -0
- data/app/helpers/concerns/decidim/flash_helper_extensions.rb +47 -0
- data/app/helpers/decidim/action_authorization_helper.rb +24 -2
- data/app/helpers/decidim/amendments_helper.rb +5 -3
- data/app/helpers/decidim/application_helper.rb +7 -1
- data/app/helpers/decidim/check_boxes_tree_helper.rb +4 -5
- data/app/helpers/decidim/cta_button_helper.rb +1 -1
- data/app/helpers/decidim/decidim_form_helper.rb +23 -0
- data/app/helpers/decidim/endorsable_helper.rb +93 -0
- data/app/helpers/decidim/filters_helper.rb +15 -5
- data/app/helpers/decidim/followable_helper.rb +11 -0
- data/app/helpers/decidim/layout_helper.rb +23 -5
- data/app/helpers/decidim/map_helper.rb +15 -2
- data/app/helpers/decidim/markup_helper.rb +9 -0
- data/app/helpers/decidim/messaging/conversation_helper.rb +61 -7
- data/app/helpers/decidim/orders_helper.rb +10 -1
- data/app/helpers/decidim/participatory_space_helpers.rb +1 -1
- data/app/helpers/decidim/resource_versions_helper.rb +24 -7
- data/app/helpers/decidim/rich_text_editor_helper.rb +1 -0
- data/app/helpers/decidim/sanitize_helper.rb +10 -2
- data/app/helpers/decidim/tooltip_helper.rb +1 -1
- data/app/helpers/decidim/traceability_helper.rb +2 -8
- data/app/helpers/decidim/user_profile_helper.rb +1 -1
- data/app/helpers/decidim/widget_urls_helper.rb +4 -2
- data/app/jobs/decidim/event_publisher_job.rb +1 -1
- data/app/mailers/concerns/decidim/multitenant_asset_host.rb +33 -0
- data/app/mailers/decidim/application_mailer.rb +1 -0
- data/app/mailers/decidim/messaging/conversation_mailer.rb +53 -4
- data/app/mailers/decidim/newsletter_mailer.rb +22 -4
- data/app/middleware/decidim/strip_x_forwarded_host.rb +14 -0
- data/app/models/decidim/action_log.rb +1 -1
- data/app/models/decidim/amendment.rb +0 -18
- data/app/models/decidim/authorization.rb +24 -0
- data/app/models/decidim/component.rb +7 -0
- data/app/models/decidim/content_block.rb +5 -3
- data/app/models/decidim/endorsement.rb +30 -0
- data/app/models/decidim/messaging/conversation.rb +39 -11
- data/app/models/decidim/messaging/message.rb +31 -5
- data/app/models/decidim/messaging/participation.rb +1 -1
- data/app/models/decidim/messaging/receipt.rb +8 -0
- data/app/models/decidim/newsletter.rb +7 -1
- data/app/models/decidim/organization.rb +16 -7
- data/app/models/decidim/user.rb +32 -0
- data/app/models/decidim/user_group.rb +23 -0
- data/app/permissions/decidim/permissions.rb +19 -6
- data/app/presenters/decidim/admin_log/user_presenter.rb +1 -1
- data/app/presenters/decidim/metric_charts_presenter.rb +33 -13
- data/app/presenters/decidim/nil_presenter.rb +29 -0
- data/app/presenters/decidim/resource_locator_presenter.rb +2 -1
- data/app/presenters/decidim/user_group_presenter.rb +1 -1
- data/app/presenters/decidim/user_presenter.rb +6 -0
- data/app/queries/decidim/metric_manage.rb +5 -0
- data/app/queries/decidim/metrics/followers_metric_manage.rb +1 -6
- data/app/queries/decidim/user_groups/admin_memberships.rb +3 -3
- data/app/services/decidim/activity_search.rb +1 -0
- data/app/services/decidim/base_diff_renderer.rb +25 -3
- data/app/services/decidim/events_manager.rb +4 -1
- data/app/types/decidim/core/decidim_type.rb +0 -4
- data/app/types/decidim/core/has_endorsable_input_sort.rb +17 -0
- data/app/types/decidim/core/has_timestamp_input_filter.rb +52 -0
- data/app/types/decidim/core/has_timestamp_input_sort.rb +12 -0
- data/app/types/decidim/core/user_entity_input_filter.rb +81 -0
- data/app/types/decidim/core/user_entity_input_sort.rb +24 -0
- data/app/types/decidim/core/user_group_type.rb +17 -5
- data/app/types/decidim/core/user_type.rb +17 -6
- data/app/uploaders/decidim/attachment_uploader.rb +1 -1
- data/app/uploaders/decidim/avatar_uploader.rb +4 -0
- data/app/uploaders/decidim/image_uploader.rb +28 -4
- data/app/uploaders/decidim/newsletter_template_image_uploader.rb +36 -0
- data/app/views/decidim/account/delete.html.erb +6 -3
- data/app/views/decidim/account/show.html.erb +17 -10
- data/app/views/decidim/amendments/_edit_form_fields.html.erb +2 -0
- data/app/views/decidim/amendments/_similar_emendation.html.erb +4 -4
- data/app/views/decidim/amendments/compare_draft.html.erb +2 -2
- data/app/views/decidim/amendments/edit_draft.html.erb +2 -2
- data/app/views/decidim/amendments/new.html.erb +2 -2
- data/app/views/decidim/amendments/preview_draft.html.erb +2 -2
- data/app/views/decidim/amendments/review.html.erb +3 -3
- data/app/views/decidim/application/_collection.html.erb +2 -2
- data/app/views/decidim/application/_document.html.erb +4 -4
- data/app/views/decidim/application/_documents.html.erb +1 -1
- data/app/views/decidim/application/_photos.html.erb +1 -1
- data/app/views/decidim/authorization_modals/show.html.erb +1 -1
- data/app/views/decidim/data_portability/show.html.erb +3 -0
- data/app/views/decidim/devise/confirmations/new.html.erb +3 -3
- data/app/views/decidim/devise/invitations/edit.html.erb +13 -13
- data/app/views/decidim/devise/omniauth_registrations/new.html.erb +5 -3
- data/app/views/decidim/devise/passwords/edit.html.erb +5 -3
- data/app/views/decidim/devise/passwords/new.html.erb +3 -3
- data/app/views/decidim/devise/registrations/edit.html.erb +2 -1
- data/app/views/decidim/devise/registrations/new.html.erb +7 -8
- data/app/views/decidim/devise/sessions/new.html.erb +4 -6
- data/app/views/decidim/devise/shared/_newsletter_modal.html.erb +3 -3
- data/app/views/decidim/devise/shared/_omniauth_buttons.html.erb +3 -1
- data/app/views/decidim/devise/shared/_omniauth_buttons_mini.html.erb +4 -1
- data/app/views/decidim/devise/unlocks/new.html.erb +3 -3
- data/app/views/decidim/doorkeeper/authorizations/new.html.erb +2 -2
- data/app/views/decidim/endorsements/_identity.html.erb +9 -0
- data/app/views/decidim/endorsements/identities.html.erb +12 -0
- data/app/views/decidim/endorsements/update_buttons_and_counters.js.erb +20 -0
- data/app/views/decidim/errors/internal_server_error.html.erb +2 -2
- data/app/views/decidim/errors/not_found.html.erb +2 -2
- data/app/views/decidim/gamification/badges/index.html.erb +4 -4
- data/app/views/decidim/group_admins/index.html.erb +6 -4
- data/app/views/decidim/group_invites/index.html.erb +5 -2
- data/app/views/decidim/group_members/index.html.erb +6 -4
- data/app/views/decidim/groups/_form.html.erb +2 -0
- data/app/views/decidim/groups/edit.html.erb +4 -2
- data/app/views/decidim/groups/new.html.erb +2 -2
- data/app/views/decidim/last_activities/index.html.erb +2 -0
- data/app/views/decidim/messaging/conversation_mailer/comanagers_new_conversation.html.erb +17 -0
- data/app/views/decidim/messaging/conversation_mailer/comanagers_new_message.html.erb +17 -0
- data/app/views/decidim/messaging/conversation_mailer/new_conversation.html.erb +2 -2
- data/app/views/decidim/messaging/conversation_mailer/new_group_conversation.html.erb +17 -0
- data/app/views/decidim/messaging/conversation_mailer/new_group_message.html.erb +17 -0
- data/app/views/decidim/messaging/conversation_mailer/new_message.html.erb +2 -2
- data/app/views/decidim/messaging/conversations/_add_conversation_users.html.erb +24 -0
- data/app/views/decidim/messaging/conversations/_conversation.html.erb +54 -0
- data/app/views/decidim/messaging/conversations/_messages.html.erb +15 -0
- data/app/views/decidim/messaging/conversations/_new_conversation_button.html.erb +33 -0
- data/app/views/decidim/messaging/conversations/_reply.html.erb +3 -3
- data/app/views/decidim/messaging/conversations/_show.html.erb +34 -15
- data/app/views/decidim/messaging/conversations/_start.html.erb +7 -1
- data/app/views/decidim/messaging/conversations/create.js.erb +1 -1
- data/app/views/decidim/messaging/conversations/index.html.erb +34 -29
- data/app/views/decidim/messaging/conversations/new.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/show.html.erb +8 -4
- data/app/views/decidim/messaging/conversations/update.js.erb +1 -1
- data/app/views/decidim/newsletter_mailer/newsletter.html.erb +2 -2
- data/app/views/decidim/newsletters/show.html.erb +8 -1
- data/app/views/decidim/notifications/index.html.erb +4 -2
- data/app/views/decidim/notifications_settings/show.html.erb +14 -1
- data/app/views/decidim/own_user_groups/index.html.erb +4 -0
- data/app/views/decidim/pages/_standalone.html.erb +1 -1
- data/app/views/decidim/pages/_tabbed.html.erb +5 -5
- data/app/views/decidim/pages/index.html.erb +22 -13
- data/app/views/decidim/profiles/_user_follow.erb +3 -3
- data/app/views/decidim/profiles/show.html.erb +2 -0
- data/app/views/decidim/scopes/_scopes_picker_input.html.erb +11 -4
- data/app/views/decidim/scopes/picker.html.erb +26 -16
- data/app/views/decidim/searches/_count.html.erb +14 -11
- data/app/views/decidim/searches/_filters.html.erb +2 -2
- data/app/views/decidim/searches/index.html.erb +5 -3
- data/app/views/decidim/shared/_check_boxes_tree.html.erb +5 -3
- data/app/views/decidim/shared/_confirm_modal.html.erb +18 -0
- data/app/views/decidim/shared/_embed_modal.html.erb +4 -1
- data/app/views/decidim/shared/_extended_navigation_bar.html.erb +2 -2
- data/app/views/decidim/shared/_filter_form_help.erb +8 -0
- data/app/views/decidim/shared/_floating_help.html.erb +7 -7
- data/app/views/decidim/shared/_login_modal.html.erb +4 -4
- data/app/views/decidim/shared/_orders.html.erb +16 -5
- data/app/views/decidim/shared/_results_per_page.html.erb +16 -6
- data/app/views/decidim/shared/_share_modal.html.erb +8 -4
- data/app/views/decidim/shared/_static_map.html.erb +1 -1
- data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +1 -1
- data/app/views/decidim/user_activities/index.html.erb +4 -0
- data/app/views/decidim/user_activities/index.js.erb +14 -0
- data/app/views/decidim/user_conversations/index.html.erb +4 -0
- data/app/views/decidim/user_conversations/show.html.erb +4 -0
- data/app/views/decidim/user_conversations/update.js.erb +8 -0
- data/app/views/decidim/user_interests/_scopes.html.erb +12 -10
- data/app/views/decidim/user_interests/show.html.erb +4 -1
- data/app/views/decidim/user_timeline/index.html.erb +5 -1
- data/app/views/decidim/user_timeline/index.js.erb +14 -0
- data/app/views/kaminari/decidim/_first_page.html.erb +5 -1
- data/app/views/kaminari/decidim/_last_page.html.erb +5 -1
- data/app/views/kaminari/decidim/_next_page.html.erb +6 -1
- data/app/views/kaminari/decidim/_page.html.erb +2 -2
- data/app/views/kaminari/decidim/_paginator.html.erb +16 -14
- data/app/views/kaminari/decidim/_prev_page.html.erb +6 -1
- data/app/views/layouts/decidim/_application.html.erb +4 -2
- data/app/views/layouts/decidim/_cookie_warning.html.erb +1 -1
- data/app/views/layouts/decidim/_edit_link.html.erb +0 -0
- data/app/views/layouts/decidim/_head.html.erb +2 -0
- data/app/views/layouts/decidim/_js_configuration.html.erb +28 -0
- data/app/views/layouts/decidim/_language_chooser.html.erb +10 -5
- data/app/views/layouts/decidim/_logo.html.erb +2 -22
- data/app/views/layouts/decidim/_mailer_logo.html.erb +2 -22
- data/app/views/layouts/decidim/_main_footer.html.erb +3 -1
- data/app/views/layouts/decidim/_mini_footer.html.erb +7 -7
- data/app/views/layouts/decidim/_omnipresent_banner.html.erb +1 -1
- data/app/views/layouts/decidim/_organization_colors.html.erb +4 -3
- data/app/views/layouts/decidim/_social_media_links.html.erb +15 -10
- data/app/views/layouts/decidim/_topbar_search.html.erb +12 -2
- data/app/views/layouts/decidim/_user_menu.html.erb +6 -6
- data/app/views/layouts/decidim/_wrapper.html.erb +21 -16
- data/app/views/layouts/decidim/newsletter_base.html.erb +46 -0
- data/app/views/layouts/decidim/user_profile.html.erb +8 -3
- data/app/views/layouts/decidim/widget.html.erb +1 -0
- data/config/initializers/devise.rb +11 -3
- data/config/initializers/invisible_captcha.rb +1 -0
- data/config/initializers/omniauth.rb +7 -1
- data/config/initializers/rack_attack.rb +25 -16
- data/config/locales/ar.yml +7 -5
- data/config/locales/bg-BG.yml +1512 -0
- data/config/locales/ca.yml +258 -6
- data/config/locales/cs.yml +297 -37
- data/config/locales/da-DK.yml +9 -0
- data/config/locales/de.yml +279 -5
- data/config/locales/el.yml +1443 -5
- data/config/locales/en.yml +263 -11
- data/config/locales/es-MX.yml +257 -5
- data/config/locales/es-PY.yml +257 -5
- data/config/locales/es.yml +257 -5
- data/config/locales/et-EE.yml +9 -0
- data/config/locales/eu.yml +7 -2
- data/config/locales/fi-plain.yml +258 -6
- data/config/locales/fi.yml +319 -67
- data/config/locales/fr-CA.yml +1585 -0
- data/config/locales/fr.yml +263 -5
- data/config/locales/ga-IE.yml +9 -0
- data/config/locales/gl.yml +7 -2
- data/config/locales/hr-HR.yml +9 -0
- data/config/locales/hu.yml +87 -5
- data/config/locales/id-ID.yml +7 -2
- data/config/locales/is-IS.yml +1 -0
- data/config/locales/it.yml +279 -27
- data/config/locales/ja-JP.yml +1578 -0
- data/config/locales/lt-LT.yml +9 -0
- data/config/locales/lv-LV.yml +1485 -0
- data/config/locales/mt-MT.yml +9 -0
- data/config/locales/nl.yml +261 -6
- data/config/locales/no.yml +117 -41
- data/config/locales/pl.yml +755 -406
- data/config/locales/pt-BR.yml +8 -4
- data/config/locales/pt.yml +875 -536
- data/config/locales/ro-RO.yml +1603 -0
- data/config/locales/ru.yml +6 -1
- data/config/locales/sk-SK.yml +1426 -0
- data/config/locales/sk.yml +1441 -0
- data/config/locales/sl.yml +71 -0
- data/config/locales/sr-CS.yml +129 -0
- data/config/locales/sv.yml +323 -24
- data/config/locales/tr-TR.yml +7 -2
- data/config/locales/uk.yml +6 -1
- data/config/routes.rb +5 -0
- data/db/migrate/20180810092428_move_organization_fields_to_hero_content_block.rb +2 -2
- data/db/migrate/20191130151925_create_decidim_endorsements.rb +13 -0
- data/db/migrate/20191204075509_add_session_token_to_users.rb +7 -0
- data/db/migrate/20200211173227_add_direct_message_types_to_users.rb +12 -0
- data/db/migrate/20200320105904_index_foreign_keys_in_decidim_action_logs.rb +9 -0
- data/db/migrate/20200320105905_index_foreign_keys_in_decidim_amendments.rb +7 -0
- data/db/migrate/20200320105909_index_foreign_keys_in_decidim_authorizations.rb +7 -0
- data/db/migrate/20200320105917_index_foreign_keys_in_decidim_contextual_help_sections.rb +7 -0
- data/db/migrate/20200320105919_index_foreign_keys_in_decidim_endorsements.rb +7 -0
- data/db/migrate/20200320105923_index_foreign_keys_in_decidim_notifications.rb +7 -0
- data/db/migrate/20200320105927_index_foreign_keys_in_oauth_access_grants.rb +7 -0
- data/db/migrate/20200323094443_add_id_to_content_blocks_scope.rb +7 -0
- data/db/migrate/20200326102407_rename_scope_column.rb +7 -0
- data/db/migrate/20200327082257_migrate_newsletters_to_templates.rb +33 -0
- data/db/migrate/20200327082954_remove_newsletter_body.rb +7 -0
- data/db/migrate/20200401073419_add_index_on_content_block_scope_id.rb +11 -0
- data/db/seeds.rb +1 -1
- data/{app/controllers/concerns → lib}/decidim/action_authorization.rb +0 -0
- data/lib/decidim/api/author_interface.rb +4 -0
- data/lib/decidim/api/endorsable_interface.rb +22 -0
- data/lib/decidim/api/participatory_space_interface.rb +2 -0
- data/lib/decidim/api/timestamps_interface.rb +2 -2
- data/lib/decidim/coauthorable.rb +1 -1
- data/lib/decidim/component_manifest.rb +14 -0
- data/lib/decidim/content_parsers.rb +1 -0
- data/lib/decidim/content_parsers/user_group_parser.rb +61 -0
- data/lib/decidim/content_parsers/user_parser.rb +3 -5
- data/lib/decidim/content_renderers.rb +1 -0
- data/lib/decidim/content_renderers/user_group_renderer.rb +30 -0
- data/lib/decidim/core.rb +65 -21
- data/lib/decidim/core/api.rb +1 -0
- data/lib/decidim/core/engine.rb +88 -6
- data/lib/decidim/core/test.rb +8 -0
- data/lib/decidim/core/test/factories.rb +103 -3
- data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +79 -0
- data/lib/decidim/core/test/shared_examples/back_to_list_button_examples.rb +17 -0
- data/lib/decidim/core/test/shared_examples/comments_examples.rb +17 -2
- data/lib/decidim/core/test/shared_examples/edit_link_shared_examples.rb +5 -1
- data/lib/decidim/core/test/shared_examples/endorsable_interface_examples.rb +22 -0
- data/lib/decidim/core/test/shared_examples/endorsements_controller_shared_context.rb +22 -0
- data/lib/decidim/core/test/shared_examples/follows_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/input_sort_examples.rb +21 -0
- data/lib/decidim/core/test/shared_examples/logo_email.rb +20 -0
- data/lib/decidim/core/test/shared_examples/metric_manage_shared_context.rb +9 -0
- data/lib/decidim/core/test/shared_examples/permissions.rb +143 -0
- data/lib/decidim/core/test/shared_examples/reports_examples.rb +4 -4
- data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +3 -3
- data/lib/decidim/core/test/shared_examples/simple_event.rb +1 -0
- data/lib/decidim/core/test/shared_examples/system_endorse_resource_examples.rb +165 -0
- data/lib/decidim/core/test/shared_examples/traceable_interface_examples.rb +3 -3
- data/lib/decidim/core/test/shared_examples/with_endorsable_permissions_examples.rb +89 -0
- data/lib/decidim/core/version.rb +1 -1
- data/lib/decidim/endorsable.rb +25 -0
- data/lib/decidim/events.rb +1 -0
- data/lib/decidim/events/user_group_event.rb +45 -0
- data/lib/decidim/exporters/csv.rb +1 -1
- data/lib/decidim/filter_form_builder.rb +15 -6
- data/lib/decidim/form_builder.rb +209 -23
- data/lib/decidim/has_attachments.rb +1 -1
- data/lib/decidim/participable.rb +6 -0
- data/lib/decidim/participatory_space_manifest.rb +15 -0
- data/lib/decidim/query_extensions.rb +9 -15
- data/lib/decidim/settings_manifest.rb +15 -1
- data/lib/decidim/view_model.rb +4 -0
- data/lib/tasks/decidim_tasks.rake +1 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.ro.js +15 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.sk.js +14 -0
- data/vendor/assets/javascripts/svg4everybody.min.js +1 -2
- data/vendor/assets/javascripts/tribute.js +11 -4
- metadata +187 -31
- data/app/assets/javascripts/decidim/vizzs/orgchart.js.es6 +0 -699
- data/app/assets/stylesheets/decidim/email.css +0 -1403
- data/app/assets/stylesheets/decidim/modules/_input-hashtags.scss +0 -124
- data/app/resolvers/decidim/core/user_resolver.rb +0 -61
- data/app/views/decidim/messaging/conversations/_message.html.erb +0 -14
@@ -6,6 +6,8 @@ module Decidim
|
|
6
6
|
class ContentBlock < ApplicationRecord
|
7
7
|
include Publicable
|
8
8
|
|
9
|
+
attr_accessor :in_preview
|
10
|
+
|
9
11
|
belongs_to :organization, foreign_key: :decidim_organization_id, class_name: "Decidim::Organization"
|
10
12
|
|
11
13
|
delegate :public_name_key, :has_settings?, :settings_form_cell, :cell, to: :manifest
|
@@ -16,12 +18,12 @@ module Decidim
|
|
16
18
|
# Public: finds the published content blocks for the given scope and
|
17
19
|
# organization. Returns them ordered by ascending weight (lowest first).
|
18
20
|
def self.for_scope(scope, organization:)
|
19
|
-
where(organization: organization,
|
21
|
+
where(organization: organization, scope_name: scope)
|
20
22
|
.order(weight: :asc)
|
21
23
|
end
|
22
24
|
|
23
25
|
def manifest
|
24
|
-
@manifest ||= Decidim.content_blocks.for(
|
26
|
+
@manifest ||= Decidim.content_blocks.for(scope_name).find { |manifest| manifest.name.to_s == manifest_name }
|
25
27
|
end
|
26
28
|
|
27
29
|
# Public: Uses the `SettingsManifest` class to generate a settings schema
|
@@ -124,7 +126,7 @@ module Decidim
|
|
124
126
|
end
|
125
127
|
|
126
128
|
@images_container.manifest = manifest
|
127
|
-
@images_container.manifest_scope =
|
129
|
+
@images_container.manifest_scope = scope_name
|
128
130
|
@images_container = @images_container.new(self)
|
129
131
|
end
|
130
132
|
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
# A resource can have an endorsement for each user or group the author/endorser belongs to.
|
5
|
+
class Endorsement < ApplicationRecord
|
6
|
+
include Decidim::Authorable
|
7
|
+
|
8
|
+
belongs_to :resource,
|
9
|
+
polymorphic: true,
|
10
|
+
counter_cache: true
|
11
|
+
|
12
|
+
validates :resource_id, uniqueness: { scope: [:resource_type, :author, :user_group] }
|
13
|
+
validate :author_and_resource_same_organization
|
14
|
+
|
15
|
+
scope :for_listing, -> { order(:decidim_user_group_id, :created_at) }
|
16
|
+
|
17
|
+
private
|
18
|
+
|
19
|
+
def organization
|
20
|
+
resource&.component&.organization
|
21
|
+
end
|
22
|
+
|
23
|
+
# Private: check if the resource and the author have the same organization
|
24
|
+
def author_and_resource_same_organization
|
25
|
+
return if !resource || !author
|
26
|
+
|
27
|
+
errors.add(:resource, :invalid) unless author.organization == resource.organization
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -24,8 +24,12 @@ module Decidim
|
|
24
24
|
|
25
25
|
has_many :receipts, through: :messages
|
26
26
|
|
27
|
+
scope :unread_messages_by, lambda { |user|
|
28
|
+
joins(:receipts).merge(Receipt.unread_by(user))
|
29
|
+
}
|
30
|
+
|
27
31
|
scope :unread_by, lambda { |user|
|
28
|
-
|
32
|
+
unread_messages_by(user).distinct
|
29
33
|
}
|
30
34
|
|
31
35
|
default_scope { order(updated_at: :desc) }
|
@@ -41,11 +45,12 @@ module Decidim
|
|
41
45
|
#
|
42
46
|
# @return (see .start)
|
43
47
|
#
|
44
|
-
def self.start!(originator:, interlocutors:, body:)
|
48
|
+
def self.start!(originator:, interlocutors:, body:, user: nil)
|
45
49
|
conversation = start(
|
46
50
|
originator: originator,
|
47
51
|
interlocutors: interlocutors,
|
48
|
-
body: body
|
52
|
+
body: body,
|
53
|
+
user: user
|
49
54
|
)
|
50
55
|
|
51
56
|
conversation.save!
|
@@ -57,17 +62,18 @@ module Decidim
|
|
57
62
|
# Initiates a conversation between a user and a set of interlocutors with
|
58
63
|
# an initial message.
|
59
64
|
#
|
60
|
-
# @param originator [Decidim::
|
65
|
+
# @param originator [Decidim::UserBaseEntity] The user or group starting the conversation
|
61
66
|
# @param interlocutors [Array<Decidim::User>] The set of interlocutors in
|
62
67
|
# the conversation (not including the originator).
|
63
68
|
# @param body [String] The content of the initial message
|
69
|
+
# @param user [Decidim::User] The user starting the conversation in case originator is a group
|
64
70
|
#
|
65
71
|
# @return [Decidim::Messaging::Conversation] The newly created conversation
|
66
72
|
#
|
67
|
-
def self.start(originator:, interlocutors:, body:)
|
73
|
+
def self.start(originator:, interlocutors:, body:, user: nil)
|
68
74
|
conversation = new(participants: [originator] + interlocutors)
|
69
75
|
|
70
|
-
conversation.add_message(sender: originator, body: body)
|
76
|
+
conversation.add_message(sender: originator, body: body, user: user)
|
71
77
|
|
72
78
|
conversation
|
73
79
|
end
|
@@ -78,8 +84,8 @@ module Decidim
|
|
78
84
|
#
|
79
85
|
# @return (see #add_message)
|
80
86
|
#
|
81
|
-
def add_message!(sender:, body:)
|
82
|
-
add_message(sender: sender, body: body)
|
87
|
+
def add_message!(sender:, body:, user: nil)
|
88
|
+
add_message(sender: sender, body: body, user: user)
|
83
89
|
|
84
90
|
save!
|
85
91
|
end
|
@@ -87,15 +93,16 @@ module Decidim
|
|
87
93
|
#
|
88
94
|
# Appends a message to this conversation
|
89
95
|
#
|
90
|
-
# @param sender [Decidim::
|
96
|
+
# @param sender [Decidim::UserBaseEntity] The sender of the message
|
91
97
|
# @param body [String] The content of the message
|
98
|
+
# @param user [Decidim::User] The user sending the message in case sender is a group
|
92
99
|
#
|
93
100
|
# @return [Decidim::Messaging::Message] The newly created message
|
94
101
|
#
|
95
|
-
def add_message(sender:, body:)
|
102
|
+
def add_message(sender:, body:, user: nil)
|
96
103
|
message = messages.build(sender: sender, body: body)
|
97
104
|
|
98
|
-
message.envelope_for(interlocutors(sender))
|
105
|
+
message.envelope_for(recipients: interlocutors(sender), from: user)
|
99
106
|
|
100
107
|
message
|
101
108
|
end
|
@@ -111,6 +118,27 @@ module Decidim
|
|
111
118
|
participants.reject { |participant| participant.id == user.id }
|
112
119
|
end
|
113
120
|
|
121
|
+
#
|
122
|
+
# Given a user, returns if ALL the interlocutors allow her to join the conversation
|
123
|
+
#
|
124
|
+
# @return Boolean
|
125
|
+
#
|
126
|
+
def accept_user?(user)
|
127
|
+
# if user is a group, members are accepted
|
128
|
+
blocked = interlocutors(user).detect { |participant| !participant.accepts_conversation?(user) }
|
129
|
+
blocked.blank?
|
130
|
+
end
|
131
|
+
|
132
|
+
#
|
133
|
+
# Given a user, returns if the user is participating in the conversation
|
134
|
+
# for groups being part of a conversation all their admin member are accepted
|
135
|
+
#
|
136
|
+
# @return Boolean
|
137
|
+
#
|
138
|
+
def participating?(user)
|
139
|
+
participants.include?(user)
|
140
|
+
end
|
141
|
+
|
114
142
|
#
|
115
143
|
# The most recent message in this conversation
|
116
144
|
#
|
@@ -12,7 +12,7 @@ module Decidim
|
|
12
12
|
|
13
13
|
belongs_to :sender,
|
14
14
|
foreign_key: :decidim_sender_id,
|
15
|
-
class_name: "Decidim::
|
15
|
+
class_name: "Decidim::UserBaseEntity"
|
16
16
|
|
17
17
|
belongs_to :conversation,
|
18
18
|
foreign_key: :decidim_conversation_id,
|
@@ -36,16 +36,42 @@ module Decidim
|
|
36
36
|
# including also a receipt for the remitent (sender) of the message.
|
37
37
|
# Receipts are unread by default, except for the sender's receipt.
|
38
38
|
#
|
39
|
-
#
|
39
|
+
# If the sender is a UserGroup then receipts will be created for its managers
|
40
|
+
# a "from" user can be specified to avoid create a receipt for the real user sending the message
|
40
41
|
#
|
41
|
-
|
42
|
-
|
42
|
+
# @param recipients [Array<Decidim::UserBaseEntity>] Users or groups receiving the message
|
43
|
+
# @param from [Array<Decidim::User>] the user sending the message in case sender is a group
|
44
|
+
#
|
45
|
+
def envelope_for(recipients:, from: nil)
|
46
|
+
@from = sender.is_a?(User) ? sender : from
|
47
|
+
@already_notified = [@from]
|
48
|
+
|
49
|
+
receipts.build(recipient: @from, read_at: Time.current) if @from.is_a?(User)
|
43
50
|
|
44
|
-
recipients.each
|
51
|
+
all_recipients(recipients).each do |recipient|
|
52
|
+
next if @already_notified.include?(recipient)
|
53
|
+
|
54
|
+
receipts.build(recipient: recipient)
|
55
|
+
@already_notified.push(recipient)
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
# Public: Returns the comment body with links
|
60
|
+
def body_with_links
|
61
|
+
Decidim::ContentRenderers::LinkRenderer.new(body).render
|
45
62
|
end
|
46
63
|
|
47
64
|
private
|
48
65
|
|
66
|
+
# returns all posible recipients from a list of users or groups
|
67
|
+
def all_recipients(recipients)
|
68
|
+
users = recipients.flat_map do |recipient|
|
69
|
+
recipient.is_a?(UserGroup) ? recipient.managers : recipient
|
70
|
+
end
|
71
|
+
users += sender.managers if sender.is_a?(UserGroup)
|
72
|
+
users
|
73
|
+
end
|
74
|
+
|
49
75
|
def sender_is_participant
|
50
76
|
errors.add(:sender, :invalid) unless conversation.participants.include?(sender)
|
51
77
|
end
|
@@ -22,6 +22,14 @@ module Decidim
|
|
22
22
|
recipient(user).update_all(read_at: Time.current)
|
23
23
|
end
|
24
24
|
# rubocop:enable Rails/SkipsModelValidations
|
25
|
+
|
26
|
+
# The number of messages unread by a user
|
27
|
+
#
|
28
|
+
# @return [Integer]
|
29
|
+
#
|
30
|
+
def self.unread_count(user)
|
31
|
+
unread_by(user).count
|
32
|
+
end
|
25
33
|
end
|
26
34
|
end
|
27
35
|
end
|
@@ -9,7 +9,7 @@ module Decidim
|
|
9
9
|
belongs_to :author, class_name: "User"
|
10
10
|
belongs_to :organization
|
11
11
|
|
12
|
-
validates :subject,
|
12
|
+
validates :subject, presence: true
|
13
13
|
validate :author_belongs_to_organization
|
14
14
|
|
15
15
|
def self.log_presenter_class_for(_log)
|
@@ -47,6 +47,12 @@ module Decidim
|
|
47
47
|
extended_data["participatory_space_types"]
|
48
48
|
end
|
49
49
|
|
50
|
+
def template
|
51
|
+
@template ||= Decidim::ContentBlock
|
52
|
+
.for_scope(:newsletter_template, organization: organization)
|
53
|
+
.find_by(scoped_resource_id: id)
|
54
|
+
end
|
55
|
+
|
50
56
|
private
|
51
57
|
|
52
58
|
def author_belongs_to_organization
|
@@ -104,22 +104,31 @@ module Decidim
|
|
104
104
|
end
|
105
105
|
|
106
106
|
def enabled_omniauth_providers
|
107
|
-
return Decidim::OmniauthProvider.enabled if omniauth_settings.nil?
|
107
|
+
return Decidim::OmniauthProvider.enabled || {} if omniauth_settings.nil?
|
108
108
|
|
109
|
-
Decidim::OmniauthProvider.enabled.
|
109
|
+
default_except_disabled = Decidim::OmniauthProvider.enabled.except(*tenant_disabled_providers_keys)
|
110
|
+
default_except_disabled.merge(tenant_enabled_providers)
|
110
111
|
end
|
111
112
|
|
112
113
|
private
|
113
114
|
|
115
|
+
def tenant_disabled_providers_keys
|
116
|
+
omniauth_settings.collect do |key, value|
|
117
|
+
next unless key.match?(/omniauth_settings_.*_enabled/) && value == false
|
118
|
+
|
119
|
+
Decidim::OmniauthProvider.extract_provider_key(key)
|
120
|
+
end.compact.uniq
|
121
|
+
end
|
122
|
+
|
114
123
|
def tenant_enabled_providers
|
115
|
-
tenant_enabled_providers_keys = omniauth_settings.map do |
|
116
|
-
next unless
|
124
|
+
tenant_enabled_providers_keys = omniauth_settings.map do |key, value|
|
125
|
+
next unless key.match?(/omniauth_settings_.*_enabled/) && value == true
|
117
126
|
|
118
|
-
Decidim::OmniauthProvider.extract_provider_key(
|
127
|
+
Decidim::OmniauthProvider.extract_provider_key(key)
|
119
128
|
end.compact.uniq
|
120
129
|
|
121
|
-
Hash[tenant_enabled_providers_keys.map do |
|
122
|
-
[
|
130
|
+
Hash[tenant_enabled_providers_keys.map do |key|
|
131
|
+
[key, omniauth_provider_settings(key)]
|
123
132
|
end]
|
124
133
|
end
|
125
134
|
|
data/app/models/decidim/user.rb
CHANGED
@@ -57,6 +57,8 @@ module Decidim
|
|
57
57
|
where("extended_data->>'interested_scopes' ~~ ANY('{#{ids}}')")
|
58
58
|
}
|
59
59
|
|
60
|
+
scope :org_admins_except_me, ->(user) { where(organization: user.organization, admin: true).where.not(id: user.id) }
|
61
|
+
|
60
62
|
attr_accessor :newsletter_notifications
|
61
63
|
|
62
64
|
searchable_fields({
|
@@ -130,10 +132,21 @@ module Decidim
|
|
130
132
|
Decidim::Follow.where(user: self, followable: followable).any?
|
131
133
|
end
|
132
134
|
|
135
|
+
# Public: whether the user accepts direct messages from another
|
136
|
+
def accepts_conversation?(user)
|
137
|
+
return follows?(user) if direct_message_types == "followed-only"
|
138
|
+
|
139
|
+
true
|
140
|
+
end
|
141
|
+
|
133
142
|
def unread_conversations
|
134
143
|
Decidim::Messaging::Conversation.unread_by(self)
|
135
144
|
end
|
136
145
|
|
146
|
+
def unread_messages_count
|
147
|
+
@unread_messages_count ||= Decidim::Messaging::Receipt.unread_count(self)
|
148
|
+
end
|
149
|
+
|
137
150
|
# Check if the user exists with the given email and the current organization
|
138
151
|
#
|
139
152
|
# warden_conditions - A hash with the authentication conditions
|
@@ -199,6 +212,25 @@ module Decidim
|
|
199
212
|
end
|
200
213
|
end
|
201
214
|
|
215
|
+
# return the groups where this user has been accepted
|
216
|
+
def accepted_user_groups
|
217
|
+
UserGroups::AcceptedUserGroups.for(self)
|
218
|
+
end
|
219
|
+
|
220
|
+
# return the groups where this user has admin permissions
|
221
|
+
def manageable_user_groups
|
222
|
+
UserGroups::ManageableUserGroups.for(self)
|
223
|
+
end
|
224
|
+
|
225
|
+
def authenticatable_salt
|
226
|
+
"#{super}#{session_token}"
|
227
|
+
end
|
228
|
+
|
229
|
+
def invalidate_all_sessions!
|
230
|
+
self.session_token = SecureRandom.hex
|
231
|
+
save!
|
232
|
+
end
|
233
|
+
|
202
234
|
protected
|
203
235
|
|
204
236
|
# Overrides devise email required validation.
|
@@ -97,6 +97,29 @@ module Decidim
|
|
97
97
|
save!
|
98
98
|
end
|
99
99
|
|
100
|
+
# sugar for the memberships query
|
101
|
+
def accepted_memberships
|
102
|
+
UserGroups::AcceptedMemberships.for(self)
|
103
|
+
end
|
104
|
+
|
105
|
+
# easy way to return all the users accepted in this group
|
106
|
+
def accepted_users
|
107
|
+
accepted_memberships.map(&:user)
|
108
|
+
end
|
109
|
+
|
110
|
+
# Currently, groups always accept conversations from anyone.
|
111
|
+
# This may change in the future in case the desired behaviour
|
112
|
+
# is to check if all (or any) of the administrators accepts conversations
|
113
|
+
# or there's simply and option for this in the group preferences.
|
114
|
+
def accepts_conversation?(_user)
|
115
|
+
true
|
116
|
+
end
|
117
|
+
|
118
|
+
def unread_messages_count_for(user)
|
119
|
+
@unread_messages_count_for ||= {}
|
120
|
+
@unread_messages_count_for[user.id] ||= Decidim::Messaging::Conversation.user_collection(self).unread_messages_by(user).count
|
121
|
+
end
|
122
|
+
|
100
123
|
private
|
101
124
|
|
102
125
|
# Private: Checks if the state user group is correct.
|
@@ -21,6 +21,7 @@ module Decidim
|
|
21
21
|
conversation_action?
|
22
22
|
user_group_action?
|
23
23
|
user_group_invitations_action?
|
24
|
+
apply_endorsement_permissions if permission_action.subject == :endorsement
|
24
25
|
|
25
26
|
permission_action
|
26
27
|
end
|
@@ -71,10 +72,10 @@ module Decidim
|
|
71
72
|
case permission_action.action
|
72
73
|
when :create
|
73
74
|
toggle_allow(authorization.user == user && not_already_active?(authorization))
|
74
|
-
when :update
|
75
|
-
toggle_allow(authorization.user == user && !authorization.granted?)
|
76
|
-
when :destroy
|
75
|
+
when :update, :destroy
|
77
76
|
toggle_allow(authorization.user == user && !authorization.granted?)
|
77
|
+
when :renew
|
78
|
+
toggle_allow(authorization.user == user && authorization.granted? && authorization.renewable?)
|
78
79
|
end
|
79
80
|
end
|
80
81
|
|
@@ -104,6 +105,12 @@ module Decidim
|
|
104
105
|
toggle_allow(amendment&.amender == user)
|
105
106
|
end
|
106
107
|
|
108
|
+
def apply_endorsement_permissions
|
109
|
+
return disallow! if !current_settings.endorsements_enabled || current_settings.endorsements_blocked
|
110
|
+
|
111
|
+
allow!
|
112
|
+
end
|
113
|
+
|
107
114
|
def notification_action?
|
108
115
|
return unless permission_action.subject == :notification
|
109
116
|
return allow! if permission_action.action == :read
|
@@ -114,10 +121,16 @@ module Decidim
|
|
114
121
|
|
115
122
|
def conversation_action?
|
116
123
|
return unless permission_action.subject == :conversation
|
117
|
-
return allow! if
|
124
|
+
return allow! if permission_action.action == :list
|
125
|
+
|
126
|
+
conversation = context.fetch(:conversation)
|
127
|
+
interlocutor = context.fetch(:interlocutor, user)
|
128
|
+
|
129
|
+
if [:create, :update].include?(permission_action.action)
|
130
|
+
return disallow! unless conversation&.accept_user? interlocutor
|
131
|
+
end
|
118
132
|
|
119
|
-
conversation
|
120
|
-
toggle_allow(conversation.participants.include?(user))
|
133
|
+
toggle_allow(conversation&.participating?(interlocutor))
|
121
134
|
end
|
122
135
|
|
123
136
|
def user_group_action?
|