decidim-core 0.15.2 → 0.16.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/README.md +14 -1
- data/app/assets/config/decidim_core_manifest.js +14 -12
- data/app/assets/images/decidim/pattern.png +0 -0
- data/app/assets/javascripts/decidim.js.es6 +4 -0
- data/app/assets/javascripts/decidim/floating_help.js.es6 +40 -0
- data/app/assets/javascripts/decidim/input_hashtags.js.es6 +6 -4
- data/app/assets/javascripts/decidim/notifications.js.es6 +1 -1
- data/app/assets/javascripts/decidim/tooltip_keep_on_hover.js.es6 +18 -0
- data/app/assets/javascripts/decidim/vizzs/areachart.js.es6 +52 -10
- data/app/assets/javascripts/decidim/vizzs/metrics.js.es6 +68 -22
- data/app/assets/javascripts/decidim/vizzs/orgchart.js.es6 +10 -13
- data/app/assets/stylesheets/decidim/conference-diploma.css.scss +61 -0
- data/app/assets/stylesheets/decidim/layouts/_home.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_buttons.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_cards.scss +17 -1
- data/app/assets/stylesheets/decidim/modules/_conference-programme.scss +0 -4
- data/app/assets/stylesheets/decidim/modules/_filters.scss +37 -2
- data/app/assets/stylesheets/decidim/modules/_floating-helper.scss +106 -0
- data/app/assets/stylesheets/decidim/modules/_forms.scss +22 -0
- data/app/assets/stylesheets/decidim/modules/_help.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_layout.scss +1 -0
- data/app/assets/stylesheets/decidim/modules/_margins.scss +1 -0
- data/app/assets/stylesheets/decidim/modules/_modules.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_navbar.scss +5 -1
- data/app/assets/stylesheets/decidim/modules/_order-by.scss +11 -1
- data/app/assets/stylesheets/decidim/modules/_process-header.scss +36 -38
- data/app/assets/stylesheets/decidim/modules/_process-nav.scss +61 -10
- data/app/assets/stylesheets/decidim/modules/_process-phase.scss +63 -30
- data/app/assets/stylesheets/decidim/modules/_share.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_typography.scss +17 -0
- data/app/assets/stylesheets/decidim/{modules → vizzs}/_orgchart.scss +2 -10
- data/app/cells/decidim/activities_cell.rb +6 -2
- data/app/cells/decidim/activity/show.erb +22 -19
- data/app/cells/decidim/activity_cell.rb +35 -5
- data/app/cells/decidim/amendable/amend_button_card/show.erb +9 -0
- data/app/cells/decidim/amendable/amend_button_card_cell.rb +43 -0
- data/app/cells/decidim/amendable/amenders_list/show.erb +18 -0
- data/app/cells/decidim/amendable/amenders_list_cell.rb +7 -0
- data/app/cells/decidim/amendable/announcement_cell.rb +58 -0
- data/app/cells/decidim/amendable/emendation_actions/show.erb +13 -0
- data/app/cells/decidim/amendable/emendation_actions_cell.rb +52 -0
- data/app/cells/decidim/amendable/promote_button_card/show.erb +9 -0
- data/app/cells/decidim/amendable/promote_button_card_cell.rb +47 -0
- data/app/cells/decidim/author/profile_inline.erb +23 -4
- data/app/cells/decidim/author/profile_minicard.erb +25 -0
- data/app/cells/decidim/author/show.erb +0 -1
- data/app/cells/decidim/author_cell.rb +6 -0
- data/app/cells/decidim/card_cell.rb +2 -4
- data/app/cells/decidim/card_m/top.erb +1 -1
- data/app/cells/decidim/card_m_cell.rb +3 -0
- data/app/cells/decidim/content_blocks/last_activity_cell.rb +1 -1
- data/app/cells/decidim/follow_button/show.erb +0 -1
- data/app/cells/decidim/follow_button_cell.rb +10 -0
- data/app/cells/decidim/following/show.erb +1 -1
- data/app/cells/decidim/following_cell.rb +1 -1
- data/app/cells/decidim/notifications/show.erb +1 -0
- data/app/cells/decidim/pad_iframe/show.erb +14 -0
- data/app/cells/decidim/pad_iframe_cell.rb +57 -0
- data/app/cells/decidim/profile/user_tabs.erb +8 -6
- data/app/cells/decidim/profile_cell.rb +1 -1
- data/app/cells/decidim/profile_sidebar/show.erb +58 -42
- data/app/cells/decidim/profile_sidebar_cell.rb +6 -0
- data/app/cells/decidim/search_results/show.erb +8 -0
- data/app/cells/decidim/search_results_cell.rb +38 -0
- data/app/cells/decidim/search_results_section/show.erb +24 -0
- data/app/cells/decidim/search_results_section_cell.rb +35 -0
- data/app/cells/decidim/user_activity/show.erb +15 -0
- data/app/cells/decidim/user_activity_cell.rb +17 -0
- data/app/cells/decidim/user_profile/header.erb +1 -16
- data/app/cells/decidim/user_profile/user_data.erb +16 -0
- data/app/cells/decidim/user_profile_cell.rb +4 -0
- data/app/cells/decidim/user_timeline/show.erb +15 -0
- data/app/cells/decidim/user_timeline_cell.rb +17 -0
- data/app/commands/decidim/accept_user_group_join_request.rb +1 -1
- data/app/commands/decidim/amendable/accept.rb +84 -0
- data/app/commands/decidim/amendable/create.rb +103 -0
- data/app/commands/decidim/amendable/promote.rb +79 -0
- data/app/commands/decidim/amendable/reject.rb +60 -0
- data/app/commands/decidim/amendable/withdraw.rb +46 -0
- data/app/commands/decidim/create_omniauth_registration.rb +17 -1
- data/app/commands/decidim/create_registration.rb +2 -0
- data/app/commands/decidim/demote_membership.rb +1 -1
- data/app/commands/decidim/invite_user.rb +1 -1
- data/app/commands/decidim/invite_user_to_group.rb +1 -1
- data/app/commands/decidim/join_user_group.rb +1 -7
- data/app/commands/decidim/messaging/reply_to_conversation.rb +1 -1
- data/app/commands/decidim/promote_membership.rb +1 -1
- data/app/commands/decidim/reject_user_group_join_request.rb +1 -1
- data/app/commands/decidim/remove_user_from_group.rb +1 -1
- data/app/commands/decidim/search.rb +65 -16
- data/app/commands/decidim/update_account.rb +1 -1
- data/app/commands/decidim/update_notifications_settings.rb +2 -1
- data/app/commands/decidim/update_user_interests.rb +35 -0
- data/app/controllers/concerns/decidim/amendments_controller.rb +104 -0
- data/app/controllers/concerns/decidim/participatory_space_context.rb +28 -6
- data/app/controllers/concerns/decidim/user_groups.rb +23 -0
- data/app/controllers/concerns/decidim/user_profile.rb +2 -4
- data/app/controllers/decidim/components/base_controller.rb +1 -0
- data/app/controllers/decidim/devise/confirmations_controller.rb +9 -0
- data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +2 -1
- data/app/controllers/decidim/devise/passwords_controller.rb +6 -0
- data/app/controllers/decidim/devise/registrations_controller.rb +5 -0
- data/app/controllers/decidim/devise/sessions_controller.rb +12 -0
- data/app/controllers/decidim/group_admins_controller.rb +3 -0
- data/app/controllers/decidim/group_email_confirmations_controller.rb +32 -0
- data/app/controllers/decidim/group_invites_controller.rb +3 -0
- data/app/controllers/decidim/group_members_controller.rb +3 -0
- data/app/controllers/decidim/groups_controller.rb +3 -0
- data/app/controllers/decidim/homepage_controller.rb +10 -0
- data/app/controllers/decidim/last_activities_controller.rb +1 -1
- data/app/controllers/decidim/messaging/conversations_controller.rb +11 -2
- data/app/controllers/decidim/open_data_controller.rb +31 -0
- data/app/controllers/decidim/own_user_groups_controller.rb +3 -1
- data/app/controllers/decidim/pages_controller.rb +7 -15
- data/app/controllers/decidim/profiles_controller.rb +13 -2
- data/app/controllers/decidim/searches_controller.rb +11 -2
- data/app/controllers/decidim/user_activities_controller.rb +28 -0
- data/app/controllers/decidim/user_group_join_requests_controller.rb +3 -0
- data/app/controllers/decidim/user_interests_controller.rb +32 -0
- data/app/controllers/decidim/user_timeline_controller.rb +40 -0
- data/app/events/decidim/amendable/amendment_accepted_event.rb +23 -0
- data/app/events/decidim/amendable/amendment_base_event.rb +39 -0
- data/app/events/decidim/amendable/amendment_created_event.rb +23 -0
- data/app/events/decidim/amendable/amendment_rejected_event.rb +23 -0
- data/app/events/decidim/amendable/emendation_promoted_event.rb +23 -0
- data/app/events/decidim/welcome_notification_event.rb +58 -0
- data/app/forms/decidim/amendable/create_form.rb +54 -0
- data/app/forms/decidim/amendable/form.rb +22 -0
- data/app/forms/decidim/amendable/promote_form.rb +26 -0
- data/app/forms/decidim/amendable/reject_form.rb +14 -0
- data/app/forms/decidim/amendable/review_form.rb +35 -0
- data/app/forms/decidim/notifications_settings_form.rb +19 -6
- data/app/forms/decidim/omniauth_registration_form.rb +2 -1
- data/app/forms/decidim/user_group_form.rb +1 -2
- data/app/forms/decidim/user_interest_scope_form.rb +25 -0
- data/app/forms/decidim/user_interests_form.rb +22 -0
- data/app/helpers/decidim/amendments_helper.rb +130 -0
- data/app/helpers/decidim/application_helper.rb +19 -2
- data/app/helpers/decidim/card_helper.rb +0 -2
- data/app/helpers/decidim/cells_paginate_helper.rb +4 -0
- data/app/helpers/decidim/contextual_help_helper.rb +10 -0
- data/app/helpers/decidim/cta_button_helper.rb +3 -1
- data/app/helpers/decidim/decidim_form_helper.rb +1 -1
- data/app/helpers/decidim/layout_helper.rb +13 -0
- data/app/helpers/decidim/multi_translation_helper.rb +0 -0
- data/app/helpers/decidim/omniauth_helper.rb +9 -1
- data/app/helpers/decidim/pad_helper.rb +16 -0
- data/app/helpers/decidim/participatory_space_helpers.rb +15 -0
- data/app/helpers/decidim/searches_helper.rb +50 -6
- data/app/helpers/decidim/translations_helper.rb +3 -2
- data/app/jobs/decidim/email_notification_generator_job.rb +4 -2
- data/app/jobs/decidim/metric_job.rb +1 -1
- data/app/jobs/decidim/notification_generator_for_recipient_job.rb +2 -2
- data/app/jobs/decidim/notification_generator_job.rb +4 -2
- data/app/jobs/decidim/open_data_job.rb +16 -0
- data/app/mailers/decidim/messaging/conversation_mailer.rb +5 -2
- data/app/mailers/decidim/newsletter_mailer.rb +6 -2
- data/app/mailers/decidim/notification_mailer.rb +2 -2
- data/app/models/decidim/action_log.rb +7 -0
- data/app/models/decidim/amendment.rb +17 -0
- data/app/models/decidim/component.rb +8 -0
- data/app/models/decidim/contextual_help_section.rb +41 -0
- data/app/models/decidim/follow.rb +30 -0
- data/app/models/decidim/notification.rb +11 -1
- data/app/models/decidim/organization.rb +41 -0
- data/app/models/decidim/searchable_resource.rb +3 -0
- data/app/models/decidim/static_page.rb +11 -0
- data/app/models/decidim/static_page_topic.rb +12 -0
- data/app/models/decidim/user.rb +25 -2
- data/app/models/decidim/user_base_entity.rb +0 -6
- data/app/models/decidim/user_group.rb +29 -3
- data/app/permissions/decidim/permissions.rb +12 -0
- data/app/presenters/decidim/admin_log/organization_presenter.rb +13 -0
- data/app/presenters/decidim/admin_log/user_group_presenter.rb +1 -1
- data/app/presenters/decidim/admin_log/user_presenter.rb +1 -1
- data/app/presenters/decidim/hashtag_presenter.rb +7 -2
- data/app/presenters/decidim/metric_charts_presenter.rb +54 -21
- data/app/presenters/decidim/user_presenter.rb +4 -8
- data/app/queries/decidim/messaging/user_conversations.rb +1 -1
- data/app/queries/decidim/metric_manage.rb +16 -2
- data/app/queries/decidim/metric_measure.rb +35 -0
- data/app/queries/decidim/metrics/followers_metric_manage.rb +64 -0
- data/app/queries/decidim/metrics/participants_metric_manage.rb +72 -0
- data/app/queries/decidim/metrics/users_metric_manage.rb +1 -1
- data/app/queries/decidim/public_components.rb +32 -0
- data/app/resolvers/decidim/core/metric_resolver.rb +43 -11
- data/app/services/decidim/action_logger.rb +10 -0
- data/app/services/decidim/activity_search.rb +88 -13
- data/app/services/decidim/email_notification_generator.rb +23 -8
- data/app/services/decidim/events_manager.rb +9 -3
- data/app/services/decidim/home_activity_search.rb +80 -0
- data/app/services/decidim/log/diff_changeset_calculator.rb +3 -1
- data/app/services/decidim/notification_generator.rb +19 -7
- data/app/services/decidim/notification_generator_for_recipient.rb +6 -9
- data/app/services/decidim/open_data_exporter.rb +55 -0
- data/app/uploaders/decidim/open_data_uploader.rb +17 -0
- data/app/views/decidim/amendments/_form.html.erb +30 -0
- data/app/views/decidim/amendments/_review_form.html.erb +19 -0
- data/app/views/decidim/amendments/new.html.erb +29 -0
- data/app/views/decidim/amendments/review.html.erb +33 -0
- data/app/views/decidim/devise/registrations/new.html.erb +2 -2
- data/app/views/decidim/devise/sessions/new.html.erb +42 -29
- data/app/views/decidim/devise/shared/_links.html.erb +3 -3
- data/app/views/decidim/devise/shared/_omniauth_buttons.html.erb +7 -5
- data/app/views/decidim/follows/update_button.js.erb +1 -1
- data/app/views/decidim/group_members/index.html.erb +1 -1
- data/app/views/decidim/groups/_form.html.erb +9 -8
- data/app/views/decidim/groups/new.html.erb +3 -0
- data/app/views/decidim/{pages/home.html.erb → homepage/show.html.erb} +0 -0
- data/app/views/decidim/messaging/conversation_mailer/new_conversation.html.erb +6 -0
- data/app/views/decidim/messaging/conversation_mailer/new_message.html.erb +6 -0
- data/app/views/decidim/messaging/conversations/_message.html.erb +14 -0
- data/app/views/decidim/messaging/conversations/_reply.html.erb +11 -0
- data/app/views/decidim/messaging/conversations/_show.html.erb +21 -0
- data/app/views/decidim/messaging/conversations/_start.html.erb +12 -0
- data/app/views/decidim/messaging/conversations/create.js.erb +1 -1
- data/app/views/decidim/messaging/conversations/index.html.erb +51 -1
- data/app/views/decidim/messaging/conversations/new.html.erb +5 -1
- data/app/views/decidim/messaging/conversations/show.html.erb +9 -1
- data/app/views/decidim/messaging/conversations/update.js.erb +1 -1
- data/app/views/decidim/notification_mailer/event_received.html.erb +13 -3
- data/app/views/decidim/notifications/index.html.erb +5 -1
- data/app/views/decidim/notifications_settings/show.html.erb +19 -0
- data/app/views/decidim/pages/_standalone.html.erb +21 -0
- data/app/views/decidim/pages/_tabbed.html.erb +45 -0
- data/app/views/decidim/pages/index.html.erb +68 -29
- data/app/views/decidim/pages/show.html.erb +28 -0
- data/app/views/decidim/profiles/show.html.erb +1 -1
- data/app/views/decidim/searches/_count.html.erb +26 -1
- data/app/views/decidim/searches/_filters.html.erb +40 -17
- data/app/views/decidim/searches/index.html.erb +5 -16
- data/app/views/decidim/searches/index.js.erb +5 -3
- data/app/views/decidim/shared/_extended_navigation_bar.html.erb +50 -0
- data/app/views/decidim/shared/_floating_help.html.erb +30 -0
- data/app/views/decidim/shared/_follow_button.html.erb +1 -1
- data/app/views/decidim/shared/_login_modal.html.erb +35 -22
- data/app/views/decidim/shared/_results_per_page.html.erb +1 -1
- data/app/views/decidim/shared/_share_modal.html.erb +1 -1
- data/app/views/decidim/user_activities/index.html.erb +5 -0
- data/app/views/decidim/user_interests/_areas.html.erb +14 -0
- data/app/views/decidim/user_interests/_scopes.html.erb +15 -0
- data/app/views/decidim/user_interests/show.html.erb +12 -0
- data/app/views/decidim/user_timeline/index.html.erb +4 -0
- data/app/views/layouts/decidim/_user_menu.html.erb +1 -1
- data/app/views/layouts/decidim/_wrapper.html.erb +12 -5
- data/config/locales/ca.yml +199 -13
- data/config/locales/de.yml +200 -13
- data/config/locales/en.yml +200 -13
- data/config/locales/es-PY.yml +200 -13
- data/config/locales/es.yml +200 -13
- data/config/locales/eu.yml +200 -13
- data/config/locales/fi-pl.yml +200 -13
- data/config/locales/fi.yml +200 -13
- data/config/locales/fr.yml +200 -13
- data/config/locales/gl.yml +200 -13
- data/config/locales/hu.yml +200 -13
- data/config/locales/id-ID.yml +198 -13
- data/config/locales/it.yml +200 -13
- data/config/locales/nl.yml +200 -13
- data/config/locales/pl.yml +204 -13
- data/config/locales/pt-BR.yml +200 -13
- data/config/locales/pt.yml +200 -13
- data/config/locales/ru.yml +2 -16
- data/config/locales/sv.yml +200 -13
- data/config/locales/tr-TR.yml +200 -13
- data/config/locales/uk.yml +2 -16
- data/config/routes.rb +27 -1
- data/db/migrate/20171212103803_create_unique_nicknames.rb +1 -1
- data/db/migrate/20180221101934_fix_nickname_index.rb +1 -1
- data/db/migrate/20180706104107_add_nickname_to_managed_users.rb +1 -1
- data/db/migrate/20180720114847_create_decidim_amendments.rb +21 -0
- data/db/migrate/20181001124950_move_users_groups_to_users_table.rb +1 -1
- data/db/migrate/20181022090732_add_columns_to_pages.rb +20 -0
- data/db/migrate/20181023104416_add_static_page_topics.rb +15 -0
- data/db/migrate/20181025082245_add_timestamps_to_components.rb +12 -0
- data/db/migrate/20181029121244_add_welcome_notification.rb +13 -0
- data/db/migrate/20181108131058_add_users_registration_mode_to_organizations.rb +7 -0
- data/db/migrate/20181113101935_create_decidim_contextual_help_sections.rb +11 -0
- data/db/migrate/20181115102958_add_following_and_followers_counters_to_users.rb +26 -0
- data/db/migrate/20181119140636_add_columns_to_static_page_topic.rb +10 -0
- data/db/migrate/20181126145142_add_id_documents_fields_to_org.rb +13 -0
- data/db/migrate/20181204110723_remove_following_users_count_from_users.rb +17 -0
- data/db/migrate/20181211080834_add_scope_to_action_logs.rb +7 -0
- data/db/migrate/20181211090933_add_area_to_action_logs.rb +7 -0
- data/db/migrate/20181214101250_add_notification_types_to_users.rb +12 -0
- data/db/migrate/20181218171503_add_user_groups_switch_to_organizations.rb +8 -0
- data/db/seeds.rb +6 -1
- data/lib/decidim/amendable.rb +86 -0
- data/lib/decidim/api/component_interface.rb +4 -0
- data/lib/decidim/api/participatory_space_interface.rb +7 -0
- data/lib/decidim/api/scopable_interface.rb +1 -1
- data/lib/decidim/coauthorable.rb +16 -7
- data/lib/decidim/component_manifest.rb +3 -2
- data/lib/decidim/components/export_manifest.rb +13 -2
- data/lib/decidim/content_parsers/hashtag_parser.rb +48 -15
- data/lib/decidim/content_parsers/user_parser.rb +26 -10
- data/lib/decidim/content_renderers/hashtag_renderer.rb +46 -23
- data/lib/decidim/core.rb +40 -2
- data/lib/decidim/core/engine.rb +46 -12
- data/lib/decidim/core/test.rb +11 -0
- data/lib/decidim/core/test/factories.rb +44 -15
- data/lib/decidim/core/test/shared_examples/amendable/accept_amendment_examples.rb +57 -0
- data/lib/decidim/core/test/shared_examples/amendable/amendment_accepted_event_examples.rb +43 -0
- data/lib/decidim/core/test/shared_examples/amendable/amendment_created_event_examples.rb +48 -0
- data/lib/decidim/core/test/shared_examples/amendable/amendment_form_examples.rb +45 -0
- data/lib/decidim/core/test/shared_examples/amendable/amendment_promoted_event_examples.rb +43 -0
- data/lib/decidim/core/test/shared_examples/amendable/amendment_rejected_event_examples.rb +43 -0
- data/lib/decidim/core/test/shared_examples/amendable/create_amendment_examples.rb +78 -0
- data/lib/decidim/core/test/shared_examples/amendable/promote_amendment_examples.rb +43 -0
- data/lib/decidim/core/test/shared_examples/amendable/reject_amendment_examples.rb +41 -0
- data/lib/decidim/core/test/shared_examples/amendable/withdraw_amendment_examples.rb +29 -0
- data/lib/decidim/core/test/shared_examples/has_contextual_help.rb +30 -0
- data/lib/decidim/core/test/shared_examples/resourceable.rb +17 -0
- data/lib/decidim/core/test/shared_examples/searchable_results_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/simple_event.rb +24 -2
- data/lib/decidim/core/version.rb +1 -1
- data/lib/decidim/events/base_event.rb +17 -12
- data/lib/decidim/events/simple_event.rb +21 -2
- data/lib/decidim/form_builder.rb +8 -0
- data/lib/decidim/gamification/badge_scorer.rb +3 -3
- data/lib/decidim/has_component.rb +1 -1
- data/lib/decidim/hashtag.rb +0 -2
- data/lib/decidim/hashtaggable.rb +2 -2
- data/lib/decidim/metric_manifest.rb +17 -2
- data/lib/decidim/metric_operation.rb +59 -0
- data/lib/decidim/metric_operation_manifest.rb +20 -0
- data/lib/decidim/metric_registry.rb +57 -19
- data/lib/decidim/paddable.rb +82 -0
- data/lib/decidim/participable.rb +24 -0
- data/lib/decidim/participatory_space_resourceable.rb +12 -0
- data/lib/decidim/query_extensions.rb +8 -1
- data/lib/decidim/resource_manifest.rb +5 -1
- data/lib/decidim/resourceable.rb +12 -0
- data/lib/decidim/searchable.rb +13 -4
- data/lib/decidim/settings_manifest.rb +2 -1
- data/lib/tasks/decidim_data_portability_tasks.rake +86 -0
- data/lib/tasks/decidim_open_data_tasks.rake +12 -0
- data/lib/tasks/decidim_tasks.rake +1 -83
- data/vendor/assets/javascripts/tribute.js +307 -145
- metadata +156 -22
- data/app/cells/decidim/conversation/show.erb +0 -18
- data/app/cells/decidim/conversation_cell.rb +0 -23
- data/app/cells/decidim/conversation_header/show.erb +0 -17
- data/app/cells/decidim/conversation_header_cell.rb +0 -16
- data/app/cells/decidim/conversations/show.erb +0 -45
- data/app/cells/decidim/conversations_cell.rb +0 -24
- data/app/cells/decidim/message/show.erb +0 -15
- data/app/cells/decidim/message_cell.rb +0 -23
- data/app/cells/decidim/new_conversation/show.erb +0 -19
- data/app/cells/decidim/new_conversation_cell.rb +0 -19
- data/app/views/decidim/pages/decidim_page.html.erb +0 -31
- data/app/views/decidim/searches/_results.html.erb +0 -5
- data/app/views/decidim/shared/_author_reference.html.erb +0 -1
@@ -49,9 +49,19 @@ module Decidim
|
|
49
49
|
# Public: The String to use as scope to search for the keys
|
50
50
|
# when using I18n.t
|
51
51
|
#
|
52
|
-
# By default is the same value as the event name.
|
52
|
+
# By default is the same value as the event name. If the event has roles,
|
53
|
+
# then the role is appended to the i18n scope.
|
53
54
|
def i18n_scope
|
54
|
-
event_name
|
55
|
+
return event_name if user_role.blank? || !event_has_roles?
|
56
|
+
"#{event_name}.#{user_role}"
|
57
|
+
end
|
58
|
+
|
59
|
+
# Public: Whether the event differentiates between different user roles.
|
60
|
+
# This will change the default i18n scope.
|
61
|
+
#
|
62
|
+
# Returns a boolean.
|
63
|
+
def event_has_roles?
|
64
|
+
false
|
55
65
|
end
|
56
66
|
|
57
67
|
# Public: The Hash of options to pass to the I18.t method.
|
@@ -78,6 +88,15 @@ module Decidim
|
|
78
88
|
@participatory_space_url ||= ResourceLocatorPresenter.new(participatory_space).url
|
79
89
|
end
|
80
90
|
|
91
|
+
# Caches the text to render as a quote in the email. It will appear, if
|
92
|
+
# present, after the `intro` section. This method is intended to be
|
93
|
+
# overwritten by each event class.
|
94
|
+
#
|
95
|
+
# Returns a string.
|
96
|
+
def resource_text
|
97
|
+
nil
|
98
|
+
end
|
99
|
+
|
81
100
|
private
|
82
101
|
|
83
102
|
def event_interpolations
|
data/lib/decidim/form_builder.rb
CHANGED
@@ -372,6 +372,14 @@ module Decidim
|
|
372
372
|
end
|
373
373
|
end
|
374
374
|
|
375
|
+
def form_field_for(attribute)
|
376
|
+
if attribute == :body
|
377
|
+
text_area attribute, rows: 10
|
378
|
+
else
|
379
|
+
text_field attribute
|
380
|
+
end
|
381
|
+
end
|
382
|
+
|
375
383
|
private
|
376
384
|
|
377
385
|
# Private: Override from FoundationRailsHelper in order to render
|
@@ -108,7 +108,7 @@ module Decidim
|
|
108
108
|
event: name,
|
109
109
|
event_class: klass,
|
110
110
|
resource: @model,
|
111
|
-
|
111
|
+
affected_users: recipients,
|
112
112
|
extra: {
|
113
113
|
badge_name: @badge.name.to_s,
|
114
114
|
previous_level: previous_level,
|
@@ -123,9 +123,9 @@ module Decidim
|
|
123
123
|
|
124
124
|
def recipients
|
125
125
|
if @model.is_a?(User)
|
126
|
-
[@model
|
126
|
+
[@model]
|
127
127
|
elsif @model.is_a?(UserGroup)
|
128
|
-
@model.users
|
128
|
+
@model.users
|
129
129
|
end
|
130
130
|
end
|
131
131
|
end
|
@@ -9,7 +9,7 @@ module Decidim
|
|
9
9
|
extend ActiveSupport::Concern
|
10
10
|
|
11
11
|
included do
|
12
|
-
belongs_to :component, foreign_key: "decidim_component_id", class_name: "Decidim::Component"
|
12
|
+
belongs_to :component, foreign_key: "decidim_component_id", class_name: "Decidim::Component", touch: true
|
13
13
|
delegate :organization, to: :component, allow_nil: true
|
14
14
|
delegate :participatory_space, to: :component, allow_nil: true
|
15
15
|
end
|
data/lib/decidim/hashtag.rb
CHANGED
data/lib/decidim/hashtaggable.rb
CHANGED
@@ -8,12 +8,12 @@ module Decidim
|
|
8
8
|
included do
|
9
9
|
def search_title
|
10
10
|
renderer = Decidim::ContentRenderers::HashtagRenderer.new(title)
|
11
|
-
renderer.
|
11
|
+
renderer.render(links: false).html_safe
|
12
12
|
end
|
13
13
|
|
14
14
|
def search_body
|
15
15
|
renderer = Decidim::ContentRenderers::HashtagRenderer.new(body)
|
16
|
-
renderer.
|
16
|
+
renderer.render(links: false).html_safe
|
17
17
|
end
|
18
18
|
end
|
19
19
|
end
|
@@ -12,9 +12,24 @@ module Decidim
|
|
12
12
|
|
13
13
|
attribute :metric_name, String
|
14
14
|
attribute :manager_class, String
|
15
|
-
attribute :highlighted, String
|
16
|
-
attribute :position, Integer
|
17
15
|
|
18
16
|
validates :metric_name, :manager_class, presence: true
|
17
|
+
|
18
|
+
def has_settings?
|
19
|
+
settings.attributes.any?
|
20
|
+
end
|
21
|
+
|
22
|
+
def settings(&block)
|
23
|
+
@settings ||= SettingsManifest.new
|
24
|
+
yield(@settings) if block
|
25
|
+
@settings
|
26
|
+
end
|
27
|
+
|
28
|
+
# stat_block is a non-required parameter
|
29
|
+
# This method make it easier to retrieve it,
|
30
|
+
# and gives an empty string if it's not configured
|
31
|
+
def stat_block
|
32
|
+
settings.attributes[:stat_block].try(:[], :default) || ""
|
33
|
+
end
|
19
34
|
end
|
20
35
|
end
|
@@ -0,0 +1,59 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
class MetricOperation
|
5
|
+
# Public: Registers a operation for metrics
|
6
|
+
#
|
7
|
+
# metric_operation - a symbol representing the name of the operation involved
|
8
|
+
# metric_name - a symbol representing the name of the metric involved
|
9
|
+
#
|
10
|
+
# Returns nothing. Raises an error if there's already a metric
|
11
|
+
# registered with that metric name.
|
12
|
+
def register(metric_operation, metric_name)
|
13
|
+
metric_operation = metric_operation.to_s
|
14
|
+
metric_name = metric_name.to_s
|
15
|
+
metric_exists = self.for(metric_operation, metric_name).present?
|
16
|
+
|
17
|
+
if metric_exists
|
18
|
+
raise(
|
19
|
+
MetricOperationAlreadyRegistered,
|
20
|
+
"There's a metric already registered with the name `:#{metric_name}`, must be unique"
|
21
|
+
)
|
22
|
+
end
|
23
|
+
|
24
|
+
metric_manifest = MetricOperationManifest.new(metric_operation: metric_operation, metric_name: metric_name)
|
25
|
+
|
26
|
+
yield(metric_manifest)
|
27
|
+
|
28
|
+
metric_manifest.validate!
|
29
|
+
|
30
|
+
metrics_manifests << metric_manifest
|
31
|
+
end
|
32
|
+
|
33
|
+
# Searches for MetricOperationManifest(s) depending on parameters
|
34
|
+
# With 'metric_operation' only:
|
35
|
+
# - Returns all manifest related to that operation
|
36
|
+
# With 'metric_operation' and 'metric_name':
|
37
|
+
# - Returns a single manifest related to that two params
|
38
|
+
def for(metric_operation, metric_name = nil)
|
39
|
+
list = if metric_name
|
40
|
+
all.find { |manifest| manifest.metric_operation == metric_operation.to_s && manifest.metric_name == metric_name.to_s }
|
41
|
+
else
|
42
|
+
all.find_all { |manifest| manifest.metric_operation == metric_operation.to_s }
|
43
|
+
end
|
44
|
+
list
|
45
|
+
end
|
46
|
+
|
47
|
+
def all
|
48
|
+
metrics_manifests
|
49
|
+
end
|
50
|
+
|
51
|
+
class MetricOperationAlreadyRegistered < StandardError; end
|
52
|
+
|
53
|
+
private
|
54
|
+
|
55
|
+
def metrics_manifests
|
56
|
+
@metrics_manifests ||= []
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
# This class acts as a manifest for metrics operations.
|
5
|
+
#
|
6
|
+
# This manifest is an expansion from Decidim::MetricManifest that holds and stores
|
7
|
+
# operations, metrics and measure class, for operations purpose
|
8
|
+
#
|
9
|
+
class MetricOperationManifest < Decidim::MetricManifest
|
10
|
+
attribute :metric_operation, String
|
11
|
+
|
12
|
+
validates :metric_operation, presence: true
|
13
|
+
|
14
|
+
def calculate(day, resource)
|
15
|
+
operation = manager_class.constantize.new(day, resource)
|
16
|
+
return unless operation.valid?
|
17
|
+
operation.calculate
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -4,31 +4,34 @@ module Decidim
|
|
4
4
|
# This class acts as a registry for metrics. Each metric needs a name
|
5
5
|
# and a manager class, that will be used for calculations
|
6
6
|
#
|
7
|
+
# Also, each metrics must have a collection of attributes:
|
8
|
+
# - highlighted: Determines if it showed in a highlighted chart
|
9
|
+
# - scopes: List of scopes where it will be used
|
10
|
+
# - weight: Priority of itself
|
11
|
+
#
|
7
12
|
# In order to register a metric, you can follow this example:
|
8
13
|
#
|
9
|
-
# Decidim.metrics_registry.register(
|
10
|
-
#
|
11
|
-
#
|
12
|
-
#
|
14
|
+
# Decidim.metrics_registry.register(:users) do
|
15
|
+
# metric_registry.manager_class = "Decidim::Metrics::UsersMetricManage"
|
16
|
+
#
|
17
|
+
# metric_registry.settings do |settings|
|
18
|
+
# settings.attribute :highlighted, type: :boolean, default: true
|
19
|
+
# settings.attribute :scopes, type: :array, default: %w(home)
|
20
|
+
# settings.attribute :weight, type: :integer, default: 1
|
21
|
+
# end
|
22
|
+
# end
|
13
23
|
#
|
14
24
|
# Metrics need to be registered in the `engine.rb` file of each module
|
15
25
|
class MetricRegistry
|
16
|
-
HIGHLIGHTED = "highlighted"
|
17
|
-
NOT_HIGHLIGHTED = "not-highlighted"
|
18
26
|
# Public: Registers a metric for calculations
|
19
27
|
#
|
20
28
|
# metric_name - a symbol representing the name of the metric
|
21
29
|
#
|
22
|
-
# manager_class - Manager class for specific metric calculation
|
23
|
-
#
|
24
|
-
# highlighted - value referencing if it's a highluithgted metric, or not
|
25
|
-
#
|
26
30
|
# Returns nothing. Raises an error if there's already a metric
|
27
31
|
# registered with that metric name.
|
28
|
-
def register(metric_name
|
32
|
+
def register(metric_name)
|
29
33
|
metric_name = metric_name.to_s
|
30
34
|
metric_exists = self.for(metric_name).present?
|
31
|
-
position ||= all.size + 1
|
32
35
|
|
33
36
|
if metric_exists
|
34
37
|
raise(
|
@@ -37,27 +40,62 @@ module Decidim
|
|
37
40
|
)
|
38
41
|
end
|
39
42
|
|
40
|
-
metric_manifest = MetricManifest.new(metric_name: metric_name
|
43
|
+
metric_manifest = MetricManifest.new(metric_name: metric_name)
|
44
|
+
|
45
|
+
yield(metric_manifest)
|
41
46
|
|
42
47
|
metric_manifest.validate!
|
43
48
|
|
44
49
|
metrics_manifests << metric_manifest
|
45
50
|
end
|
46
51
|
|
47
|
-
def for(metric_name)
|
48
|
-
|
52
|
+
def for(metric_name, list = nil)
|
53
|
+
list ||= all
|
54
|
+
list.find { |manifest| manifest.metric_name == metric_name.to_s }
|
49
55
|
end
|
50
56
|
|
51
57
|
def all
|
52
58
|
metrics_manifests
|
53
59
|
end
|
54
60
|
|
55
|
-
def
|
56
|
-
|
61
|
+
def filtered(highlight: nil, scope: nil, sort: nil, block: nil)
|
62
|
+
result = all
|
63
|
+
unless highlight.nil?
|
64
|
+
result = if highlight
|
65
|
+
highlighted(result)
|
66
|
+
else
|
67
|
+
not_highlighted(result)
|
68
|
+
end
|
69
|
+
end
|
70
|
+
result = scoped(scope, result) if scope.present?
|
71
|
+
result = sorted(result) if sort.present?
|
72
|
+
result = stat_block(block, result) if block.present?
|
73
|
+
result
|
74
|
+
end
|
75
|
+
|
76
|
+
def highlighted(list = nil)
|
77
|
+
list ||= all
|
78
|
+
list.find_all { |manifest| manifest.settings.attributes[:highlighted][:default] }
|
79
|
+
end
|
80
|
+
|
81
|
+
def not_highlighted(list = nil)
|
82
|
+
list ||= all
|
83
|
+
list.find_all { |manifest| !manifest.settings.attributes[:highlighted][:default] }
|
84
|
+
end
|
85
|
+
|
86
|
+
def scoped(scope, list = nil)
|
87
|
+
list ||= all
|
88
|
+
list.find_all { |manifest| manifest.settings.attributes[:scopes][:default].include?(scope.to_s) }
|
89
|
+
end
|
90
|
+
|
91
|
+
def stat_block(block, list = nil)
|
92
|
+
list ||= all
|
93
|
+
list.find_all { |manifest| manifest.stat_block == block.to_s }
|
57
94
|
end
|
58
95
|
|
59
|
-
def
|
60
|
-
|
96
|
+
def sorted(list = nil)
|
97
|
+
list ||= all
|
98
|
+
list.sort_by { |manifest| manifest.settings.attributes[:weight].default }
|
61
99
|
end
|
62
100
|
|
63
101
|
class MetricAlreadyRegistered < StandardError; end
|
@@ -0,0 +1,82 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "active_support/concern"
|
4
|
+
|
5
|
+
module Decidim
|
6
|
+
# A concern with the components needed when you want a model to be able to create
|
7
|
+
# links from it to another resource.
|
8
|
+
module Paddable
|
9
|
+
extend ActiveSupport::Concern
|
10
|
+
include HasComponent
|
11
|
+
include HasReference
|
12
|
+
|
13
|
+
included do
|
14
|
+
# Public: The String with the URL to access the pad with read/write permissions.
|
15
|
+
def pad_public_url
|
16
|
+
return unless pad
|
17
|
+
|
18
|
+
build_pad_url pad.id
|
19
|
+
end
|
20
|
+
|
21
|
+
# Public: The String with the URL to access the pad with read permissions only.
|
22
|
+
def pad_read_only_url
|
23
|
+
return unless pad
|
24
|
+
|
25
|
+
build_pad_url pad.read_only_id
|
26
|
+
end
|
27
|
+
|
28
|
+
# Public: Returns a EtherpadLite::Pad instance if Etherpad is configured.
|
29
|
+
def pad
|
30
|
+
return if Decidim.etherpad.blank?
|
31
|
+
return unless component.settings.enable_pads_creation
|
32
|
+
|
33
|
+
@pad ||= etherpad.pad(pad_id)
|
34
|
+
end
|
35
|
+
|
36
|
+
# Public: Whether to show the pad or not.
|
37
|
+
#
|
38
|
+
# True by default if a Pad exists.
|
39
|
+
#
|
40
|
+
# This should be overwritten at the included model to customise the rules.
|
41
|
+
# Returns a Boolean.
|
42
|
+
def pad_is_visible?
|
43
|
+
pad
|
44
|
+
end
|
45
|
+
|
46
|
+
# Public: Whether the pad is writable or not.
|
47
|
+
#
|
48
|
+
# True by default if a Pad exists.
|
49
|
+
#
|
50
|
+
# This should be overwritten at the included model to customise the rules.
|
51
|
+
# Returns a Boolean.
|
52
|
+
def pad_is_writable?
|
53
|
+
pad
|
54
|
+
end
|
55
|
+
|
56
|
+
private
|
57
|
+
|
58
|
+
def etherpad
|
59
|
+
@etherpad ||= EtherpadLite.connect(
|
60
|
+
Decidim.etherpad.fetch(:server),
|
61
|
+
Decidim.etherpad.fetch(:api_key),
|
62
|
+
Decidim.etherpad.fetch(:api_version, "1.2.1")
|
63
|
+
)
|
64
|
+
end
|
65
|
+
|
66
|
+
def pad_id
|
67
|
+
@pad_id ||= [
|
68
|
+
reference,
|
69
|
+
Digest::MD5.hexdigest("#{id}-#{Rails.application.secrets.secret_key_base}")
|
70
|
+
].join("-").slice(0, 50)
|
71
|
+
end
|
72
|
+
|
73
|
+
def build_pad_url(id)
|
74
|
+
[
|
75
|
+
Decidim.etherpad.fetch(:server),
|
76
|
+
"p",
|
77
|
+
id
|
78
|
+
].join("/")
|
79
|
+
end
|
80
|
+
end
|
81
|
+
end
|
82
|
+
end
|
data/lib/decidim/participable.rb
CHANGED
@@ -93,6 +93,30 @@ module Decidim
|
|
93
93
|
def public_spaces
|
94
94
|
published
|
95
95
|
end
|
96
|
+
|
97
|
+
# Public: Adds a sane default way to retrieve active spaces. Please, overwrite
|
98
|
+
# this from your model class in case this is not correct for your model.
|
99
|
+
#
|
100
|
+
# Returns an `ActiveRecord::Association`.
|
101
|
+
def active_spaces
|
102
|
+
public_spaces
|
103
|
+
end
|
104
|
+
|
105
|
+
# Public: Adds a sane default way to retrieve future spaces. Please, overwrite
|
106
|
+
# this from your model class in case this is not correct for your model.
|
107
|
+
#
|
108
|
+
# Returns an `ActiveRecord::Association`.
|
109
|
+
def future_spaces
|
110
|
+
none
|
111
|
+
end
|
112
|
+
|
113
|
+
# Public: Adds a sane default way to retrieve past spaces. Please, overwrite
|
114
|
+
# this from your model class in case this is not correct for your model.
|
115
|
+
#
|
116
|
+
# Returns an `ActiveRecord::Association`.
|
117
|
+
def past_spaces
|
118
|
+
none
|
119
|
+
end
|
96
120
|
end
|
97
121
|
end
|
98
122
|
end
|