decidim-core 0.26.10 → 0.27.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 (643) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/app/cells/decidim/amendable/announcement_cell.rb +4 -9
  4. data/app/cells/decidim/announcement_cell.rb +2 -2
  5. data/app/cells/decidim/author_cell.rb +1 -1
  6. data/app/cells/decidim/card_m_cell.rb +1 -1
  7. data/app/cells/decidim/collapsible_list/show.erb +1 -1
  8. data/app/cells/decidim/content_blocks/cta/show.erb +1 -1
  9. data/app/cells/decidim/content_blocks/cta_cell.rb +1 -1
  10. data/app/cells/decidim/content_blocks/footer_sub_hero/show.erb +1 -1
  11. data/app/cells/decidim/content_blocks/hero/show.erb +2 -2
  12. data/app/cells/decidim/content_blocks/highlighted_content_banner/show.erb +5 -5
  13. data/app/cells/decidim/content_blocks/highlighted_elements_cell.rb +1 -1
  14. data/app/cells/decidim/content_blocks/how_to_participate/show.erb +1 -1
  15. data/app/cells/decidim/content_blocks/last_activity/show.erb +1 -1
  16. data/app/cells/decidim/content_blocks/last_activity_cell.rb +3 -3
  17. data/app/cells/decidim/content_blocks/stats_cell.rb +4 -5
  18. data/app/cells/decidim/content_blocks/sub_hero/show.erb +1 -1
  19. data/app/cells/decidim/content_blocks/sub_hero_cell.rb +1 -1
  20. data/app/cells/decidim/data_consent/category.erb +64 -0
  21. data/app/cells/decidim/data_consent/dialog.erb +29 -0
  22. data/app/cells/decidim/data_consent/modal.erb +39 -0
  23. data/app/cells/decidim/data_consent/show.erb +3 -0
  24. data/app/cells/decidim/data_consent_cell.rb +21 -0
  25. data/app/cells/decidim/follow_button_cell.rb +5 -7
  26. data/app/cells/decidim/newsletter_templates/base_cell.rb +0 -8
  27. data/app/cells/decidim/newsletter_templates/basic_only_text/show.erb +4 -4
  28. data/app/cells/decidim/newsletter_templates/image_text_cta/show.erb +4 -4
  29. data/app/cells/decidim/profile_sidebar_cell.rb +1 -1
  30. data/app/cells/decidim/search_results_cell.rb +1 -1
  31. data/app/cells/decidim/tos_page/refuse_btn_modal.erb +1 -1
  32. data/app/cells/decidim/upload_modal/files.erb +52 -0
  33. data/app/cells/decidim/upload_modal/modal.erb +49 -0
  34. data/app/cells/decidim/upload_modal/show.erb +3 -0
  35. data/app/cells/decidim/upload_modal_cell.rb +205 -0
  36. data/app/cells/decidim/user_conversation/reply.erb +1 -1
  37. data/app/cells/decidim/user_conversations/add_conversation_users.erb +5 -3
  38. data/app/cells/decidim/version_cell.rb +3 -14
  39. data/app/cells/decidim/versions_list_cell.rb +3 -14
  40. data/app/cells/decidim/versions_list_item_cell.rb +2 -13
  41. data/app/commands/decidim/accept_group_invitation.rb +1 -1
  42. data/app/commands/decidim/accept_user_group_join_request.rb +1 -1
  43. data/app/commands/decidim/amendable/accept.rb +1 -1
  44. data/app/commands/decidim/amendable/create_draft.rb +1 -1
  45. data/app/commands/decidim/amendable/destroy_draft.rb +1 -1
  46. data/app/commands/decidim/amendable/promote.rb +1 -1
  47. data/app/commands/decidim/amendable/publish_draft.rb +1 -1
  48. data/app/commands/decidim/amendable/reject.rb +1 -1
  49. data/app/commands/decidim/amendable/update_draft.rb +1 -1
  50. data/app/commands/decidim/amendable/withdraw.rb +1 -1
  51. data/app/commands/decidim/attachment_methods.rb +3 -2
  52. data/app/commands/decidim/create_editor_image.rb +1 -1
  53. data/app/commands/decidim/create_follow.rb +1 -1
  54. data/app/commands/decidim/create_omniauth_registration.rb +2 -3
  55. data/app/commands/decidim/create_registration.rb +1 -2
  56. data/app/commands/decidim/create_report.rb +1 -1
  57. data/app/commands/decidim/create_user_group.rb +2 -2
  58. data/app/commands/decidim/create_user_report.rb +5 -3
  59. data/app/commands/decidim/delete_follow.rb +1 -1
  60. data/app/commands/decidim/demote_membership.rb +1 -1
  61. data/app/commands/decidim/destroy_account.rb +1 -1
  62. data/app/commands/decidim/endorse_resource.rb +1 -3
  63. data/app/commands/decidim/gallery_methods.rb +45 -10
  64. data/app/commands/decidim/invite_user.rb +1 -3
  65. data/app/commands/decidim/invite_user_again.rb +1 -1
  66. data/app/commands/decidim/invite_user_to_group.rb +1 -1
  67. data/app/commands/decidim/join_user_group.rb +1 -1
  68. data/app/commands/decidim/leave_user_group.rb +8 -2
  69. data/app/commands/decidim/messaging/reply_to_conversation.rb +2 -2
  70. data/app/commands/decidim/messaging/start_conversation.rb +2 -2
  71. data/app/commands/decidim/multiple_attachments_methods.rb +44 -5
  72. data/app/commands/decidim/promote_membership.rb +1 -1
  73. data/app/commands/decidim/reject_group_invitation.rb +1 -1
  74. data/app/commands/decidim/reject_user_group_join_request.rb +1 -1
  75. data/app/commands/decidim/remove_user_from_group.rb +1 -1
  76. data/app/commands/decidim/resend_confirmation_instructions.rb +18 -0
  77. data/app/commands/decidim/search.rb +10 -9
  78. data/app/commands/decidim/unendorse_resource.rb +2 -2
  79. data/app/commands/decidim/unsubscribe_settings.rb +1 -1
  80. data/app/commands/decidim/update_account.rb +2 -2
  81. data/app/commands/decidim/update_notifications_settings.rb +3 -2
  82. data/app/commands/decidim/update_password.rb +31 -0
  83. data/app/commands/decidim/update_user_group.rb +2 -2
  84. data/app/commands/decidim/update_user_interests.rb +1 -1
  85. data/app/commands/decidim/validate_upload.rb +15 -0
  86. data/app/controllers/concerns/decidim/devise_controllers.rb +0 -1
  87. data/app/controllers/concerns/decidim/filter_resource.rb +23 -24
  88. data/app/controllers/concerns/decidim/force_authentication.rb +1 -2
  89. data/app/controllers/concerns/decidim/http_caching_disabler.rb +1 -1
  90. data/app/controllers/concerns/decidim/needs_password_change.rb +43 -0
  91. data/app/controllers/concerns/decidim/needs_tos_accepted.rb +3 -3
  92. data/app/controllers/concerns/decidim/orderable.rb +1 -1
  93. data/app/controllers/concerns/decidim/participatory_space_context.rb +2 -2
  94. data/app/controllers/concerns/decidim/resource_versions_concern.rb +0 -4
  95. data/app/controllers/decidim/account_controller.rb +45 -0
  96. data/app/controllers/decidim/application_controller.rb +1 -1
  97. data/app/controllers/decidim/authorization_modals_controller.rb +1 -1
  98. data/app/controllers/decidim/devise/invitations_controller.rb +4 -9
  99. data/app/controllers/decidim/devise/passwords_controller.rb +33 -0
  100. data/app/controllers/decidim/devise/registrations_controller.rb +3 -5
  101. data/app/controllers/decidim/devise/sessions_controller.rb +2 -0
  102. data/app/controllers/decidim/{data_portability_controller.rb → download_your_data_controller.rb} +8 -8
  103. data/app/controllers/decidim/groups_controller.rb +5 -5
  104. data/app/controllers/decidim/last_activities_controller.rb +7 -9
  105. data/app/controllers/decidim/links_controller.rb +11 -10
  106. data/app/controllers/decidim/manifests_controller.rb +11 -0
  107. data/app/controllers/decidim/newsletters_controller.rb +1 -1
  108. data/app/controllers/decidim/notifications_subscriptions_controller.rb +16 -0
  109. data/app/controllers/decidim/offline_controller.rb +7 -0
  110. data/app/controllers/decidim/profiles_controller.rb +2 -2
  111. data/app/controllers/decidim/searches_controller.rb +4 -3
  112. data/app/controllers/decidim/short_links_controller.rb +35 -0
  113. data/app/controllers/decidim/upload_validations_controller.rb +44 -0
  114. data/app/controllers/decidim/user_activities_controller.rb +32 -16
  115. data/app/controllers/decidim/user_interests_controller.rb +0 -2
  116. data/app/controllers/decidim/user_timeline_controller.rb +7 -9
  117. data/app/events/decidim/change_nickname_event.rb +21 -0
  118. data/app/events/decidim/resource_endorsed_event.rb +1 -2
  119. data/app/forms/decidim/account_form.rb +4 -4
  120. data/app/forms/decidim/amendable/form.rb +1 -2
  121. data/app/forms/decidim/form.rb +1 -1
  122. data/app/forms/decidim/messaging/conversation_form.rb +1 -1
  123. data/app/forms/decidim/notifications_settings_form.rb +16 -2
  124. data/app/forms/decidim/password_form.rb +10 -0
  125. data/app/forms/decidim/registration_form.rb +3 -3
  126. data/app/forms/decidim/upload_validation_form.rb +54 -0
  127. data/app/forms/decidim/user_group_form.rb +1 -1
  128. data/app/forms/decidim/user_interest_scope_form.rb +1 -1
  129. data/app/forms/decidim/user_interests_form.rb +1 -1
  130. data/app/forms/translatable_presence_validator.rb +2 -2
  131. data/app/forms/url_validator.rb +1 -1
  132. data/app/helpers/decidim/application_helper.rb +2 -2
  133. data/app/helpers/decidim/attachments_helper.rb +1 -1
  134. data/app/helpers/decidim/cells_helper.rb +0 -1
  135. data/app/helpers/decidim/cells_paginate_helper.rb +1 -1
  136. data/app/helpers/decidim/datalist_select_helper.rb +40 -0
  137. data/app/helpers/decidim/decidim_form_helper.rb +1 -1
  138. data/app/helpers/decidim/external_domain_helper.rb +3 -14
  139. data/app/helpers/decidim/filters_helper.rb +1 -5
  140. data/app/helpers/decidim/followable_helper.rb +1 -1
  141. data/app/helpers/decidim/icon_helper.rb +4 -4
  142. data/app/helpers/decidim/layout_helper.rb +19 -16
  143. data/app/helpers/decidim/map_helper.rb +12 -8
  144. data/app/helpers/decidim/meta_tags_helper.rb +0 -2
  145. data/app/helpers/decidim/newsletters_helper.rb +0 -1
  146. data/app/helpers/decidim/notifications_settings_helper.rb +15 -0
  147. data/app/helpers/decidim/passwords_helper.rb +41 -0
  148. data/app/helpers/decidim/resource_helper.rb +0 -2
  149. data/app/helpers/decidim/sanitize_helper.rb +6 -15
  150. data/app/helpers/decidim/searches_helper.rb +6 -6
  151. data/app/helpers/decidim/short_link_helper.rb +28 -0
  152. data/app/helpers/decidim/translations_helper.rb +2 -2
  153. data/app/jobs/decidim/{data_portability_export_job.rb → download_your_data_export_job.rb} +5 -8
  154. data/app/jobs/decidim/email_notifications_digest_generator_job.rb +21 -0
  155. data/app/jobs/decidim/notification_generator_for_recipient_job.rb +5 -3
  156. data/app/jobs/decidim/open_data_job.rb +0 -2
  157. data/app/jobs/decidim/reminder_generator_job.rb +12 -0
  158. data/app/jobs/decidim/resend_confirmation_instructions_job.rb +11 -0
  159. data/app/jobs/decidim/user_report_job.rb +2 -2
  160. data/app/mailers/concerns/decidim/multitenant_asset_host.rb +11 -3
  161. data/app/mailers/decidim/application_mailer.rb +1 -1
  162. data/app/mailers/decidim/block_user_mailer.rb +8 -7
  163. data/app/mailers/decidim/export_mailer.rb +2 -2
  164. data/app/mailers/decidim/newsletter_mailer.rb +5 -12
  165. data/app/mailers/decidim/newsletters_opt_in_mailer.rb +7 -5
  166. data/app/mailers/decidim/notification_mailer.rb +0 -1
  167. data/app/mailers/decidim/notifications_digest_mailer.rb +23 -0
  168. data/app/mailers/decidim/user_report_mailer.rb +10 -11
  169. data/app/models/decidim/action_log.rb +95 -11
  170. data/app/models/decidim/amendment.rb +0 -1
  171. data/app/models/decidim/area.rb +1 -2
  172. data/app/models/decidim/area_type.rb +5 -0
  173. data/app/models/decidim/attachment.rb +6 -0
  174. data/app/models/decidim/attachment_collection.rb +5 -0
  175. data/app/models/decidim/category.rb +9 -4
  176. data/app/models/decidim/coauthorship.rb +0 -2
  177. data/app/models/decidim/contextual_help_section.rb +5 -1
  178. data/app/models/decidim/follow.rb +2 -2
  179. data/app/models/decidim/gamification/badge_score.rb +0 -1
  180. data/app/models/decidim/identity.rb +2 -2
  181. data/app/models/decidim/messaging/conversation.rb +4 -4
  182. data/app/models/decidim/messaging/message.rb +1 -2
  183. data/app/models/decidim/messaging/participation.rb +0 -2
  184. data/app/models/decidim/messaging/receipt.rb +0 -2
  185. data/app/models/decidim/newsletter.rb +0 -28
  186. data/app/models/decidim/notification.rb +5 -2
  187. data/app/models/decidim/oauth_application.rb +12 -1
  188. data/app/models/decidim/organization.rb +7 -13
  189. data/app/models/decidim/participatory_space_private_user.rb +4 -2
  190. data/app/models/decidim/permission_action.rb +1 -0
  191. data/app/models/decidim/reminder.rb +10 -0
  192. data/app/models/decidim/reminder_delivery.rb +7 -0
  193. data/app/models/decidim/reminder_record.rb +29 -0
  194. data/app/models/decidim/report.rb +2 -2
  195. data/app/models/decidim/scope.rb +3 -4
  196. data/app/models/decidim/scope_type.rb +1 -24
  197. data/app/models/decidim/share_token.rb +0 -2
  198. data/app/models/decidim/short_link.rb +162 -0
  199. data/app/models/decidim/user.rb +35 -13
  200. data/app/models/decidim/user_base_entity.rb +1 -4
  201. data/app/models/decidim/user_block.rb +2 -2
  202. data/app/models/decidim/user_group.rb +4 -4
  203. data/app/models/decidim/user_moderation.rb +0 -2
  204. data/app/models/decidim/user_report.rb +2 -2
  205. data/app/packs/entrypoints/decidim_core.js +2 -2
  206. data/app/packs/entrypoints/decidim_sw.js +1 -0
  207. data/app/packs/images/decidim/gamification/badges/decidim_gamification_badges_invitations.svg +1 -0
  208. data/app/packs/src/decidim/autocomplete.js +298 -0
  209. data/app/packs/src/decidim/cookie_consent/consent_manager.js +133 -0
  210. data/app/packs/src/decidim/cookie_consent/cookie_consent.js +103 -0
  211. data/app/packs/src/decidim/datalist_select.js +36 -0
  212. data/app/packs/src/decidim/direct_uploads/upload_field.js +117 -0
  213. data/app/packs/src/decidim/direct_uploads/upload_modal.js +264 -0
  214. data/app/packs/src/decidim/direct_uploads/upload_utility.js +49 -0
  215. data/app/packs/src/decidim/direct_uploads/uploader.js +89 -0
  216. data/app/packs/src/decidim/editor/linebreak_module.js +8 -0
  217. data/app/packs/src/decidim/editor.js +33 -70
  218. data/app/packs/src/decidim/external_domain_warning.js +1 -1
  219. data/app/packs/src/decidim/external_link.js +14 -3
  220. data/app/packs/src/decidim/external_link.test.js +64 -0
  221. data/app/packs/src/decidim/form_filter.component.test.js +5 -148
  222. data/app/packs/src/decidim/form_filter.js +4 -26
  223. data/app/packs/src/decidim/geocoding/attach_input.js +1 -4
  224. data/app/packs/src/decidim/geocoding/provider/here.js +21 -17
  225. data/app/packs/src/decidim/geocoding/provider/photon.js +1 -1
  226. data/app/packs/src/decidim/geocoding.js +10 -35
  227. data/app/packs/src/decidim/identity_selector_dialog.js +1 -1
  228. data/app/packs/src/decidim/impersonation.js +3 -3
  229. data/app/packs/src/decidim/input_character_counter.js +177 -7
  230. data/app/packs/src/decidim/input_multiple_mentions.js +87 -187
  231. data/app/packs/src/decidim/map/controller/drag_marker.js +2 -0
  232. data/app/packs/src/decidim/map/controller/markers.js +1 -0
  233. data/app/packs/src/decidim/map/controller/static.js +1 -0
  234. data/app/packs/src/decidim/map/controller.js +2 -0
  235. data/app/packs/src/decidim/map/factory.js +1 -4
  236. data/app/packs/src/decidim/map/icon.js +3 -1
  237. data/app/packs/src/decidim/map/legacy.js +1 -0
  238. data/app/packs/src/decidim/map/provider/default.js +0 -2
  239. data/app/packs/src/decidim/map/provider/here.js +1 -2
  240. data/app/packs/src/decidim/map/svg-icon.js +248 -0
  241. data/app/packs/src/decidim/security/selfxss_warning.js +5 -1
  242. data/app/packs/src/decidim/session_timeouter.js +15 -15
  243. data/app/packs/src/decidim/sw/a2hs.js +28 -0
  244. data/app/packs/src/decidim/sw/index.js +3 -0
  245. data/app/packs/src/decidim/sw/loader.js +18 -0
  246. data/app/packs/src/decidim/sw/push-permissions.js +87 -0
  247. data/app/packs/src/decidim/sw/sw.js +80 -0
  248. data/app/packs/src/decidim/vizzs/areachart.js +33 -28
  249. data/app/packs/src/decidim/vizzs/linechart.js +23 -18
  250. data/app/packs/src/decidim/vizzs/rowchart.js +15 -11
  251. data/app/packs/stylesheets/decidim/_editor.scss +0 -129
  252. data/app/packs/stylesheets/decidim/email.scss +66 -7
  253. data/app/packs/stylesheets/decidim/extras/_quill.scss +6 -0
  254. data/app/packs/stylesheets/decidim/layouts/_user.scss +8 -0
  255. data/app/packs/stylesheets/decidim/modules/_autocomplete.scss +99 -0
  256. data/app/packs/stylesheets/decidim/modules/_buttons.scss +6 -10
  257. data/app/packs/stylesheets/decidim/modules/_cards.scss +1 -3
  258. data/app/packs/stylesheets/decidim/modules/_comments.scss +0 -26
  259. data/app/packs/stylesheets/decidim/modules/_cookie-consent.scss +115 -0
  260. data/app/packs/stylesheets/decidim/modules/_footer.scss +4 -0
  261. data/app/packs/stylesheets/decidim/modules/_forms.scss +0 -5
  262. data/app/packs/stylesheets/decidim/modules/_input-multiple-mentions.scss +29 -2
  263. data/app/packs/stylesheets/decidim/modules/_modules.scss +3 -1
  264. data/app/packs/stylesheets/decidim/modules/_reveal.scss +15 -0
  265. data/app/packs/stylesheets/decidim/modules/_upload_modal.scss +143 -0
  266. data/app/packs/stylesheets/decidim/utils/_fontface.scss +3 -0
  267. data/app/packs/stylesheets/decidim/vizzs/_linechart.scss +2 -2
  268. data/app/packs/stylesheets/decidim/vizzs/_rowchart.scss +2 -2
  269. data/app/permissions/decidim/permissions.rb +4 -8
  270. data/app/presenters/decidim/admin_log/area_type_presenter.rb +34 -0
  271. data/app/presenters/decidim/admin_log/attachment_collection_presenter.rb +35 -0
  272. data/app/presenters/decidim/admin_log/attachment_presenter.rb +27 -0
  273. data/app/presenters/decidim/admin_log/category_presenter.rb +36 -0
  274. data/app/presenters/decidim/admin_log/component_presenter.rb +35 -3
  275. data/app/presenters/decidim/admin_log/contextual_help_section_presenter.rb +33 -0
  276. data/app/presenters/decidim/admin_log/organization_presenter.rb +9 -4
  277. data/app/presenters/decidim/admin_log/scope_type_presenter.rb +34 -0
  278. data/app/presenters/decidim/admin_log/user_group_presenter.rb +1 -1
  279. data/app/presenters/decidim/admin_log/user_moderation_presenter.rb +1 -1
  280. data/app/presenters/decidim/home_stats_presenter.rb +8 -13
  281. data/app/presenters/decidim/log/base_presenter.rb +1 -1
  282. data/app/presenters/decidim/menu_item_presenter.rb +1 -1
  283. data/app/presenters/decidim/metric_charts_presenter.rb +7 -1
  284. data/app/presenters/decidim/nil_presenter.rb +3 -1
  285. data/app/presenters/decidim/notification_presenter.rb +1 -1
  286. data/app/presenters/decidim/notification_to_mailer_presenter.rb +39 -0
  287. data/app/presenters/decidim/notifications_digest_presenter.rb +42 -0
  288. data/app/presenters/decidim/official_author_presenter.rb +4 -0
  289. data/app/presenters/decidim/organization_presenter.rb +22 -0
  290. data/app/presenters/decidim/push_notification_presenter.rb +24 -0
  291. data/app/presenters/decidim/stats_presenter.rb +9 -8
  292. data/app/presenters/decidim/user_group_presenter.rb +1 -1
  293. data/app/presenters/decidim/user_presenter.rb +5 -13
  294. data/app/presenters/decidim/validation_errors_presenter.rb +1 -1
  295. data/app/queries/decidim/messaging/user_conversations.rb +1 -1
  296. data/app/queries/decidim/metric_manage.rb +1 -1
  297. data/app/queries/decidim/metrics/users_metric_manage.rb +6 -6
  298. data/app/queries/decidim/own_activities.rb +11 -0
  299. data/app/queries/decidim/participatory_processes_with_user_role.rb +1 -1
  300. data/app/{services/decidim/activity_search.rb → queries/decidim/public_activities.rb} +35 -78
  301. data/app/queries/decidim/public_components.rb +1 -1
  302. data/app/queries/decidim/similar_emendations.rb +1 -1
  303. data/app/queries/decidim/stats_users_count.rb +1 -1
  304. data/app/queries/decidim/user_groups/accepted_memberships.rb +1 -1
  305. data/app/queries/decidim/user_groups/accepted_user_groups.rb +1 -1
  306. data/app/queries/decidim/user_groups/accepted_users.rb +1 -1
  307. data/app/queries/decidim/user_groups/admin_memberships.rb +1 -1
  308. data/app/queries/decidim/user_groups/invited_memberships.rb +1 -1
  309. data/app/queries/decidim/user_groups/manageable_user_groups.rb +1 -1
  310. data/app/queries/decidim/user_groups/member_memberships.rb +1 -1
  311. data/app/scrubbers/decidim/user_input_scrubber.rb +5 -32
  312. data/app/services/decidim/{data_portability_exporter.rb → download_your_data_exporter.rb} +6 -6
  313. data/app/services/decidim/email_notification_generator.rb +2 -2
  314. data/app/services/decidim/engine_resolver.rb +66 -0
  315. data/app/services/decidim/events_manager.rb +1 -1
  316. data/app/services/decidim/iframe_disabler.rb +31 -0
  317. data/app/services/decidim/notification_generator_for_recipient.rb +1 -1
  318. data/app/services/decidim/notifications_digest_sending_decider.rb +18 -0
  319. data/app/services/decidim/notifications_subscriptions_persistor.rb +37 -0
  320. data/app/services/decidim/open_data_exporter.rb +1 -1
  321. data/app/services/decidim/resource_search.rb +17 -164
  322. data/app/services/decidim/send_push_notification.rb +59 -0
  323. data/app/services/decidim/traceability.rb +1 -2
  324. data/app/uploaders/decidim/application_uploader.rb +2 -12
  325. data/app/uploaders/decidim/cw/attachment_uploader.rb +1 -1
  326. data/app/uploaders/decidim/cw/{data_portability_uploader.rb → download_your_data_uploader.rb} +3 -3
  327. data/app/uploaders/decidim/cw/image_uploader.rb +2 -2
  328. data/app/uploaders/decidim/organization_favicon_uploader.rb +3 -2
  329. data/app/validators/etiquette_validator.rb +3 -7
  330. data/app/validators/passthru_validator.rb +29 -21
  331. data/app/validators/password_validator.rb +25 -4
  332. data/app/validators/uploader_image_dimensions_validator.rb +1 -1
  333. data/app/views/decidim/account/_account_notification.js.erb +20 -0
  334. data/app/views/decidim/account/_password_fields.html.erb +2 -2
  335. data/app/views/decidim/account/cancel_email_change.js.erb +6 -0
  336. data/app/views/decidim/account/resend_confirmation_instructions.erb +1 -0
  337. data/app/views/decidim/account/show.html.erb +19 -6
  338. data/app/views/decidim/application/{_attachments.html.erb → _attachments.erb} +2 -2
  339. data/app/views/decidim/application/_collection.html.erb +1 -1
  340. data/app/views/decidim/application/{_documents.html.erb → _documents.erb} +2 -2
  341. data/app/views/decidim/devise/confirmations/new.html.erb +1 -1
  342. data/app/views/decidim/devise/invitations/edit.html.erb +3 -4
  343. data/app/views/decidim/devise/omniauth_registrations/new.html.erb +3 -3
  344. data/app/views/decidim/devise/passwords/edit.html.erb +7 -5
  345. data/app/views/decidim/devise/passwords/new.html.erb +1 -1
  346. data/app/views/decidim/devise/registrations/edit.html.erb +41 -0
  347. data/app/views/decidim/devise/registrations/new.html.erb +5 -5
  348. data/app/views/decidim/devise/sessions/new.html.erb +2 -2
  349. data/app/views/decidim/{data_portability → download_your_data}/show.html.erb +2 -2
  350. data/app/views/decidim/export_mailer/download_your_data_export.html.erb +7 -0
  351. data/app/views/decidim/last_activities/index.html.erb +1 -1
  352. data/app/views/decidim/links/_modal.html.erb +1 -1
  353. data/app/views/decidim/links/new.html.erb +1 -1
  354. data/app/views/decidim/manifests/show.json.erb +31 -0
  355. data/app/views/decidim/messaging/conversations/_add_conversation_users.html.erb +5 -3
  356. data/app/views/decidim/messaging/conversations/_conversation.html.erb +5 -1
  357. data/app/views/decidim/messaging/conversations/_reply.html.erb +1 -1
  358. data/app/views/decidim/messaging/conversations/_start.html.erb +1 -3
  359. data/app/views/decidim/messaging/conversations/create.js.erb +1 -0
  360. data/app/views/decidim/newsletter_mailer/newsletter.html.erb +3 -3
  361. data/app/views/decidim/newsletters/show.html.erb +1 -1
  362. data/app/views/decidim/notification_mailer/event_received.html.erb +1 -1
  363. data/app/views/decidim/notifications_digest_mailer/_email_content.html.erb +11 -0
  364. data/app/views/decidim/notifications_digest_mailer/digest_mail.erb +27 -0
  365. data/app/views/decidim/notifications_settings/show.html.erb +79 -52
  366. data/app/views/decidim/offline/show.html.erb +9 -0
  367. data/app/views/decidim/pages/_standalone.html.erb +1 -1
  368. data/app/views/decidim/pages/_tabbed.html.erb +1 -1
  369. data/app/views/decidim/reported_mailer/hide.html.erb +1 -1
  370. data/app/views/decidim/reported_mailer/report.html.erb +1 -1
  371. data/app/views/decidim/scopes/picker.html.erb +1 -1
  372. data/app/views/decidim/searches/_filters.html.erb +2 -2
  373. data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +3 -3
  374. data/app/views/decidim/user_interests/show.html.erb +13 -11
  375. data/app/views/decidim/user_report_mailer/notify.html.erb +10 -3
  376. data/app/views/devise/mailer/confirmation_instructions.html.erb +3 -1
  377. data/app/views/layouts/decidim/_application.html.erb +6 -3
  378. data/app/views/layouts/decidim/_cookie_warning.html.erb +8 -8
  379. data/app/views/layouts/decidim/_decidim_javascript.html.erb +12 -0
  380. data/app/views/layouts/decidim/_head.html.erb +4 -2
  381. data/app/views/layouts/decidim/_js_configuration.html.erb +5 -1
  382. data/app/views/layouts/decidim/_mailer_logo.html.erb +2 -2
  383. data/app/views/layouts/decidim/_main_footer.html.erb +1 -0
  384. data/app/views/layouts/decidim/_offline_banner.html.erb +11 -0
  385. data/app/views/layouts/decidim/newsletter_base.html.erb +2 -2
  386. data/app/views/layouts/decidim/widget.html.erb +2 -2
  387. data/config/assets.rb +1 -0
  388. data/config/locales/am-ET.yml +1 -0
  389. data/config/locales/ar.yml +86 -461
  390. data/config/locales/bg.yml +57 -32
  391. data/config/locales/ca.yml +246 -85
  392. data/config/locales/cs.yml +256 -97
  393. data/config/locales/da.yml +1 -3
  394. data/config/locales/de.yml +93 -159
  395. data/config/locales/el.yml +53 -137
  396. data/config/locales/en.yml +220 -59
  397. data/config/locales/eo.yml +8 -13
  398. data/config/locales/es-MX.yml +234 -73
  399. data/config/locales/es-PY.yml +236 -75
  400. data/config/locales/es.yml +244 -83
  401. data/config/locales/et.yml +1 -3
  402. data/config/locales/eu.yml +416 -479
  403. data/config/locales/fi-plain.yml +222 -61
  404. data/config/locales/fi.yml +236 -75
  405. data/config/locales/fr-CA.yml +218 -71
  406. data/config/locales/fr.yml +224 -77
  407. data/config/locales/ga-IE.yml +15 -9
  408. data/config/locales/gl.yml +112 -35
  409. data/config/locales/hr.yml +1 -3
  410. data/config/locales/hu.yml +106 -266
  411. data/config/locales/id-ID.yml +61 -35
  412. data/config/locales/is-IS.yml +12 -23
  413. data/config/locales/it.yml +66 -41
  414. data/config/locales/ja.yml +235 -83
  415. data/config/locales/ko.yml +1 -0
  416. data/config/locales/lb.yml +57 -38
  417. data/config/locales/lt.yml +1 -1788
  418. data/config/locales/lv.yml +55 -28
  419. data/config/locales/mt.yml +1 -0
  420. data/config/locales/nl.yml +81 -39
  421. data/config/locales/no.yml +84 -41
  422. data/config/locales/om-ET.yml +1 -0
  423. data/config/locales/pl.yml +127 -46
  424. data/config/locales/pt-BR.yml +52 -80
  425. data/config/locales/pt.yml +54 -35
  426. data/config/locales/ro-RO.yml +55 -43
  427. data/config/locales/ru.yml +35 -29
  428. data/config/locales/si-LK.yml +1 -0
  429. data/config/locales/sk.yml +62 -45
  430. data/config/locales/sl.yml +6 -1
  431. data/config/locales/so-SO.yml +1 -0
  432. data/config/locales/sr-CS.yml +1 -10
  433. data/config/locales/sv.yml +127 -55
  434. data/config/locales/sw-KE.yml +1 -0
  435. data/config/locales/ti-ER.yml +1 -0
  436. data/config/locales/tr-TR.yml +55 -40
  437. data/config/locales/uk.yml +30 -30
  438. data/config/locales/val-ES.yml +1 -0
  439. data/config/locales/vi.yml +1 -0
  440. data/config/locales/zh-CN.yml +53 -33
  441. data/config/locales/zh-TW.yml +1 -1721
  442. data/config/routes.rb +19 -22
  443. data/db/migrate/20180508111710_add_accepted_tos_version_field_to_users.rb +1 -0
  444. data/db/migrate/20181030090144_destroy_deleted_users_follows.rb +2 -1
  445. data/db/migrate/20181204110723_remove_following_users_count_from_users.rb +2 -11
  446. data/db/migrate/20181214101250_add_notification_types_to_users.rb +1 -6
  447. data/db/migrate/20190412131728_fix_user_names.rb +2 -9
  448. data/db/migrate/20200211173227_add_direct_message_types_to_users.rb +1 -6
  449. data/db/migrate/20210302150803_invalidate_all_sessions_for_deleted_users.rb +3 -10
  450. data/db/migrate/20210310120640_add_followable_counter_cache_to_users.rb +3 -13
  451. data/db/migrate/20210831181634_add_service_name_to_active_storage_blobs.active_storage.rb +22 -0
  452. data/db/migrate/20210831181635_create_active_storage_variant_records.active_storage.rb +14 -0
  453. data/db/migrate/20211208155453_create_decidim_reminders.rb +11 -0
  454. data/db/migrate/20211209121025_create_decidim_reminder_records.rb +11 -0
  455. data/db/migrate/20211209121040_create_decidim_reminder_deliveries.rb +10 -0
  456. data/db/migrate/20220118121921_change_required_description_categories.rb +7 -0
  457. data/db/migrate/20220127113419_add_notification_settings_to_users.rb +7 -0
  458. data/db/migrate/20220203121137_add_notifications_sending_frequency_to_users.rb +7 -0
  459. data/db/migrate/20220215172439_add_digest_sent_at_to_users.rb +7 -0
  460. data/db/migrate/20220323195258_add_index_to_decidim_users_notifications_sending_frequency.rb +7 -0
  461. data/db/migrate/20220427142214_drop_emails_on_notifications_flag_from_user.rb +15 -0
  462. data/db/migrate/20220518094535_add_previous_passwords_to_users.rb +20 -0
  463. data/db/migrate/20220524195530_create_decidim_short_links.rb +23 -0
  464. data/db/seeds.rb +17 -19
  465. data/lib/decidim/acts_as_tree.rb +47 -0
  466. data/lib/decidim/api/input_sorts/component_input_sort.rb +2 -1
  467. data/lib/decidim/api/interfaces/authorable_interface.rb +6 -5
  468. data/lib/decidim/api/types/localized_string_type.rb +0 -9
  469. data/lib/decidim/api/types/translated_field_type.rb +5 -20
  470. data/lib/decidim/asset_router.rb +80 -0
  471. data/lib/decidim/attachment_attributes.rb +8 -8
  472. data/lib/decidim/attribute_object/form.rb +174 -0
  473. data/lib/decidim/attribute_object/model.rb +148 -0
  474. data/lib/decidim/attribute_object/nested_validator.rb +22 -0
  475. data/lib/decidim/attribute_object/type_map.rb +14 -0
  476. data/lib/decidim/attribute_object/type_resolver.rb +91 -0
  477. data/lib/decidim/attribute_object.rb +26 -0
  478. data/lib/decidim/attributes/array.rb +62 -0
  479. data/lib/decidim/attributes/blob.rb +20 -0
  480. data/lib/decidim/attributes/clean_string.rb +12 -6
  481. data/lib/decidim/attributes/hash.rb +36 -0
  482. data/lib/decidim/attributes/integer.rb +17 -0
  483. data/lib/decidim/attributes/localized_date.rb +8 -14
  484. data/lib/decidim/attributes/model.rb +24 -0
  485. data/lib/decidim/attributes/object.rb +28 -0
  486. data/lib/decidim/attributes/symbol.rb +23 -0
  487. data/lib/decidim/attributes/time_with_zone.rb +7 -17
  488. data/lib/decidim/attributes.rb +29 -0
  489. data/lib/decidim/authorable.rb +21 -6
  490. data/lib/decidim/authorization_form_builder.rb +9 -11
  491. data/lib/decidim/carrier_wave_migrator_service.rb +15 -15
  492. data/lib/decidim/coauthorable.rb +22 -4
  493. data/lib/decidim/command.rb +44 -0
  494. data/lib/decidim/common_passwords.rb +1 -1
  495. data/lib/decidim/component_manifest.rb +5 -5
  496. data/lib/decidim/component_validator.rb +2 -2
  497. data/lib/decidim/content_block_manifest.rb +1 -1
  498. data/lib/decidim/content_parsers/hashtag_parser.rb +2 -2
  499. data/lib/decidim/content_parsers/resource_parser.rb +1 -1
  500. data/lib/decidim/content_parsers/user_group_parser.rb +1 -1
  501. data/lib/decidim/content_parsers/user_parser.rb +4 -4
  502. data/lib/decidim/content_renderers/hashtag_renderer.rb +1 -1
  503. data/lib/decidim/content_renderers/link_renderer.rb +2 -2
  504. data/lib/decidim/content_renderers/user_group_renderer.rb +1 -1
  505. data/lib/decidim/content_renderers/user_renderer.rb +1 -1
  506. data/lib/decidim/controller_helpers.rb +41 -0
  507. data/lib/decidim/core/engine.rb +35 -19
  508. data/lib/decidim/core/test/factories.rb +54 -21
  509. data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +16 -4
  510. data/lib/decidim/core/test/shared_examples/amendable/amendment_form_examples.rb +1 -1
  511. data/lib/decidim/core/test/shared_examples/authorable_interface_examples.rb +15 -2
  512. data/lib/decidim/core/test/shared_examples/coauthorable_interface_examples.rb +2 -2
  513. data/lib/decidim/core/test/shared_examples/comments_examples.rb +203 -60
  514. data/lib/decidim/core/test/shared_examples/errors.rb +0 -2
  515. data/lib/decidim/core/test/shared_examples/localised_email.rb +1 -1
  516. data/lib/decidim/core/test/shared_examples/logo_email.rb +1 -1
  517. data/lib/decidim/core/test/shared_examples/map_examples.rb +3 -6
  518. data/lib/decidim/core/test/shared_examples/preview_component_with_share_token_examples.rb +0 -6
  519. data/lib/decidim/core/test/shared_examples/resource_search_examples.rb +120 -40
  520. data/lib/decidim/core/test/shared_examples/resourceable.rb +0 -6
  521. data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +3 -7
  522. data/lib/decidim/core/test/shared_examples/searchable_participatory_space_examples.rb +1 -1
  523. data/lib/decidim/core/test/shared_examples/searchable_resources_shared_context.rb +1 -1
  524. data/lib/decidim/core/test/shared_examples/system_endorse_resource_examples.rb +3 -3
  525. data/lib/decidim/core/test/shared_examples/translated_event_examples.rb +2 -2
  526. data/lib/decidim/core/test/shared_examples/with_endorsable_permissions_examples.rb +1 -1
  527. data/lib/decidim/core/test.rb +0 -4
  528. data/lib/decidim/core/version.rb +1 -1
  529. data/lib/decidim/core.rb +106 -55
  530. data/lib/decidim/{data_portability.rb → download_your_data.rb} +3 -3
  531. data/lib/decidim/{data_portability_serializers/data_portability_conversation_serializer.rb → download_your_data_serializers/download_your_data_conversation_serializer.rb} +2 -2
  532. data/lib/decidim/{data_portability_serializers/data_portability_follow_serializer.rb → download_your_data_serializers/download_your_data_follow_serializer.rb} +2 -2
  533. data/lib/decidim/{data_portability_serializers/data_portability_identity_serializer.rb → download_your_data_serializers/download_your_data_identity_serializer.rb} +2 -2
  534. data/lib/decidim/{data_portability_serializers/data_portability_notification_serializer.rb → download_your_data_serializers/download_your_data_notification_serializer.rb} +2 -2
  535. data/lib/decidim/{data_portability_serializers/data_portability_participatory_space_private_user_serializer.rb → download_your_data_serializers/download_your_data_participatory_space_private_user_serializer.rb} +2 -2
  536. data/lib/decidim/{data_portability_serializers/data_portability_report_serializer.rb → download_your_data_serializers/download_your_data_report_serializer.rb} +2 -2
  537. data/lib/decidim/{data_portability_serializers/data_portability_user_group_serializer.rb → download_your_data_serializers/download_your_data_user_group_serializer.rb} +2 -2
  538. data/lib/decidim/{data_portability_serializers/data_portability_user_serializer.rb → download_your_data_serializers/download_your_data_user_serializer.rb} +3 -3
  539. data/lib/decidim/download_your_data_serializers.rb +23 -0
  540. data/lib/decidim/endorsable.rb +1 -1
  541. data/lib/decidim/engine_router.rb +7 -1
  542. data/lib/decidim/env.rb +56 -0
  543. data/lib/decidim/event_recorder.rb +25 -0
  544. data/lib/decidim/events/base_event.rb +10 -14
  545. data/lib/decidim/events/simple_event.rb +6 -5
  546. data/lib/decidim/exporters/export_data.rb +1 -1
  547. data/lib/decidim/exporters/export_manifest.rb +2 -1
  548. data/lib/decidim/exporters.rb +1 -10
  549. data/lib/decidim/file_validator_humanizer.rb +24 -1
  550. data/lib/decidim/filterable_resource.rb +55 -0
  551. data/lib/decidim/fingerprint_calculator.rb +2 -4
  552. data/lib/decidim/form_builder.rb +174 -145
  553. data/lib/decidim/gamification/badge.rb +2 -3
  554. data/lib/decidim/gamification/badge_scorer.rb +1 -0
  555. data/lib/decidim/has_area.rb +27 -0
  556. data/lib/decidim/has_attachments.rb +2 -2
  557. data/lib/decidim/has_category.rb +36 -0
  558. data/lib/decidim/has_resource_permission.rb +2 -0
  559. data/lib/decidim/importers/import_manifest.rb +3 -21
  560. data/lib/decidim/jsonb_attributes.rb +6 -4
  561. data/lib/decidim/manifest_messages.rb +23 -0
  562. data/lib/decidim/map/autocomplete.rb +6 -4
  563. data/lib/decidim/map/frontend.rb +2 -2
  564. data/lib/decidim/map/provider/dynamic_map/here.rb +1 -46
  565. data/lib/decidim/map/provider/geocoding/here.rb +5 -5
  566. data/lib/decidim/map/provider/here.rb +3 -0
  567. data/lib/decidim/map/provider/osm.rb +3 -0
  568. data/lib/decidim/map.rb +4 -4
  569. data/lib/decidim/menu.rb +1 -1
  570. data/lib/decidim/metric_manifest.rb +2 -2
  571. data/lib/decidim/nicknamizable.rb +1 -1
  572. data/lib/decidim/notification_setting_manifest.rb +19 -0
  573. data/lib/decidim/organization_settings.rb +8 -7
  574. data/lib/decidim/participatory_space_context_manifest.rb +2 -2
  575. data/lib/decidim/participatory_space_manifest.rb +2 -2
  576. data/lib/decidim/participatory_space_resourceable.rb +1 -7
  577. data/lib/decidim/processes_file_locally.rb +31 -0
  578. data/lib/decidim/publicable.rb +0 -4
  579. data/lib/decidim/query.rb +84 -0
  580. data/lib/decidim/record_encryptor.rb +29 -8
  581. data/lib/decidim/reminder_manifest.rb +75 -0
  582. data/lib/decidim/reminder_registry.rb +67 -0
  583. data/lib/decidim/resource_manifest.rb +1 -1
  584. data/lib/decidim/resourceable.rb +15 -5
  585. data/lib/decidim/scopable.rb +15 -0
  586. data/lib/decidim/settings_manifest.rb +4 -4
  587. data/lib/decidim/spring.rb +16 -0
  588. data/lib/decidim/translatable_attributes.rb +13 -16
  589. data/lib/decidim/url_option_resolver.rb +50 -0
  590. data/lib/decidim/view_hooks.rb +1 -1
  591. data/lib/decidim/view_model.rb +5 -1
  592. data/lib/decidim/webpacker/thread_safe_compiler.rb +30 -0
  593. data/lib/decidim/webpacker/webpack/custom.js +15 -3
  594. data/lib/decidim/webpacker/webpacker.yml +1 -1
  595. data/lib/decidim/webpacker.rb +2 -0
  596. data/lib/devise/models/decidim_validatable.rb +1 -1
  597. data/lib/tasks/decidim_active_storage_migration_tasks.rake +1 -3
  598. data/lib/tasks/{decidim_data_portability_tasks.rake → decidim_download_your_data_tasks.rake} +9 -9
  599. data/lib/tasks/decidim_mailers_tasks.rake +23 -0
  600. data/lib/tasks/decidim_metrics_tasks.rake +1 -1
  601. data/lib/tasks/decidim_pwa_tasks.rake +18 -0
  602. data/lib/tasks/decidim_reminders_tasks.rake +17 -0
  603. data/lib/tasks/decidim_tasks.rake +6 -1
  604. data/lib/tasks/decidim_webpacker_tasks.rake +1 -1
  605. data/lib/tasks/upgrade/decidim_fix_nickname_uniqueness.rake +51 -0
  606. metadata +186 -105
  607. data/app/controllers/decidim/cookie_policy_controller.rb +0 -24
  608. data/app/helpers/decidim/cookies_helper.rb +0 -11
  609. data/app/packs/src/decidim/editor/clipboard_override.js +0 -147
  610. data/app/packs/src/decidim/editor/clipboard_utilities.js +0 -119
  611. data/app/packs/src/decidim/vizzs/renders.js +0 -9
  612. data/app/packs/src/decidim/vizzs.js +0 -1
  613. data/app/packs/stylesheets/decidim/modules/_cookie-bar.scss +0 -26
  614. data/app/scrubbers/decidim/admin_input_scrubber.rb +0 -27
  615. data/app/services/decidim/home_activity_search.rb +0 -80
  616. data/app/services/decidim/participatory_space_search.rb +0 -54
  617. data/app/views/decidim/cookie_policy/accept.js.erb +0 -3
  618. data/app/views/decidim/export_mailer/data_portability_export.html.erb +0 -7
  619. data/app/views/decidim/links/_invalid_url_modal.html.erb +0 -17
  620. data/app/views/decidim/links/invalid_url.js.erb +0 -24
  621. data/config/environment.rb +0 -3
  622. data/config/locales/fa-IR.yml +0 -1
  623. data/config/locales/gn-PY.yml +0 -4
  624. data/config/locales/ka-GE.yml +0 -4
  625. data/config/locales/kaa.yml +0 -5
  626. data/config/locales/lo-LA.yml +0 -1
  627. data/config/locales/oc-FR.yml +0 -3
  628. data/config/locales/sq-AL.yml +0 -1
  629. data/config/locales/th-TH.yml +0 -1
  630. data/db/migrate/20231027142329_change_default_value_for_decidim_endorsements.rb +0 -11
  631. data/lib/decidim/core/test/shared_examples/editor_shared_examples.rb +0 -10
  632. data/lib/decidim/core/test/shared_examples/mcell_examples.rb +0 -17
  633. data/lib/decidim/core/test/shared_examples/resource_endorsed_event_examples.rb +0 -60
  634. data/lib/decidim/core/test/shared_examples/versions_controller_examples.rb +0 -40
  635. data/lib/decidim/data_portability_serializers.rb +0 -23
  636. data/lib/decidim/dependency_resolver.rb +0 -278
  637. data/lib/decidim/middleware/rails_cookies.rb +0 -23
  638. data/lib/tasks/upgrade/decidim_deduplicate_endorsements.rake +0 -53
  639. data/lib/tasks/upgrade/decidim_user_moderation.rake +0 -14
  640. /data/app/packs/src/decidim/vizzs/{metrics.js → index.js} +0 -0
  641. /data/app/views/decidim/application/{_document.html.erb → _document.erb} +0 -0
  642. /data/app/views/decidim/application/{_photos.html.erb → _photos.erb} +0 -0
  643. /data/app/views/decidim/{data_portability → download_your_data}/export.html.erb +0 -0
