decidim-core 0.29.6 → 0.30.0.rc1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/cells/decidim/activity/show.erb +6 -6
- data/app/cells/decidim/address/show.erb +3 -3
- data/app/cells/decidim/amendable/amend_button_card/show.erb +6 -4
- data/app/cells/decidim/amendable/amend_button_card_cell.rb +8 -0
- data/app/cells/decidim/amendable/amendments/show.erb +1 -1
- data/app/cells/decidim/amendable/promote_button_card/show.erb +2 -0
- data/app/cells/decidim/author/flag.erb +6 -0
- data/app/cells/decidim/author/flag_user.erb +14 -0
- data/app/cells/decidim/author/show.erb +2 -6
- data/app/cells/decidim/author_cell.rb +1 -11
- data/app/cells/decidim/card_l/extra_data.erb +1 -0
- data/app/cells/decidim/card_metadata_cell.rb +9 -16
- data/app/cells/decidim/comments_button_cell.rb +14 -2
- data/app/cells/decidim/content_blocks/highlighted_elements_cell.rb +2 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_with_cell_for_list_cell.rb +1 -1
- data/app/cells/decidim/content_blocks/participatory_space_extra_data/extra_data.erb +2 -2
- data/app/cells/decidim/content_blocks/participatory_space_main_data/title.erb +2 -11
- data/app/cells/decidim/endorsement_block/show.erb +0 -1
- data/app/cells/decidim/endorsement_block_cell.rb +6 -0
- data/app/cells/decidim/endorsement_buttons/button_content.erb +1 -1
- data/app/cells/decidim/endorsement_buttons/select_identity_button.erb +1 -1
- data/app/cells/decidim/endorsement_buttons/show.erb +7 -7
- data/app/cells/decidim/endorsement_buttons/verification_modal.erb +4 -2
- data/app/cells/decidim/endorsers_list/empty.erb +3 -0
- data/app/cells/decidim/endorsers_list/full.erb +17 -5
- data/app/cells/decidim/endorsers_list/show.erb +19 -10
- data/app/cells/decidim/endorsers_list_cell.rb +19 -6
- data/app/cells/decidim/flag_modal/flag_user.erb +34 -0
- data/app/cells/decidim/flag_modal/show.erb +52 -0
- data/app/cells/decidim/flag_modal_cell.rb +56 -0
- data/app/cells/decidim/follow_button/show.erb +1 -2
- data/app/cells/decidim/follow_button_cell.rb +5 -0
- data/app/cells/decidim/footer_topics/show.erb +2 -2
- data/app/cells/decidim/group_admins/show.erb +1 -3
- data/app/cells/decidim/group_members/show.erb +2 -6
- data/app/cells/decidim/images_panel/show.erb +2 -5
- data/app/cells/decidim/map/show.erb +3 -0
- data/app/cells/decidim/map/template.erb +14 -0
- data/app/cells/decidim/map_cell.rb +39 -0
- data/app/cells/decidim/notification_actions/buttons_cell.rb +1 -1
- data/app/cells/decidim/onboarding_action_message/show.erb +15 -0
- data/app/cells/decidim/onboarding_action_message_cell.rb +81 -0
- data/app/cells/decidim/participatory_space_dropdown_metadata/metadata.erb +4 -4
- data/app/cells/decidim/participatory_space_dropdown_metadata/show.erb +3 -5
- data/app/cells/decidim/participatory_space_private_user/show.erb +23 -0
- data/app/cells/decidim/participatory_space_private_user_cell.rb +21 -0
- data/app/cells/decidim/profile/avatar.erb +2 -0
- data/app/cells/decidim/profile/badge.erb +3 -3
- data/app/cells/decidim/profile/details.erb +1 -2
- data/app/cells/decidim/profile_actions/show.erb +1 -1
- data/app/cells/decidim/profile_sidebar/show.erb +167 -0
- data/app/cells/decidim/profile_sidebar_cell.rb +68 -0
- data/app/cells/decidim/progress_bar/show.erb +2 -2
- data/app/cells/decidim/report_button/already_reported_modal.erb +2 -2
- data/app/cells/decidim/report_button/flag_modal.erb +36 -24
- data/app/cells/decidim/report_button_cell.rb +9 -2
- data/app/cells/decidim/resource_history/show.erb +20 -0
- data/app/cells/decidim/resource_history_cell.rb +66 -0
- data/app/cells/decidim/resource_types_filter/show.erb +1 -1
- data/app/cells/decidim/resource_types_filter_cell.rb +6 -6
- data/app/cells/decidim/share_button_cell.rb +0 -4
- data/app/cells/decidim/share_widget/modal.erb +26 -0
- data/app/cells/decidim/share_widget/show.erb +2 -0
- data/app/cells/decidim/share_widget_cell.rb +20 -0
- data/app/cells/decidim/tags/show.erb +7 -4
- data/app/cells/decidim/tags_cell.rb +11 -72
- data/app/cells/decidim/upload_modal/files.erb +4 -4
- data/app/cells/decidim/upload_modal_cell.rb +3 -5
- data/app/cells/decidim/user_activity/show.erb +1 -1
- data/app/cells/decidim/user_activity_cell.rb +1 -6
- data/app/commands/decidim/amendable/accept.rb +1 -2
- data/app/commands/decidim/amendable/create_draft.rb +2 -2
- data/app/commands/decidim/create_ephemeral_user.rb +52 -0
- data/app/commands/decidim/create_omniauth_registration.rb +21 -17
- data/app/commands/decidim/create_report.rb +8 -11
- data/app/commands/decidim/create_user_group.rb +6 -2
- data/app/commands/decidim/destroy_ephemeral_user.rb +47 -0
- data/app/commands/decidim/invite_user.rb +1 -1
- data/app/commands/decidim/search.rb +0 -14
- data/app/commands/decidim/update_account.rb +11 -3
- data/app/commands/decidim/update_notifications_settings.rb +1 -0
- data/app/commands/decidim/update_resources_taxonomies.rb +67 -0
- data/app/commands/decidim/update_user_group.rb +7 -1
- data/app/constraints/decidim/current_component.rb +1 -1
- data/app/controllers/concerns/decidim/ajax_permission_handler.rb +21 -0
- data/app/controllers/concerns/decidim/devise_authentication_methods.rb +3 -6
- data/app/controllers/concerns/decidim/devise_controllers.rb +2 -0
- data/app/controllers/concerns/decidim/disable_redirection_to_external_host.rb +1 -1
- data/app/controllers/concerns/decidim/ephemeral_session_checker.rb +87 -0
- data/app/controllers/concerns/decidim/filter_resource.rb +4 -2
- data/app/controllers/concerns/decidim/has_members_page.rb +25 -0
- data/app/controllers/concerns/decidim/locale_switcher.rb +2 -2
- data/app/controllers/concerns/decidim/needs_password_change.rb +0 -1
- data/app/controllers/concerns/decidim/needs_permission.rb +2 -1
- data/app/controllers/concerns/decidim/needs_tos_accepted.rb +4 -5
- data/app/controllers/concerns/decidim/onboarding_action_methods.rb +52 -0
- data/app/controllers/concerns/decidim/participatory_space_context.rb +1 -4
- data/app/controllers/decidim/amendments_controller.rb +3 -3
- data/app/controllers/decidim/application_controller.rb +9 -0
- data/app/controllers/decidim/authorization_modals_controller.rb +8 -2
- data/app/controllers/decidim/components/base_controller.rb +3 -7
- data/app/controllers/decidim/devise/confirmations_controller.rb +4 -0
- data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +8 -1
- data/app/controllers/decidim/devise/registrations_controller.rb +1 -1
- data/app/controllers/decidim/devise/sessions_controller.rb +2 -0
- data/app/controllers/decidim/download_your_data_controller.rb +33 -2
- data/app/controllers/decidim/editor_images_controller.rb +1 -11
- data/app/controllers/decidim/follows_controller.rb +1 -1
- data/app/controllers/decidim/geolocation_controller.rb +19 -0
- data/app/controllers/decidim/homepage_controller.rb +0 -1
- data/app/controllers/decidim/open_data_controller.rb +33 -8
- data/app/controllers/decidim/profiles_controller.rb +2 -2
- data/app/controllers/decidim/reports_controller.rb +2 -7
- data/app/controllers/decidim/user_activities_controller.rb +1 -1
- data/app/controllers/decidim/user_conversations_controller.rb +1 -11
- data/app/events/decidim/soft_delete_resource_event.rb +15 -0
- data/app/forms/decidim/account_form.rb +2 -5
- data/app/forms/decidim/amendable/form.rb +4 -2
- data/app/forms/decidim/ephemeral_user_form.rb +22 -0
- data/app/forms/decidim/notifications_settings_form.rb +1 -0
- data/app/forms/decidim/omniauth_registration_form.rb +15 -2
- data/app/forms/decidim/registration_form.rb +1 -1
- data/app/forms/decidim/user_group_form.rb +0 -2
- data/app/helpers/concerns/decidim/flash_helper_extensions.rb +17 -2
- data/app/helpers/decidim/action_authorization_helper.rb +75 -14
- data/app/helpers/decidim/amendments_helper.rb +1 -11
- data/app/helpers/decidim/application_helper.rb +6 -2
- data/app/helpers/decidim/breadcrumb_helper.rb +6 -0
- data/app/helpers/decidim/cache_helper.rb +1 -1
- data/app/helpers/decidim/check_boxes_tree_helper.rb +25 -53
- data/app/helpers/decidim/decidim_form_helper.rb +0 -44
- data/app/helpers/decidim/endorsable_helper.rb +0 -10
- data/app/helpers/decidim/filters_helper.rb +0 -25
- data/app/helpers/decidim/layout_helper.rb +6 -6
- data/app/helpers/decidim/map_helper.rb +1 -1
- data/app/helpers/decidim/menu_helper.rb +2 -2
- data/app/helpers/decidim/messaging/conversation_helper.rb +2 -3
- data/app/helpers/decidim/meta_tags_helper.rb +32 -23
- data/app/helpers/decidim/modal_helper.rb +23 -0
- data/app/helpers/decidim/omniauth_helper.rb +5 -5
- data/app/helpers/decidim/onboarding_action_helper.rb +13 -0
- data/app/helpers/decidim/orders_helper.rb +1 -2
- data/app/helpers/decidim/paginate_helper.rb +1 -1
- data/app/helpers/decidim/participatory_space_helpers.rb +1 -1
- data/app/helpers/decidim/passwords_helper.rb +2 -2
- data/app/helpers/decidim/taxonomies_helper.rb +40 -0
- data/app/helpers/decidim/tooltip_helper.rb +1 -4
- data/app/jobs/decidim/download_your_data_export_job.rb +2 -19
- data/app/jobs/decidim/event_publisher_job.rb +18 -9
- data/app/jobs/decidim/export_job.rb +5 -1
- data/app/jobs/decidim/export_participatory_space_job.rb +4 -1
- data/app/jobs/decidim/open_data_job.rb +4 -4
- data/app/mailers/decidim/export_mailer.rb +7 -12
- data/app/mailers/decidim/notifications_digest_mailer.rb +1 -7
- data/app/mailers/decidim/reported_mailer.rb +2 -18
- data/app/models/decidim/action_log.rb +20 -1
- data/app/models/decidim/category.rb +4 -0
- data/app/models/decidim/component.rb +25 -3
- data/app/models/decidim/metric.rb +2 -1
- data/app/models/decidim/moderation.rb +16 -0
- data/app/models/decidim/newsletter.rb +12 -8
- data/app/models/decidim/organization.rb +7 -3
- data/app/models/decidim/participatory_space_private_user.rb +20 -0
- data/app/models/decidim/private_export.rb +24 -0
- data/app/models/decidim/push_notification_message.rb +1 -1
- data/app/models/decidim/report.rb +1 -1
- data/app/models/decidim/scope.rb +4 -0
- data/app/models/decidim/share_token.rb +36 -10
- data/app/models/decidim/taxonomization.rb +23 -0
- data/app/models/decidim/taxonomy.rb +139 -0
- data/app/models/decidim/taxonomy_filter.rb +130 -0
- data/app/models/decidim/taxonomy_filter_item.rb +33 -0
- data/app/models/decidim/user.rb +13 -23
- data/app/models/decidim/user_base_entity.rb +12 -4
- data/app/models/decidim/user_moderation.rb +9 -0
- data/app/models/decidim/user_report.rb +4 -0
- data/app/packs/entrypoints/decidim_core.js +1 -0
- data/app/packs/entrypoints/decidim_geocoding.js +2 -0
- data/app/packs/images/decidim/brands/facebook.svg +10 -0
- data/app/packs/images/decidim/brands/google.svg +7 -1
- data/app/packs/images/decidim/brands/twitter-x.svg +3 -0
- data/app/packs/images/decidim/default-avatar.svg +1 -1
- data/app/packs/src/decidim/callout.js +8 -13
- data/app/packs/src/decidim/check_boxes_tree.js +0 -1
- data/app/packs/src/decidim/clipboard.js +18 -9
- data/app/packs/src/decidim/datepicker/datepicker_functions.js +3 -3
- data/app/packs/src/decidim/datepicker/generate_datepicker.js +0 -2
- data/app/packs/src/decidim/datepicker/generate_timepicker.js +0 -2
- data/app/packs/src/decidim/decidim_application.js +1 -0
- data/app/packs/src/decidim/direct_uploads/upload_field.js +4 -3
- data/app/packs/src/decidim/direct_uploads/upload_modal.js +9 -8
- data/app/packs/src/decidim/editor/common/suggestion.js +1 -11
- data/app/packs/src/decidim/form_filter.js +0 -6
- data/app/packs/src/decidim/geocoding/reverse_geocoding.js +60 -0
- data/app/packs/src/decidim/index.js +9 -5
- data/app/packs/src/decidim/input_character_counter.js +1 -1
- data/app/packs/src/decidim/map/provider/here.js +1 -1
- data/app/packs/src/decidim/onboarding_pending_action.js +24 -0
- data/app/packs/src/decidim/sticky_footer.js +29 -0
- data/app/packs/src/decidim/sticky_header.js +6 -31
- data/app/packs/src/decidim/user_registrations.js +13 -0
- data/app/packs/src/decidim/vendor/leaflet-tilelayer-here.js +212 -0
- data/app/packs/stylesheets/decidim/_accordion.scss +30 -0
- data/app/packs/stylesheets/decidim/_activity.scss +4 -4
- data/app/packs/stylesheets/decidim/_author.scss +0 -8
- data/app/packs/stylesheets/decidim/_buttons.scss +19 -0
- data/app/packs/stylesheets/decidim/_cards.scss +1 -9
- data/app/packs/stylesheets/decidim/_content_blocks.scss +0 -4
- data/app/packs/stylesheets/decidim/_dropdown.scss +1 -1
- data/app/packs/stylesheets/decidim/_endorsers_list.scss +26 -20
- data/app/packs/stylesheets/decidim/_filters.scss +1 -1
- data/app/packs/stylesheets/decidim/_forms.scss +2 -2
- data/app/packs/stylesheets/decidim/_header.scss +39 -70
- data/app/packs/stylesheets/decidim/_layout.scss +34 -4
- data/app/packs/stylesheets/decidim/_login.scss +53 -6
- data/app/packs/stylesheets/decidim/_modal.scss +47 -1
- data/app/packs/stylesheets/decidim/_modal_tos_refuse.scss +4 -0
- data/app/packs/stylesheets/decidim/_modal_update.scss +1 -5
- data/app/packs/stylesheets/decidim/_participatory_spaces.scss +46 -0
- data/app/packs/stylesheets/decidim/_profile.scss +7 -7
- data/app/packs/stylesheets/decidim/_success_image.scss +64 -0
- data/app/packs/stylesheets/decidim/_tribute.scss +36 -0
- data/app/packs/stylesheets/decidim/application.scss +1 -1
- data/app/packs/stylesheets/decidim/editor.scss +1 -3
- data/app/packs/stylesheets/decidim/geocoding_addons.scss +5 -0
- data/app/packs/stylesheets/decidim/map.scss +7 -10
- data/app/packs/stylesheets/decidim/resource_history.scss +31 -0
- data/app/permissions/decidim/default_permissions.rb +0 -2
- data/app/permissions/decidim/permissions.rb +9 -15
- data/app/presenters/decidim/admin_log/base_user_presenter.rb +67 -0
- data/app/presenters/decidim/admin_log/component_presenter.rb +32 -3
- data/app/presenters/decidim/admin_log/moderation_presenter.rb +30 -3
- data/app/presenters/decidim/admin_log/share_token_presenter.rb +39 -0
- data/app/presenters/decidim/admin_log/taxonomy_filter_presenter.rb +57 -0
- data/app/presenters/decidim/admin_log/taxonomy_presenter.rb +48 -0
- data/app/presenters/decidim/admin_log/user_group_presenter.rb +6 -6
- data/app/presenters/decidim/admin_log/user_presenter.rb +4 -18
- data/app/presenters/decidim/log/user_presenter.rb +0 -1
- data/app/presenters/decidim/log/value_types/date_presenter.rb +1 -0
- data/app/presenters/decidim/log/value_types/taxonomy_presenter.rb +29 -0
- data/app/presenters/decidim/notification_to_mailer_presenter.rb +3 -7
- data/app/presenters/decidim/participatory_space_private_user_presenter.rb +50 -0
- data/app/presenters/decidim/taxonomy_filter_presenter.rb +19 -0
- data/app/presenters/decidim/taxonomy_presenter.rb +14 -0
- data/app/presenters/decidim/user_presenter.rb +1 -1
- data/app/queries/decidim/last_activity.rb +0 -25
- data/app/queries/decidim/metrics/blocked_users_metric_manage.rb +2 -2
- data/app/queries/decidim/metrics/users_metric_manage.rb +2 -2
- data/app/queries/decidim/public_activities.rb +1 -12
- data/app/queries/decidim/stats_users_count.rb +2 -2
- data/app/resolvers/decidim/meta_image_url_resolver.rb +128 -0
- data/app/serializers/decidim/exporters/open_data_blocked_user_serializer.rb +25 -0
- data/app/serializers/decidim/exporters/open_data_metric_serializer.rb +22 -0
- data/app/serializers/decidim/exporters/open_data_moderation_serializer.rb +30 -0
- data/app/serializers/decidim/exporters/open_data_taxonomy_serializer.rb +30 -0
- data/app/serializers/decidim/exporters/open_data_user_group_serializer.rb +38 -0
- data/app/serializers/decidim/exporters/open_data_user_serializer.rb +39 -0
- data/app/serializers/decidim/exporters/participatory_space_serializer.rb +104 -0
- data/app/serializers/decidim/exporters/serializer.rb +25 -0
- data/app/serializers/decidim/schema_org_breadcrumb_list_serializer.rb +52 -0
- data/app/services/decidim/action_authorizer.rb +32 -3
- data/app/services/decidim/base_diff_renderer.rb +1 -3
- data/app/services/decidim/download_your_data_exporter.rb +58 -24
- data/app/services/decidim/onboarding_manager.rb +272 -0
- data/app/services/decidim/open_data_exporter.rb +139 -13
- data/app/services/decidim/static_map_generator.rb +1 -1
- data/app/services/decidim/traceability.rb +13 -0
- data/app/uploaders/decidim/application_uploader.rb +1 -1
- data/app/validators/etiquette_validator.rb +9 -2
- data/app/validators/passthru_validator.rb +1 -1
- data/app/validators/password_validator.rb +1 -3
- data/app/validators/translated_etiquette_validator.rb +32 -0
- data/app/views/decidim/account/_password_fields.html.erb +2 -2
- data/app/views/decidim/application/_accordion_section.html.erb +14 -0
- data/app/views/decidim/application/_collection.html.erb +30 -18
- data/app/views/decidim/application/_document.html.erb +2 -2
- data/app/views/decidim/devise/omniauth_registrations/new.html.erb +5 -1
- data/app/views/decidim/devise/omniauth_registrations/new_tos_fields.html.erb +29 -0
- data/app/views/decidim/devise/registrations/new.html.erb +10 -22
- data/app/views/decidim/devise/sessions/new.html.erb +24 -29
- data/app/views/decidim/devise/shared/_omniauth_buttons.html.erb +2 -4
- data/app/views/decidim/devise/shared/_tos_fields.html.erb +16 -0
- data/app/views/decidim/download_your_data/_export.html.erb +15 -0
- data/app/views/decidim/download_your_data/show.html.erb +51 -5
- data/app/views/decidim/endorsements/update_buttons_and_counters.js.erb +16 -19
- data/app/views/decidim/errors/internal_server_error.html.erb +1 -1
- data/app/views/decidim/errors/not_found.html.erb +1 -1
- data/app/views/decidim/export_mailer/download_your_data_export.html.erb +2 -2
- data/app/views/decidim/export_mailer/export.html.erb +5 -1
- data/app/views/decidim/last_activities/index.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_reply_form.html.erb +2 -1
- data/app/views/decidim/messaging/conversations/_start.html.erb +1 -1
- data/app/views/decidim/newsletters/unsubscribe.html.erb +4 -16
- data/app/views/decidim/notifications_settings/show.html.erb +22 -0
- data/app/views/decidim/open_data/_how_to_open_accordion_section.html.erb +15 -0
- data/app/views/decidim/open_data/index.html.erb +108 -0
- data/app/views/decidim/pages/show.html.erb +2 -1
- data/app/views/decidim/participatory_space_private_users/_participatory_space_private_user.html.erb +1 -0
- data/app/views/decidim/reported_mailer/hide.html.erb +9 -0
- data/app/views/decidim/reported_mailer/report.html.erb +1 -1
- data/app/views/decidim/searches/_count.html.erb +1 -1
- data/app/views/decidim/searches/_filters.html.erb +39 -76
- data/app/views/decidim/shared/_component_announcement.html.erb +1 -1
- data/app/views/decidim/shared/_confirm_modal.html.erb +5 -3
- data/app/views/decidim/shared/_filters.html.erb +5 -7
- data/app/views/decidim/shared/_login_modal.html.erb +26 -20
- data/app/views/decidim/shared/_orders.html.erb +2 -2
- data/app/views/decidim/shared/_resource_actions.html.erb +21 -0
- data/app/views/decidim/shared/_results_per_page.html.erb +1 -1
- data/app/views/decidim/shared/filters/_check_boxes_tree.html.erb +1 -2
- data/app/views/decidim/shared/filters/_collection.html.erb +1 -1
- data/app/views/decidim/shared/filters/_dropdown_label.html.erb +7 -4
- data/app/views/kaminari/decidim/_page.html.erb +1 -1
- data/app/views/kaminari/decidim/_paginator.html.erb +1 -1
- data/app/views/layouts/decidim/_application.html.erb +1 -2
- data/app/views/layouts/decidim/_logo.html.erb +2 -2
- data/app/views/layouts/decidim/_logo_mobile.html.erb +1 -1
- data/app/views/layouts/decidim/_meta_tags_config.html.erb +6 -11
- data/app/views/layouts/decidim/_schema_org_breadcrumb_list.html.erb +3 -0
- data/app/views/layouts/decidim/_wrapper.html.erb +15 -9
- data/app/views/layouts/decidim/footer/_main.html.erb +1 -1
- data/app/views/layouts/decidim/footer/_main_intro.html.erb +1 -1
- data/app/views/layouts/decidim/footer/_main_legal.html.erb +1 -1
- data/app/views/layouts/decidim/footer/_main_links.html.erb +1 -1
- data/app/views/layouts/decidim/footer/_mini.html.erb +2 -2
- data/app/views/layouts/decidim/header/_close_ephemeral_session.html.erb +25 -0
- data/app/views/layouts/decidim/header/_main.html.erb +14 -10
- data/app/views/layouts/decidim/header/_main_links_desktop.html.erb +0 -6
- data/app/views/layouts/decidim/header/_main_links_dropdown.html.erb +0 -2
- data/app/views/layouts/decidim/header/_main_links_mobile_account.html.erb +1 -1
- data/app/views/layouts/decidim/header/_menu_breadcrumb_items.html.erb +2 -0
- data/app/views/layouts/decidim/header/_menu_breadcrumb_main_dropdown_desktop.html.erb +11 -5
- data/app/views/layouts/decidim/header/_menu_breadcrumb_mobile_tablet.html.erb +5 -5
- data/app/views/layouts/decidim/header/_mobile_language_choose.html.erb +1 -1
- data/app/views/layouts/decidim/shared/_layout_item.html.erb +1 -1
- data/config/assets.rb +2 -1
- data/config/locales/ar.yml +38 -74
- data/config/locales/bg-BG.yml +2 -2
- data/config/locales/bg.yml +38 -74
- data/config/locales/bs-BA.yml +0 -2
- data/config/locales/ca.yml +382 -138
- data/config/locales/cs.yml +379 -121
- data/config/locales/de.yml +370 -133
- data/config/locales/el.yml +26 -58
- data/config/locales/en.yml +354 -110
- data/config/locales/eo.yml +0 -4
- data/config/locales/es-MX.yml +368 -127
- data/config/locales/es-PY.yml +373 -132
- data/config/locales/es.yml +374 -130
- data/config/locales/eu.yml +491 -245
- data/config/locales/fi-plain.yml +367 -130
- data/config/locales/fi.yml +372 -132
- data/config/locales/fr-CA.yml +180 -125
- data/config/locales/fr-LU.yml +3 -3
- data/config/locales/fr.yml +180 -122
- data/config/locales/ga-IE.yml +4 -25
- data/config/locales/gl.yml +23 -58
- data/config/locales/hu.yml +35 -62
- data/config/locales/id-ID.yml +24 -57
- data/config/locales/is-IS.yml +6 -25
- data/config/locales/it.yml +39 -218
- data/config/locales/ja.yml +235 -141
- data/config/locales/lb-LU.yml +2 -2
- data/config/locales/lb.yml +31 -76
- data/config/locales/lt.yml +29 -64
- data/config/locales/lv.yml +24 -58
- data/config/locales/nl.yml +26 -75
- data/config/locales/no.yml +26 -70
- data/config/locales/pl.yml +35 -72
- data/config/locales/pt-BR.yml +44 -63
- data/config/locales/pt.yml +26 -70
- data/config/locales/ro-RO.yml +118 -183
- data/config/locales/ru.yml +16 -43
- data/config/locales/sk-SK.yml +3 -3
- data/config/locales/sk.yml +27 -72
- data/config/locales/sl.yml +0 -4
- data/config/locales/sr-CS.yml +0 -2
- data/config/locales/sv.yml +141 -133
- data/config/locales/tr-TR.yml +32 -75
- data/config/locales/uk.yml +8 -29
- data/config/locales/zh-CN.yml +24 -68
- data/config/locales/zh-TW.yml +28 -62
- data/config/routes.rb +4 -10
- 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/20181001124950_move_users_groups_to_users_table.rb +1 -1
- data/db/migrate/20181025082245_add_timestamps_to_components.rb +2 -0
- data/db/migrate/20190412131728_fix_user_names.rb +1 -1
- data/db/migrate/20240628111905_add_visible_to_components.rb +7 -0
- data/db/migrate/20240704115429_create_decidim_taxonomies.rb +23 -0
- data/db/migrate/20240717093514_add_registered_only_to_decidim_share_tokens.rb +7 -0
- data/db/migrate/20240722215500_change_object_changes_on_versions.rb +39 -0
- data/db/migrate/20240806065417_create_decidim_taxonomy_filters.rb +23 -0
- data/db/migrate/20240822161348_add_deleted_at_to_decidim_components.rb +8 -0
- data/db/migrate/20240906162524_add_part_of_to_taxonomies.rb +26 -0
- data/db/migrate/20241001135825_add_role_to_participatory_space_private_users.rb +7 -0
- data/db/migrate/20241001140408_add_published_to_participatory_space_private_users.rb +7 -0
- data/db/migrate/20241022002600_create_private_exports.rb +18 -0
- data/db/migrate/20241028114430_add_component_counter_to_taxonomy_filters.rb +7 -0
- data/db/migrate/20241111104357_add_names_and_space_boolean_to_taxonomy_filters.rb +9 -0
- data/db/migrate/20241127093708_add_taxonomy_to_metrics.rb +7 -0
- data/db/migrate/20241204121445_add_participatory_space_manifests_from_taxonomy_filters.rb +9 -0
- data/decidim-core.gemspec +14 -17
- data/lib/decidim/action_authorization.rb +3 -2
- data/lib/decidim/amendable.rb +1 -1
- data/lib/decidim/api/input_filters/category_input_filter.rb +5 -3
- data/lib/decidim/api/input_filters/component_input_filter.rb +33 -20
- data/lib/decidim/api/input_filters/user_entity_input_filter.rb +53 -44
- data/lib/decidim/api/input_sorts/component_input_sort.rb +15 -13
- data/lib/decidim/api/input_sorts/user_entity_input_sort.rb +4 -4
- data/lib/decidim/api/interfaces/author_interface.rb +3 -2
- data/lib/decidim/api/interfaces/coauthorable_interface.rb +5 -5
- data/lib/decidim/api/interfaces/endorsable_interface.rb +2 -2
- data/lib/decidim/api/interfaces/participatory_space_interface.rb +5 -10
- data/lib/decidim/api/interfaces/taxonomizable_interface.rb +13 -0
- data/lib/decidim/api/types/amendment_type.rb +5 -7
- data/lib/decidim/api/types/area_api_type.rb +3 -3
- data/lib/decidim/api/types/attachment_type.rb +3 -3
- data/lib/decidim/api/types/category_type.rb +2 -2
- data/lib/decidim/api/types/decidim_type.rb +5 -1
- data/lib/decidim/api/types/fingerprint_type.rb +1 -1
- data/lib/decidim/api/types/localized_string_type.rb +1 -1
- data/lib/decidim/api/types/metric_history_type.rb +2 -0
- data/lib/decidim/api/types/metric_type.rb +1 -1
- data/lib/decidim/api/types/organization_type.rb +5 -0
- data/lib/decidim/api/types/participatory_space_link_type.rb +2 -2
- data/lib/decidim/api/types/participatory_space_manifest_type.rb +1 -1
- data/lib/decidim/api/types/quantifiable_translated_field_type.rb +1 -1
- data/lib/decidim/api/types/scope_api_type.rb +2 -3
- data/lib/decidim/api/types/session_type.rb +1 -2
- data/lib/decidim/api/types/taxonomy_type.rb +15 -0
- data/lib/decidim/api/types/trace_version_type.rb +2 -2
- data/lib/decidim/api/types/translated_field_type.rb +3 -5
- data/lib/decidim/api/types/user_group_type.rb +7 -20
- data/lib/decidim/api/types/user_type.rb +7 -20
- data/lib/decidim/asset_router/storage.rb +10 -15
- data/lib/decidim/assets/tailwind/tailwind.config.js.erb +3 -3
- data/lib/decidim/attachment_attributes.rb +1 -1
- data/lib/decidim/attribute_encryptor.rb +1 -1
- data/lib/decidim/attribute_object/nested_validator.rb +1 -1
- data/lib/decidim/attributes/integer_with_units.rb +27 -0
- data/lib/decidim/attributes/time_with_zone.rb +1 -5
- data/lib/decidim/attributes.rb +2 -0
- data/lib/decidim/authorization_form_builder.rb +0 -7
- data/lib/decidim/coauthorable.rb +1 -1
- data/lib/decidim/command.rb +3 -3
- data/lib/decidim/commands/destroy_resource.rb +5 -1
- data/lib/decidim/commands/resource_handler.rb +2 -2
- data/lib/decidim/commands/restore_resource.rb +45 -0
- data/lib/decidim/commands/soft_delete_resource.rb +63 -0
- data/lib/decidim/component_manifest.rb +7 -0
- data/lib/decidim/content_parsers/blob_parser.rb +8 -10
- data/lib/decidim/content_parsers/user_parser.rb +1 -1
- data/lib/decidim/core/api.rb +2 -0
- data/lib/decidim/core/engine.rb +21 -7
- data/lib/decidim/core/menu.rb +0 -5
- data/lib/decidim/core/seeds.rb +42 -2
- data/lib/decidim/core/test/factories.rb +107 -4
- data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +85 -0
- data/lib/decidim/core/test/shared_examples/announcements_examples.rb +0 -4
- data/lib/decidim/core/test/shared_examples/comments_examples.rb +393 -38
- data/lib/decidim/core/test/shared_examples/components_controller_hide_shared_examples.rb +11 -0
- data/lib/decidim/core/test/shared_examples/components_controller_reorder_shared_examples.rb +21 -0
- data/lib/decidim/core/test/shared_examples/download_open_data_shared_context.rb +36 -0
- data/lib/decidim/core/test/shared_examples/download_open_data_shared_examples.rb +45 -0
- data/lib/decidim/core/test/shared_examples/download_your_data_shared_examples.rb +17 -0
- data/lib/decidim/core/test/shared_examples/etiquette_validator_examples.rb +25 -0
- data/lib/decidim/core/test/shared_examples/follows_examples.rb +43 -0
- data/lib/decidim/core/test/shared_examples/has_taxonomies.rb +94 -0
- data/lib/decidim/core/test/shared_examples/manage_share_tokens_examples.rb +237 -0
- data/lib/decidim/core/test/shared_examples/map_examples.rb +2 -0
- data/lib/decidim/core/test/shared_examples/open_data_exporter_examples.rb +102 -0
- data/lib/decidim/core/test/shared_examples/participatory_space_members_page_examples.rb +46 -0
- data/lib/decidim/core/test/shared_examples/participatory_space_search_examples.rb +98 -0
- data/lib/decidim/core/test/shared_examples/permissions.rb +7 -7
- data/lib/decidim/core/test/shared_examples/preview_with_share_token_examples.rb +94 -0
- data/lib/decidim/core/test/shared_examples/reports_examples.rb +15 -53
- data/lib/decidim/core/test/shared_examples/resource_endorsed_event_examples.rb +2 -2
- data/lib/decidim/core/test/shared_examples/resource_search_examples.rb +75 -69
- data/lib/decidim/core/test/shared_examples/searchable_resources_shared_context.rb +1 -1
- data/lib/decidim/core/test/shared_examples/simple_event.rb +33 -19
- data/lib/decidim/core/test/shared_examples/social_share_examples.rb +7 -14
- data/lib/decidim/core/test/shared_examples/softdeleteable_components_examples.rb +173 -0
- data/lib/decidim/core/test/shared_examples/system_endorse_resource_examples.rb +54 -8
- data/lib/decidim/core/test/shared_examples/taxonomizable_interface_examples.rb +20 -0
- data/lib/decidim/core/test/shared_examples/taxonomizable_resource_examples.rb +37 -0
- data/lib/decidim/core/test/shared_examples/taxonomy_settings.rb +49 -0
- data/lib/decidim/core/test/shared_examples/translated_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/uncommentable_component_examples.rb +0 -26
- data/lib/decidim/core/test/shared_examples/versions_controller_examples.rb +2 -28
- data/lib/decidim/core/test/shared_examples/with_endorsable_permissions_examples.rb +1 -1
- data/lib/decidim/core/test.rb +9 -5
- data/lib/decidim/core/version.rb +1 -1
- data/lib/decidim/core.rb +58 -0
- data/lib/decidim/download_your_data_serializers/download_your_data_identity_serializer.rb +0 -4
- data/lib/decidim/download_your_data_serializers/download_your_data_participatory_space_private_user_serializer.rb +3 -1
- data/lib/decidim/download_your_data_serializers/download_your_data_report_serializer.rb +2 -1
- data/lib/decidim/download_your_data_serializers/download_your_data_user_serializer.rb +6 -7
- data/lib/decidim/download_your_data_serializers.rb +19 -0
- data/lib/decidim/exporters/csv.rb +6 -0
- data/lib/decidim/exporters/export_manifest.rb +14 -0
- data/lib/decidim/exporters/pdf.rb +26 -22
- data/lib/decidim/filter_form_builder.rb +12 -15
- data/lib/decidim/form_builder.rb +7 -144
- data/lib/decidim/has_category.rb +5 -1
- data/lib/decidim/has_private_users.rb +4 -0
- data/lib/decidim/has_taxonomy_settings.rb +47 -0
- data/lib/decidim/has_upload_validations.rb +1 -1
- data/lib/decidim/legacy_form_builder.rb +118 -0
- data/lib/decidim/maintenance/import_models/application_record.rb +93 -0
- data/lib/decidim/maintenance/import_models/area.rb +82 -0
- data/lib/decidim/maintenance/import_models/area_type.rb +12 -0
- data/lib/decidim/maintenance/import_models/assembly_type.rb +49 -0
- data/lib/decidim/maintenance/import_models/categorization.rb +14 -0
- data/lib/decidim/maintenance/import_models/category.rb +107 -0
- data/lib/decidim/maintenance/import_models/participatory_process_type.rb +21 -0
- data/lib/decidim/maintenance/import_models/scope.rb +163 -0
- data/lib/decidim/maintenance/import_models.rb +19 -0
- data/lib/decidim/maintenance/taxonomy_importer.rb +132 -0
- data/lib/decidim/maintenance/taxonomy_plan.rb +78 -0
- data/lib/decidim/maintenance.rb +12 -0
- data/lib/decidim/map/autocomplete.rb +52 -8
- data/lib/decidim/map/dynamic_map.rb +1 -1
- data/lib/decidim/map/provider/dynamic_map/here.rb +40 -1
- data/lib/decidim/map/provider/geocoding/here.rb +9 -3
- data/lib/decidim/map/provider/static_map/here.rb +0 -34
- data/lib/decidim/map.rb +3 -6
- data/lib/decidim/moderation_tools.rb +16 -19
- data/lib/decidim/newsletter_encryptor.rb +1 -1
- data/lib/decidim/nicknamizable.rb +9 -6
- data/lib/decidim/paddable.rb +1 -1
- data/lib/decidim/participable.rb +10 -10
- data/lib/decidim/participatory_space_user.rb +10 -0
- data/lib/decidim/private_download_helper.rb +15 -0
- data/lib/decidim/record_encryptor.rb +51 -46
- data/lib/decidim/reportable.rb +2 -6
- data/lib/decidim/resourceable.rb +16 -0
- data/lib/decidim/seeds.rb +18 -20
- data/lib/decidim/settings_manifest.rb +34 -1
- data/lib/decidim/soft_deletable.rb +17 -0
- data/lib/decidim/taxonomizable.rb +72 -0
- data/lib/decidim/translatable_attributes.rb +1 -5
- data/lib/decidim/view_model.rb +0 -1
- data/lib/tasks/decidim_download_your_data_tasks.rake +2 -4
- data/lib/tasks/decidim_procfile.rake +6 -0
- data/lib/tasks/decidim_tasks.rake +1 -0
- data/lib/tasks/decidim_taxonomies.rake +155 -0
- data/lib/tasks/upgrade/{decidim_fix_categorization.rake → clean.rake} +25 -18
- data/lib/tasks/upgrade/decidim_active_storage_migration_tasks.rake +1 -1
- data/lib/tasks/upgrade/decidim_fix_nickname_uniqueness.rake +20 -23
- data/lib/tasks/upgrade/migrations.rake +91 -0
- metadata +201 -114
- data/app/cells/decidim/amendable/amenders_list/show.erb +0 -0
- data/app/cells/decidim/author/badge.erb +0 -6
- data/app/cells/decidim/content_blocks/base/content.erb +0 -0
- data/app/cells/decidim/endorsers_list/full_endorsers_list.erb +0 -3
- data/app/cells/decidim/endorsers_list_button/content.erb +0 -1
- data/app/cells/decidim/endorsers_list_button_cell.rb +0 -15
- data/app/cells/decidim/report_user_button/already_reported_modal.erb +0 -11
- data/app/cells/decidim/report_user_button/flag_modal.erb +0 -47
- data/app/cells/decidim/report_user_button/show.erb +0 -2
- data/app/cells/decidim/report_user_button_cell.rb +0 -59
- data/app/cells/decidim/scopes_picker/scope_picker_prompt.erb +0 -3
- data/app/cells/decidim/scopes_picker/scope_picker_values.erb +0 -5
- data/app/cells/decidim/scopes_picker/show.erb +0 -14
- data/app/cells/decidim/scopes_picker_cell.rb +0 -92
- data/app/commands/decidim/update_user_interests.rb +0 -41
- data/app/controllers/decidim/scopes_controller.rb +0 -84
- data/app/controllers/decidim/user_interests_controller.rb +0 -30
- data/app/forms/decidim/user_interest_scope_form.rb +0 -25
- data/app/forms/decidim/user_interests_form.rb +0 -17
- data/app/helpers/decidim/categories_helper.rb +0 -26
- data/app/helpers/decidim/scopes_helper.rb +0 -105
- data/app/jobs/decidim/hide_child_resources_job.rb +0 -24
- data/app/packs/images/decidim/vendor/leaflet/layers-2x.png +0 -0
- data/app/packs/images/decidim/vendor/leaflet/layers.png +0 -0
- data/app/packs/images/decidim/vendor/leaflet/marker-icon-2x.png +0 -0
- data/app/packs/images/decidim/vendor/leaflet/marker-icon.png +0 -0
- data/app/packs/images/decidim/vendor/leaflet/marker-shadow.png +0 -0
- data/app/packs/src/decidim/dropdown_menu.js +0 -18
- data/app/packs/stylesheets/decidim/_hashtags.scss +0 -5
- data/app/packs/stylesheets/decidim/legacy/MarkerCluster.Default.scss +0 -67
- data/app/packs/stylesheets/decidim/legacy/MarkerCluster.scss +0 -18
- data/app/packs/stylesheets/decidim/legacy/leaflet.scss +0 -705
- data/app/validators/scope_belongs_to_component_validator.rb +0 -16
- data/app/views/decidim/account/_user_groups.html.erb +0 -0
- data/app/views/decidim/reported_mailer/hidden_automatically.html.erb +0 -25
- data/app/views/decidim/reported_mailer/hidden_manually.html.erb +0 -25
- data/app/views/decidim/scopes/_scopes_picker_input.html.erb +0 -19
- data/app/views/decidim/scopes/picker.html.erb +0 -53
- data/app/views/decidim/shared/_comments.html.erb +0 -0
- data/app/views/decidim/shared/_share_modal.html.erb +0 -26
- data/app/views/decidim/shared/_tags.html.erb +0 -1
- data/app/views/decidim/user_interests/_areas.html.erb +0 -14
- data/app/views/decidim/user_interests/_scopes.html.erb +0 -22
- data/app/views/decidim/user_interests/show.html.erb +0 -22
- data/config/initializers/foundation_rails_helper.rb +0 -4
- data/config/locales/ca-IT.yml +0 -2146
- data/lib/decidim/core/test/shared_examples/has_category.rb +0 -38
- data/lib/decidim/core/test/shared_examples/has_scope.rb +0 -11
- data/lib/decidim/core/test/shared_examples/manage_component_share_tokens.rb +0 -83
- data/lib/decidim/core/test/shared_examples/preview_component_with_share_token_examples.rb +0 -49
- data/lib/decidim/core/test/shared_examples/scope_helper_examples.rb +0 -93
- data/lib/decidim/seven_zip_wrapper.rb +0 -29
- data/lib/tasks/upgrade/clean_hidden_resources.rake +0 -33
|
@@ -9,48 +9,86 @@ module Decidim
|
|
|
9
9
|
class OpenDataExporter
|
|
10
10
|
FILE_NAME_PATTERN = "%{host}-open-data-%{entity}.csv"
|
|
11
11
|
|
|
12
|
-
attr_reader :organization, :path
|
|
12
|
+
attr_reader :organization, :path, :resource, :help_definition
|
|
13
|
+
|
|
14
|
+
include Decidim::TranslatableAttributes
|
|
13
15
|
|
|
14
16
|
# Public: Initializes the class.
|
|
15
17
|
#
|
|
16
18
|
# organization - The Organization to export the data from.
|
|
17
19
|
# path - The String path where to write the zip file.
|
|
18
|
-
|
|
20
|
+
# resource - The String of the component or participatory space to export. If nil, it will export all.
|
|
21
|
+
def initialize(organization, path, resource = nil)
|
|
19
22
|
@organization = organization
|
|
20
23
|
@path = File.expand_path path
|
|
24
|
+
@resource = resource
|
|
25
|
+
@help_definition = {}
|
|
21
26
|
end
|
|
22
27
|
|
|
23
28
|
def export
|
|
24
29
|
dirname = File.dirname(path)
|
|
25
30
|
FileUtils.mkdir_p(dirname) unless File.directory?(dirname)
|
|
26
|
-
|
|
31
|
+
if resource.nil?
|
|
32
|
+
File.binwrite(path, data_for_all_resources)
|
|
33
|
+
else
|
|
34
|
+
File.write(path, data_for_resource(resource))
|
|
35
|
+
end
|
|
27
36
|
end
|
|
28
37
|
|
|
29
38
|
private
|
|
30
39
|
|
|
31
|
-
def
|
|
40
|
+
def data_for_all_resources
|
|
32
41
|
buffer = Zip::OutputStream.write_buffer do |out|
|
|
42
|
+
core_data_manifests.each do |manifest|
|
|
43
|
+
add_file_to_output(out, format(FILE_NAME_PATTERN, { host: organization.host, entity: manifest.name }), data_for_core(manifest).read)
|
|
44
|
+
end
|
|
33
45
|
open_data_component_manifests.each do |manifest|
|
|
34
|
-
add_file_to_output(out, format(FILE_NAME_PATTERN, { host: organization.host, entity: manifest.name }), data_for_component(manifest))
|
|
46
|
+
add_file_to_output(out, format(FILE_NAME_PATTERN, { host: organization.host, entity: manifest.name }), data_for_component(manifest).read)
|
|
35
47
|
end
|
|
36
48
|
open_data_participatory_space_manifests.each do |manifest|
|
|
37
|
-
add_file_to_output(out, format(FILE_NAME_PATTERN, { host: organization.host, entity: manifest.name }), data_for_participatory_space(manifest))
|
|
49
|
+
add_file_to_output(out, format(FILE_NAME_PATTERN, { host: organization.host, entity: manifest.name }), data_for_participatory_space(manifest).read)
|
|
38
50
|
end
|
|
51
|
+
|
|
52
|
+
add_file_to_output(out, "README.md", readme)
|
|
53
|
+
add_file_to_output(out, "LICENSE.md", license)
|
|
39
54
|
end
|
|
40
55
|
|
|
41
56
|
buffer.string
|
|
42
57
|
end
|
|
43
58
|
|
|
59
|
+
def data_for_core(export_manifest)
|
|
60
|
+
collection = export_manifest.collection.call(organization)
|
|
61
|
+
exporter = Decidim::Exporters::CSV.new(collection, export_manifest.serializer)
|
|
62
|
+
|
|
63
|
+
get_help_definition(:core, exporter, export_manifest) unless collection.empty?
|
|
64
|
+
|
|
65
|
+
exporter.export
|
|
66
|
+
end
|
|
67
|
+
|
|
68
|
+
def data_for_resource(resource)
|
|
69
|
+
export_manifest = (core_data_manifests + open_data_component_manifests + open_data_participatory_space_manifests)
|
|
70
|
+
.select { |manifest| manifest.name == resource.to_sym }.first
|
|
71
|
+
|
|
72
|
+
case export_manifest.respond_to?(:manifest) && export_manifest.manifest
|
|
73
|
+
when Decidim::ComponentManifest
|
|
74
|
+
data_for_component(export_manifest).read
|
|
75
|
+
when Decidim::ParticipatorySpaceManifest
|
|
76
|
+
data_for_participatory_space(export_manifest).read
|
|
77
|
+
else
|
|
78
|
+
data_for_core(export_manifest).read
|
|
79
|
+
end
|
|
80
|
+
end
|
|
81
|
+
|
|
44
82
|
def data_for_component(export_manifest, col_sep = Decidim.default_csv_col_sep)
|
|
45
83
|
headers = []
|
|
46
84
|
collection = []
|
|
47
85
|
ActiveRecord::Base.uncached do
|
|
48
|
-
components.where(manifest_name: export_manifest.manifest.name).find_each do |component|
|
|
86
|
+
components.where(manifest_name: export_manifest.manifest.name).unscope(:order).find_each do |component|
|
|
49
87
|
export_manifest.collection.call(component).find_in_batches(batch_size: 100) do |batch|
|
|
50
|
-
|
|
88
|
+
serializer = export_manifest.open_data_serializer.nil? ? export_manifest.serializer : export_manifest.open_data_serializer
|
|
89
|
+
exporter = Decidim::Exporters::CSV.new(batch, serializer)
|
|
51
90
|
headers.push(*exporter.headers)
|
|
52
91
|
exported = exporter.export
|
|
53
|
-
|
|
54
92
|
tmpdir = Dir::Tmpname.create(export_manifest.name.to_s) do
|
|
55
93
|
# just get an empty file name
|
|
56
94
|
end
|
|
@@ -59,6 +97,8 @@ module Decidim
|
|
|
59
97
|
File.write(filename, exported.read)
|
|
60
98
|
|
|
61
99
|
collection.push(filename)
|
|
100
|
+
|
|
101
|
+
get_help_definition(:components, exporter, export_manifest) unless collection.empty?
|
|
62
102
|
end
|
|
63
103
|
end
|
|
64
104
|
end
|
|
@@ -76,16 +116,102 @@ module Decidim
|
|
|
76
116
|
end
|
|
77
117
|
|
|
78
118
|
def data_for_participatory_space(export_manifest)
|
|
79
|
-
collection = participatory_spaces.
|
|
119
|
+
collection = participatory_spaces.flat_map do |participatory_space|
|
|
80
120
|
export_manifest.collection.call(participatory_space)
|
|
81
121
|
end
|
|
122
|
+
serializer = export_manifest.open_data_serializer.nil? ? export_manifest.serializer : export_manifest.open_data_serializer
|
|
123
|
+
exporter = Decidim::Exporters::CSV.new(collection, serializer)
|
|
124
|
+
get_help_definition(:spaces, exporter, export_manifest) unless collection.empty?
|
|
125
|
+
|
|
126
|
+
exporter.export
|
|
127
|
+
end
|
|
128
|
+
|
|
129
|
+
def get_help_definition(manifest_type, exporter, export_manifest)
|
|
130
|
+
help_definition[manifest_type] = {} if help_definition[manifest_type].nil?
|
|
131
|
+
help_definition[manifest_type][export_manifest.name] = {} if help_definition[manifest_type][export_manifest.name].blank?
|
|
132
|
+
exporter.headers_without_locales.each do |header|
|
|
133
|
+
help_definition[manifest_type][export_manifest.name][header] = I18n.t("decidim.open_data.help.#{export_manifest.name}.#{header}")
|
|
134
|
+
end
|
|
135
|
+
end
|
|
136
|
+
|
|
137
|
+
def readme
|
|
138
|
+
"# #{I18n.t("decidim.open_data.help.core.title", organization: translated_attribute(organization.name))}\n\n
|
|
139
|
+
#{I18n.t("decidim.open_data.help.core.description")}\n\n
|
|
140
|
+
#{core_readme}
|
|
141
|
+
#{space_readme}
|
|
142
|
+
#{component_readme}
|
|
143
|
+
"
|
|
144
|
+
end
|
|
145
|
+
|
|
146
|
+
def core_readme
|
|
147
|
+
return unless help_definition.fetch(:core, false)
|
|
148
|
+
|
|
149
|
+
readme_file = "## #{I18n.t("decidim.open_data.help.core.main")}\n\n"
|
|
150
|
+
help_definition.fetch(:core, []).each do |element, headers|
|
|
151
|
+
readme_file << "### #{element}\n\n"
|
|
152
|
+
|
|
153
|
+
headers.each do |header, help_value|
|
|
154
|
+
readme_file << "* #{header}: #{help_value}\n"
|
|
155
|
+
end
|
|
156
|
+
|
|
157
|
+
readme_file << "\n\n"
|
|
158
|
+
end
|
|
159
|
+
readme_file
|
|
160
|
+
end
|
|
161
|
+
|
|
162
|
+
def space_readme
|
|
163
|
+
return unless help_definition.fetch(:spaces, false)
|
|
164
|
+
|
|
165
|
+
readme_file = "## #{I18n.t("decidim.open_data.help.core.spaces")}\n\n"
|
|
166
|
+
|
|
167
|
+
help_definition.fetch(:spaces, []).each do |space, headers|
|
|
168
|
+
readme_file << "### #{space}\n\n"
|
|
169
|
+
|
|
170
|
+
headers.each do |header, help_value|
|
|
171
|
+
readme_file << "* #{header}: #{help_value}\n"
|
|
172
|
+
end
|
|
173
|
+
|
|
174
|
+
readme_file << "\n\n"
|
|
175
|
+
end
|
|
176
|
+
readme_file
|
|
177
|
+
end
|
|
178
|
+
|
|
179
|
+
def component_readme
|
|
180
|
+
return unless help_definition.fetch(:components, false)
|
|
181
|
+
|
|
182
|
+
readme_file = "## #{I18n.t("decidim.open_data.help.core.components")}\n\n"
|
|
183
|
+
|
|
184
|
+
help_definition.fetch(:components, []).each do |component, headers|
|
|
185
|
+
readme_file << "### #{component}\n\n"
|
|
186
|
+
|
|
187
|
+
headers.each do |header, help_value|
|
|
188
|
+
readme_file << "* #{header}: #{help_value}\n"
|
|
189
|
+
end
|
|
190
|
+
|
|
191
|
+
readme_file << "\n\n"
|
|
192
|
+
end
|
|
82
193
|
|
|
83
|
-
|
|
194
|
+
readme_file
|
|
84
195
|
end
|
|
85
196
|
|
|
86
|
-
def
|
|
197
|
+
def license
|
|
198
|
+
link_database = "#{I18n.t("license_database_name", scope: "decidim.open_data.index.license")}: #{I18n.t("license_database_link", scope: "decidim.open_data.index.license")}"
|
|
199
|
+
link_contents = "#{I18n.t("license_contents_name", scope: "decidim.open_data.index.license")}: #{I18n.t("license_contents_link", scope: "decidim.open_data.index.license")}"
|
|
200
|
+
|
|
201
|
+
license_file = I18n.t("title", scope: "decidim.open_data.index.license")
|
|
202
|
+
license_file << "\n\n"
|
|
203
|
+
license_file << I18n.t("body_1_html", scope: "decidim.open_data.index.license", organization_name: translated_attribute(organization.name), link_database:, link_contents:)
|
|
204
|
+
|
|
205
|
+
license_file
|
|
206
|
+
end
|
|
207
|
+
|
|
208
|
+
def add_file_to_output(output, file_name, string)
|
|
87
209
|
output.put_next_entry(file_name)
|
|
88
|
-
output.write
|
|
210
|
+
output.write string
|
|
211
|
+
end
|
|
212
|
+
|
|
213
|
+
def core_data_manifests
|
|
214
|
+
@core_data_manifests ||= Decidim.open_data_manifests.select(&:include_in_open_data)
|
|
89
215
|
end
|
|
90
216
|
|
|
91
217
|
def open_data_component_manifests
|
|
@@ -15,7 +15,7 @@ module Decidim
|
|
|
15
15
|
def data
|
|
16
16
|
return if @resource.blank? || map_utility.nil?
|
|
17
17
|
|
|
18
|
-
Rails.cache.fetch(@resource.
|
|
18
|
+
Rails.cache.fetch(@resource.cache_key) do
|
|
19
19
|
map_utility.image_data(
|
|
20
20
|
latitude: @resource.latitude,
|
|
21
21
|
longitude: @resource.longitude,
|
|
@@ -69,6 +69,19 @@ module Decidim
|
|
|
69
69
|
end
|
|
70
70
|
end
|
|
71
71
|
|
|
72
|
+
# Performs the given block and sets the author of the action without log.
|
|
73
|
+
#
|
|
74
|
+
# author - An object that implements `to_gid` or a String
|
|
75
|
+
#
|
|
76
|
+
# Returns whatever the given block returns.
|
|
77
|
+
def perform_action_without_log!(author)
|
|
78
|
+
PaperTrail.request(whodunnit: gid(author)) do
|
|
79
|
+
Decidim::ApplicationRecord.transaction do
|
|
80
|
+
block_given? ? yield : nil
|
|
81
|
+
end
|
|
82
|
+
end
|
|
83
|
+
end
|
|
84
|
+
|
|
72
85
|
# Updates the `resource` with `update!` and sets the author of the version.
|
|
73
86
|
#
|
|
74
87
|
# resource - An ActiveRecord instance that implements `Decidim::Traceable`
|
|
@@ -6,9 +6,11 @@ class EtiquetteValidator < ActiveModel::EachValidator
|
|
|
6
6
|
include ActionView::Helpers::SanitizeHelper
|
|
7
7
|
|
|
8
8
|
def validate_each(record, attribute, value)
|
|
9
|
+
return unless Decidim.enable_etiquette_validator
|
|
9
10
|
return if value.blank?
|
|
10
11
|
|
|
11
|
-
|
|
12
|
+
# remove HTML tags, from WYSIWYG editor
|
|
13
|
+
text_value = clean_value(value)
|
|
12
14
|
|
|
13
15
|
validate_caps(record, attribute, text_value)
|
|
14
16
|
validate_marks(record, attribute, text_value)
|
|
@@ -17,8 +19,13 @@ class EtiquetteValidator < ActiveModel::EachValidator
|
|
|
17
19
|
|
|
18
20
|
private
|
|
19
21
|
|
|
22
|
+
def clean_value(value)
|
|
23
|
+
ActionController::Base.helpers.strip_tags(value).to_s.strip
|
|
24
|
+
end
|
|
25
|
+
|
|
20
26
|
def validate_caps(record, attribute, value)
|
|
21
|
-
|
|
27
|
+
number_of_caps = value.scan(/[A-Z]/).length
|
|
28
|
+
return if number_of_caps.zero? || number_of_caps < value.length / 2 # 50%
|
|
22
29
|
|
|
23
30
|
record.errors.add(attribute, options[:message] || :too_much_caps)
|
|
24
31
|
end
|
|
@@ -33,7 +33,7 @@ class PassthruValidator < ActiveModel::EachValidator
|
|
|
33
33
|
value = dummy.public_send(dummy_attr)
|
|
34
34
|
elsif dummy.respond_to? :file
|
|
35
35
|
dummy.public_send("file=", value)
|
|
36
|
-
value = dummy.
|
|
36
|
+
value = dummy.file
|
|
37
37
|
end
|
|
38
38
|
|
|
39
39
|
target_validators(attribute).each do |validator|
|
|
@@ -55,9 +55,7 @@ class PasswordValidator < ActiveModel::EachValidator
|
|
|
55
55
|
attr_reader :record, :attribute, :value
|
|
56
56
|
|
|
57
57
|
def get_message(reason)
|
|
58
|
-
I18n.t
|
|
59
|
-
rescue I18n::MissingTranslationData
|
|
60
|
-
I18n.t "password_validator.fallback"
|
|
58
|
+
I18n.t "password_validator.#{reason}"
|
|
61
59
|
end
|
|
62
60
|
|
|
63
61
|
def organization
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
# This validator takes care of i18n fields ensuring the validated content is
|
|
4
|
+
# respectful, does not use caps, and overall is meaningful.
|
|
5
|
+
#
|
|
6
|
+
# validates :my_i18n_field, translated_etiquette: true
|
|
7
|
+
class TranslatedEtiquetteValidator < EtiquetteValidator
|
|
8
|
+
def validate_each(record, attribute, _value)
|
|
9
|
+
translated_attr = "#{attribute}_#{default_locale_for(record)}".gsub("-", "__")
|
|
10
|
+
translated_value = record.send(translated_attr)
|
|
11
|
+
return if translated_value.blank?
|
|
12
|
+
|
|
13
|
+
text_value = strip_tags(translated_value)
|
|
14
|
+
|
|
15
|
+
validate_caps(record, translated_attr, text_value)
|
|
16
|
+
validate_marks(record, translated_attr, text_value)
|
|
17
|
+
validate_caps_first(record, translated_attr, text_value)
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
private
|
|
21
|
+
|
|
22
|
+
def default_locale_for(record)
|
|
23
|
+
return record.default_locale if record.respond_to?(:default_locale)
|
|
24
|
+
|
|
25
|
+
if record.current_organization
|
|
26
|
+
record.current_organization.default_locale
|
|
27
|
+
else
|
|
28
|
+
record.errors.add(:current_organization, :blank)
|
|
29
|
+
Decidim.default_locale
|
|
30
|
+
end
|
|
31
|
+
end
|
|
32
|
+
end
|
|
@@ -3,11 +3,11 @@
|
|
|
3
3
|
data-hide-password="<%= t "hide_password", scope: "decidim.devise.shared.password_fields" %>"
|
|
4
4
|
data-hidden-password="<%= t "hidden_password", scope: "decidim.devise.shared.password_fields" %>"
|
|
5
5
|
data-shown-password="<%= t "shown_password", scope: "decidim.devise.shared.password_fields" %>">
|
|
6
|
-
<%= form.send(:custom_label, :password, t("activemodel.attributes.user.password"), {
|
|
6
|
+
<%= form.send(:custom_label, :password, t("activemodel.attributes.user.password"), {}) %>
|
|
7
7
|
|
|
8
8
|
<% if local_assigns.has_key?(:show_help_text) || local_assigns.has_key?(:user) %>
|
|
9
9
|
<%= form.password_field :password, password_field_options_for(user) %>
|
|
10
10
|
<% else %>
|
|
11
|
-
<%= form.password_field :password, autocomplete: "current-password", required: true, label: false %>
|
|
11
|
+
<%= form.password_field :password, autocomplete: "current-password", required: true, label: false, placeholder: "************" %>
|
|
12
12
|
<% end %>
|
|
13
13
|
</div>
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
<div class="card-accordion" data-component="accordion">
|
|
2
|
+
<div class="card-accordion-divider">
|
|
3
|
+
<button class="card-accordion-divider-button" data-open="<%= open_accordion ||= false %>" data-controls="panel-title--<%= panel_id %>" type="button">
|
|
4
|
+
<h2 class="card-accordion-title" id="title">
|
|
5
|
+
<%= title %>
|
|
6
|
+
</h2>
|
|
7
|
+
<%= icon "arrow-down-s-line", class: "mb-4" %>
|
|
8
|
+
</button>
|
|
9
|
+
</div>
|
|
10
|
+
|
|
11
|
+
<div id="panel-title--<%= panel_id %>" class="card-accordion-section editor-content" aria-hidden="true">
|
|
12
|
+
<%= yield %>
|
|
13
|
+
</div>
|
|
14
|
+
</div>
|
|
@@ -1,25 +1,37 @@
|
|
|
1
1
|
<% unless attachment_collection.unused? %>
|
|
2
|
-
<
|
|
3
|
-
<
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
</button>
|
|
2
|
+
<div class="documents__dropdown-container">
|
|
3
|
+
<button id="dropdown-documents-trigger-<%= attachment_collection.id %>" class="documents__collection-trigger" data-component="dropdown" data-target="dropdown-menu-documents-<%= attachment_collection.id %>" aria-expanded="false">
|
|
4
|
+
<div class="documents-details">
|
|
5
|
+
<span>
|
|
6
|
+
<span class="documents__collection-trigger__icon">
|
|
7
|
+
<%= icon "folder-line" %>
|
|
8
|
+
<%= icon "folder-open-line" %>
|
|
9
|
+
</span>
|
|
10
|
+
<%= decidim_escape_translated(attachment_collection.name) %>
|
|
11
|
+
</span>
|
|
13
12
|
|
|
14
|
-
<div
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
13
|
+
<div class="card__list-metadata">
|
|
14
|
+
<div><%= icon "file-text-line" %><%= t("decidim.documents", count: documents.count) %></div>
|
|
15
|
+
<% sum = 0
|
|
16
|
+
documents.each { |document| sum += document.file_size.to_i } %>
|
|
17
|
+
<div><%= icon "scales-2-line" %><%= number_to_human_size(sum) %></div>
|
|
18
|
+
</div>
|
|
19
|
+
</div>
|
|
18
20
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
21
|
+
<%= icon "arrow-down-s-fill" %>
|
|
22
|
+
<%= icon "arrow-up-s-fill" %>
|
|
23
|
+
</button>
|
|
24
|
+
|
|
25
|
+
<div id="dropdown-menu-documents-<%= attachment_collection.id %>" class="documents__collection-content" aria-hidden="true">
|
|
26
|
+
<% if (description = attachment_collection.description).present? %>
|
|
27
|
+
<p><%= decidim_escape_translated(description) %></p>
|
|
22
28
|
<% end %>
|
|
29
|
+
|
|
30
|
+
<div class="documents__container">
|
|
31
|
+
<% documents.each do |document| %>
|
|
32
|
+
<%= render partial: "decidim/application/document", formats: [:html], locals: { document: } %>
|
|
33
|
+
<% end %>
|
|
34
|
+
</div>
|
|
23
35
|
</div>
|
|
24
36
|
</div>
|
|
25
37
|
<% end %>
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
<div id="<%= dom_id(document) %>">
|
|
2
2
|
<div class="card__list-content">
|
|
3
|
-
|
|
3
|
+
<%= link_to document.url, target: "_blank", rel: "noopener noreferrer", class: "card__list-title", title: t("decidim.application.document.download") do %>
|
|
4
4
|
<%= h attachment_title(document) %>
|
|
5
|
-
|
|
5
|
+
<% end %>
|
|
6
6
|
<% if document.description.present? %>
|
|
7
7
|
<div class="card__list-text"><%= decidim_escape_translated(document.description) %></div>
|
|
8
8
|
<% end %>
|
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
<%= form_required_explanation %>
|
|
14
14
|
</div>
|
|
15
15
|
|
|
16
|
-
<%= decidim_form_for(@form, namespace: "registration", as: resource_name, url: decidim.omniauth_registrations_path(resource_name)) do |f| %>
|
|
16
|
+
<%= decidim_form_for(@form, namespace: "registration", as: resource_name, url: decidim.omniauth_registrations_path(resource_name), html: { id: "omniauth-register-form" }) do |f| %>
|
|
17
17
|
|
|
18
18
|
<div class="form__wrapper">
|
|
19
19
|
<%= f.text_field :name, help_text: t("decidim.devise.omniauth_registrations.new.username_help"), autocomplete: "name", placeholder: "John Doe" %>
|
|
@@ -22,6 +22,8 @@
|
|
|
22
22
|
|
|
23
23
|
<%= f.email_field :email, autocomplete: "email", placeholder: t("placeholder_email", scope: "decidim.devise.shared") %>
|
|
24
24
|
|
|
25
|
+
<%= render partial: "decidim/devise/shared/tos_fields", locals: { form: f, user: :user } %>
|
|
26
|
+
|
|
25
27
|
<%= f.hidden_field :uid %>
|
|
26
28
|
<%= f.hidden_field :provider %>
|
|
27
29
|
<%= f.hidden_field :oauth_signature %>
|
|
@@ -35,3 +37,5 @@
|
|
|
35
37
|
</div>
|
|
36
38
|
<% end %>
|
|
37
39
|
<% end %>
|
|
40
|
+
|
|
41
|
+
<%= render "decidim/devise/shared/newsletter_modal" %>
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
<%= render layout: "layouts/decidim/shared/layout_center" do %>
|
|
2
|
+
<div class="flex justify-center">
|
|
3
|
+
<h1 class="title-decorator my-12"><%= t("decidim.devise.omniauth_registrations.new_tos_fields.sign_up_title") %></h1>
|
|
4
|
+
</div>
|
|
5
|
+
|
|
6
|
+
<%= decidim_form_for(@form, namespace: "registration", as: resource_name, url: decidim.omniauth_registrations_path(resource_name), html: { id: "omniauth-register-form" }) do |f| %>
|
|
7
|
+
|
|
8
|
+
<div class="form__wrapper">
|
|
9
|
+
<%= f.hidden_field :name %>
|
|
10
|
+
<%= f.hidden_field :nickname %>
|
|
11
|
+
<%= f.hidden_field :email %>
|
|
12
|
+
|
|
13
|
+
<%= render partial: "decidim/devise/shared/tos_fields", locals: { form: f, user: :user } %>
|
|
14
|
+
|
|
15
|
+
<%= f.hidden_field :uid %>
|
|
16
|
+
<%= f.hidden_field :provider %>
|
|
17
|
+
<%= f.hidden_field :oauth_signature %>
|
|
18
|
+
</div>
|
|
19
|
+
|
|
20
|
+
<div class="form__wrapper-block">
|
|
21
|
+
<button type="submit" class="button button__lg button__secondary">
|
|
22
|
+
<span><%= t("decidim.devise.omniauth_registrations.new_tos_fields.sign_up") %></span>
|
|
23
|
+
<%= icon "arrow-right-line", class: "fill-current" %>
|
|
24
|
+
</button>
|
|
25
|
+
</div>
|
|
26
|
+
<% end %>
|
|
27
|
+
<% end %>
|
|
28
|
+
|
|
29
|
+
<%= render "decidim/devise/shared/newsletter_modal" %>
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
<%= render "decidim/devise/shared/links" %>
|
|
5
5
|
<% end %>
|
|
6
6
|
|
|
7
|
-
<%= render
|
|
7
|
+
<%= render(layout: "layouts/decidim/shared/layout_center", locals: { columns: 8 }) do %>
|
|
8
8
|
<div class="flex justify-center">
|
|
9
9
|
<h1 class="title-decorator my-12"><%= t("decidim.devise.registrations.new.sign_up") %></h1>
|
|
10
10
|
</div>
|
|
@@ -23,8 +23,6 @@
|
|
|
23
23
|
<%= form_required_explanation %>
|
|
24
24
|
</div>
|
|
25
25
|
|
|
26
|
-
<span class="login__info-separator"></span>
|
|
27
|
-
|
|
28
26
|
<% cache current_organization do %>
|
|
29
27
|
<%= render "decidim/devise/shared/omniauth_buttons" %>
|
|
30
28
|
<% end %>
|
|
@@ -32,7 +30,7 @@
|
|
|
32
30
|
<%= decidim_form_for(@form, namespace: "registration", as: resource_name, url: registration_path(resource_name), html: { id: "register-form" }) do |f| %>
|
|
33
31
|
<%= invisible_captcha %>
|
|
34
32
|
|
|
35
|
-
<div class="form__wrapper">
|
|
33
|
+
<div class="form__wrapper pb-12">
|
|
36
34
|
<%= f.text_field :name, help_text: t("decidim.devise.registrations.new.username_help"), autocomplete: "name", placeholder: "John Doe" %>
|
|
37
35
|
|
|
38
36
|
<%= f.email_field :email, autocomplete: "email", placeholder: t("placeholder_email", scope: "decidim.devise.shared") %>
|
|
@@ -40,32 +38,22 @@
|
|
|
40
38
|
<%= render partial: "decidim/account/password_fields", locals: { form: f, user: :user } %>
|
|
41
39
|
</div>
|
|
42
40
|
|
|
43
|
-
|
|
44
|
-
<h2 class="h4"><%= t("decidim.devise.registrations.new.tos_title") %></h2>
|
|
45
|
-
|
|
46
|
-
<div>
|
|
47
|
-
<% terms_of_service_summary_content_blocks.each do |content_block| %>
|
|
48
|
-
<%= cell content_block.manifest.cell, content_block %>
|
|
49
|
-
<% end %>
|
|
50
|
-
</div>
|
|
51
|
-
|
|
52
|
-
<%= f.check_box :tos_agreement, label: t("decidim.devise.registrations.new.tos_agreement", link: link_to(t("decidim.devise.registrations.new.terms"), page_path("terms-of-service"))), label_options: { class: "form__wrapper-checkbox-label" } %>
|
|
53
|
-
</div>
|
|
54
|
-
|
|
55
|
-
<div id="card__newsletter" class="form__wrapper-block">
|
|
56
|
-
<h2 class="h4"><%= t("decidim.devise.registrations.new.newsletter_title") %></h2>
|
|
57
|
-
<%= f.check_box :newsletter, label: t("decidim.devise.registrations.new.newsletter"), checked: @form.newsletter, label_options: { class: "form__wrapper-checkbox-label" } %>
|
|
58
|
-
</div>
|
|
41
|
+
<%= render partial: "decidim/devise/shared/tos_fields", locals: { form: f, user: :user } %>
|
|
59
42
|
|
|
60
43
|
<div class="form__wrapper-block">
|
|
61
44
|
<button type="submit" class="button button__lg button__secondary">
|
|
62
45
|
<%= t("decidim.devise.registrations.new.sign_up") %>
|
|
63
|
-
<%= icon "arrow-right-line", class: "fill-current" %>
|
|
64
46
|
</button>
|
|
65
47
|
</div>
|
|
66
48
|
|
|
67
49
|
<div class="login__links">
|
|
68
|
-
|
|
50
|
+
<%- if current_organization.sign_up_enabled? && devise_mapping.confirmable? && controller_name != "confirmations" %>
|
|
51
|
+
<%= link_to t("devise.shared.links.didn_t_receive_confirmation_instructions"), new_confirmation_path(resource_name) %>
|
|
52
|
+
<% end -%>
|
|
53
|
+
|
|
54
|
+
<%- if devise_mapping.lockable? && resource_class.unlock_strategy_enabled?(:email) && controller_name != "unlocks" %>
|
|
55
|
+
<%= link_to t("devise.shared.links.didn_t_receive_unlock_instructions"), new_unlock_path(resource_name) %>
|
|
56
|
+
<% end -%>
|
|
69
57
|
</div>
|
|
70
58
|
<% end %>
|
|
71
59
|
<% end %>
|
|
@@ -1,32 +1,13 @@
|
|
|
1
1
|
<% add_decidim_page_title(t("devise.sessions.new.log_in")) %>
|
|
2
2
|
|
|
3
|
-
<%= render
|
|
3
|
+
<%= render(layout: "layouts/decidim/shared/layout_center", locals: { columns: 8 }) do %>
|
|
4
4
|
|
|
5
5
|
<div class="flex justify-center">
|
|
6
6
|
<h1 class="title-decorator my-12"><%= t("devise.sessions.new.log_in") %></h1>
|
|
7
7
|
</div>
|
|
8
8
|
|
|
9
|
-
<div class="login__info font-semibold">
|
|
10
|
-
<% if current_organization.sign_up_enabled? %>
|
|
11
|
-
<p>
|
|
12
|
-
<%= t("decidim.devise.sessions.new.are_you_new?") %>
|
|
13
|
-
<%= link_to t("decidim.devise.sessions.new.register"), new_user_registration_path %>
|
|
14
|
-
</p>
|
|
15
|
-
<% elsif current_organization.sign_in_enabled? %>
|
|
16
|
-
<p>
|
|
17
|
-
<%= t("decidim.devise.sessions.new.sign_up_disabled") %>
|
|
18
|
-
</p>
|
|
19
|
-
<% else %>
|
|
20
|
-
<p>
|
|
21
|
-
<%= t("decidim.devise.sessions.new.sign_in_disabled") %>
|
|
22
|
-
</p>
|
|
23
|
-
<% end %>
|
|
24
|
-
</div>
|
|
25
|
-
|
|
26
|
-
<span class="login__info-separator"></span>
|
|
27
|
-
|
|
28
9
|
<% cache current_organization do %>
|
|
29
|
-
<%= render "decidim/devise/shared/omniauth_buttons" %>
|
|
10
|
+
<%= render partial: "decidim/devise/shared/omniauth_buttons", locals: { is_horizontal: true } %>
|
|
30
11
|
<% end %>
|
|
31
12
|
|
|
32
13
|
<% if current_organization.sign_in_enabled? %>
|
|
@@ -36,22 +17,36 @@
|
|
|
36
17
|
|
|
37
18
|
<%= render partial: "decidim/account/password_fields", locals: { form: f } %>
|
|
38
19
|
|
|
39
|
-
|
|
40
|
-
|
|
20
|
+
</div>
|
|
21
|
+
<div class="login__modal-remember">
|
|
22
|
+
<% if devise_mapping.rememberable? %>
|
|
23
|
+
<%= f.check_box :remember_me, label_options: { class: "form__wrapper-checkbox-label" } %>
|
|
24
|
+
<%= link_to t("devise.shared.links.forgot_your_password"), new_password_path(:user), class: "sign-up-link" %>
|
|
25
|
+
<% end %>
|
|
26
|
+
</div>
|
|
27
|
+
|
|
28
|
+
<div class="login__info mb-10 flex justify-center font-semibold">
|
|
29
|
+
<% if current_organization.sign_up_enabled? %>
|
|
30
|
+
<p>
|
|
31
|
+
<%= t("decidim.devise.sessions.new.are_you_new?") %>
|
|
32
|
+
<%= link_to t("decidim.devise.sessions.new.register"), new_user_registration_path %>
|
|
33
|
+
</p>
|
|
34
|
+
<% elsif current_organization.sign_in_enabled? %>
|
|
35
|
+
<p>
|
|
36
|
+
<%= t("decidim.devise.sessions.new.sign_up_disabled") %>
|
|
37
|
+
</p>
|
|
38
|
+
<% else %>
|
|
39
|
+
<p>
|
|
40
|
+
<%= t("decidim.devise.sessions.new.sign_in_disabled") %>
|
|
41
|
+
</p>
|
|
41
42
|
<% end %>
|
|
42
43
|
</div>
|
|
43
44
|
|
|
44
45
|
<div class="form__wrapper-block">
|
|
45
46
|
<button type="submit" class="button button__lg button__secondary">
|
|
46
47
|
<%= t("devise.sessions.new.log_in") %>
|
|
47
|
-
<%= icon "arrow-right-line", class: "fill-current" %>
|
|
48
48
|
</button>
|
|
49
49
|
</div>
|
|
50
|
-
|
|
51
|
-
<div class="login__links">
|
|
52
|
-
<%= render "decidim/devise/shared/links" %>
|
|
53
|
-
</div>
|
|
54
50
|
<% end %>
|
|
55
|
-
|
|
56
51
|
<% end %>
|
|
57
52
|
<% end %>
|
|
@@ -2,12 +2,10 @@
|
|
|
2
2
|
<% if Devise.mappings[:user].omniauthable? && current_organization.enabled_omniauth_providers.any? %>
|
|
3
3
|
<div class="login__omniauth<%= " login__omniauth__horizontal" if is_horizontal %>">
|
|
4
4
|
<%- current_organization.enabled_omniauth_providers.keys.each do |provider| %>
|
|
5
|
-
<% link_classes = "login__omniauth-button button--#{normalize_provider_name(provider)}" %>
|
|
5
|
+
<% link_classes = "login__omniauth-button login__omniauth-button--#{normalize_provider_name(provider)}" %>
|
|
6
6
|
<%= link_to decidim.send("user_#{provider}_omniauth_authorize_path"), class: link_classes, method: :post, title: t("devise.shared.links.log_in_with_provider", provider: normalize_provider_name(provider).titleize) do %>
|
|
7
7
|
<%= oauth_icon provider %>
|
|
8
|
-
<span>
|
|
9
|
-
<%= normalize_provider_name(provider).titleize %>
|
|
10
|
-
</span>
|
|
8
|
+
<span><%= t("devise.shared.links.log_in_with_provider", provider: normalize_provider_name(provider).titleize) %></span>
|
|
11
9
|
<% end %>
|
|
12
10
|
<% end %>
|
|
13
11
|
</div>
|