decidim-core 0.23.6 → 0.24.0.rc1
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 +2 -2
- data/app/assets/images/decidim/icons.svg +1 -1
- data/app/assets/javascripts/decidim/core/bundle.js +1 -1
- data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
- data/app/assets/javascripts/decidim/editor/history_override.js.es6 +117 -0
- data/app/assets/javascripts/decidim/editor/linebreak_module.js.es6 +83 -0
- data/app/assets/javascripts/decidim/editor/modified_backspace_offset1.js.es6 +98 -0
- data/app/assets/javascripts/decidim/editor/modified_backspace_offset_any.js.es6 +48 -0
- data/app/assets/javascripts/decidim/editor/modified_backspace_utils.js.es6 +31 -0
- data/app/assets/javascripts/decidim/editor/modified_enter.js.es6 +118 -0
- data/app/assets/javascripts/decidim/editor.js.es6 +15 -4
- data/app/assets/javascripts/decidim/form_filter.component.js.es6 +25 -0
- data/app/assets/javascripts/decidim/geocoding/attach_input.js.es6 +41 -4
- data/app/assets/javascripts/decidim/input_character_counter.js.es6 +6 -1
- data/app/assets/javascripts/decidim/map/controller/markers.js.es6 +27 -9
- data/app/assets/javascripts/decidim/session_timeouter.js.es6 +78 -0
- data/app/assets/javascripts/decidim.js.es6 +1 -0
- data/app/assets/stylesheets/decidim/_variables.scss +9 -0
- data/app/assets/stylesheets/decidim/email.scss +14 -2
- data/app/assets/stylesheets/decidim/extras/_external-links.scss +0 -1
- data/app/assets/stylesheets/decidim/extras/_process_stats.scss +1 -1
- data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +1 -0
- data/app/assets/stylesheets/decidim/modules/_author-avatar.scss +2 -2
- data/app/assets/stylesheets/decidim/modules/_buttons.scss +2 -2
- data/app/assets/stylesheets/decidim/modules/_cards.scss +18 -1
- data/app/assets/stylesheets/decidim/modules/_collapsible-list.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_comments.scss +5 -1
- data/app/assets/stylesheets/decidim/modules/_conference-speaker.scss +4 -3
- data/app/assets/stylesheets/decidim/modules/_data-picker.scss +7 -0
- data/app/assets/stylesheets/decidim/modules/_extra.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_forms.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_loading-spinner.scss +34 -0
- data/app/assets/stylesheets/decidim/modules/_modules.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_opinion-toggle.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_reveal.scss +6 -0
- data/app/assets/stylesheets/decidim/modules/_signup.scss +1 -0
- data/app/assets/stylesheets/decidim/modules/{_process-stats.scss → _space-stats.scss} +1 -1
- data/app/cells/decidim/activity/show.erb +1 -1
- data/app/cells/decidim/activity_cell.rb +11 -14
- data/app/cells/decidim/address/details.erb +5 -5
- data/app/cells/decidim/address_cell.rb +0 -21
- data/app/cells/decidim/announcement/show.erb +4 -4
- data/app/cells/decidim/announcement_cell.rb +22 -2
- data/app/cells/decidim/author/flag_user.erb +10 -0
- data/app/cells/decidim/author/profile_minicard.erb +1 -1
- data/app/cells/decidim/author_cell.rb +9 -1
- data/app/cells/decidim/card_m/top.erb +1 -1
- data/app/cells/decidim/card_m_cell.rb +1 -1
- data/app/cells/decidim/content_blocks/cta/show.erb +14 -0
- data/app/cells/decidim/content_blocks/cta_cell.rb +35 -0
- data/app/cells/decidim/content_blocks/cta_settings_form/show.erb +9 -0
- data/app/cells/decidim/content_blocks/cta_settings_form_cell.rb +13 -0
- data/app/cells/decidim/content_blocks/hero_cell.rb +14 -0
- data/app/cells/decidim/content_blocks/highlighted_elements/elements.erb +0 -0
- data/app/cells/decidim/content_blocks/highlighted_elements/heading.erb +0 -0
- data/app/cells/decidim/content_blocks/highlighted_elements/show.erb +4 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_cell.rb +51 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_settings_form/show.erb +3 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_settings_form_cell.rb +28 -0
- data/app/cells/decidim/content_blocks/last_activity_cell.rb +11 -0
- data/app/cells/decidim/content_blocks/metrics_cell.rb +0 -6
- data/app/cells/decidim/content_blocks/stats_cell.rb +0 -6
- data/app/cells/decidim/date/show.erb +31 -0
- data/app/cells/decidim/date_cell.rb +50 -0
- data/app/cells/decidim/endorsement_buttons_cell.rb +3 -3
- data/app/cells/decidim/flag_modal/flag_user.erb +24 -0
- data/app/cells/decidim/flag_modal/show.erb +24 -0
- data/app/cells/decidim/flag_modal_cell.rb +25 -0
- data/app/cells/decidim/profile/inaccessible.erb +9 -0
- data/app/cells/decidim/profile_cell.rb +9 -1
- data/app/cells/decidim/profile_sidebar/show.erb +10 -1
- data/app/cells/decidim/profile_sidebar_cell.rb +1 -0
- data/app/cells/decidim/reported_content/show.erb +5 -0
- data/app/cells/decidim/reported_content_cell.rb +44 -0
- data/app/cells/decidim/scopes_picker/scope_picker_prompt.erb +3 -0
- data/app/cells/decidim/scopes_picker/scope_picker_values.erb +5 -0
- data/app/cells/decidim/scopes_picker/show.erb +14 -0
- data/app/cells/decidim/scopes_picker_cell.rb +93 -0
- data/app/cells/decidim/tos_page/announcement.erb +1 -1
- data/app/cells/decidim/tos_page/form.erb +15 -13
- data/app/cells/decidim/tos_page_cell.rb +10 -8
- data/app/cells/decidim/translation_bar_cell.rb +1 -1
- data/app/cells/decidim/user_conversation/conversation_header.erb +1 -1
- data/app/cells/decidim/user_conversations_cell.rb +1 -1
- data/app/commands/decidim/create_report.rb +11 -1
- data/app/commands/decidim/create_user_report.rb +67 -0
- data/app/commands/decidim/destroy_account.rb +0 -2
- data/app/commands/decidim/gallery_methods.rb +2 -2
- data/app/commands/decidim/multiple_attachments_methods.rb +14 -10
- data/app/commands/decidim/search.rb +5 -2
- data/app/commands/decidim/update_notifications_settings.rb +1 -0
- data/app/commands/decidim/update_user_group.rb +1 -0
- data/app/controllers/concerns/decidim/devise_controllers.rb +1 -1
- data/app/controllers/concerns/decidim/flaggable.rb +5 -1
- data/app/controllers/concerns/decidim/force_authentication.rb +11 -3
- data/app/controllers/concerns/decidim/locale_switcher.rb +5 -0
- data/app/controllers/concerns/decidim/needs_permission.rb +7 -1
- data/app/controllers/concerns/decidim/orderable.rb +3 -1
- data/app/controllers/concerns/decidim/user_blocked_checker.rb +26 -0
- data/app/controllers/decidim/application_controller.rb +22 -0
- data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +3 -1
- data/app/controllers/decidim/devise/sessions_controller.rb +10 -6
- data/app/controllers/decidim/errors_controller.rb +1 -1
- data/app/controllers/decidim/locales_controller.rb +1 -1
- data/app/controllers/decidim/profiles_controller.rb +6 -0
- data/app/controllers/decidim/report_users_controller.rb +42 -0
- data/app/controllers/decidim/scopes_controller.rb +19 -10
- data/app/controllers/decidim/timeouts_controller.rb +28 -0
- data/app/controllers/decidim/user_activities_controller.rb +5 -0
- data/app/controllers/decidim/user_timeline_controller.rb +1 -0
- data/app/events/decidim/demoted_membership_event.rb +2 -2
- data/app/events/decidim/invited_to_group_event.rb +2 -2
- data/app/events/decidim/join_request_accepted_event.rb +2 -2
- data/app/events/decidim/join_request_created_event.rb +2 -2
- data/app/events/decidim/join_request_rejected_event.rb +2 -2
- data/app/events/decidim/promoted_to_admin_event.rb +2 -2
- data/app/events/decidim/removed_from_group_event.rb +2 -2
- data/app/forms/decidim/account_form.rb +2 -2
- data/app/forms/decidim/invite_user_form.rb +2 -2
- data/app/forms/decidim/messaging/conversation_form.rb +1 -1
- data/app/forms/decidim/messaging/message_form.rb +1 -1
- data/app/forms/decidim/notifications_settings_form.rb +20 -0
- data/app/forms/url_validator.rb +20 -0
- data/app/helpers/decidim/action_authorization_helper.rb +2 -0
- data/app/helpers/decidim/application_helper.rb +1 -3
- data/app/helpers/decidim/cells_helper.rb +6 -0
- data/app/helpers/decidim/filters_helper.rb +9 -0
- data/app/helpers/decidim/messaging/conversation_helper.rb +11 -1
- data/app/helpers/decidim/newsletters_helper.rb +7 -9
- data/app/helpers/decidim/scopes_helper.rb +1 -1
- data/app/jobs/decidim/block_user_job.rb +11 -0
- data/app/jobs/decidim/export_job.rb +2 -2
- data/app/jobs/decidim/find_and_update_descendants_job.rb +48 -0
- data/app/jobs/decidim/machine_translation_resource_job.rb +3 -0
- data/app/jobs/decidim/machine_translation_save_job.rb +29 -0
- data/app/jobs/decidim/update_search_indexes_job.rb +11 -0
- data/app/jobs/decidim/user_report_job.rb +11 -0
- data/app/mailers/decidim/block_user_mailer.rb +21 -0
- data/app/mailers/decidim/reported_mailer.rb +33 -3
- data/app/mailers/decidim/user_report_mailer.rb +21 -0
- data/app/models/decidim/area.rb +0 -1
- data/app/models/decidim/area_type.rb +1 -1
- data/app/models/decidim/attachment.rb +3 -2
- data/app/models/decidim/attachment_collection.rb +1 -1
- data/app/models/decidim/authorization.rb +4 -0
- data/app/models/decidim/category.rb +6 -1
- data/app/models/decidim/impersonation_log.rb +5 -7
- data/app/models/decidim/metric.rb +2 -2
- data/app/models/decidim/moderation.rb +12 -0
- data/app/models/decidim/organization.rb +5 -1
- data/app/models/decidim/scope.rb +5 -2
- data/app/models/decidim/scope_type.rb +1 -1
- data/app/models/decidim/share_token.rb +1 -1
- data/app/models/decidim/static_page.rb +11 -1
- data/app/models/decidim/static_page_topic.rb +4 -0
- data/app/models/decidim/user.rb +13 -8
- data/app/models/decidim/user_base_entity.rb +13 -13
- data/app/models/decidim/user_block.rb +10 -0
- data/app/models/decidim/user_group.rb +1 -4
- data/app/models/decidim/user_moderation.rb +22 -0
- data/app/models/decidim/user_report.rb +31 -0
- data/app/permissions/decidim/permissions.rb +1 -3
- data/app/permissions/decidim/report_user_permissions.rb +13 -0
- data/app/presenters/decidim/admin_log/impersonation_log_presenter.rb +39 -0
- data/app/presenters/decidim/admin_log/organization_presenter.rb +1 -2
- data/app/presenters/decidim/admin_log/user_moderation_presenter.rb +63 -0
- data/app/presenters/decidim/admin_log/user_presenter.rb +18 -9
- data/app/presenters/decidim/home_stats_presenter.rb +3 -3
- data/app/presenters/decidim/log/diff_presenter.rb +4 -3
- data/app/presenters/decidim/log/resource_presenter.rb +4 -4
- data/app/presenters/decidim/log/user_presenter.rb +1 -1
- data/app/presenters/decidim/menu_presenter.rb +12 -7
- data/app/presenters/decidim/nil_presenter.rb +0 -2
- data/app/presenters/decidim/user_presenter.rb +1 -1
- data/app/queries/decidim/metrics/blocked_users_metric_manage.rb +26 -0
- data/app/queries/decidim/metrics/followers_metric_manage.rb +3 -0
- data/app/queries/decidim/metrics/participants_metric_manage.rb +3 -0
- data/app/queries/decidim/metrics/reported_users_metric_manage.rb +26 -0
- data/app/queries/decidim/metrics/user_reports_metric_manage.rb +26 -0
- data/app/queries/decidim/user_groups/accepted_memberships.rb +1 -1
- data/app/queries/decidim/user_groups/admin_memberships.rb +1 -1
- data/app/queries/decidim/user_groups/member_memberships.rb +1 -1
- data/app/services/decidim/activity_search.rb +1 -3
- data/app/services/decidim/base_diff_renderer.rb +1 -1
- data/app/services/decidim/data_portability_exporter.rb +1 -0
- data/app/services/decidim/email_notification_generator.rb +2 -2
- data/app/services/decidim/events_manager.rb +1 -1
- data/app/services/decidim/open_data_exporter.rb +36 -7
- data/app/services/decidim/zip_stream/zip_stream_writer.rb +3 -3
- data/app/uploaders/decidim/application_uploader.rb +22 -2
- data/app/uploaders/decidim/attachment_uploader.rb +2 -4
- data/app/uploaders/decidim/downloader.rb +9 -0
- data/app/uploaders/decidim/image_uploader.rb +9 -21
- data/app/uploaders/decidim/open_data_uploader.rb +5 -0
- data/app/uploaders/decidim/record_image_uploader.rb +2 -2
- data/app/validators/etiquette_validator.rb +0 -7
- data/app/validators/uploader_content_type_validator.rb +4 -2
- data/app/views/decidim/application/_document.html.erb +1 -1
- data/app/views/decidim/block_user_mailer/notify.html.erb +7 -0
- data/app/views/decidim/devise/confirmations/new.html.erb +1 -1
- data/app/views/decidim/devise/registrations/edit.html.erb +1 -1
- data/app/views/decidim/devise/unlocks/new.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_conversation.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_messages.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_show.html.erb +4 -4
- data/app/views/decidim/notifications_settings/show.html.erb +11 -0
- data/app/views/decidim/pages/_standalone.html.erb +3 -1
- data/app/views/decidim/reported_mailer/report.html.erb +9 -17
- data/app/views/decidim/shared/_check_boxes_tree.html.erb +3 -3
- data/app/views/decidim/shared/_component_announcement.html.erb +2 -2
- data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +1 -1
- data/app/views/decidim/user_report_mailer/notify.html.erb +7 -0
- data/app/views/decidim/widgets/_data_picker.html.erb +1 -1
- data/app/views/layouts/decidim/_application.html.erb +1 -0
- data/app/views/layouts/decidim/_js_configuration.html.erb +1 -1
- data/app/views/layouts/decidim/_main_footer.html.erb +6 -4
- data/app/views/layouts/decidim/_timeout_modal.html.erb +21 -0
- data/config/initializers/active_support.rb +7 -0
- data/config/initializers/devise.rb +1 -1
- data/config/initializers/omniauth.rb +1 -1
- data/config/locales/ar.yml +1 -7
- data/config/locales/bg.yml +1 -13
- data/config/locales/ca.yml +46 -17
- data/config/locales/cs.yml +118 -53
- data/config/locales/de.yml +83 -18
- data/config/locales/el.yml +1 -14
- data/config/locales/en.yml +79 -14
- data/config/locales/eo.yml +0 -1
- data/config/locales/es-MX.yml +31 -14
- data/config/locales/es-PY.yml +31 -14
- data/config/locales/es.yml +34 -17
- data/config/locales/eu.yml +4 -10
- data/config/locales/fi-plain.yml +80 -16
- data/config/locales/fi.yml +85 -21
- data/config/locales/fr-CA.yml +79 -14
- data/config/locales/fr.yml +76 -11
- data/config/locales/gl.yml +1 -15
- data/config/locales/hu.yml +1 -12
- data/config/locales/id-ID.yml +1 -7
- data/config/locales/is-IS.yml +0 -9
- data/config/locales/it.yml +72 -19
- data/config/locales/ja.yml +1 -14
- data/config/locales/lv.yml +1 -12
- data/config/locales/nl.yml +38 -13
- data/config/locales/no.yml +7 -14
- data/config/locales/pl.yml +81 -14
- data/config/locales/pt-BR.yml +1 -7
- data/config/locales/pt.yml +1 -14
- data/config/locales/ro-RO.yml +15 -25
- data/config/locales/ru.yml +7 -12
- data/config/locales/sk.yml +2 -13
- data/config/locales/sr-CS.yml +0 -9
- data/config/locales/sv.yml +5 -27
- data/config/locales/tr-TR.yml +65 -14
- data/config/locales/uk.yml +7 -9
- data/config/locales/zh-CN.yml +1 -14
- data/config/routes.rb +9 -4
- data/db/migrate/20170713131206_add_admin_to_users.rb +1 -1
- data/db/migrate/20180206143340_fix_reference_for_all_resources.rb +2 -0
- data/db/migrate/20180314085339_rename_maximum_votes_per_proposal_to_threshold_per_proposal.rb +2 -2
- data/db/migrate/20200929171508_remove_show_statistics_from_organizations.rb +7 -0
- data/db/migrate/20201010124755_create_decidim_user_moderations.rb +12 -0
- data/db/migrate/20201010124756_create_decidim_user_reports.rb +16 -0
- data/db/migrate/20201010224433_add_suspension_fields_to_decidim_users.rb +8 -0
- data/db/migrate/20201011074641_create_decidim_user_suspensions.rb +14 -0
- data/db/migrate/20201011081626_add_current_suspension_id_to_decidim_users.rb +7 -0
- data/db/migrate/20201013071533_add_reported_content_to_moderations.rb +7 -0
- data/db/migrate/20201019074554_add_locale_to_moderation_reports.rb +7 -0
- data/db/migrate/20201127114444_encrypt_authorization_metadatas.rb +35 -0
- data/db/migrate/20201128130723_add_allow_public_access_to_static_pages.rb +17 -0
- data/db/migrate/20201218144706_update_table_block_user_functionality.rb +8 -0
- data/db/migrate/20201218145252_rename_decidim_user_fields_for_block_functionality.rb +9 -0
- data/db/migrate/20210208134328_add_email_on_moderations_to_users.rb +7 -0
- data/db/seeds.rb +14 -13
- data/lib/decidim/amendable.rb +3 -2
- data/{app/functions/decidim/core → lib/decidim/api/functions}/component_finder_base.rb +1 -1
- data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list.rb +4 -4
- data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list_base.rb +3 -1
- data/lib/decidim/api/functions/needs_api_default_order.rb +24 -0
- data/{app/functions/decidim/core → lib/decidim/api/functions}/needs_api_filter_and_order.rb +0 -0
- data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_finder_base.rb +2 -2
- data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_list_base.rb +3 -1
- data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_finder.rb +1 -4
- data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_list.rb +1 -3
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/base_input_filter.rb +0 -0
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/component_input_filter.rb +20 -22
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_hastaggable_input_filter.rb +1 -1
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_localized_input_filter.rb +3 -3
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_publishable_input_filter.rb +6 -6
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_timestamp_input_filter.rb +12 -12
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/participatory_space_input_filter.rb +0 -1
- data/lib/decidim/api/input_filters/user_entity_input_filter.rb +89 -0
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/base_input_sort.rb +3 -2
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/component_input_sort.rb +10 -11
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_endorsable_input_sort.rb +2 -4
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_localized_input_sort.rb +3 -3
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_publishable_input_sort.rb +1 -1
- data/lib/decidim/api/input_sorts/has_timestamp_input_sort.rb +12 -0
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/participatory_space_input_sort.rb +1 -1
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/user_entity_input_sort.rb +4 -4
- data/lib/decidim/api/{amendable_entity_interface.rb → interfaces/amendable_entity_interface.rb} +5 -5
- data/lib/decidim/api/interfaces/amendable_interface.rb +17 -0
- data/lib/decidim/api/{attachable_interface.rb → interfaces/attachable_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/author_interface.rb +32 -0
- data/lib/decidim/api/interfaces/authorable_interface.rb +23 -0
- data/lib/decidim/api/{categorizable_interface.rb → interfaces/categorizable_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/coauthorable_interface.rb +30 -0
- data/lib/decidim/api/interfaces/component_interface.rb +22 -0
- data/lib/decidim/api/interfaces/endorsable_interface.rb +19 -0
- data/lib/decidim/api/{fingerprint_interface.rb → interfaces/fingerprint_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/participatory_space_interface.rb +48 -0
- data/lib/decidim/api/interfaces/participatory_space_resourceable_interface.rb +25 -0
- data/lib/decidim/api/{scopable_interface.rb → interfaces/scopable_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/timestamps_interface.rb +15 -0
- data/lib/decidim/api/interfaces/traceable_interface.rb +14 -0
- data/lib/decidim/api/scalars/date_time_type.rb +17 -0
- data/lib/decidim/api/scalars/date_type.rb +17 -0
- data/lib/decidim/api/types/amendment_type.rb +19 -0
- data/lib/decidim/api/types/area_api_type.rb +16 -0
- data/lib/decidim/api/types/area_type_type.rb +13 -0
- data/lib/decidim/api/types/attachment_type.rb +13 -0
- data/lib/decidim/api/types/category_type.rb +14 -0
- data/{app/types/decidim/core → lib/decidim/api/types}/component_type.rb +2 -4
- data/lib/decidim/api/types/coordinates_type.rb +21 -0
- data/lib/decidim/api/types/decidim_type.rb +13 -0
- data/lib/decidim/api/types/fingerprint_type.rb +12 -0
- data/lib/decidim/api/types/hashtag_type.rb +13 -0
- data/lib/decidim/api/types/localized_string_type.rb +13 -0
- data/lib/decidim/api/types/metric_history_type.rb +18 -0
- data/lib/decidim/api/types/metric_type.rb +13 -0
- data/lib/decidim/api/types/organization_type.rb +17 -0
- data/lib/decidim/api/types/participatory_space_link_type.rb +22 -0
- data/lib/decidim/api/types/participatory_space_type.rb +10 -0
- data/lib/decidim/api/types/scope_api_type.rb +16 -0
- data/lib/decidim/api/types/session_type.rb +22 -0
- data/lib/decidim/api/types/statistic_type.rb +20 -0
- data/lib/decidim/api/types/trace_version_type.rb +21 -0
- data/lib/decidim/api/types/translated_field_type.rb +36 -0
- data/lib/decidim/api/types/user_group_type.rb +64 -0
- data/lib/decidim/api/types/user_type.rb +67 -0
- data/lib/decidim/attachment_attributes.rb +57 -0
- data/lib/decidim/attributes/clean_string.rb +37 -0
- data/lib/decidim/attributes.rb +1 -0
- data/lib/decidim/coauthorable.rb +3 -3
- data/lib/decidim/component_manifest.rb +17 -0
- data/lib/decidim/content_block_manifest.rb +1 -1
- data/lib/decidim/content_parsers/hashtag_parser.rb +3 -6
- data/lib/decidim/content_parsers/user_group_parser.rb +2 -5
- data/lib/decidim/content_parsers/user_parser.rb +2 -5
- data/lib/decidim/content_processor.rb +1 -1
- data/lib/decidim/content_renderers/hashtag_renderer.rb +3 -6
- data/lib/decidim/core/api.rb +71 -16
- data/lib/decidim/core/engine.rb +35 -6
- data/lib/decidim/core/test/factories.rb +53 -15
- data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/amendment_accepted_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/amendment_promoted_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/amendment_rejected_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/categorizable_interface_examples.rb +6 -14
- data/lib/decidim/core/test/shared_examples/comments_examples.rb +11 -9
- data/lib/decidim/core/test/shared_examples/component_type.rb +1 -1
- data/lib/decidim/core/test/shared_examples/controller_render_views.rb +28 -0
- data/lib/decidim/core/test/shared_examples/follows_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/logo_email.rb +1 -1
- data/lib/decidim/core/test/shared_examples/map_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/process_announcements_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/reportable.rb +8 -0
- data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/searchable_participatory_space_examples.rb +2 -3
- data/lib/decidim/core/test/shared_examples/searchable_results_examples.rb +46 -0
- data/lib/decidim/core/test/shared_examples/static_pages_examples.rb +43 -0
- data/lib/decidim/core/test.rb +2 -0
- data/lib/decidim/core/version.rb +1 -1
- data/lib/decidim/core.rb +11 -3
- data/lib/decidim/diffy_extension.rb +2 -2
- data/lib/decidim/exporters/csv.rb +3 -2
- data/lib/decidim/exporters/export_data.rb +1 -1
- data/lib/decidim/faker/internet.rb +17 -0
- data/lib/decidim/faker/localized.rb +43 -20
- data/lib/decidim/file_validator_humanizer.rb +6 -4
- data/lib/decidim/form_builder.rb +33 -22
- data/lib/decidim/gamification/badge_scorer.rb +3 -2
- data/lib/decidim/gamification/base_event.rb +2 -2
- data/lib/decidim/geocodable.rb +2 -0
- data/lib/decidim/has_category.rb +1 -1
- data/lib/decidim/has_private_users.rb +1 -1
- data/lib/decidim/importers/import_manifest.rb +36 -0
- data/lib/decidim/map/autocomplete.rb +11 -1
- data/lib/decidim/metric_operation.rb +5 -6
- data/lib/decidim/participatory_space_resourceable.rb +1 -3
- data/lib/decidim/query_extensions.rb +90 -69
- data/lib/decidim/randomable.rb +6 -1
- data/lib/decidim/record_encryptor.rb +131 -0
- data/lib/decidim/reportable.rb +26 -0
- data/lib/decidim/resource_manifest.rb +3 -0
- data/lib/decidim/resourceable.rb +6 -6
- data/lib/decidim/scopable.rb +1 -1
- data/lib/decidim/search_resource_fields_mapper.rb +1 -1
- data/lib/decidim/searchable.rb +9 -0
- data/lib/decidim/settings_manifest.rb +2 -1
- data/lib/decidim/shareable_with_token.rb +0 -1
- data/lib/decidim/translatable_attributes.rb +2 -1
- data/lib/decidim/translatable_resource.rb +10 -0
- data/lib/decidim/user_reportable.rb +33 -0
- data/lib/decidim/view_model.rb +26 -0
- data/lib/premailer/adapter/decidim.rb +4 -4
- data/lib/tasks/decidim_data_portability_tasks.rake +4 -4
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.ko.js +18 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.vi.js +14 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-CN.js +14 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-TW.js +14 -0
- metadata +190 -95
- data/app/functions/decidim/core/participatory_space_finder.rb +0 -11
- data/app/functions/decidim/core/participatory_space_list.rb +0 -11
- data/app/helpers/decidim/cache_helper.rb +0 -14
- data/app/types/decidim/core/amendment_type.rb +0 -26
- data/app/types/decidim/core/area_api_type.rb +0 -16
- data/app/types/decidim/core/area_type_type.rb +0 -14
- data/app/types/decidim/core/attachment_type.rb +0 -14
- data/app/types/decidim/core/category_type.rb +0 -16
- data/app/types/decidim/core/coordinates_type.rb +0 -19
- data/app/types/decidim/core/date_time_type.rb +0 -12
- data/app/types/decidim/core/date_type.rb +0 -13
- data/app/types/decidim/core/decidim_type.rb +0 -19
- data/app/types/decidim/core/fingerprint_type.rb +0 -15
- data/app/types/decidim/core/has_timestamp_input_sort.rb +0 -12
- data/app/types/decidim/core/hashtag_type.rb +0 -13
- data/app/types/decidim/core/localized_string_type.rb +0 -14
- data/app/types/decidim/core/metric_history_type.rb +0 -17
- data/app/types/decidim/core/metric_type.rb +0 -14
- data/app/types/decidim/core/organization_type.rb +0 -20
- data/app/types/decidim/core/participatory_space_link_type.rb +0 -24
- data/app/types/decidim/core/participatory_space_type.rb +0 -12
- data/app/types/decidim/core/scope_api_type.rb +0 -16
- data/app/types/decidim/core/session_type.rb +0 -19
- data/app/types/decidim/core/statistic_type.rb +0 -22
- data/app/types/decidim/core/trace_version_type.rb +0 -29
- data/app/types/decidim/core/translated_field_type.rb +0 -45
- data/app/types/decidim/core/user_entity_input_filter.rb +0 -81
- data/app/types/decidim/core/user_group_type.rb +0 -51
- data/app/types/decidim/core/user_type.rb +0 -52
- data/app/views/decidim/shared/_announcement.html.erb +0 -1
- data/app/views/decidim/shared/_flag_modal.html.erb +0 -20
- data/db/migrate/20210302150803_invalidate_all_sessions_for_deleted_users.rb +0 -11
- data/lib/decidim/api/amendable_interface.rb +0 -18
- data/lib/decidim/api/author_interface.rb +0 -29
- data/lib/decidim/api/authorable_interface.rb +0 -22
- data/lib/decidim/api/coauthorable_interface.rb +0 -29
- data/lib/decidim/api/component_interface.rb +0 -20
- data/lib/decidim/api/endorsable_interface.rb +0 -22
- data/lib/decidim/api/participatory_space_interface.rb +0 -47
- data/lib/decidim/api/participatory_space_resourceable_interface.rb +0 -21
- data/lib/decidim/api/timestamps_interface.rb +0 -21
- data/lib/decidim/api/traceable_interface.rb +0 -14
@@ -26,6 +26,11 @@
|
|
26
26
|
$(`#${this.config.popupTemplateId}`).html()
|
27
27
|
);
|
28
28
|
|
29
|
+
const updateCoordinates = (data) => {
|
30
|
+
$('input[data-type="latitude"]').val(data.lat);
|
31
|
+
$('input[data-type="longitude"]').val(data.lng);
|
32
|
+
};
|
33
|
+
|
29
34
|
const bounds = new L.LatLngBounds(
|
30
35
|
markersData.map(
|
31
36
|
(markerData) => [markerData.latitude, markerData.longitude]
|
@@ -36,17 +41,30 @@
|
|
36
41
|
let marker = L.marker([markerData.latitude, markerData.longitude], {
|
37
42
|
icon: this.createIcon(),
|
38
43
|
keyboard: true,
|
39
|
-
title: markerData.title
|
44
|
+
title: markerData.title,
|
45
|
+
draggable: markerData.draggable
|
40
46
|
});
|
41
|
-
let node = document.createElement("div");
|
42
47
|
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
48
|
+
if (markerData.draggable) {
|
49
|
+
updateCoordinates({
|
50
|
+
lat: markerData.latitude,
|
51
|
+
lng: markerData.longitude
|
52
|
+
});
|
53
|
+
marker.on("drag", (ev) => {
|
54
|
+
updateCoordinates(ev.target.getLatLng());
|
55
|
+
});
|
56
|
+
} else {
|
57
|
+
let node = document.createElement("div");
|
58
|
+
|
59
|
+
$.tmpl(this.config.popupTemplateId, markerData).appendTo(node);
|
60
|
+
|
61
|
+
marker.bindPopup(node, {
|
62
|
+
maxwidth: 640,
|
63
|
+
minWidth: 500,
|
64
|
+
keepInView: true,
|
65
|
+
className: "map-info"
|
66
|
+
}).openPopup();
|
67
|
+
}
|
50
68
|
|
51
69
|
this.markerClusters.addLayer(marker);
|
52
70
|
});
|
@@ -0,0 +1,78 @@
|
|
1
|
+
((exports) => {
|
2
|
+
exports.$(() => {
|
3
|
+
const Foundation = exports.Foundation;
|
4
|
+
const $timeoutModal = $("#timeoutModal");
|
5
|
+
const timeoutInSeconds = parseInt($timeoutModal.data("session-timeout"), 10);
|
6
|
+
const secondsUntilTimeoutPath = $timeoutModal.data("seconds-until-timeout-path");
|
7
|
+
const interval = $timeoutModal.data("session-timeouter-interval");
|
8
|
+
let endsAt = exports.moment().add(timeoutInSeconds, "seconds");
|
9
|
+
const popup = new Foundation.Reveal($timeoutModal);
|
10
|
+
const $continueSessionButton = $("#continueSession");
|
11
|
+
|
12
|
+
// Ajax request is made at timeout_modal.html.erb
|
13
|
+
$continueSessionButton.on("click", () => {
|
14
|
+
$("#timeoutModal").foundation("close")
|
15
|
+
// In admin panel we have to hide all overlays
|
16
|
+
$(".reveal-overlay").css("display", "none");
|
17
|
+
})
|
18
|
+
|
19
|
+
if (!timeoutInSeconds) {
|
20
|
+
return;
|
21
|
+
}
|
22
|
+
|
23
|
+
const setTimer = (secondsUntilExpiration) => {
|
24
|
+
if (!secondsUntilExpiration) {
|
25
|
+
return;
|
26
|
+
}
|
27
|
+
endsAt = exports.moment().add(secondsUntilExpiration, "seconds")
|
28
|
+
}
|
29
|
+
|
30
|
+
const sessionTimeLeft = () => {
|
31
|
+
return $.ajax({
|
32
|
+
method: "GET",
|
33
|
+
url: secondsUntilTimeoutPath,
|
34
|
+
contentType: "application/json",
|
35
|
+
headers: {
|
36
|
+
"X-CSRF-Token": $("meta[name=csrf-token]").attr("content")
|
37
|
+
}
|
38
|
+
})
|
39
|
+
}
|
40
|
+
|
41
|
+
const exitInterval = setInterval(() => {
|
42
|
+
const diff = endsAt - exports.moment();
|
43
|
+
const diffInSeconds = Math.round(diff / 1000);
|
44
|
+
if (diffInSeconds > 150) {
|
45
|
+
return;
|
46
|
+
}
|
47
|
+
|
48
|
+
sessionTimeLeft().then((result) => {
|
49
|
+
const secondsUntilSessionExpires = result.seconds_remaining;
|
50
|
+
setTimer(secondsUntilSessionExpires)
|
51
|
+
|
52
|
+
if (secondsUntilSessionExpires <= 90) {
|
53
|
+
$timeoutModal.find("#reveal-hidden-sign-out")[0].click();
|
54
|
+
} else if (secondsUntilSessionExpires <= 150) {
|
55
|
+
popup.open();
|
56
|
+
}
|
57
|
+
});
|
58
|
+
}, interval);
|
59
|
+
|
60
|
+
// Devise restarts its own timer on ajax requests,
|
61
|
+
// so here we restart our.
|
62
|
+
$(document).on("ajax:complete", () => {
|
63
|
+
setTimer(timeoutInSeconds);
|
64
|
+
});
|
65
|
+
|
66
|
+
$(document).ajaxComplete((_event, _xhr, settings) => {
|
67
|
+
if (settings && settings.url === secondsUntilTimeoutPath) {
|
68
|
+
return;
|
69
|
+
}
|
70
|
+
setTimer(timeoutInSeconds);
|
71
|
+
});
|
72
|
+
|
73
|
+
window.addEventListener("beforeunload", () => {
|
74
|
+
clearInterval(exitInterval);
|
75
|
+
return;
|
76
|
+
});
|
77
|
+
})
|
78
|
+
})(window)
|
@@ -1091,7 +1091,7 @@ a{
|
|
1091
1091
|
}
|
1092
1092
|
|
1093
1093
|
a:hover{
|
1094
|
-
color:
|
1094
|
+
color: var(--secondary);
|
1095
1095
|
}
|
1096
1096
|
|
1097
1097
|
a:active{
|
@@ -1246,7 +1246,13 @@ table.button.large table a{
|
|
1246
1246
|
|
1247
1247
|
table.button.expand,
|
1248
1248
|
table.button.expanded{
|
1249
|
-
width: 100
|
1249
|
+
width: 100%;
|
1250
|
+
}
|
1251
|
+
|
1252
|
+
// Fix for Outlook to center the button
|
1253
|
+
table.button.expand > tr > td,
|
1254
|
+
table.button.expanded > tr > td{
|
1255
|
+
text-align: center;
|
1250
1256
|
}
|
1251
1257
|
|
1252
1258
|
table.button.expand table,
|
@@ -1255,6 +1261,12 @@ table.button.expanded table{
|
|
1255
1261
|
margin: auto;
|
1256
1262
|
}
|
1257
1263
|
|
1264
|
+
// Fix for Outlook to center the button link text
|
1265
|
+
table.button.expand table > tr > td,
|
1266
|
+
table.button.expanded table > tr > td{
|
1267
|
+
text-align: center;
|
1268
|
+
}
|
1269
|
+
|
1258
1270
|
table.button.expand table a,
|
1259
1271
|
table.button.expanded table a{
|
1260
1272
|
text-align: center;
|
@@ -11,13 +11,13 @@ $author-data-color: $muted;
|
|
11
11
|
@include flex;
|
12
12
|
@include flex-align($x: left, $y: middle);
|
13
13
|
|
14
|
-
color:
|
14
|
+
color: var(--secondary);
|
15
15
|
font-size: .9rem;
|
16
16
|
padding-left: 30px;
|
17
17
|
position: relative;
|
18
18
|
|
19
19
|
.author__name{
|
20
|
-
color:
|
20
|
+
color: var(--secondary);
|
21
21
|
margin-bottom: 0;
|
22
22
|
}
|
23
23
|
|
@@ -339,7 +339,7 @@
|
|
339
339
|
background-color: $muted;
|
340
340
|
|
341
341
|
&:hover{
|
342
|
-
background-color: var(--
|
342
|
+
background-color: var(--primary);
|
343
343
|
}
|
344
344
|
|
345
345
|
&.hollow{
|
@@ -371,7 +371,7 @@
|
|
371
371
|
|
372
372
|
.link{
|
373
373
|
cursor: pointer;
|
374
|
-
color:
|
374
|
+
color: var(--secondary);
|
375
375
|
font-weight: 600;
|
376
376
|
|
377
377
|
&:hover{
|
@@ -89,6 +89,10 @@ a .card__title{
|
|
89
89
|
.card__header{
|
90
90
|
margin-bottom: $card-padding / 2;
|
91
91
|
|
92
|
+
.card__title{
|
93
|
+
margin-bottom: .5rem;
|
94
|
+
}
|
95
|
+
|
92
96
|
&.collapse{
|
93
97
|
margin-bottom: 0;
|
94
98
|
}
|
@@ -957,6 +961,7 @@ a .card__title{
|
|
957
961
|
font-size: $global-font-size;
|
958
962
|
text-transform: none;
|
959
963
|
justify-content: left;
|
964
|
+
flex-direction: row;
|
960
965
|
|
961
966
|
strong{
|
962
967
|
text-transform: uppercase;
|
@@ -1090,12 +1095,24 @@ a .card__title{
|
|
1090
1095
|
@include flex;
|
1091
1096
|
@include flex-align($x: left, $y: null);
|
1092
1097
|
|
1098
|
+
flex-direction: column;
|
1099
|
+
|
1100
|
+
@include breakpoint(medium){
|
1101
|
+
flex-direction: row;
|
1102
|
+
}
|
1103
|
+
|
1093
1104
|
> *{
|
1094
1105
|
padding: $global-margin;
|
1095
1106
|
flex: 0 0 25%;
|
1096
1107
|
|
1097
1108
|
&:not(:nth-child(4n)){
|
1098
|
-
border-right:
|
1109
|
+
border-right: 0;
|
1110
|
+
border-bottom: $card-border;
|
1111
|
+
|
1112
|
+
@include breakpoint(medium){
|
1113
|
+
border-bottom: 0;
|
1114
|
+
border-right: $card-border;
|
1115
|
+
}
|
1099
1116
|
}
|
1100
1117
|
}
|
1101
1118
|
}
|
@@ -113,6 +113,10 @@ $comment-form-bg: $light-gray;
|
|
113
113
|
color: $white;
|
114
114
|
outline: none;
|
115
115
|
}
|
116
|
+
|
117
|
+
form.button_to{
|
118
|
+
display: inline-block;
|
119
|
+
}
|
116
120
|
}
|
117
121
|
|
118
122
|
.comment__votes--up{
|
@@ -207,7 +211,7 @@ $comment-form-bg: $light-gray;
|
|
207
211
|
}
|
208
212
|
|
209
213
|
a:focus{
|
210
|
-
background-color:
|
214
|
+
background-color: var(--secondary);
|
211
215
|
color: $white;
|
212
216
|
outline: none;
|
213
217
|
}
|
@@ -78,9 +78,10 @@
|
|
78
78
|
@include breakpoint(medium){
|
79
79
|
position: relative;
|
80
80
|
|
81
|
-
&:nth-of-type(
|
82
|
-
&:nth-of-type(4n +
|
83
|
-
|
81
|
+
&:nth-of-type(4) .speaker-bio,
|
82
|
+
&:nth-of-type(4n + 5) .speaker-bio,
|
83
|
+
&:nth-of-type(5n) .speaker-bio,{
|
84
|
+
transform: translateY(-10%) translateX(-60%);
|
84
85
|
}
|
85
86
|
}
|
86
87
|
}
|
@@ -10,3 +10,37 @@
|
|
10
10
|
vertical-align: middle;
|
11
11
|
}
|
12
12
|
}
|
13
|
+
|
14
|
+
.spinner-container{
|
15
|
+
position: relative;
|
16
|
+
cursor: wait;
|
17
|
+
|
18
|
+
&::before{
|
19
|
+
content: " ";
|
20
|
+
position: absolute;
|
21
|
+
top: 0;
|
22
|
+
left: 0;
|
23
|
+
width: 100%;
|
24
|
+
height: 100%;
|
25
|
+
background-color: rgba($white, .8);
|
26
|
+
z-index: 1;
|
27
|
+
}
|
28
|
+
|
29
|
+
&::after{
|
30
|
+
-webkit-animation: animation-spin 800ms infinite linear;
|
31
|
+
animation: animation-spin 800ms infinite linear;
|
32
|
+
width: 25px;
|
33
|
+
height: 25px;
|
34
|
+
box-sizing: border-box;
|
35
|
+
border-radius: 50%;
|
36
|
+
border: 3px solid #e8e8e8;
|
37
|
+
border-right-color: var(--primary);
|
38
|
+
display: inline-block;
|
39
|
+
position: absolute;
|
40
|
+
content: "";
|
41
|
+
vertical-align: middle;
|
42
|
+
z-index: 1;
|
43
|
+
top: 47%;
|
44
|
+
left: 47%;
|
45
|
+
}
|
46
|
+
}
|
@@ -52,6 +52,7 @@
|
|
52
52
|
@import "decidim/modules/versions";
|
53
53
|
@import "decidim/modules/sticky";
|
54
54
|
@import "decidim/modules/notification";
|
55
|
+
@import "decidim/modules/space-stats";
|
55
56
|
|
56
57
|
//Process elements
|
57
58
|
@import "decidim/modules/process-header";
|
@@ -64,7 +65,6 @@
|
|
64
65
|
@import "decidim/modules/inline-filters";
|
65
66
|
@import "decidim/modules/reference";
|
66
67
|
@import "decidim/modules/status-labels";
|
67
|
-
@import "decidim/modules/process-stats";
|
68
68
|
|
69
69
|
//Conference elements
|
70
70
|
@import "decidim/modules/conference-nav";
|
@@ -36,9 +36,10 @@ module Decidim
|
|
36
36
|
resource_title = resource.try(:resource_title) || resource.try(:title)
|
37
37
|
return if resource_title.blank?
|
38
38
|
|
39
|
-
|
39
|
+
case resource_title
|
40
|
+
when String
|
40
41
|
resource_title
|
41
|
-
|
42
|
+
when Hash
|
42
43
|
translated_attribute(resource_title)
|
43
44
|
end
|
44
45
|
end
|
@@ -50,9 +51,10 @@ module Decidim
|
|
50
51
|
resource_description = resource.try(:resource_description) || resource.try(:description)
|
51
52
|
return if resource_description.blank?
|
52
53
|
|
53
|
-
resource_description =
|
54
|
+
resource_description = case resource_description
|
55
|
+
when String
|
54
56
|
resource_description
|
55
|
-
|
57
|
+
when Hash
|
56
58
|
translated_attribute(resource_description)
|
57
59
|
end
|
58
60
|
|
@@ -66,7 +68,7 @@ module Decidim
|
|
66
68
|
|
67
69
|
# The text to show as the link to the resource.
|
68
70
|
def resource_link_text
|
69
|
-
translated_attribute(resource.title)
|
71
|
+
decidim_html_escape(translated_attribute(resource.title))
|
70
72
|
end
|
71
73
|
|
72
74
|
def created_at
|
@@ -82,12 +84,6 @@ module Decidim
|
|
82
84
|
model.user_lazy if resource.respond_to?(:user)
|
83
85
|
end
|
84
86
|
|
85
|
-
delegate :action, to: :model
|
86
|
-
|
87
|
-
def element_id
|
88
|
-
"action-#{model.id}"
|
89
|
-
end
|
90
|
-
|
91
87
|
private
|
92
88
|
|
93
89
|
def published?
|
@@ -107,9 +103,10 @@ module Decidim
|
|
107
103
|
def author
|
108
104
|
return unless show_author? && user.is_a?(UserBaseEntity)
|
109
105
|
|
110
|
-
presenter =
|
106
|
+
presenter = case user
|
107
|
+
when Decidim::User
|
111
108
|
UserPresenter.new(user)
|
112
|
-
|
109
|
+
when Decidim::UserGroup
|
113
110
|
UserGroupPresenter.new(user)
|
114
111
|
end
|
115
112
|
|
@@ -126,7 +123,7 @@ module Decidim
|
|
126
123
|
|
127
124
|
def participatory_space_link
|
128
125
|
link_to(
|
129
|
-
translated_attribute(participatory_space.title),
|
126
|
+
decidim_html_escape(translated_attribute(participatory_space.title)),
|
130
127
|
resource_locator(participatory_space).path
|
131
128
|
)
|
132
129
|
end
|
@@ -1,7 +1,7 @@
|
|
1
|
-
<% if
|
2
|
-
<strong><%= location %></strong><br>
|
1
|
+
<% if model.respond_to? :location %>
|
2
|
+
<strong><%= translated_attribute model.location %></strong><br>
|
3
3
|
<% end %>
|
4
|
-
<span><%= address %></span><br>
|
5
|
-
<% if
|
6
|
-
<span><%= location_hints %></span>
|
4
|
+
<span><%= model.address %></span><br>
|
5
|
+
<% if model.respond_to? :location_hints %>
|
6
|
+
<span><%= translated_attribute model.location_hints %></span>
|
7
7
|
<% end %>
|
@@ -5,32 +5,11 @@ module Decidim
|
|
5
5
|
class AddressCell < Decidim::ViewModel
|
6
6
|
include Cell::ViewModel::Partial
|
7
7
|
include LayoutHelper
|
8
|
-
include Decidim::SanitizeHelper
|
9
8
|
|
10
9
|
def details
|
11
10
|
render
|
12
11
|
end
|
13
12
|
|
14
|
-
def has_location?
|
15
|
-
model.respond_to?(:location)
|
16
|
-
end
|
17
|
-
|
18
|
-
def has_location_hints?
|
19
|
-
model.respond_to?(:location_hints)
|
20
|
-
end
|
21
|
-
|
22
|
-
def location_hints
|
23
|
-
decidim_sanitize(translated_attribute(model.location_hints))
|
24
|
-
end
|
25
|
-
|
26
|
-
def location
|
27
|
-
decidim_sanitize(translated_attribute(model.location))
|
28
|
-
end
|
29
|
-
|
30
|
-
def address
|
31
|
-
decidim_sanitize(translated_attribute(model.address))
|
32
|
-
end
|
33
|
-
|
34
13
|
private
|
35
14
|
|
36
15
|
def resource_icon
|
@@ -1,11 +1,11 @@
|
|
1
1
|
<div class="row column">
|
2
2
|
<%= content_tag :div, class: "callout announcement mb-sm #{callout_class} cell-announcement" do %>
|
3
|
-
<% if
|
4
|
-
<
|
3
|
+
<% if has_title? %>
|
4
|
+
<p class="heading2"><%= clean_title %></p>
|
5
5
|
|
6
|
-
|
6
|
+
<%= clean_body %>
|
7
7
|
<% else %>
|
8
|
-
<%=
|
8
|
+
<%= clean_announcement %>
|
9
9
|
<% end %>
|
10
10
|
<% end %>
|
11
11
|
</div>
|
@@ -22,12 +22,32 @@ module Decidim
|
|
22
22
|
|
23
23
|
private
|
24
24
|
|
25
|
+
def has_title?
|
26
|
+
announcement.is_a?(Hash) && announcement.has_key?(:title)
|
27
|
+
end
|
28
|
+
|
25
29
|
def callout_class
|
26
|
-
|
30
|
+
options[:callout_class] ||= "secondary"
|
27
31
|
end
|
28
32
|
|
29
33
|
def announcement
|
30
|
-
model
|
34
|
+
model
|
35
|
+
end
|
36
|
+
|
37
|
+
def clean_title
|
38
|
+
clean(announcement[:title])
|
39
|
+
end
|
40
|
+
|
41
|
+
def clean_body
|
42
|
+
Array(announcement[:body]).map { |paragraph| tag.p(clean(paragraph)) }.join("")
|
43
|
+
end
|
44
|
+
|
45
|
+
def clean_announcement
|
46
|
+
clean(announcement)
|
47
|
+
end
|
48
|
+
|
49
|
+
def clean(value)
|
50
|
+
decidim_sanitize(translated_attribute(value))
|
31
51
|
end
|
32
52
|
end
|
33
53
|
end
|
@@ -0,0 +1,10 @@
|
|
1
|
+
<% if user_flaggable? && model.try(:id) != current_user.try(:id) %>
|
2
|
+
<button type="button" class="link-alt" data-open="<%= current_user.present? ? "flagUserModal" : "loginModal" %>" title="<%= t("report", scope: "decidim.proposals.proposals.show") %>" aria-controls="<%= current_user.present? ? "flagUserModal" : "loginModal" %>" aria-haspopup="true" tabindex="0">
|
3
|
+
<%= icon "flag", aria_hidden: true, class: "icon--small", role: "img", "aria-hidden": true %>
|
4
|
+
<span class="show-for-sr">
|
5
|
+
<%= t("report", scope: "decidim.proposals.proposals.show") %>
|
6
|
+
</span>
|
7
|
+
</button>
|
8
|
+
|
9
|
+
<%= cell("decidim/flag_modal", model).flag_user %>
|
10
|
+
<% end %>
|
@@ -4,7 +4,7 @@
|
|
4
4
|
<%= cell("decidim/user_profile", raw_model).user_data %>
|
5
5
|
</div>
|
6
6
|
<div class="card__text card--picture-offset">
|
7
|
-
<%=
|
7
|
+
<%= text_link_to_current_or_new_conversation_with(model) %>
|
8
8
|
</div>
|
9
9
|
</div>
|
10
10
|
<div class="ml-s">
|