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.

Files changed (455) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -2
  3. data/app/assets/images/decidim/icons.svg +1 -1
  4. data/app/assets/javascripts/decidim/core/bundle.js +1 -1
  5. data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
  6. data/app/assets/javascripts/decidim/editor/history_override.js.es6 +117 -0
  7. data/app/assets/javascripts/decidim/editor/linebreak_module.js.es6 +83 -0
  8. data/app/assets/javascripts/decidim/editor/modified_backspace_offset1.js.es6 +98 -0
  9. data/app/assets/javascripts/decidim/editor/modified_backspace_offset_any.js.es6 +48 -0
  10. data/app/assets/javascripts/decidim/editor/modified_backspace_utils.js.es6 +31 -0
  11. data/app/assets/javascripts/decidim/editor/modified_enter.js.es6 +118 -0
  12. data/app/assets/javascripts/decidim/editor.js.es6 +15 -4
  13. data/app/assets/javascripts/decidim/form_filter.component.js.es6 +25 -0
  14. data/app/assets/javascripts/decidim/geocoding/attach_input.js.es6 +41 -4
  15. data/app/assets/javascripts/decidim/input_character_counter.js.es6 +6 -1
  16. data/app/assets/javascripts/decidim/map/controller/markers.js.es6 +27 -9
  17. data/app/assets/javascripts/decidim/session_timeouter.js.es6 +78 -0
  18. data/app/assets/javascripts/decidim.js.es6 +1 -0
  19. data/app/assets/stylesheets/decidim/_variables.scss +9 -0
  20. data/app/assets/stylesheets/decidim/email.scss +14 -2
  21. data/app/assets/stylesheets/decidim/extras/_external-links.scss +0 -1
  22. data/app/assets/stylesheets/decidim/extras/_process_stats.scss +1 -1
  23. data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +1 -0
  24. data/app/assets/stylesheets/decidim/modules/_author-avatar.scss +2 -2
  25. data/app/assets/stylesheets/decidim/modules/_buttons.scss +2 -2
  26. data/app/assets/stylesheets/decidim/modules/_cards.scss +18 -1
  27. data/app/assets/stylesheets/decidim/modules/_collapsible-list.scss +1 -1
  28. data/app/assets/stylesheets/decidim/modules/_comments.scss +5 -1
  29. data/app/assets/stylesheets/decidim/modules/_conference-speaker.scss +4 -3
  30. data/app/assets/stylesheets/decidim/modules/_data-picker.scss +7 -0
  31. data/app/assets/stylesheets/decidim/modules/_extra.scss +4 -0
  32. data/app/assets/stylesheets/decidim/modules/_forms.scss +4 -0
  33. data/app/assets/stylesheets/decidim/modules/_loading-spinner.scss +34 -0
  34. data/app/assets/stylesheets/decidim/modules/_modules.scss +1 -1
  35. data/app/assets/stylesheets/decidim/modules/_opinion-toggle.scss +1 -1
  36. data/app/assets/stylesheets/decidim/modules/_reveal.scss +6 -0
  37. data/app/assets/stylesheets/decidim/modules/_signup.scss +1 -0
  38. data/app/assets/stylesheets/decidim/modules/{_process-stats.scss → _space-stats.scss} +1 -1
  39. data/app/cells/decidim/activity/show.erb +1 -1
  40. data/app/cells/decidim/activity_cell.rb +11 -14
  41. data/app/cells/decidim/address/details.erb +5 -5
  42. data/app/cells/decidim/address_cell.rb +0 -21
  43. data/app/cells/decidim/announcement/show.erb +4 -4
  44. data/app/cells/decidim/announcement_cell.rb +22 -2
  45. data/app/cells/decidim/author/flag_user.erb +10 -0
  46. data/app/cells/decidim/author/profile_minicard.erb +1 -1
  47. data/app/cells/decidim/author_cell.rb +9 -1
  48. data/app/cells/decidim/card_m/top.erb +1 -1
  49. data/app/cells/decidim/card_m_cell.rb +1 -1
  50. data/app/cells/decidim/content_blocks/cta/show.erb +14 -0
  51. data/app/cells/decidim/content_blocks/cta_cell.rb +35 -0
  52. data/app/cells/decidim/content_blocks/cta_settings_form/show.erb +9 -0
  53. data/app/cells/decidim/content_blocks/cta_settings_form_cell.rb +13 -0
  54. data/app/cells/decidim/content_blocks/hero_cell.rb +14 -0
  55. data/app/cells/decidim/content_blocks/highlighted_elements/elements.erb +0 -0
  56. data/app/cells/decidim/content_blocks/highlighted_elements/heading.erb +0 -0
  57. data/app/cells/decidim/content_blocks/highlighted_elements/show.erb +4 -0
  58. data/app/cells/decidim/content_blocks/highlighted_elements_cell.rb +51 -0
  59. data/app/cells/decidim/content_blocks/highlighted_elements_settings_form/show.erb +3 -0
  60. data/app/cells/decidim/content_blocks/highlighted_elements_settings_form_cell.rb +28 -0
  61. data/app/cells/decidim/content_blocks/last_activity_cell.rb +11 -0
  62. data/app/cells/decidim/content_blocks/metrics_cell.rb +0 -6
  63. data/app/cells/decidim/content_blocks/stats_cell.rb +0 -6
  64. data/app/cells/decidim/date/show.erb +31 -0
  65. data/app/cells/decidim/date_cell.rb +50 -0
  66. data/app/cells/decidim/endorsement_buttons_cell.rb +3 -3
  67. data/app/cells/decidim/flag_modal/flag_user.erb +24 -0
  68. data/app/cells/decidim/flag_modal/show.erb +24 -0
  69. data/app/cells/decidim/flag_modal_cell.rb +25 -0
  70. data/app/cells/decidim/profile/inaccessible.erb +9 -0
  71. data/app/cells/decidim/profile_cell.rb +9 -1
  72. data/app/cells/decidim/profile_sidebar/show.erb +10 -1
  73. data/app/cells/decidim/profile_sidebar_cell.rb +1 -0
  74. data/app/cells/decidim/reported_content/show.erb +5 -0
  75. data/app/cells/decidim/reported_content_cell.rb +44 -0
  76. data/app/cells/decidim/scopes_picker/scope_picker_prompt.erb +3 -0
  77. data/app/cells/decidim/scopes_picker/scope_picker_values.erb +5 -0
  78. data/app/cells/decidim/scopes_picker/show.erb +14 -0
  79. data/app/cells/decidim/scopes_picker_cell.rb +93 -0
  80. data/app/cells/decidim/tos_page/announcement.erb +1 -1
  81. data/app/cells/decidim/tos_page/form.erb +15 -13
  82. data/app/cells/decidim/tos_page_cell.rb +10 -8
  83. data/app/cells/decidim/translation_bar_cell.rb +1 -1
  84. data/app/cells/decidim/user_conversation/conversation_header.erb +1 -1
  85. data/app/cells/decidim/user_conversations_cell.rb +1 -1
  86. data/app/commands/decidim/create_report.rb +11 -1
  87. data/app/commands/decidim/create_user_report.rb +67 -0
  88. data/app/commands/decidim/destroy_account.rb +0 -2
  89. data/app/commands/decidim/gallery_methods.rb +2 -2
  90. data/app/commands/decidim/multiple_attachments_methods.rb +14 -10
  91. data/app/commands/decidim/search.rb +5 -2
  92. data/app/commands/decidim/update_notifications_settings.rb +1 -0
  93. data/app/commands/decidim/update_user_group.rb +1 -0
  94. data/app/controllers/concerns/decidim/devise_controllers.rb +1 -1
  95. data/app/controllers/concerns/decidim/flaggable.rb +5 -1
  96. data/app/controllers/concerns/decidim/force_authentication.rb +11 -3
  97. data/app/controllers/concerns/decidim/locale_switcher.rb +5 -0
  98. data/app/controllers/concerns/decidim/needs_permission.rb +7 -1
  99. data/app/controllers/concerns/decidim/orderable.rb +3 -1
  100. data/app/controllers/concerns/decidim/user_blocked_checker.rb +26 -0
  101. data/app/controllers/decidim/application_controller.rb +22 -0
  102. data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +3 -1
  103. data/app/controllers/decidim/devise/sessions_controller.rb +10 -6
  104. data/app/controllers/decidim/errors_controller.rb +1 -1
  105. data/app/controllers/decidim/locales_controller.rb +1 -1
  106. data/app/controllers/decidim/profiles_controller.rb +6 -0
  107. data/app/controllers/decidim/report_users_controller.rb +42 -0
  108. data/app/controllers/decidim/scopes_controller.rb +19 -10
  109. data/app/controllers/decidim/timeouts_controller.rb +28 -0
  110. data/app/controllers/decidim/user_activities_controller.rb +5 -0
  111. data/app/controllers/decidim/user_timeline_controller.rb +1 -0
  112. data/app/events/decidim/demoted_membership_event.rb +2 -2
  113. data/app/events/decidim/invited_to_group_event.rb +2 -2
  114. data/app/events/decidim/join_request_accepted_event.rb +2 -2
  115. data/app/events/decidim/join_request_created_event.rb +2 -2
  116. data/app/events/decidim/join_request_rejected_event.rb +2 -2
  117. data/app/events/decidim/promoted_to_admin_event.rb +2 -2
  118. data/app/events/decidim/removed_from_group_event.rb +2 -2
  119. data/app/forms/decidim/account_form.rb +2 -2
  120. data/app/forms/decidim/invite_user_form.rb +2 -2
  121. data/app/forms/decidim/messaging/conversation_form.rb +1 -1
  122. data/app/forms/decidim/messaging/message_form.rb +1 -1
  123. data/app/forms/decidim/notifications_settings_form.rb +20 -0
  124. data/app/forms/url_validator.rb +20 -0
  125. data/app/helpers/decidim/action_authorization_helper.rb +2 -0
  126. data/app/helpers/decidim/application_helper.rb +1 -3
  127. data/app/helpers/decidim/cells_helper.rb +6 -0
  128. data/app/helpers/decidim/filters_helper.rb +9 -0
  129. data/app/helpers/decidim/messaging/conversation_helper.rb +11 -1
  130. data/app/helpers/decidim/newsletters_helper.rb +7 -9
  131. data/app/helpers/decidim/scopes_helper.rb +1 -1
  132. data/app/jobs/decidim/block_user_job.rb +11 -0
  133. data/app/jobs/decidim/export_job.rb +2 -2
  134. data/app/jobs/decidim/find_and_update_descendants_job.rb +48 -0
  135. data/app/jobs/decidim/machine_translation_resource_job.rb +3 -0
  136. data/app/jobs/decidim/machine_translation_save_job.rb +29 -0
  137. data/app/jobs/decidim/update_search_indexes_job.rb +11 -0
  138. data/app/jobs/decidim/user_report_job.rb +11 -0
  139. data/app/mailers/decidim/block_user_mailer.rb +21 -0
  140. data/app/mailers/decidim/reported_mailer.rb +33 -3
  141. data/app/mailers/decidim/user_report_mailer.rb +21 -0
  142. data/app/models/decidim/area.rb +0 -1
  143. data/app/models/decidim/area_type.rb +1 -1
  144. data/app/models/decidim/attachment.rb +3 -2
  145. data/app/models/decidim/attachment_collection.rb +1 -1
  146. data/app/models/decidim/authorization.rb +4 -0
  147. data/app/models/decidim/category.rb +6 -1
  148. data/app/models/decidim/impersonation_log.rb +5 -7
  149. data/app/models/decidim/metric.rb +2 -2
  150. data/app/models/decidim/moderation.rb +12 -0
  151. data/app/models/decidim/organization.rb +5 -1
  152. data/app/models/decidim/scope.rb +5 -2
  153. data/app/models/decidim/scope_type.rb +1 -1
  154. data/app/models/decidim/share_token.rb +1 -1
  155. data/app/models/decidim/static_page.rb +11 -1
  156. data/app/models/decidim/static_page_topic.rb +4 -0
  157. data/app/models/decidim/user.rb +13 -8
  158. data/app/models/decidim/user_base_entity.rb +13 -13
  159. data/app/models/decidim/user_block.rb +10 -0
  160. data/app/models/decidim/user_group.rb +1 -4
  161. data/app/models/decidim/user_moderation.rb +22 -0
  162. data/app/models/decidim/user_report.rb +31 -0
  163. data/app/permissions/decidim/permissions.rb +1 -3
  164. data/app/permissions/decidim/report_user_permissions.rb +13 -0
  165. data/app/presenters/decidim/admin_log/impersonation_log_presenter.rb +39 -0
  166. data/app/presenters/decidim/admin_log/organization_presenter.rb +1 -2
  167. data/app/presenters/decidim/admin_log/user_moderation_presenter.rb +63 -0
  168. data/app/presenters/decidim/admin_log/user_presenter.rb +18 -9
  169. data/app/presenters/decidim/home_stats_presenter.rb +3 -3
  170. data/app/presenters/decidim/log/diff_presenter.rb +4 -3
  171. data/app/presenters/decidim/log/resource_presenter.rb +4 -4
  172. data/app/presenters/decidim/log/user_presenter.rb +1 -1
  173. data/app/presenters/decidim/menu_presenter.rb +12 -7
  174. data/app/presenters/decidim/nil_presenter.rb +0 -2
  175. data/app/presenters/decidim/user_presenter.rb +1 -1
  176. data/app/queries/decidim/metrics/blocked_users_metric_manage.rb +26 -0
  177. data/app/queries/decidim/metrics/followers_metric_manage.rb +3 -0
  178. data/app/queries/decidim/metrics/participants_metric_manage.rb +3 -0
  179. data/app/queries/decidim/metrics/reported_users_metric_manage.rb +26 -0
  180. data/app/queries/decidim/metrics/user_reports_metric_manage.rb +26 -0
  181. data/app/queries/decidim/user_groups/accepted_memberships.rb +1 -1
  182. data/app/queries/decidim/user_groups/admin_memberships.rb +1 -1
  183. data/app/queries/decidim/user_groups/member_memberships.rb +1 -1
  184. data/app/services/decidim/activity_search.rb +1 -3
  185. data/app/services/decidim/base_diff_renderer.rb +1 -1
  186. data/app/services/decidim/data_portability_exporter.rb +1 -0
  187. data/app/services/decidim/email_notification_generator.rb +2 -2
  188. data/app/services/decidim/events_manager.rb +1 -1
  189. data/app/services/decidim/open_data_exporter.rb +36 -7
  190. data/app/services/decidim/zip_stream/zip_stream_writer.rb +3 -3
  191. data/app/uploaders/decidim/application_uploader.rb +22 -2
  192. data/app/uploaders/decidim/attachment_uploader.rb +2 -4
  193. data/app/uploaders/decidim/downloader.rb +9 -0
  194. data/app/uploaders/decidim/image_uploader.rb +9 -21
  195. data/app/uploaders/decidim/open_data_uploader.rb +5 -0
  196. data/app/uploaders/decidim/record_image_uploader.rb +2 -2
  197. data/app/validators/etiquette_validator.rb +0 -7
  198. data/app/validators/uploader_content_type_validator.rb +4 -2
  199. data/app/views/decidim/application/_document.html.erb +1 -1
  200. data/app/views/decidim/block_user_mailer/notify.html.erb +7 -0
  201. data/app/views/decidim/devise/confirmations/new.html.erb +1 -1
  202. data/app/views/decidim/devise/registrations/edit.html.erb +1 -1
  203. data/app/views/decidim/devise/unlocks/new.html.erb +1 -1
  204. data/app/views/decidim/messaging/conversations/_conversation.html.erb +1 -1
  205. data/app/views/decidim/messaging/conversations/_messages.html.erb +1 -1
  206. data/app/views/decidim/messaging/conversations/_show.html.erb +4 -4
  207. data/app/views/decidim/notifications_settings/show.html.erb +11 -0
  208. data/app/views/decidim/pages/_standalone.html.erb +3 -1
  209. data/app/views/decidim/reported_mailer/report.html.erb +9 -17
  210. data/app/views/decidim/shared/_check_boxes_tree.html.erb +3 -3
  211. data/app/views/decidim/shared/_component_announcement.html.erb +2 -2
  212. data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +1 -1
  213. data/app/views/decidim/user_report_mailer/notify.html.erb +7 -0
  214. data/app/views/decidim/widgets/_data_picker.html.erb +1 -1
  215. data/app/views/layouts/decidim/_application.html.erb +1 -0
  216. data/app/views/layouts/decidim/_js_configuration.html.erb +1 -1
  217. data/app/views/layouts/decidim/_main_footer.html.erb +6 -4
  218. data/app/views/layouts/decidim/_timeout_modal.html.erb +21 -0
  219. data/config/initializers/active_support.rb +7 -0
  220. data/config/initializers/devise.rb +1 -1
  221. data/config/initializers/omniauth.rb +1 -1
  222. data/config/locales/ar.yml +1 -7
  223. data/config/locales/bg.yml +1 -13
  224. data/config/locales/ca.yml +46 -17
  225. data/config/locales/cs.yml +118 -53
  226. data/config/locales/de.yml +83 -18
  227. data/config/locales/el.yml +1 -14
  228. data/config/locales/en.yml +79 -14
  229. data/config/locales/eo.yml +0 -1
  230. data/config/locales/es-MX.yml +31 -14
  231. data/config/locales/es-PY.yml +31 -14
  232. data/config/locales/es.yml +34 -17
  233. data/config/locales/eu.yml +4 -10
  234. data/config/locales/fi-plain.yml +80 -16
  235. data/config/locales/fi.yml +85 -21
  236. data/config/locales/fr-CA.yml +79 -14
  237. data/config/locales/fr.yml +76 -11
  238. data/config/locales/gl.yml +1 -15
  239. data/config/locales/hu.yml +1 -12
  240. data/config/locales/id-ID.yml +1 -7
  241. data/config/locales/is-IS.yml +0 -9
  242. data/config/locales/it.yml +72 -19
  243. data/config/locales/ja.yml +1 -14
  244. data/config/locales/lv.yml +1 -12
  245. data/config/locales/nl.yml +38 -13
  246. data/config/locales/no.yml +7 -14
  247. data/config/locales/pl.yml +81 -14
  248. data/config/locales/pt-BR.yml +1 -7
  249. data/config/locales/pt.yml +1 -14
  250. data/config/locales/ro-RO.yml +15 -25
  251. data/config/locales/ru.yml +7 -12
  252. data/config/locales/sk.yml +2 -13
  253. data/config/locales/sr-CS.yml +0 -9
  254. data/config/locales/sv.yml +5 -27
  255. data/config/locales/tr-TR.yml +65 -14
  256. data/config/locales/uk.yml +7 -9
  257. data/config/locales/zh-CN.yml +1 -14
  258. data/config/routes.rb +9 -4
  259. data/db/migrate/20170713131206_add_admin_to_users.rb +1 -1
  260. data/db/migrate/20180206143340_fix_reference_for_all_resources.rb +2 -0
  261. data/db/migrate/20180314085339_rename_maximum_votes_per_proposal_to_threshold_per_proposal.rb +2 -2
  262. data/db/migrate/20200929171508_remove_show_statistics_from_organizations.rb +7 -0
  263. data/db/migrate/20201010124755_create_decidim_user_moderations.rb +12 -0
  264. data/db/migrate/20201010124756_create_decidim_user_reports.rb +16 -0
  265. data/db/migrate/20201010224433_add_suspension_fields_to_decidim_users.rb +8 -0
  266. data/db/migrate/20201011074641_create_decidim_user_suspensions.rb +14 -0
  267. data/db/migrate/20201011081626_add_current_suspension_id_to_decidim_users.rb +7 -0
  268. data/db/migrate/20201013071533_add_reported_content_to_moderations.rb +7 -0
  269. data/db/migrate/20201019074554_add_locale_to_moderation_reports.rb +7 -0
  270. data/db/migrate/20201127114444_encrypt_authorization_metadatas.rb +35 -0
  271. data/db/migrate/20201128130723_add_allow_public_access_to_static_pages.rb +17 -0
  272. data/db/migrate/20201218144706_update_table_block_user_functionality.rb +8 -0
  273. data/db/migrate/20201218145252_rename_decidim_user_fields_for_block_functionality.rb +9 -0
  274. data/db/migrate/20210208134328_add_email_on_moderations_to_users.rb +7 -0
  275. data/db/seeds.rb +14 -13
  276. data/lib/decidim/amendable.rb +3 -2
  277. data/{app/functions/decidim/core → lib/decidim/api/functions}/component_finder_base.rb +1 -1
  278. data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list.rb +4 -4
  279. data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list_base.rb +3 -1
  280. data/lib/decidim/api/functions/needs_api_default_order.rb +24 -0
  281. data/{app/functions/decidim/core → lib/decidim/api/functions}/needs_api_filter_and_order.rb +0 -0
  282. data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_finder_base.rb +2 -2
  283. data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_list_base.rb +3 -1
  284. data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_finder.rb +1 -4
  285. data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_list.rb +1 -3
  286. data/{app/types/decidim/core → lib/decidim/api/input_filters}/base_input_filter.rb +0 -0
  287. data/{app/types/decidim/core → lib/decidim/api/input_filters}/component_input_filter.rb +20 -22
  288. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_hastaggable_input_filter.rb +1 -1
  289. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_localized_input_filter.rb +3 -3
  290. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_publishable_input_filter.rb +6 -6
  291. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_timestamp_input_filter.rb +12 -12
  292. data/{app/types/decidim/core → lib/decidim/api/input_filters}/participatory_space_input_filter.rb +0 -1
  293. data/lib/decidim/api/input_filters/user_entity_input_filter.rb +89 -0
  294. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/base_input_sort.rb +3 -2
  295. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/component_input_sort.rb +10 -11
  296. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_endorsable_input_sort.rb +2 -4
  297. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_localized_input_sort.rb +3 -3
  298. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_publishable_input_sort.rb +1 -1
  299. data/lib/decidim/api/input_sorts/has_timestamp_input_sort.rb +12 -0
  300. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/participatory_space_input_sort.rb +1 -1
  301. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/user_entity_input_sort.rb +4 -4
  302. data/lib/decidim/api/{amendable_entity_interface.rb → interfaces/amendable_entity_interface.rb} +5 -5
  303. data/lib/decidim/api/interfaces/amendable_interface.rb +17 -0
  304. data/lib/decidim/api/{attachable_interface.rb → interfaces/attachable_interface.rb} +3 -3
  305. data/lib/decidim/api/interfaces/author_interface.rb +32 -0
  306. data/lib/decidim/api/interfaces/authorable_interface.rb +23 -0
  307. data/lib/decidim/api/{categorizable_interface.rb → interfaces/categorizable_interface.rb} +3 -3
  308. data/lib/decidim/api/interfaces/coauthorable_interface.rb +30 -0
  309. data/lib/decidim/api/interfaces/component_interface.rb +22 -0
  310. data/lib/decidim/api/interfaces/endorsable_interface.rb +19 -0
  311. data/lib/decidim/api/{fingerprint_interface.rb → interfaces/fingerprint_interface.rb} +3 -3
  312. data/lib/decidim/api/interfaces/participatory_space_interface.rb +48 -0
  313. data/lib/decidim/api/interfaces/participatory_space_resourceable_interface.rb +25 -0
  314. data/lib/decidim/api/{scopable_interface.rb → interfaces/scopable_interface.rb} +3 -3
  315. data/lib/decidim/api/interfaces/timestamps_interface.rb +15 -0
  316. data/lib/decidim/api/interfaces/traceable_interface.rb +14 -0
  317. data/lib/decidim/api/scalars/date_time_type.rb +17 -0
  318. data/lib/decidim/api/scalars/date_type.rb +17 -0
  319. data/lib/decidim/api/types/amendment_type.rb +19 -0
  320. data/lib/decidim/api/types/area_api_type.rb +16 -0
  321. data/lib/decidim/api/types/area_type_type.rb +13 -0
  322. data/lib/decidim/api/types/attachment_type.rb +13 -0
  323. data/lib/decidim/api/types/category_type.rb +14 -0
  324. data/{app/types/decidim/core → lib/decidim/api/types}/component_type.rb +2 -4
  325. data/lib/decidim/api/types/coordinates_type.rb +21 -0
  326. data/lib/decidim/api/types/decidim_type.rb +13 -0
  327. data/lib/decidim/api/types/fingerprint_type.rb +12 -0
  328. data/lib/decidim/api/types/hashtag_type.rb +13 -0
  329. data/lib/decidim/api/types/localized_string_type.rb +13 -0
  330. data/lib/decidim/api/types/metric_history_type.rb +18 -0
  331. data/lib/decidim/api/types/metric_type.rb +13 -0
  332. data/lib/decidim/api/types/organization_type.rb +17 -0
  333. data/lib/decidim/api/types/participatory_space_link_type.rb +22 -0
  334. data/lib/decidim/api/types/participatory_space_type.rb +10 -0
  335. data/lib/decidim/api/types/scope_api_type.rb +16 -0
  336. data/lib/decidim/api/types/session_type.rb +22 -0
  337. data/lib/decidim/api/types/statistic_type.rb +20 -0
  338. data/lib/decidim/api/types/trace_version_type.rb +21 -0
  339. data/lib/decidim/api/types/translated_field_type.rb +36 -0
  340. data/lib/decidim/api/types/user_group_type.rb +64 -0
  341. data/lib/decidim/api/types/user_type.rb +67 -0
  342. data/lib/decidim/attachment_attributes.rb +57 -0
  343. data/lib/decidim/attributes/clean_string.rb +37 -0
  344. data/lib/decidim/attributes.rb +1 -0
  345. data/lib/decidim/coauthorable.rb +3 -3
  346. data/lib/decidim/component_manifest.rb +17 -0
  347. data/lib/decidim/content_block_manifest.rb +1 -1
  348. data/lib/decidim/content_parsers/hashtag_parser.rb +3 -6
  349. data/lib/decidim/content_parsers/user_group_parser.rb +2 -5
  350. data/lib/decidim/content_parsers/user_parser.rb +2 -5
  351. data/lib/decidim/content_processor.rb +1 -1
  352. data/lib/decidim/content_renderers/hashtag_renderer.rb +3 -6
  353. data/lib/decidim/core/api.rb +71 -16
  354. data/lib/decidim/core/engine.rb +35 -6
  355. data/lib/decidim/core/test/factories.rb +53 -15
  356. data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +1 -1
  357. data/lib/decidim/core/test/shared_examples/amendable/amendment_accepted_event_examples.rb +1 -1
  358. data/lib/decidim/core/test/shared_examples/amendable/amendment_promoted_event_examples.rb +1 -1
  359. data/lib/decidim/core/test/shared_examples/amendable/amendment_rejected_event_examples.rb +1 -1
  360. data/lib/decidim/core/test/shared_examples/categorizable_interface_examples.rb +6 -14
  361. data/lib/decidim/core/test/shared_examples/comments_examples.rb +11 -9
  362. data/lib/decidim/core/test/shared_examples/component_type.rb +1 -1
  363. data/lib/decidim/core/test/shared_examples/controller_render_views.rb +28 -0
  364. data/lib/decidim/core/test/shared_examples/follows_examples.rb +1 -1
  365. data/lib/decidim/core/test/shared_examples/logo_email.rb +1 -1
  366. data/lib/decidim/core/test/shared_examples/map_examples.rb +1 -1
  367. data/lib/decidim/core/test/shared_examples/process_announcements_examples.rb +1 -1
  368. data/lib/decidim/core/test/shared_examples/reportable.rb +8 -0
  369. data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +1 -1
  370. data/lib/decidim/core/test/shared_examples/searchable_participatory_space_examples.rb +2 -3
  371. data/lib/decidim/core/test/shared_examples/searchable_results_examples.rb +46 -0
  372. data/lib/decidim/core/test/shared_examples/static_pages_examples.rb +43 -0
  373. data/lib/decidim/core/test.rb +2 -0
  374. data/lib/decidim/core/version.rb +1 -1
  375. data/lib/decidim/core.rb +11 -3
  376. data/lib/decidim/diffy_extension.rb +2 -2
  377. data/lib/decidim/exporters/csv.rb +3 -2
  378. data/lib/decidim/exporters/export_data.rb +1 -1
  379. data/lib/decidim/faker/internet.rb +17 -0
  380. data/lib/decidim/faker/localized.rb +43 -20
  381. data/lib/decidim/file_validator_humanizer.rb +6 -4
  382. data/lib/decidim/form_builder.rb +33 -22
  383. data/lib/decidim/gamification/badge_scorer.rb +3 -2
  384. data/lib/decidim/gamification/base_event.rb +2 -2
  385. data/lib/decidim/geocodable.rb +2 -0
  386. data/lib/decidim/has_category.rb +1 -1
  387. data/lib/decidim/has_private_users.rb +1 -1
  388. data/lib/decidim/importers/import_manifest.rb +36 -0
  389. data/lib/decidim/map/autocomplete.rb +11 -1
  390. data/lib/decidim/metric_operation.rb +5 -6
  391. data/lib/decidim/participatory_space_resourceable.rb +1 -3
  392. data/lib/decidim/query_extensions.rb +90 -69
  393. data/lib/decidim/randomable.rb +6 -1
  394. data/lib/decidim/record_encryptor.rb +131 -0
  395. data/lib/decidim/reportable.rb +26 -0
  396. data/lib/decidim/resource_manifest.rb +3 -0
  397. data/lib/decidim/resourceable.rb +6 -6
  398. data/lib/decidim/scopable.rb +1 -1
  399. data/lib/decidim/search_resource_fields_mapper.rb +1 -1
  400. data/lib/decidim/searchable.rb +9 -0
  401. data/lib/decidim/settings_manifest.rb +2 -1
  402. data/lib/decidim/shareable_with_token.rb +0 -1
  403. data/lib/decidim/translatable_attributes.rb +2 -1
  404. data/lib/decidim/translatable_resource.rb +10 -0
  405. data/lib/decidim/user_reportable.rb +33 -0
  406. data/lib/decidim/view_model.rb +26 -0
  407. data/lib/premailer/adapter/decidim.rb +4 -4
  408. data/lib/tasks/decidim_data_portability_tasks.rake +4 -4
  409. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.ko.js +18 -0
  410. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.vi.js +14 -0
  411. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-CN.js +14 -0
  412. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-TW.js +14 -0
  413. metadata +190 -95
  414. data/app/functions/decidim/core/participatory_space_finder.rb +0 -11
  415. data/app/functions/decidim/core/participatory_space_list.rb +0 -11
  416. data/app/helpers/decidim/cache_helper.rb +0 -14
  417. data/app/types/decidim/core/amendment_type.rb +0 -26
  418. data/app/types/decidim/core/area_api_type.rb +0 -16
  419. data/app/types/decidim/core/area_type_type.rb +0 -14
  420. data/app/types/decidim/core/attachment_type.rb +0 -14
  421. data/app/types/decidim/core/category_type.rb +0 -16
  422. data/app/types/decidim/core/coordinates_type.rb +0 -19
  423. data/app/types/decidim/core/date_time_type.rb +0 -12
  424. data/app/types/decidim/core/date_type.rb +0 -13
  425. data/app/types/decidim/core/decidim_type.rb +0 -19
  426. data/app/types/decidim/core/fingerprint_type.rb +0 -15
  427. data/app/types/decidim/core/has_timestamp_input_sort.rb +0 -12
  428. data/app/types/decidim/core/hashtag_type.rb +0 -13
  429. data/app/types/decidim/core/localized_string_type.rb +0 -14
  430. data/app/types/decidim/core/metric_history_type.rb +0 -17
  431. data/app/types/decidim/core/metric_type.rb +0 -14
  432. data/app/types/decidim/core/organization_type.rb +0 -20
  433. data/app/types/decidim/core/participatory_space_link_type.rb +0 -24
  434. data/app/types/decidim/core/participatory_space_type.rb +0 -12
  435. data/app/types/decidim/core/scope_api_type.rb +0 -16
  436. data/app/types/decidim/core/session_type.rb +0 -19
  437. data/app/types/decidim/core/statistic_type.rb +0 -22
  438. data/app/types/decidim/core/trace_version_type.rb +0 -29
  439. data/app/types/decidim/core/translated_field_type.rb +0 -45
  440. data/app/types/decidim/core/user_entity_input_filter.rb +0 -81
  441. data/app/types/decidim/core/user_group_type.rb +0 -51
  442. data/app/types/decidim/core/user_type.rb +0 -52
  443. data/app/views/decidim/shared/_announcement.html.erb +0 -1
  444. data/app/views/decidim/shared/_flag_modal.html.erb +0 -20
  445. data/db/migrate/20210302150803_invalidate_all_sessions_for_deleted_users.rb +0 -11
  446. data/lib/decidim/api/amendable_interface.rb +0 -18
  447. data/lib/decidim/api/author_interface.rb +0 -29
  448. data/lib/decidim/api/authorable_interface.rb +0 -22
  449. data/lib/decidim/api/coauthorable_interface.rb +0 -29
  450. data/lib/decidim/api/component_interface.rb +0 -20
  451. data/lib/decidim/api/endorsable_interface.rb +0 -22
  452. data/lib/decidim/api/participatory_space_interface.rb +0 -47
  453. data/lib/decidim/api/participatory_space_resourceable_interface.rb +0 -21
  454. data/lib/decidim/api/timestamps_interface.rb +0 -21
  455. 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