@@ -8,22 +8,27 @@ module Decidim
8
8
 
9
9
  def build_gallery(attached_to = nil)
10
10
  @gallery = []
11
- @form.add_photos.each do |photo|
12
- next unless image? photo
11
+ @form.add_photos.compact_blank.each do |photo|
12
+ if photo.is_a?(Hash) && photo.has_key?(:id)
13
+ update_attachment_title_for(photo)
14
+ next
15
+ end
13
16
 
14
17
  @gallery << Attachment.new(
15
- title: { I18n.locale => photo.original_filename },
18
+ title: photos_title(photo),
16
19
  attached_to: attached_to || gallery_attached_to,
17
- file: photo, # Define attached_to before this
18
- content_type: photo.content_type
20
+ file: photos_signed_id(photo), # Define attached_to before this
21
+ content_type: photos_content_type(photo)
19
22
  )
20
23
  end
21
24
  end
22
25
 
23
- def image?(image)
24
- return unless image.respond_to? :content_type
26
+ def update_attachment_title_for(photo)
27
+ Decidim::Attachment.find(photo[:id]).update(title: title_for(photo))
28
+ end
25
29
 
26
- image.content_type.start_with? "image"
30
+ def image?(signed_id)
31
+ blob(signed_id).content_type.start_with? "image"
27
32
  end
