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
@@ -127,7 +127,9 @@ module Decidim
|
|
127
127
|
end
|
128
128
|
return label unless locale
|
129
129
|
|
130
|
-
locale_name = I18n.t("locale.name", locale: locale)
|
130
|
+
locale_name = I18n.t("locale.name", locale: locale) if I18n.available_locales.include?(locale.to_sym)
|
131
|
+
locale_name ||= locale
|
132
|
+
|
131
133
|
"#{label} (#{locale_name})"
|
132
134
|
end
|
133
135
|
end
|
@@ -12,14 +12,21 @@ module Decidim
|
|
12
12
|
# event - A String with the name of the event.
|
13
13
|
# event_class - A class that wraps the event.
|
14
14
|
# resource - an instance of a class implementing the `Decidim::Resource` concern.
|
15
|
+
# followers - a collection of Users that receive the notification because
|
16
|
+
# they're following it
|
17
|
+
# affected_users - a collection of Users that receive the notification because
|
18
|
+
# they're affected by it
|
15
19
|
# extra - a Hash with extra information for the event.
|
16
|
-
|
20
|
+
# rubocop:disable Metrics/ParameterLists
|
21
|
+
def initialize(event, event_class, resource, followers, affected_users, extra)
|
17
22
|
@event = event
|
18
23
|
@event_class = event_class
|
19
24
|
@resource = resource
|
20
|
-
@
|
25
|
+
@followers = followers
|
26
|
+
@affected_users = affected_users
|
21
27
|
@extra = extra
|
22
28
|
end
|
29
|
+
# rubocop:enable Metrics/ParameterLists
|
23
30
|
|
24
31
|
# Schedules a job for each recipient to create the notification. Returns `nil`
|
25
32
|
# if the resource is not resource or if it is not present.
|
@@ -29,21 +36,26 @@ module Decidim
|
|
29
36
|
return unless resource
|
30
37
|
return unless event_class.types.include?(:notification)
|
31
38
|
|
32
|
-
|
33
|
-
generate_notification_for(
|
39
|
+
followers.each do |recipient|
|
40
|
+
generate_notification_for(recipient, user_role: :follower) if ["all", "followed-only"].include?(recipient.notification_types)
|
41
|
+
end
|
42
|
+
|
43
|
+
affected_users.each do |recipient|
|
44
|
+
generate_notification_for(recipient, user_role: :affected_user) if ["all", "own-only"].include?(recipient.notification_types)
|
34
45
|
end
|
35
46
|
end
|
36
47
|
|
37
48
|
private
|
38
49
|
|
39
|
-
attr_reader :event, :event_class, :resource, :
|
50
|
+
attr_reader :event, :event_class, :resource, :followers, :affected_users, :extra
|
40
51
|
|
41
|
-
def generate_notification_for(
|
52
|
+
def generate_notification_for(recipient, user_role:)
|
42
53
|
NotificationGeneratorForRecipientJob.perform_later(
|
43
54
|
event,
|
44
55
|
event_class.name,
|
45
56
|
resource,
|
46
|
-
|
57
|
+
recipient,
|
58
|
+
user_role.to_s,
|
47
59
|
extra
|
48
60
|
)
|
49
61
|
end
|
@@ -11,13 +11,14 @@ module Decidim
|
|
11
11
|
# event - A String with the name of the event.
|
12
12
|
# event_class - The class that wraps the event, in order to decorate it.
|
13
13
|
# resource - an instance of a class implementing the `Decidim::Resource` concern.
|
14
|
-
# recipient - the
|
14
|
+
# recipient - the User that will receive the notification.
|
15
15
|
# extra - a Hash with extra information to be included in the notification.
|
16
|
-
def initialize(event, event_class, resource,
|
16
|
+
def initialize(event, event_class, resource, recipient, user_role, extra) # rubocop:disable Metrics/ParameterLists
|
17
17
|
@event = event
|
18
18
|
@event_class = event_class
|
19
19
|
@resource = resource
|
20
|
-
@
|
20
|
+
@recipient = recipient
|
21
|
+
@user_role = user_role
|
21
22
|
@extra = extra
|
22
23
|
end
|
23
24
|
|
@@ -42,14 +43,10 @@ module Decidim
|
|
42
43
|
event_class: event_class,
|
43
44
|
resource: resource,
|
44
45
|
event_name: event,
|
45
|
-
extra: extra
|
46
|
+
extra: extra.merge(received_as: user_role)
|
46
47
|
)
|
47
48
|
end
|
48
49
|
|
49
|
-
attr_reader :event, :event_class, :resource, :
|
50
|
-
|
51
|
-
def recipient
|
52
|
-
@recipient ||= User.find_by(id: recipient_id)
|
53
|
-
end
|
50
|
+
attr_reader :event, :event_class, :resource, :recipient, :user_role, :extra
|
54
51
|
end
|
55
52
|
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
# Public: It generates a ZIP file with Open Data CSV files ready
|
5
|
+
# to be uploaded somewhere so users can download an organization
|
6
|
+
# data.
|
7
|
+
class OpenDataExporter
|
8
|
+
attr_reader :organization, :path
|
9
|
+
|
10
|
+
# Public: Initializes the class.
|
11
|
+
#
|
12
|
+
# organization - The Organization to export the data from.
|
13
|
+
# path - The String path where to write the zip file.
|
14
|
+
def initialize(organization, path)
|
15
|
+
@organization = organization
|
16
|
+
@path = File.expand_path path
|
17
|
+
end
|
18
|
+
|
19
|
+
def export
|
20
|
+
dirname = File.dirname(path)
|
21
|
+
FileUtils.mkdir_p(dirname) unless File.directory?(dirname)
|
22
|
+
File.open(path, "wb") { |file| file.write(data) }
|
23
|
+
end
|
24
|
+
|
25
|
+
private
|
26
|
+
|
27
|
+
def data
|
28
|
+
buffer = Zip::OutputStream.write_buffer do |out|
|
29
|
+
open_data_manifests.each do |export_manifest|
|
30
|
+
csv_data = data_for(export_manifest)
|
31
|
+
out.put_next_entry("#{organization.host}-open-data-#{export_manifest.name}.csv")
|
32
|
+
out.write csv_data.read
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
buffer.string
|
37
|
+
end
|
38
|
+
|
39
|
+
def data_for(export_manifest)
|
40
|
+
collection = components.where(manifest_name: export_manifest.component_manifest.name).find_each.flat_map do |component|
|
41
|
+
export_manifest.collection.call(component)
|
42
|
+
end
|
43
|
+
|
44
|
+
Decidim::Exporters::CSV.new(collection, export_manifest.serializer).export
|
45
|
+
end
|
46
|
+
|
47
|
+
def open_data_manifests
|
48
|
+
@open_data_manifests ||= Decidim.component_manifests.flat_map(&:export_manifests).select(&:include_in_open_data?)
|
49
|
+
end
|
50
|
+
|
51
|
+
def components
|
52
|
+
@components ||= organization.published_components
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
# This class deals with uploading open data.
|
5
|
+
class OpenDataUploader < ApplicationUploader
|
6
|
+
protected
|
7
|
+
|
8
|
+
# Override the directory where uploaded files will be stored. We only want one copy of the Open Data
|
9
|
+
# export.
|
10
|
+
def store_dir
|
11
|
+
default_path = "uploads/open-data"
|
12
|
+
|
13
|
+
return File.join(Decidim.base_uploads_path, default_path) if Decidim.base_uploads_path.present?
|
14
|
+
default_path
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
<%= decidim_form_for(@form, url: amends_path, method: :post) do |form| %>
|
2
|
+
<%= form.hidden_field :amendable_gid %>
|
3
|
+
<%= form.hidden_field :amendable_type %>
|
4
|
+
<%= form.hidden_field :emendation_type %>
|
5
|
+
|
6
|
+
<%= form.fields_for :emendation_fields, form.object.emendation_fields do |emendation_form| %>
|
7
|
+
<% @form.amendable.attributes.each do |key, value| %>
|
8
|
+
<% key = key.to_sym %>
|
9
|
+
<% if @form.amendable.fields.include?(key) %>
|
10
|
+
<div class="field">
|
11
|
+
<%= emendation_form.form_field_for key %>
|
12
|
+
</div>
|
13
|
+
<% elsif @form.amendable.ignore_fields.include?(key) %>
|
14
|
+
<%= emendation_form.hidden_field key, value: emendation_ignored_field_value(key) %>
|
15
|
+
<% else %>
|
16
|
+
<%= emendation_form.hidden_field key, value: value %>
|
17
|
+
<% end %>
|
18
|
+
<% end %>
|
19
|
+
<% end %>
|
20
|
+
|
21
|
+
<% if current_organization.user_groups_enabled? && current_user.user_groups.verified.any? %>
|
22
|
+
<div class="field">
|
23
|
+
<%= user_group_select_field form, :user_group_id %>
|
24
|
+
</div>
|
25
|
+
<% end %>
|
26
|
+
|
27
|
+
<div class="actions">
|
28
|
+
<%= form.submit t("send", scope: "decidim.amendments.new"), class: "button expanded mt-s mb-none", data: { disable: true } %>
|
29
|
+
</div>
|
30
|
+
<% end %>
|
@@ -0,0 +1,19 @@
|
|
1
|
+
<%= decidim_form_for(@form, url: accept_amend_path(emendation.amendment), method: :patch) do |form| %>
|
2
|
+
|
3
|
+
<%= form.fields_for :emendation_fields, form.object.emendation_fields do |emendation_form| %>
|
4
|
+
<% @form.emendation.attributes.each do |key, value| %>
|
5
|
+
<% key = key.to_sym %>
|
6
|
+
<% if @form.emendation.fields.include?(key) %>
|
7
|
+
<div class="field">
|
8
|
+
<%= emendation_form.form_field_for key %>
|
9
|
+
</div>
|
10
|
+
<% else %>
|
11
|
+
<%= emendation_form.hidden_field key, value: value %>
|
12
|
+
<% end %>
|
13
|
+
<% end %>
|
14
|
+
<% end %>
|
15
|
+
|
16
|
+
<div class="actions">
|
17
|
+
<%= form.submit t("send", scope: "decidim.amendments.review"), class: "button expanded mt-s mb-none", data: { disable: true } %>
|
18
|
+
</div>
|
19
|
+
<% end %>
|
@@ -0,0 +1,29 @@
|
|
1
|
+
<main class="wrapper">
|
2
|
+
<div class="row">
|
3
|
+
<div class="columns large-3">
|
4
|
+
<div class="m-bottom">
|
5
|
+
<%= link_to :back do %>
|
6
|
+
<%= icon "chevron-left", class: "icon--small" %>
|
7
|
+
<%= t("back", scope: "decidim.amendments.new") %>
|
8
|
+
<% end %>
|
9
|
+
</div>
|
10
|
+
<div class="section">
|
11
|
+
<p>
|
12
|
+
<%= t("help_text", scope: "decidim.amendments.new", model_name: amendable.model_name.human.downcase ) %>
|
13
|
+
<strong>
|
14
|
+
<%= amendable.title %>
|
15
|
+
</strong>
|
16
|
+
</p>
|
17
|
+
</div>
|
18
|
+
</div>
|
19
|
+
<div class="columns large-6">
|
20
|
+
<h2 class="section-heading"><%= t("heading", scope: "decidim.amendments.new") %></h2>
|
21
|
+
<div class="card">
|
22
|
+
<div class="card__content">
|
23
|
+
<%= render "form" %>
|
24
|
+
</div>
|
25
|
+
</div>
|
26
|
+
</div>
|
27
|
+
<div class="columns large-3"></div>
|
28
|
+
</div>
|
29
|
+
</main>
|
@@ -0,0 +1,33 @@
|
|
1
|
+
<main class="wrapper">
|
2
|
+
<div class="row">
|
3
|
+
<div class="columns large-3">
|
4
|
+
<div class="m-bottom">
|
5
|
+
<%= link_to :back do %>
|
6
|
+
<%= icon "chevron-left", class: "icon--small" %>
|
7
|
+
<%= t("back", scope: "decidim.amendments.review") %>
|
8
|
+
<% end %>
|
9
|
+
</div>
|
10
|
+
<div class="section">
|
11
|
+
<p>
|
12
|
+
<%= t("help_text", scope: "decidim.amendments.review", model_name: emendation.amendable.model_name.human.downcase) %>
|
13
|
+
|
14
|
+
<strong>
|
15
|
+
<%= emendation.amendable.title %>
|
16
|
+
</strong>
|
17
|
+
</p>
|
18
|
+
</div>
|
19
|
+
</div>
|
20
|
+
<div class="columns large-6">
|
21
|
+
<h2 class="section-heading">
|
22
|
+
<%= t("heading", scope: "decidim.amendments.review") %>
|
23
|
+
</h2>
|
24
|
+
|
25
|
+
<div class="card">
|
26
|
+
<div class="card__content">
|
27
|
+
<%= render "review_form" %>
|
28
|
+
</div>
|
29
|
+
</div>
|
30
|
+
</div>
|
31
|
+
<div class="columns large-3"></div>
|
32
|
+
</div>
|
33
|
+
</main>
|
@@ -19,6 +19,8 @@
|
|
19
19
|
</div>
|
20
20
|
</div>
|
21
21
|
|
22
|
+
<%= render "decidim/devise/shared/omniauth_buttons" %>
|
23
|
+
|
22
24
|
<div class="row">
|
23
25
|
<div class="columns large-6 medium-10 medium-centered">
|
24
26
|
|
@@ -89,8 +91,6 @@
|
|
89
91
|
<% end %>
|
90
92
|
</div>
|
91
93
|
</div>
|
92
|
-
|
93
|
-
<%= render "decidim/devise/shared/omniauth_buttons" %>
|
94
94
|
</div>
|
95
95
|
</main>
|
96
96
|
<%= render "decidim/devise/shared/newsletter_modal" %>
|
@@ -5,41 +5,54 @@
|
|
5
5
|
<div class="row collapse">
|
6
6
|
<div class="columns large-8 large-centered text-center page-title">
|
7
7
|
<h1 class="heading1"><%= t("devise.sessions.new.sign_in") %></h1>
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
8
|
+
<% if current_organization.sign_up_enabled? %>
|
9
|
+
<p>
|
10
|
+
<%= t(".are_you_new?") %>
|
11
|
+
<%= link_to t(".register"), new_user_registration_path %>
|
12
|
+
</p>
|
13
|
+
<% elsif current_organization.sign_in_enabled? %>
|
14
|
+
<p>
|
15
|
+
<%= t(".sign_up_disabled") %>
|
16
|
+
</p>
|
17
|
+
<% else %>
|
18
|
+
<p>
|
19
|
+
<%= t(".sign_in_disabled") %>
|
20
|
+
</p>
|
21
|
+
<% end %>
|
12
22
|
</div>
|
13
23
|
</div>
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
</div>
|
27
|
-
<fieldset>
|
28
|
-
<% if devise_mapping.rememberable? %>
|
24
|
+
<%= render "decidim/devise/shared/omniauth_buttons" %>
|
25
|
+
|
26
|
+
<% if current_organization.sign_in_enabled? %>
|
27
|
+
<div class="row">
|
28
|
+
<div class="columns large-6 medium-centered">
|
29
|
+
<div class="card">
|
30
|
+
<div class="card__content">
|
31
|
+
<%= decidim_form_for(resource, as: resource_name, url: session_path(resource_name), html: { class: "register-form new_user" }) do |f| %>
|
32
|
+
<div>
|
33
|
+
<div class="field">
|
34
|
+
<%= f.email_field :email, autofocus: true %>
|
35
|
+
</div>
|
29
36
|
<div class="field">
|
30
|
-
<%= f.
|
37
|
+
<%= f.password_field :password, autocomplete: "off" %>
|
31
38
|
</div>
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
+
</div>
|
40
|
+
<fieldset>
|
41
|
+
<% if devise_mapping.rememberable? %>
|
42
|
+
<div class="field">
|
43
|
+
<%= f.check_box :remember_me %>
|
44
|
+
</div>
|
45
|
+
<% end %>
|
46
|
+
</fieldset>
|
47
|
+
<div class="actions">
|
48
|
+
<%= f.submit t("devise.sessions.new.sign_in"), class: "button expanded" %>
|
49
|
+
</div>
|
50
|
+
<% end %>
|
51
|
+
<%= render "decidim/devise/shared/links" %>
|
52
|
+
</div>
|
39
53
|
</div>
|
40
54
|
</div>
|
41
55
|
</div>
|
42
|
-
|
43
|
-
<%= render "decidim/devise/shared/omniauth_buttons" %>
|
56
|
+
<% end %>
|
44
57
|
</div>
|
45
58
|
</main>
|
@@ -1,10 +1,10 @@
|
|
1
|
-
<%- if controller_name != "sessions" %>
|
1
|
+
<%- if controller_name != "sessions" && resource_class != Decidim::UserGroup %>
|
2
2
|
<p class="text-center">
|
3
3
|
<%= link_to t("devise.shared.links.sign_in"), new_session_path(resource_name) %>
|
4
4
|
</p>
|
5
5
|
<% end -%>
|
6
6
|
|
7
|
-
<%- if devise_mapping.registerable? && controller_name != "registrations" %>
|
7
|
+
<%- if current_organization.sign_up_enabled? && devise_mapping.registerable? && controller_name != "registrations" %>
|
8
8
|
<p class="text-center">
|
9
9
|
<%= link_to t("devise.shared.links.sign_up"), new_registration_path(resource_name) %>
|
10
10
|
</p>
|
@@ -16,7 +16,7 @@
|
|
16
16
|
</p>
|
17
17
|
<% end -%>
|
18
18
|
|
19
|
-
<%- if devise_mapping.confirmable? && controller_name != "confirmations" %>
|
19
|
+
<%- if current_organization.sign_up_enabled? && devise_mapping.confirmable? && controller_name != "confirmations" %>
|
20
20
|
<p class="text-center">
|
21
21
|
<%= link_to t("devise.shared.links.didn_t_receive_confirmation_instructions"), new_confirmation_path(resource_name) %>
|
22
22
|
</p>
|
@@ -1,10 +1,7 @@
|
|
1
|
-
<% if
|
1
|
+
<% if Devise.mappings[:user].omniauthable? && any_social_provider_enabled? %>
|
2
2
|
<div class="row">
|
3
3
|
<div class="columns large-4 mediumlarge-6 medium-8 medium-centered">
|
4
|
-
|
5
|
-
<span class="register__separator__text"><%= t(".or") %></span>
|
6
|
-
</span>
|
7
|
-
<%- resource_class.omniauth_providers.each do |provider| %>
|
4
|
+
<%- Decidim::User.omniauth_providers.each do |provider| %>
|
8
5
|
<% if social_provider_enabled? provider %>
|
9
6
|
<div class="social-register">
|
10
7
|
<%= link_to decidim.send("user_#{provider}_omniauth_authorize_path"), class: "button button--social button--#{normalize_provider_name(provider)}" do %>
|
@@ -16,6 +13,11 @@
|
|
16
13
|
</div>
|
17
14
|
<% end %>
|
18
15
|
<% end %>
|
16
|
+
<%- if current_organization.sign_in_enabled? %>
|
17
|
+
<span class="register__separator">
|
18
|
+
<span class="register__separator__text"><%= t(".or") %></span>
|
19
|
+
</span>
|
20
|
+
<%- end %>
|
19
21
|
</div>
|
20
22
|
</div>
|
21
23
|
<% end %>
|
@@ -1,3 +1,3 @@
|
|
1
1
|
var $followResource = $("#<%= dom_id(resource, :follow) %>");
|
2
2
|
|
3
|
-
morphdom($followResource[0], "<%= j((cell "decidim/follow_button", resource, inline: @inline
|
3
|
+
morphdom($followResource[0], "<%= j((cell "decidim/follow_button", resource, inline: @inline).to_s.strip.html_safe) %>");
|