- $.tmpl(this.config.popupTemplateId, markerData).appendTo(node);
44
- marker.bindPopup(node, {
45
- maxwidth: 640,
46
- minWidth: 500,
47
- keepInView: true,
48
- className: "map-info"
49
- }).openPopup();
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)
@@ -38,6 +38,7 @@
38
38
  // = require decidim/responsive_horizontal_tabs.js
39
39
  // = require decidim/geocoding/attach_input
40
40
  // = require decidim/security/selfxss_warning
41
+ // = require decidim/session_timeouter
41
42
 
42
43
  // = require_self
43
44
  // = require decidim/configuration
@@ -1,3 +1,12 @@
1
+ // Foundation Variables
2
+ $primary-color: null;
3
+ $secondary-color: null;
4
+ $success-color: null;
5
+ $warning-color: null;
6
+ $alert-color: null;
7
+ $-zf-size: null;
8
+ $-zf-bp-value: null;
9
+
1
10
  // Variables
2
11
 
3
12
  $primary: #cb3c29 !default;
@@ -1091,7 +1091,7 @@ a{
1091
1091
  }
1092
1092
 
1093
1093
  a:hover{
1094
- color: #147dc2;
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% !important;
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;
@@ -1,6 +1,5 @@
1
1
  .external-link-container{
2
2
  position: relative;
3
- display: inline-block;
4
3
  }
5
4
 
6
5
  .external-link-indicator{
@@ -28,7 +28,7 @@
28
28
  .icon{
29
29
  width: 1.5em;
30
30
  height: 1.5em;
31
- color: #599aa6;
31
+ color: var(--secondary);
32
32
  vertical-align: middle;
33
33
  margin-right: .5rem;
34
34
  }
@@ -9,6 +9,7 @@ $order-border: $border;
9
9
  flex-wrap: wrap;
10
10
 
11
11
  a:hover{
12
+ color: var(--secondary);
12
13
  text-decoration: underline;
13
14
  }
14
15
 
@@ -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: $author-data-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: $anchor-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(--secondary);
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: $anchor-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: $card-border;
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
  }
@@ -36,7 +36,7 @@
36
36
 
37
37
  .collapsible-list__see-more{
38
38
  display: none;
39
- color: #599aa6;
39
+ color: $secondary;
40
40
  }
41
41
 
42
42
  .collapsible-list__see-more:hover{
@@ -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: $secondary;
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(4n + 3) .speaker-bio,
82
- &:nth-of-type(4n + 4) .speaker-bio{
83
- transform: translateY(-10%) translateX(-50%);
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
  }
@@ -78,6 +78,13 @@
78
78
  }
79
79
  }