28
33
 
29
34
  def gallery_invalid?
@@ -36,17 +41,27 @@ module Decidim
36
41
  false
37
42
  end
38
43
 
39
- def create_gallery
44
+ def create_gallery(first_weight: 0)
45
+ weight = first_weight
46
+ # Add the weights first to the old photos
47
+ @form.photos.each do |photo|
48
+ photo.update!(weight: weight)
49
+ weight += 1
50
+ end
40
51
  @gallery.map! do |photo|
52
+ photo.weight = weight
41
53
  photo.attached_to = gallery_attached_to
42
54
  photo.save!
55
+ weight += 1
43
56
  @form.photos << photo
44
57
  end
45
58
  end
46
59
 
47
60
  def photo_cleanup!
48
61
  gallery_attached_to.photos.each do |photo|
49
- photo.destroy! if @form.photos.map(&:id).exclude? photo.id
62
+ next unless @form.photos.map(&:id).exclude?(photo.id)
63
+
64
+ photo.destroy! if (@form.respond_to?(:documents) && @form.documents.map(&:id).exclude?(photo.id)) || !@form.respond_to?(:documents)
50
65
  end
51
66
  # manually reset cached photos
52
67
  gallery_attached_to.reload
@@ -68,5 +83,25 @@ module Decidim
68
83
 
