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
@@ -5,8 +5,7 @@ module Decidim
|
|
5
5
|
# A parser that searches user mentions in content.
|
6
6
|
#
|
7
7
|
# A word starting with `@` will be considered as a possible mention if
|
8
|
-
# they only contains letters, numbers or underscores.
|
9
|
-
# followed with an underscore, then it is not considered.
|
8
|
+
# they only contains letters, numbers or underscores.
|
10
9
|
#
|
11
10
|
# @see BaseParser Examples of how to use a content parser
|
12
11
|
class UserParser < BaseParser
|
@@ -16,9 +15,8 @@ module Decidim
|
|
16
15
|
# @return [Array] an array of Decidim::User mentioned in content
|
17
16
|
Metadata = Struct.new(:users)
|
18
17
|
|
19
|
-
# Matches a nickname if
|
20
|
-
|
21
|
-
MENTION_REGEX = /\B@([a-zA-Z0-9]\w*)\b/.freeze
|
18
|
+
# Matches a nickname if contains letters, numbers or underscores.
|
19
|
+
MENTION_REGEX = /\B@(\w*)\b/.freeze
|
22
20
|
|
23
21
|
# Replaces found mentions matching a nickname of an existing
|
24
22
|
# user in the current organization with a global id. Other
|
@@ -4,6 +4,7 @@ module Decidim
|
|
4
4
|
module ContentRenderers
|
5
5
|
autoload :BaseRenderer, "decidim/content_renderers/base_renderer"
|
6
6
|
autoload :UserRenderer, "decidim/content_renderers/user_renderer"
|
7
|
+
autoload :UserGroupRenderer, "decidim/content_renderers/user_group_renderer"
|
7
8
|
autoload :HashtagRenderer, "decidim/content_renderers/hashtag_renderer"
|
8
9
|
autoload :LinkRenderer, "decidim/content_renderers/link_renderer"
|
9
10
|
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
module ContentRenderers
|
5
|
+
# A renderer that searches Global IDs representing users in content
|
6
|
+
# and replaces it with a link to their profile with the nickname.
|
7
|
+
#
|
8
|
+
# e.g. gid://<APP_NAME>/Decidim::UserGroup/1
|
9
|
+
#
|
10
|
+
# @see BaseRenderer Examples of how to use a content renderer
|
11
|
+
class UserGroupRenderer < BaseRenderer
|
12
|
+
# Matches a global id representing a Decidim::UserGroup
|
13
|
+
GLOBAL_ID_REGEX = %r{gid://\S+/Decidim::UserGroup/\d+}.freeze
|
14
|
+
|
15
|
+
# Replaces found Global IDs matching an existing user with
|
16
|
+
# a link to their profile. The Global IDs representing an
|
17
|
+
# invalid Decidim::UserGroup are replaced with an empty string.
|
18
|
+
#
|
19
|
+
# @return [String] the content ready to display (contains HTML)
|
20
|
+
def render
|
21
|
+
content.gsub(GLOBAL_ID_REGEX) do |user_gid|
|
22
|
+
user = GlobalID::Locator.locate(user_gid)
|
23
|
+
Decidim::UserGroupPresenter.new(user).display_mention
|
24
|
+
rescue ActiveRecord::RecordNotFound => _e
|
25
|
+
""
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
data/lib/decidim/core.rb
CHANGED
@@ -81,6 +81,8 @@ module Decidim
|
|
81
81
|
autoload :HasResourcePermission, "decidim/has_resource_permission"
|
82
82
|
autoload :PermissionsRegistry, "decidim/permissions_registry"
|
83
83
|
autoload :Randomable, "decidim/randomable"
|
84
|
+
autoload :Endorsable, "decidim/endorsable"
|
85
|
+
autoload :ActionAuthorization, "decidim/action_authorization"
|
84
86
|
|
85
87
|
include ActiveSupport::Configurable
|
86
88
|
# Loads seeds from all engines.
|
@@ -131,9 +133,19 @@ module Decidim
|
|
131
133
|
# the mails.
|
132
134
|
config_accessor :mailer_sender
|
133
135
|
|
136
|
+
# Whether SSL should be enabled or not.
|
137
|
+
config_accessor :force_ssl do
|
138
|
+
true
|
139
|
+
end
|
140
|
+
|
134
141
|
# Exposes a configuration option: The application available locales.
|
135
142
|
config_accessor :available_locales do
|
136
|
-
%w(en ar ca de el es es-MX es-PY eu fi-pl fi fr gl hu id it nl no pl pt pt-BR ru sv tr uk)
|
143
|
+
%w(en ar ca de el es es-MX es-PY eu fi-pl fi fr gl hu id it nl no pl pt pt-BR ro ru sk sv tr uk)
|
144
|
+
end
|
145
|
+
|
146
|
+
# Exposes a configuration option: The application default locale.
|
147
|
+
config_accessor :default_locale do
|
148
|
+
:en
|
137
149
|
end
|
138
150
|
|
139
151
|
# Exposes a configuration option: an array of symbols representing processors
|
@@ -153,11 +165,6 @@ module Decidim
|
|
153
165
|
[]
|
154
166
|
end
|
155
167
|
|
156
|
-
# Exposes a configuration option: The application default locale.
|
157
|
-
config_accessor :default_locale do
|
158
|
-
:en
|
159
|
-
end
|
160
|
-
|
161
168
|
# Exposes a configuration option: an object to configure geocoder
|
162
169
|
config_accessor :geocoder
|
163
170
|
|
@@ -192,6 +199,11 @@ module Decidim
|
|
192
199
|
end
|
193
200
|
end
|
194
201
|
|
202
|
+
# Exposes a configuration option: the whitelist ips
|
203
|
+
config_accessor :system_accesslist_ips do
|
204
|
+
[]
|
205
|
+
end
|
206
|
+
|
195
207
|
# Exposes a configuration option: the currency unit
|
196
208
|
config_accessor :currency_unit do
|
197
209
|
"€"
|
@@ -212,7 +224,7 @@ module Decidim
|
|
212
224
|
5.megabytes
|
213
225
|
end
|
214
226
|
|
215
|
-
# The number of reports which
|
227
|
+
# The number of reports which a resource can receive before hiding it
|
216
228
|
config_accessor :max_reports_before_hiding do
|
217
229
|
3
|
218
230
|
end
|
@@ -247,39 +259,71 @@ module Decidim
|
|
247
259
|
2.days
|
248
260
|
end
|
249
261
|
|
262
|
+
# How long can a user remained logged in before the session expires
|
263
|
+
config_accessor :expire_session_after do
|
264
|
+
1.day
|
265
|
+
end
|
266
|
+
|
250
267
|
# Exposes a configuration option: an object to configure Etherpad
|
251
|
-
config_accessor :etherpad
|
268
|
+
config_accessor :etherpad do
|
269
|
+
# {
|
270
|
+
# server: <your url>,
|
271
|
+
# api_key: <your key>,
|
272
|
+
# api_version: <your version>
|
273
|
+
# }
|
274
|
+
end
|
252
275
|
|
253
276
|
# A base path for the uploads. If set, make sure it ends in a slash.
|
254
277
|
# Uploads will be set to `<base_path>/uploads/`. This can be useful if you
|
255
278
|
# want to use the same uploads place for both staging and production
|
256
279
|
# environments, but in different folders.
|
257
|
-
config_accessor :base_uploads_path
|
280
|
+
config_accessor :base_uploads_path do
|
281
|
+
nil
|
282
|
+
end
|
258
283
|
|
259
|
-
#
|
260
|
-
|
284
|
+
# The name of the class to deliver SMS codes to users.
|
285
|
+
#
|
286
|
+
# Check the example in `decidim-verifications`.
|
287
|
+
config_accessor :sms_gateway_service do
|
288
|
+
# "MyGatewayClass"
|
289
|
+
end
|
261
290
|
|
262
|
-
#
|
263
|
-
#
|
264
|
-
|
291
|
+
# The name of the class used to generate a timestamp from a document.
|
292
|
+
#
|
293
|
+
# Check the example in `decidim-initiatives`
|
294
|
+
config_accessor :timestamp_service do
|
295
|
+
# "MyTimestampService"
|
296
|
+
end
|
265
297
|
|
266
|
-
#
|
267
|
-
#
|
268
|
-
|
298
|
+
# The name of the class used to process a pdf and add a signature to the
|
299
|
+
# document.
|
300
|
+
#
|
301
|
+
# Check the example in `decidim-initiatives`
|
302
|
+
config_accessor :pdf_signature_service do
|
303
|
+
# "MyPDFSignatureService"
|
304
|
+
end
|
269
305
|
|
270
|
-
#
|
306
|
+
# The Decidim::Exporters::CSV's default column separator
|
271
307
|
config_accessor :default_csv_col_sep do
|
272
308
|
";"
|
273
309
|
end
|
274
310
|
|
275
|
-
# Exposes a configuration option:
|
311
|
+
# Exposes a configuration option: HTTP_X_FORWADED_HOST header follow-up.
|
312
|
+
# If a caching system is in place, it can also allow cache and log poisoning attacks,
|
313
|
+
# allowing attackers to control the contents of caches and logs that could be used for other attacks.
|
314
|
+
config_accessor :follow_http_x_forwarded_host do
|
315
|
+
false
|
316
|
+
end
|
317
|
+
|
318
|
+
# The list of roles a user can have, not considering the space-specific roles.
|
276
319
|
config_accessor :user_roles do
|
277
320
|
%w(admin user_manager)
|
278
321
|
end
|
279
322
|
|
280
|
-
#
|
281
|
-
# locale keys and values to construct the input collection in
|
323
|
+
# The list of visibility options for amendments. An Array of Strings that
|
324
|
+
# serve both as locale keys and values to construct the input collection in
|
282
325
|
# Decidim::Amendment::VisibilityStepSetting::options.
|
326
|
+
#
|
283
327
|
# This collection is used in Decidim::Admin::SettingsHelper to generate a
|
284
328
|
# radio buttons collection input field form for a Decidim::Component
|
285
329
|
# step setting :amendments_visibility.
|
data/lib/decidim/core/api.rb
CHANGED
@@ -17,5 +17,6 @@ module Decidim
|
|
17
17
|
autoload :AmendableEntityInterface, "decidim/api/amendable_entity_interface"
|
18
18
|
autoload :TraceableInterface, "decidim/api/traceable_interface"
|
19
19
|
autoload :TimestampsInterface, "decidim/api/timestamps_interface"
|
20
|
+
autoload :EndorsableInterface, "decidim/api/endorsable_interface"
|
20
21
|
end
|
21
22
|
end
|
data/lib/decidim/core/engine.rb
CHANGED
@@ -59,12 +59,14 @@ module Decidim
|
|
59
59
|
|
60
60
|
initializer "decidim.middleware" do |app|
|
61
61
|
app.config.middleware.insert_before Warden::Manager, Decidim::CurrentOrganization
|
62
|
+
app.config.middleware.insert_before Warden::Manager, Decidim::StripXForwardedHost
|
62
63
|
app.config.middleware.use BatchLoader::Middleware
|
63
64
|
end
|
64
65
|
|
65
66
|
initializer "decidim.assets" do |app|
|
66
67
|
app.config.assets.paths << File.expand_path("../../../app/assets/stylesheets", __dir__)
|
67
|
-
app.config.assets.precompile += %w(decidim_core_manifest.js
|
68
|
+
app.config.assets.precompile += %w(decidim_core_manifest.js
|
69
|
+
decidim/identity_selector_dialog)
|
68
70
|
|
69
71
|
Decidim.component_manifests.each do |component|
|
70
72
|
app.config.assets.precompile += [component.icon]
|
@@ -196,7 +198,7 @@ module Decidim
|
|
196
198
|
|
197
199
|
initializer "decidim.content_processors" do |_app|
|
198
200
|
Decidim.configure do |config|
|
199
|
-
config.content_processors += [:user, :hashtag, :link]
|
201
|
+
config.content_processors += [:user, :user_group, :hashtag, :link]
|
200
202
|
end
|
201
203
|
end
|
202
204
|
|
@@ -240,9 +242,7 @@ module Decidim
|
|
240
242
|
# #call can be used in order to allow conditional checks (to allow non-SSL
|
241
243
|
# redirects to localhost for example).
|
242
244
|
#
|
243
|
-
|
244
|
-
#
|
245
|
-
force_ssl_in_redirect_uri false
|
245
|
+
force_ssl_in_redirect_uri !Rails.env.development?
|
246
246
|
|
247
247
|
# WWW-Authenticate Realm (default "Doorkeeper").
|
248
248
|
realm "Decidim"
|
@@ -255,6 +255,22 @@ module Decidim
|
|
255
255
|
end
|
256
256
|
end
|
257
257
|
|
258
|
+
initializer "SSL and HSTS" do
|
259
|
+
Rails.application.configure do
|
260
|
+
config.force_ssl = Rails.env.production? && Decidim.config.force_ssl
|
261
|
+
end
|
262
|
+
end
|
263
|
+
|
264
|
+
initializer "Disable Rack::Runtime" do
|
265
|
+
Rails.application.configure do
|
266
|
+
config.middleware.delete Rack::Runtime
|
267
|
+
end
|
268
|
+
end
|
269
|
+
|
270
|
+
initializer "Expire sessions" do
|
271
|
+
Rails.application.config.session_store :cookie_store, expire_after: Decidim.config.expire_session_after
|
272
|
+
end
|
273
|
+
|
258
274
|
initializer "decidim.core.register_resources" do
|
259
275
|
Decidim.register_resource(:user) do |resource|
|
260
276
|
resource.model_class_name = "Decidim::User"
|
@@ -302,7 +318,7 @@ module Decidim
|
|
302
318
|
end
|
303
319
|
end
|
304
320
|
|
305
|
-
initializer "decidim.core.
|
321
|
+
initializer "decidim.core.homepage_content_blocks" do
|
306
322
|
Decidim.content_blocks.register(:homepage, :hero) do |content_block|
|
307
323
|
content_block.cell = "decidim/content_blocks/hero"
|
308
324
|
content_block.settings_form_cell = "decidim/content_blocks/hero_settings_form"
|
@@ -374,6 +390,68 @@ module Decidim
|
|
374
390
|
end
|
375
391
|
end
|
376
392
|
|
393
|
+
initializer "decidim.core.newsletter_templates" do
|
394
|
+
Decidim.content_blocks.register(:newsletter_template, :basic_only_text) do |content_block|
|
395
|
+
content_block.cell = "decidim/newsletter_templates/basic_only_text"
|
396
|
+
content_block.settings_form_cell = "decidim/newsletter_templates/basic_only_text_settings_form"
|
397
|
+
content_block.public_name_key = "decidim.newsletter_templates.basic_only_text.name"
|
398
|
+
|
399
|
+
content_block.settings do |settings|
|
400
|
+
settings.attribute(
|
401
|
+
:body,
|
402
|
+
type: :text,
|
403
|
+
translated: true,
|
404
|
+
preview: -> { I18n.t("decidim.newsletter_templates.basic_only_text.body_preview") }
|
405
|
+
)
|
406
|
+
end
|
407
|
+
|
408
|
+
content_block.default!
|
409
|
+
end
|
410
|
+
|
411
|
+
Decidim.content_blocks.register(:newsletter_template, :image_text_cta) do |content_block|
|
412
|
+
content_block.cell = "decidim/newsletter_templates/image_text_cta"
|
413
|
+
content_block.settings_form_cell = "decidim/newsletter_templates/image_text_cta_settings_form"
|
414
|
+
content_block.public_name_key = "decidim.newsletter_templates.image_text_cta.name"
|
415
|
+
|
416
|
+
content_block.images = [
|
417
|
+
{
|
418
|
+
name: :main_image,
|
419
|
+
uploader: "Decidim::NewsletterTemplateImageUploader",
|
420
|
+
preview: -> { ActionController::Base.helpers.asset_path("decidim/placeholder.jpg") }
|
421
|
+
}
|
422
|
+
]
|
423
|
+
|
424
|
+
content_block.settings do |settings|
|
425
|
+
settings.attribute(
|
426
|
+
:introduction,
|
427
|
+
type: :text,
|
428
|
+
translated: true,
|
429
|
+
preview: -> { I18n.t("decidim.newsletter_templates.image_text_cta.introduction_preview") }
|
430
|
+
)
|
431
|
+
settings.attribute(
|
432
|
+
:body,
|
433
|
+
type: :text,
|
434
|
+
translated: true,
|
435
|
+
preview: -> { I18n.t("decidim.newsletter_templates.image_text_cta.body_preview") }
|
436
|
+
)
|
437
|
+
settings.attribute(
|
438
|
+
:cta_text,
|
439
|
+
type: :text,
|
440
|
+
translated: true,
|
441
|
+
preview: -> { I18n.t("decidim.newsletter_templates.image_text_cta.cta_text_preview") }
|
442
|
+
)
|
443
|
+
settings.attribute(
|
444
|
+
:cta_url,
|
445
|
+
type: :text,
|
446
|
+
translated: true,
|
447
|
+
preview: -> { "http://decidim.org" }
|
448
|
+
)
|
449
|
+
end
|
450
|
+
|
451
|
+
content_block.default!
|
452
|
+
end
|
453
|
+
end
|
454
|
+
|
377
455
|
initializer "decidim.core.add_badges" do
|
378
456
|
Decidim::Gamification.register_badge(:invitations) do |badge|
|
379
457
|
badge.levels = [1, 5, 10, 30, 50]
|
@@ -389,6 +467,10 @@ module Decidim
|
|
389
467
|
initializer "nbspw" do
|
390
468
|
NOBSPW.configuration.use_ruby_grep = true
|
391
469
|
end
|
470
|
+
|
471
|
+
config.to_prepare do
|
472
|
+
FoundationRailsHelper::FlashHelper.send(:include, Decidim::FlashHelperExtensions)
|
473
|
+
end
|
392
474
|
end
|
393
475
|
end
|
394
476
|
end
|
data/lib/decidim/core/test.rb
CHANGED
@@ -5,6 +5,7 @@ require "decidim/core/test/shared_examples/authorable"
|
|
5
5
|
require "decidim/core/test/shared_examples/coauthorable"
|
6
6
|
require "decidim/core/test/shared_examples/publicable"
|
7
7
|
require "decidim/core/test/shared_examples/localised_email"
|
8
|
+
require "decidim/core/test/shared_examples/logo_email"
|
8
9
|
require "decidim/core/test/shared_examples/has_attachments"
|
9
10
|
require "decidim/core/test/shared_examples/has_attachment_collections"
|
10
11
|
require "decidim/core/test/shared_examples/has_component"
|
@@ -28,6 +29,7 @@ require "decidim/core/test/shared_examples/searchable_results_examples"
|
|
28
29
|
require "decidim/core/test/shared_examples/has_space_in_mcell_examples"
|
29
30
|
require "decidim/core/test/shared_examples/railtie_examples"
|
30
31
|
require "decidim/core/test/shared_examples/edit_link_shared_examples"
|
32
|
+
require "decidim/core/test/shared_examples/endorsements_controller_shared_context"
|
31
33
|
require "decidim/core/test/shared_examples/amendable/create_amendment_draft_examples"
|
32
34
|
require "decidim/core/test/shared_examples/amendable/update_amendment_draft_examples"
|
33
35
|
require "decidim/core/test/shared_examples/amendable/destroy_amendment_draft_examples"
|
@@ -46,4 +48,10 @@ require "decidim/core/test/shared_examples/uncommentable_component_examples"
|
|
46
48
|
require "decidim/core/test/shared_examples/searchable_resources_shared_context"
|
47
49
|
require "decidim/core/test/shared_examples/searchable_participatory_space_examples"
|
48
50
|
require "decidim/core/test/shared_examples/has_private_users"
|
51
|
+
require "decidim/core/test/shared_examples/with_endorsable_permissions_examples"
|
52
|
+
require "decidim/core/test/shared_examples/system_endorse_resource_examples"
|
49
53
|
require "decidim/core/test/shared_examples/rich_text_editor_examples"
|
54
|
+
require "decidim/core/test/shared_examples/back_to_list_button_examples"
|
55
|
+
require "decidim/core/test/shared_examples/permissions"
|
56
|
+
require "decidim/core/test/shared_examples/admin_resource_gallery_examples"
|
57
|
+
require "decidim/core/test/shared_examples/metric_manage_shared_context"
|
@@ -335,8 +335,9 @@ FactoryBot.define do
|
|
335
335
|
|
336
336
|
trait :with_one_step do
|
337
337
|
step_settings do
|
338
|
+
participatory_space_with_steps if participatory_space.active_step.nil?
|
338
339
|
{
|
339
|
-
|
340
|
+
participatory_space.active_step.id => { dummy_step_setting: true }
|
340
341
|
}
|
341
342
|
end
|
342
343
|
end
|
@@ -360,6 +361,44 @@ FactoryBot.define do
|
|
360
361
|
trait :with_permissions do
|
361
362
|
settings { { Random.rand => Random.new.bytes(5) } }
|
362
363
|
end
|
364
|
+
|
365
|
+
transient do
|
366
|
+
participatory_space_with_steps do
|
367
|
+
create(:participatory_process_step,
|
368
|
+
active: true,
|
369
|
+
end_date: 1.month.from_now,
|
370
|
+
participatory_process: participatory_space)
|
371
|
+
participatory_space.reload
|
372
|
+
participatory_space.steps.reload
|
373
|
+
end
|
374
|
+
end
|
375
|
+
|
376
|
+
trait :with_endorsements_enabled do
|
377
|
+
step_settings do
|
378
|
+
participatory_space_with_steps if participatory_space.active_step.nil?
|
379
|
+
{
|
380
|
+
participatory_space.active_step.id => { endorsements_enabled: true }
|
381
|
+
}
|
382
|
+
end
|
383
|
+
end
|
384
|
+
|
385
|
+
trait :with_endorsements_disabled do
|
386
|
+
step_settings do
|
387
|
+
participatory_space_with_steps if participatory_space.active_step.nil?
|
388
|
+
{
|
389
|
+
participatory_space.active_step.id => { endorsements_enabled: false }
|
390
|
+
}
|
391
|
+
end
|
392
|
+
end
|
393
|
+
|
394
|
+
trait :with_endorsements_blocked do
|
395
|
+
step_settings do
|
396
|
+
participatory_space_with_steps if participatory_space.active_step.nil?
|
397
|
+
{
|
398
|
+
participatory_space.active_step.id => { endorsements_blocked: true }
|
399
|
+
}
|
400
|
+
end
|
401
|
+
end
|
363
402
|
end
|
364
403
|
|
365
404
|
factory :scope_type, class: "Decidim::ScopeType" do
|
@@ -403,6 +442,11 @@ FactoryBot.define do
|
|
403
442
|
end
|
404
443
|
|
405
444
|
factory :dummy_resource, class: "Decidim::DummyResources::DummyResource" do
|
445
|
+
transient do
|
446
|
+
users { nil }
|
447
|
+
# user_groups correspondence to users is by sorting order
|
448
|
+
user_groups { [] }
|
449
|
+
end
|
406
450
|
title { generate(:name) }
|
407
451
|
component { create(:component, manifest_name: "dummy") }
|
408
452
|
author { create(:user, :confirmed, organization: component.organization) }
|
@@ -411,6 +455,33 @@ FactoryBot.define do
|
|
411
455
|
trait :published do
|
412
456
|
published_at { Time.current }
|
413
457
|
end
|
458
|
+
|
459
|
+
trait :with_endorsements do
|
460
|
+
after :create do |resource|
|
461
|
+
5.times.collect do
|
462
|
+
create(:endorsement, resource: resource, author: build(:user, organization: resource.component.organization))
|
463
|
+
end
|
464
|
+
end
|
465
|
+
end
|
466
|
+
end
|
467
|
+
|
468
|
+
factory :coauthorable_dummy_resource, class: "Decidim::DummyResources::CoauthorableDummyResource" do
|
469
|
+
title { generate(:name) }
|
470
|
+
component { create(:component, manifest_name: "dummy") }
|
471
|
+
|
472
|
+
transient do
|
473
|
+
authors_list { [create(:user, organization: component.organization)] }
|
474
|
+
end
|
475
|
+
|
476
|
+
after :build do |resource, evaluator|
|
477
|
+
evaluator.authors_list.each do |coauthor|
|
478
|
+
resource.coauthorships << if coauthor.is_a?(::Decidim::UserGroup)
|
479
|
+
build(:coauthorship, author: coauthor.users.first, user_group: coauthor, coauthorable: resource, organization: evaluator.component.organization)
|
480
|
+
else
|
481
|
+
build(:coauthorship, author: coauthor, coauthorable: resource, organization: evaluator.component.organization)
|
482
|
+
end
|
483
|
+
end
|
484
|
+
end
|
414
485
|
end
|
415
486
|
|
416
487
|
factory :resource_link, class: "Decidim::ResourceLink" do
|
@@ -420,12 +491,25 @@ FactoryBot.define do
|
|
420
491
|
end
|
421
492
|
|
422
493
|
factory :newsletter, class: "Decidim::Newsletter" do
|
494
|
+
transient do
|
495
|
+
body { Decidim::Faker::Localized.wrapped("<p>", "</p>") { generate_localized_title } }
|
496
|
+
end
|
497
|
+
|
423
498
|
author { build(:user, :confirmed, organization: organization) }
|
424
499
|
organization
|
425
500
|
|
426
501
|
subject { generate_localized_title }
|
427
502
|
|
428
|
-
|
503
|
+
after(:create) do |newsletter, evaluator|
|
504
|
+
create(
|
505
|
+
:content_block,
|
506
|
+
:newsletter_template,
|
507
|
+
organization: evaluator.organization,
|
508
|
+
scoped_resource_id: newsletter.id,
|
509
|
+
manifest_name: "basic_only_text",
|
510
|
+
settings: evaluator.body.transform_keys { |key| "body_#{key}" }
|
511
|
+
)
|
512
|
+
end
|
429
513
|
|
430
514
|
trait :sent do
|
431
515
|
sent_at { Time.current }
|
@@ -547,10 +631,15 @@ FactoryBot.define do
|
|
547
631
|
|
548
632
|
factory :content_block, class: "Decidim::ContentBlock" do
|
549
633
|
organization
|
550
|
-
|
634
|
+
scope_name { :homepage }
|
551
635
|
manifest_name { :hero }
|
552
636
|
weight { 1 }
|
553
637
|
published_at { Time.current }
|
638
|
+
|
639
|
+
trait :newsletter_template do
|
640
|
+
scope_name { :newsletter_template }
|
641
|
+
manifest_name { :basic_only_text }
|
642
|
+
end
|
554
643
|
end
|
555
644
|
|
556
645
|
factory :hashtag, class: "Decidim::Hashtag" do
|
@@ -583,4 +672,15 @@ FactoryBot.define do
|
|
583
672
|
state { "rejected" }
|
584
673
|
end
|
585
674
|
end
|
675
|
+
|
676
|
+
factory :endorsement, class: "Decidim::Endorsement" do
|
677
|
+
resource { build(:dummy_resource) }
|
678
|
+
author { resource.try(:creator_author) || resource.try(:author) || build(:user, organization: resource.organization) }
|
679
|
+
end
|
680
|
+
|
681
|
+
factory :user_group_endorsement, class: "Decidim::Endorsement" do
|
682
|
+
resource { build(:dummy_resource) }
|
683
|
+
author { build(:user, organization: resource.organization) }
|
684
|
+
user_group { create(:user_group, verified_at: Time.current, organization: resource.organization, users: [author]) }
|
685
|
+
end
|
586
686
|
end
|