80
80
  }
81
+
82
+ .picker-values{
83
+ .label.primary{
84
+ background: #eee;
85
+ color: #202734;
86
+ }
87
+ }
81
88
  }
82
89
 
83
90
  #data_picker-modal{
@@ -30,6 +30,10 @@
30
30
  line-height: 1;
31
31
  }
32
32
 
33
+ .extra__date-container{
34
+ margin-bottom: 1rem;
35
+ }
36
+
33
37
  .extra__month{
34
38
  display: block;
35
39
  font-size: 1rem;
@@ -46,6 +46,10 @@ label,
46
46
  margin-top: $form-spacing * -1;
47
47
  }
48
48
 
49
+ #registration_user_nickname_characters{
50
+ margin-top: 1rem;
51
+ }
52
+
49
53
  .form-input-extra-before{
50
54
  margin-bottom: $form-spacing / 2;
51
55
  }
@@ -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";
@@ -50,6 +50,6 @@
50
50
  &:hover,
51
51
  &:focus,
52
52
  &.is-active{
53
- background-color: $secondary;
53
+ background-color: var(--secondary);
54
54
  }
55
55
  }
@@ -73,3 +73,9 @@
73
73
  .reveal__trigger{
74
74
  cursor: pointer;
75
75
  }
76
+
77
+ .reveal__buttons{
78
+ display: flex;
79
+ justify-content: space-between;
80
+ padding: 0 1rem;
81
+ }
@@ -66,6 +66,7 @@
66
66
  // this is the prefix div