69
84
  form.current_component.organization if form.respond_to?(:current_component)
70
85
  end
86
+
87
+ def photos_signed_id(photo)
88
+ return photo[:file] if photo.is_a?(Hash)
89
+
90
+ photo
91
+ end
92
+
93
+ def photos_title(photo)
94
+ return { I18n.locale => photo[:title] } if photo.is_a?(Hash) && photo.has_key?(:title)
95
+
96
+ { I18n.locale => "" }
97
+ end
98
+
99
+ def photos_content_type(photo)
100
+ blob(photos_signed_id(photo)).content_type
101
+ end
102
+
103
+ def blob(signed_id)
104
+ ActiveStorage::Blob.find_signed(signed_id)
105
+ end
71
106
  end
72
107
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # A command with the business logic to invite a user to an organization.
5
- class InviteUser < Rectify::Command
5
+ class InviteUser < Decidim::Command
6
6
  # Public: Initializes the command.
7
7
  #
8
8
  # form - A form object with the params.
@@ -27,9 +27,7 @@ module Decidim
27
27
  attr_reader :form
28
28
 
29
29
  def user
30
- # rubocop:disable Rails/FindBy
31
30
  @user ||= Decidim::User.where(organization: form.organization).where(email: form.email.downcase).first
32
- # rubocop:enable Rails/FindBy
33
31
  end
34
32
 
35
33
  def update_user
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # A command with the business logic to invite an user to an organization.
5
- class InviteUserAgain < Rectify::Command
5
+ class InviteUserAgain < Decidim::Command
6
6
  # Public: Initializes the command.
7
7
  #
8
8
  # user - The user that receives the invitation instructions.
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # A command with all the business logic to invite a user to a group.
5
- class InviteUserToGroup < Rectify::Command
5
+ class InviteUserToGroup < Decidim::Command
6
6
  # Public: Initializes the command.
7
7
  #
8
8
  # form - A form object with the params.
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # A command with all the business logic to join a user group.
5
- class JoinUserGroup < Rectify::Command
5
+ class JoinUserGroup < Decidim::Command
6
6
  # Public: Initializes the command.
7
7
  #
8
8
  # user - the user that wants to join the group
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # A command with all the business logic to leave a user group.
5
- class LeaveUserGroup < Rectify::Command
5
+ class LeaveUserGroup < Decidim::Command
6
6
  # Public: Initializes the command.
7
7
  #
8
8
  # user - the user that wants to leave the group
@@ -20,6 +20,7 @@ module Decidim
20
20
  # Returns nothing.
21
21
  def call
22
22
  return broadcast(:invalid) unless can_leave?
23
+ return broadcast(:last_admin) if last_admin?
23
24
 