67
67
  @extend .input-group-label;
68
68
 
69
+ padding: 0;
69
70
  border-#{$global-right}: 0;
70
71
  width: 8%;
71
72
  height: 3rem;
@@ -1,4 +1,4 @@
1
- .process-stats{
1
+ .space-stats{
2
2
  overflow: hidden;
3
3
  margin: 2rem 0;
4
4
  display: flex;
@@ -1,4 +1,4 @@
1
- <div class="card card--activity" id="<%= element_id %>">
1
+ <div class="card card--activity">
2
2
  <div class="card__content">
3
3
  <div class="card__text">
4
4
  <div class="text-medium">
@@ -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
- if resource_title.is_a?(String)
39
+ case resource_title
40
+ when String
40
41
  resource_title
41
- elsif resource_title.is_a?(Hash)
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 = if resource_description.is_a?(String)
54
+ resource_description = case resource_description
55
+ when String
54
56
  resource_description
55
- elsif resource_description.is_a?(Hash)
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 = if user.is_a?(Decidim::User)
106
+ presenter = case user
107
+ when Decidim::User
111
108
  UserPresenter.new(user)
112
- elsif user.is_a?(Decidim::UserGroup)
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 has_location? %>
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 has_location_hints? %>
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 announcement.class == Hash && announcement.key?(:title) %>
4
- <span><%= decidim_sanitize translated_attribute announcement[:title] %></span>
3
+ <% if has_title? %>
4
+ <p class="heading2"><%= clean_title %></p>
5
5
 
6
- <p><%= decidim_sanitize translated_attribute announcement[:body] %></p>
6
+ <%= clean_body %>
7
7
  <% else %>
8
- <%= decidim_sanitize translated_attribute announcement %>
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
- model[:callout_class] ||= "secondary"
30
+ options[:callout_class] ||= "secondary"
27
31
  end
28
32
 
29
33
  def announcement
30
- model[:announcement]
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
- <%= link_to t("decidim.profiles.show.view_full_profile"), profile_path %>
7
+ <%= text_link_to_current_or_new_conversation_with(model) %>
8
8
  </div>
9
9
  </div>
10
10
  <div class="ml-s">