24
25
  leave_user_group
25
26
 
@@ -35,7 +36,12 @@ module Decidim
35
36
  end
36
37
 
37
38
  def can_leave?
38
- Decidim::UserGroupMembership.where(user: user, user_group: user_group).where.not(role: :creator).any?
39
+ Decidim::UserGroupMembership.where(user: user, user_group: user_group).any?
40
+ end
41
+
42
+ def last_admin?
43
+ admin_memberships = Decidim::UserGroupMembership.where(user_group: user_group, role: [:creator, :admin])
44
+ admin_memberships.length == 1 && admin_memberships.pluck(:decidim_user_id).include?(user.id)
39
45
  end
40
46
  end
41
47
  end
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module Messaging
5
5
  # A command with all the business logic for replying to a conversation
6
- class ReplyToConversation < Rectify::Command
6
+ class ReplyToConversation < Decidim::Command
7
7
  # Public: Initializes the command.
8
8
  #
9
9
  # conversation - The conversation to be updated.
@@ -72,7 +72,7 @@ module Decidim
72
72
  end
73
73
 
74
74
  # in order for a recipient to receive an email it should not have direct-messages disabled
75
- # if direct-messages are disabled, only send if he follows the sending user
75
+ # if direct-messages are disabled, only send if they follow the sending user
76
76
  def notify(recipient)
77
77
  return unless conversation.unread_count(recipient) == 1
78
78
  return unless recipient.accepts_conversation?(form.context.current_user)
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module Messaging
5
5
  # A command with all the business logic for replying to a conversation
6
- class StartConversation < Rectify::Command
6
+ class StartConversation < Decidim::Command
7
7
  # Public: Initializes the command.
8
8
  #
9
9
  # form - A conversation form
@@ -72,7 +72,7 @@ module Decidim
72
72
  end
73
73
 
74
74
  # in order for a recipient to receive an email it should not have direct-messages disabled
75
- # if direct-messages are disabled, only send if he follows the sending user
75
+ # if direct-messages are disabled, only send if they follow the sending user
76
76
  def notify(recipient)
77
77
  return unless recipient.accepts_conversation?(form.context.current_user)
78
78
 
@@ -6,16 +6,25 @@ module Decidim
6
6
 
7
7
  def build_attachments
8
8
  @documents = []
9
- @form.add_documents.each do |file|
9
+ @form.add_documents.compact_blank.each do |attachment|
10
+ if attachment.is_a?(Hash) && attachment.has_key?(:id)
11
+ update_attachment_title_for(attachment)
12
+ next
13
+ end
14
+
10
15
  @documents << Attachment.new(
11
- title: { I18n.locale => file.original_filename },
16
+ title: title_for(attachment),
12
17
  attached_to: @attached_to || documents_attached_to,
13
- file: file,
14
- content_type: file.content_type
18
+ file: signed_id_for(attachment),
19
+ content_type: content_type_for(attachment)
15
20
  )
16
21
  end
17
22
  end
18
23
 
24
+ def update_attachment_title_for(attachment)
25
+ Decidim::Attachment.find(attachment[:id]).update(title: title_for(attachment))
26
+ end
27
+
19
28
  def attachments_invalid?
20
29
  @documents.each do |document|
21
30
  next if document.valid? || !document.errors.has_key?(:file)
@@ -30,10 +39,18 @@ module Decidim
30
39
  false
31
40
  end
32
41
 
33
- def create_attachments
42
+ def create_attachments(first_weight: 0)
43
+ weight = first_weight
44
+ # Add the weights first to the old document
45
+ @form.documents.each do |document|
46
+ document.update!(weight: weight)
47
+ weight += 1
48
+ end
34
49
  @documents.map! do |document|
50
+ document.weight = weight
35
51
  document.attached_to = documents_attached_to
36
52
  document.save!
53
+ weight += 1
37
54
  @form.documents << document
38
55
  end
39
56
  end
@@ -57,5 +74,27 @@ module Decidim
57
74
 
58
75
  form.current_component.organization if form.respond_to?(:current_component)
59
76
  end
77
+
78
+ def signed_id_for(attachment)
79
+ return attachment[:file] if attachment.is_a?(Hash)
80
+
81
+ attachment
82
+ end
83
+
84
+ def title_for(attachment)
85
+ return { I18n.locale => attachment[:title] } if attachment.is_a?(Hash) && attachment.has_key?(:title)
86
+
87
+ { I18n.locale => "" }
88
+ end
89
+
90
+ def content_type_for(attachment)
91
+ return attachment.content_type if attachment.instance_of?(ActionDispatch::Http::UploadedFile)
92
+
93
+ blob(signed_id_for(attachment)).content_type
94
+ end
95
+
96
+ def blob(signed_id)
97
+ ActiveStorage::Blob.find_signed(signed_id)
98
+ end
60
99
  end
61
100
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # A command with all the business logic to promote a user to group admin.
5
- class PromoteMembership < Rectify::Command
5
+ class PromoteMembership < Decidim::Command
6
6
  # Public: Initializes the command.
7
7
  #
8
8
  # membership - the UserGroupMembership to be promoted.
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  # A command with all the business logic to reject an invitation to belong to a
5
5
  # group.
6
- class RejectGroupInvitation < Rectify::Command
6
+ class RejectGroupInvitation < Decidim::Command
7
7
  # Public: Initializes the command.
8
8
  #
9
9
  # user_group - the UserGroup where the user has been invited
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  # A command with all the business logic to reject a join request to a user
5
5
  # group.
6
- class RejectUserGroupJoinRequest < Rectify::Command
6
+ class RejectUserGroupJoinRequest < Decidim::Command
7
7
  # Public: Initializes the command.
8
8
  #
9
9
  # membership - the UserGroupMembership to be accepted.
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # A command with all the business logic to remove a user from a group.
5
- class RemoveUserFromGroup < Rectify::Command
5
+ class RemoveUserFromGroup < Decidim::Command
6
6
  # Public: Initializes the command.
7
7
  #
8
8
  # membership - the UserGroupMembership to be accepted.
@@ -0,0 +1,18 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ class ResendConfirmationInstructions < Decidim::Command
5
+ def initialize(user)
6
+ @user = user
7
+ @unconfirmed_email = user.unconfirmed_email
8
+ end
9
+
10
+ def call
11
+ return broadcast(:invalid) unless @unconfirmed_email
12
+
13
+ ResendConfirmationInstructionsJob.perform_later(@user)
14
+
15
+ broadcast(:ok)
16
+ end
17
+ end
18
+ end
@@ -2,8 +2,8 @@
2
2
 
3
3
  module Decidim
4
4
  # A command that will act as a search service, with all the business logic for performing searches.
5
- class Search < Rectify::Command
6
- ACCEPTED_FILTERS = [:decidim_scope_id].freeze
5
+ class Search < Decidim::Command
6
+ ACCEPTED_FILTERS = [:decidim_scope_id_eq].freeze
7
7
  HIGHLIGHTED_RESULTS_COUNT = 4
8
8
 
9
9
  # Public: Initializes the command.
@@ -30,9 +30,9 @@ module Decidim
30
30
  result_ids = filtered_query_for(class_name).pluck(:resource_id)
31
31
  results_count = result_ids.count
32
32
 
33
- results = if filters[:resource_type].present? && filters[:resource_type] == class_name
33
+ results = if filters[:with_resource_type].present? && filters[:with_resource_type] == class_name
34
34
  paginate(klass.order_by_id_list(result_ids))
35
- elsif filters[:resource_type].present?
35
+ elsif filters[:with_resource_type].present?
36
36
  ApplicationRecord.none
37
37
  else
38
38
  klass.order_by_id_list(result_ids.take(HIGHLIGHTED_RESULTS_COUNT))
@@ -59,15 +59,15 @@ module Decidim
59
59
  def clean_filters
60
60
  @clean_filters ||= filters.select do |attribute_name, value|
61
61
  ACCEPTED_FILTERS.include?(attribute_name.to_sym) && value.present?
62
- end.merge(decidim_participatory_space: spaces_to_filter).compact
62
+ end.compact
63
63
  end
64
64
 
65
65
  def spaces_to_filter
66
- return nil if filters[:space_state].blank?
66
+ return nil if filters[:with_space_state].blank?
67
67
 
68
68
  Decidim.participatory_space_manifests.flat_map do |manifest|
69
69
  public_spaces = manifest.participatory_spaces.call(organization).public_spaces
70
- spaces = case filters[:space_state]
70
+ spaces = case filters[:with_space_state]
71
71
  when "active"
72
72
  public_spaces.active_spaces
73
73
  when "future"
@@ -88,9 +88,10 @@ module Decidim
88
88
  resource_type: class_name
89
89
  )
90
90
 
91
- clean_filters.each_pair do |attribute_name, value|
92
- query = query.where(attribute_name => value)
91
+ if (spaces = spaces_to_filter)
92
+ query = query.where(decidim_participatory_space: spaces)
93
93
  end
94
+ query = query.ransack(clean_filters).result if clean_filters.any?
94
95
 
95
96
  query = query.order("datetime DESC")
96
97
  query = query.global_search(I18n.transliterate(term)) if term.present?
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # A command with all the business logic to unendorse a resource, both as a user or as a user_group.
5
- class UnendorseResource < Rectify::Command
5
+ class UnendorseResource < Decidim::Command
6
6
  # Public: Initializes the command.
7
7
  #
8
8
  # resource - A Decidim::Endorsable object.
@@ -31,7 +31,7 @@ module Decidim
31
31
  query = if @current_group.present?
32
32
  @resource.endorsements.where(decidim_user_group_id: @current_group&.id)
33
33
  else
34
- @resource.endorsements.where(author: @current_user, decidim_user_group_id: 0)
34
+ @resource.endorsements.where(author: @current_user)
35
35
  end
36
36
  query.destroy_all
37
37
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # This command unsubscribes user from newsletter.
5
- class UnsubscribeSettings < Rectify::Command
5
+ class UnsubscribeSettings < Decidim::Command
6
6
  # unsubscribe user from newsletter.
7
7
  #
8
8
  # user - The user to be updated.
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # This command updates the user's account.
5
- class UpdateAccount < Rectify::Command
5
+ class UpdateAccount < Decidim::Command
6
6
  # Updates a user's account.
7
7
  #
8
8
  # user - The user to be updated.
@@ -42,7 +42,7 @@ module Decidim
42
42
 
43
43
  def update_avatar
44
44
  if @form.avatar.present?
45
- @user.avatar = @form.avatar
45
+ @user.avatar.attach(@form.avatar)
46
46
  elsif @form.remove_avatar
47
47
  @user.avatar = nil
48
48
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # This command updates the user's notifications settings.
5
- class UpdateNotificationsSettings < Rectify::Command
5
+ class UpdateNotificationsSettings < Decidim::Command
6
6
  # Updates a user's notifications settings.
7
7
  #
8
8
  # user - The user to be updated.
@@ -24,11 +24,12 @@ module Decidim
24
24
  private
25
25
 
26
26
  def update_notifications_settings
27
- @user.email_on_notification = @form.email_on_notification
28
27
  @user.newsletter_notifications_at = @form.newsletter_notifications_at
29
28
  @user.notification_types = @form.notification_types
30
29
  @user.direct_message_types = @form.direct_message_types
31
30
  @user.email_on_moderations = @form.email_on_moderations
31
+ @user.notification_settings = @user.notification_settings.merge(@form.notification_settings)
32
+ @user.notifications_sending_frequency = @form.notifications_sending_frequency
32
33
  end
33
34
  end
34
35
  end
@@ -0,0 +1,31 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ # Decidim command updates user's password
5
+ class UpdatePassword < Decidim::Command
6
+ # Updates a user's password.
7
+ #
8
+ # user - The user to be updated.
9
+ # form - The form with the data.
10
+ def initialize(user, form)
11
+ @user = user
12
+ @form = form
13
+ end
14
+
15
+ def call
16
+ return broadcast(:invalid) if form.invalid?
17
+
18
+ user.password = form.password
19
+
20
+ if user.save
21
+ broadcast(:ok)
22
+ else
23
+ broadcast(:invalid)
24
+ end
25
+ end
26
+
27
+ private
28
+
29
+ attr_reader :form, :user
30
+ end
31
+ end
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # A command with all the business logic to update a user group profile.
5
- class UpdateUserGroup < Rectify::Command
5
+ class UpdateUserGroup < Decidim::Command
6
6
  # Public: Initializes the command.
7
7
  #
8
8
  # form - A form object with the params.
@@ -60,7 +60,7 @@ module Decidim
60
60
  affected_users: Decidim::User.org_admins_except_me(form.current_user)
61
61
  }
62
62
 
63
- Decidim::EventsManager.publish(data)
63
+ Decidim::EventsManager.publish(**data)
64
64
  end
65
65
  end
66
66
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # This command updates the user's interests.
5
- class UpdateUserInterests < Rectify::Command
5
+ class UpdateUserInterests < Decidim::Command
6
6
  # Updates a user's intersts.
7
7
  #
8
8
  # user - The user to be updated.
@@ -0,0 +1,15 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ class ValidateUpload < Decidim::Command
5
+ def initialize(form)
6
+ @form = form
7
+ end
8
+
9
+ def call
10
+ return broadcast(:invalid, @form.errors) if @form.invalid?
11
+
12
+ broadcast(:ok)
13
+ end
14
+ end
15
+ end
@@ -25,7 +25,6 @@ module Decidim
25
25
  helper Decidim::MetaTagsHelper
26
26
  helper Decidim::DecidimFormHelper
27
27
  helper Decidim::LanguageChooserHelper
28
- helper Decidim::CookiesHelper
29
28
  helper Decidim::ReplaceButtonsHelper
30
29
  helper Decidim::LayoutHelper
31
30
  helper Decidim::MenuHelper
@@ -20,20 +20,24 @@ module Decidim
20
20
  end
21
21
 
22
22
  def respond_to_missing?(method_name, include_private = false)
23
- @filter.present? && @filter.has_key?(method_name) || super
23
+ (@filter.present? && @filter.has_key?(method_name)) || super
24
24
  end
25
25
  end
26
26
 
27
27
  included do
28
- helper_method :search, :filter
28
+ helper_method :search, :filter_params, :filter
29
29
 
30
30
  private
31
31
 
32
32
  def search
33
- @search ||= search_klass.new(search_params)
33
+ @search ||= search_with(filter_params)
34
34
  end
35
35
 
36
- def search_klass
36
+ def search_with(provided_params)
37
+ search_collection.ransack(provided_params, context_params.merge(auth_object: current_user))
38
+ end
39
+
40
+ def search_collection
37
41
  raise NotImplementedError, "A search class is neeeded to filter resources"
38
42
  end
39
43
 
@@ -41,19 +45,15 @@ module Decidim
41
45
  @filter ||= Filter.new(filter_params)
42
46
  end
43
47
 
44
- def search_params
45
- default_search_params
46
- .merge(filter_params)
47
- .merge(context_params)
48
- end
49
-
48
+ # Fetches the correct filter parameters from the request parameters in
49
+ # order to limit the parameters which can be used for searching the
50
+ # resources. Otherwise the user could pass extra search parameters from
51
+ # the request using the Ransack API.
50
52
  def filter_params
51
- default_filter_params
52
- .merge(params.to_unsafe_h[:filter].try(:symbolize_keys) || {})
53
- end
54
-
55
- def default_search_params
56
- {}
53
+ @filter_params = begin
54
+ passed_params = params.to_unsafe_h[:filter].try(:symbolize_keys) || {}
55
+ default_filter_params.merge(passed_params.slice(*default_filter_params.keys))
56
+ end
57
57
  end
58
58
 
59
59
  def default_filter_params
@@ -76,14 +76,13 @@ module Decidim
76
76
  end
77
77
  end
78
78
 
79
- # If the controller responds to current_component, its search service uses the
80
- # base class Decidim::ResourceSearch; else it uses the ParticipatorySpaceSearch.
81
- # They need different context_params to set up the base_query:
82
- # - ResourceSearch uses `component`
83
- # - ParticipatorySpaceSearch uses `organization`
84
- # - Both use `current_user`
85
- # - Both need `organization` for localized searches in order to fetch the
86
- # available locales from the organization in Decidim::ResourceSearch.
79
+ # If the controller responds to current_component, its is probably
80
+ # searching against that component. Otherwise it is be likely to search
81
+ # against a participatory space. The context params are passed to the
82
+ # Ransack search classes which may be customized per model in case they
83
+ # need this contextual information. For such searches, take a look at the
84
+ # ResourceSearch class or any search class inheriting from that which
85
+ # utilize this context information, such as the current user.
87
86
  def context_params
88
87
  context = {
89
88
  current_user: current_user,
@@ -36,8 +36,7 @@ module Decidim
36
36
 
37
37
  def unauthorized_paths
38
38
  # /locale is for changing the locale
39
- # /cookies is for accepting the cookies
40
- %w(/locale /cookies) + Decidim::StaticPage.where(
39
+ %w(/locale) + Decidim::StaticPage.where(
41
40
  organization: current_organization,
42
41
  allow_public_access: true
43
42
  ).pluck(Arel.sql("CONCAT('/pages/', slug)"))
@@ -13,9 +13,9 @@ module Decidim
13
13
  end
14
14
 
15
15
  def disable_http_caching
16
- response.headers["Cache-Control"] = "no-cache, no-store"
17
16
  response.headers["Pragma"] = "no-cache"
18
17
  response.headers["Expires"] = "Fri, 01 Jan 1990 00:00:00 GMT"
18
+ response.cache_control.replace(no_cache: true, extras: ["no-store"])
19
19
  end
20
20
  end
21
21
  end