decidim-core 0.23.5 → 0.24.2

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 (460) 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.js.es6 +2 -0
  5. data/app/assets/javascripts/decidim/core/bundle.js +1 -1
  6. data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
  7. data/app/assets/javascripts/decidim/editor.js.es6 +15 -4
  8. data/app/assets/javascripts/decidim/editor/history_override.js.es6 +117 -0
  9. data/app/assets/javascripts/decidim/editor/linebreak_module.js.es6 +90 -0
  10. data/app/assets/javascripts/decidim/editor/modified_backspace_offset1.js.es6 +98 -0
  11. data/app/assets/javascripts/decidim/editor/modified_backspace_offset_any.js.es6 +48 -0
  12. data/app/assets/javascripts/decidim/editor/modified_backspace_utils.js.es6 +31 -0
  13. data/app/assets/javascripts/decidim/editor/modified_enter.js.es6 +123 -0
  14. data/app/assets/javascripts/decidim/form_filter.component.js.es6 +25 -0
  15. data/app/assets/javascripts/decidim/gallery.js.es6 +5 -0
  16. data/app/assets/javascripts/decidim/geocoding/attach_input.js.es6 +41 -4
  17. data/app/assets/javascripts/decidim/input_character_counter.js.es6 +6 -1
  18. data/app/assets/javascripts/decidim/map/controller/markers.js.es6 +40 -10
  19. data/app/assets/javascripts/decidim/session_timeouter.js.es6 +78 -0
  20. data/app/assets/stylesheets/decidim/_variables.scss +9 -0
  21. data/app/assets/stylesheets/decidim/email.scss +14 -2
  22. data/app/assets/stylesheets/decidim/extras/_external-links.scss +0 -1
  23. data/app/assets/stylesheets/decidim/extras/_process_stats.scss +1 -1
  24. data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +1 -0
  25. data/app/assets/stylesheets/decidim/modules/_author-avatar.scss +2 -2
  26. data/app/assets/stylesheets/decidim/modules/_buttons.scss +2 -2
  27. data/app/assets/stylesheets/decidim/modules/_cards.scss +18 -1
  28. data/app/assets/stylesheets/decidim/modules/_collapsible-list.scss +1 -1
  29. data/app/assets/stylesheets/decidim/modules/_comments.scss +5 -1
  30. data/app/assets/stylesheets/decidim/modules/_conference-speaker.scss +4 -3
  31. data/app/assets/stylesheets/decidim/modules/_data-picker.scss +7 -0
  32. data/app/assets/stylesheets/decidim/modules/_extra.scss +4 -0
  33. data/app/assets/stylesheets/decidim/modules/_forms.scss +4 -0
  34. data/app/assets/stylesheets/decidim/modules/_loading-spinner.scss +34 -0
  35. data/app/assets/stylesheets/decidim/modules/_modules.scss +1 -1
  36. data/app/assets/stylesheets/decidim/modules/_opinion-toggle.scss +1 -1
  37. data/app/assets/stylesheets/decidim/modules/_reveal.scss +6 -0
  38. data/app/assets/stylesheets/decidim/modules/_signup.scss +1 -0
  39. data/app/assets/stylesheets/decidim/modules/{_process-stats.scss → _space-stats.scss} +1 -1
  40. data/app/cells/decidim/activity_cell.rb +11 -8
  41. data/app/cells/decidim/announcement/show.erb +4 -4
  42. data/app/cells/decidim/announcement_cell.rb +43 -8
  43. data/app/cells/decidim/author/flag_user.erb +10 -0
  44. data/app/cells/decidim/author/profile_minicard.erb +1 -1
  45. data/app/cells/decidim/author_cell.rb +9 -1
  46. data/app/cells/decidim/card_m/top.erb +1 -1
  47. data/app/cells/decidim/card_m_cell.rb +1 -1
  48. data/app/cells/decidim/content_blocks/cta/show.erb +14 -0
  49. data/app/cells/decidim/content_blocks/cta_cell.rb +35 -0
  50. data/app/cells/decidim/content_blocks/cta_settings_form/show.erb +9 -0
  51. data/app/cells/decidim/content_blocks/cta_settings_form_cell.rb +13 -0
  52. data/app/cells/decidim/content_blocks/hero_cell.rb +14 -0
  53. data/app/cells/decidim/content_blocks/highlighted_elements/elements.erb +0 -0
  54. data/app/cells/decidim/content_blocks/highlighted_elements/heading.erb +0 -0
  55. data/app/cells/decidim/content_blocks/highlighted_elements/show.erb +4 -0
  56. data/app/cells/decidim/content_blocks/highlighted_elements_cell.rb +51 -0
  57. data/app/cells/decidim/content_blocks/highlighted_elements_settings_form/show.erb +3 -0
  58. data/app/cells/decidim/content_blocks/highlighted_elements_settings_form_cell.rb +28 -0
  59. data/app/cells/decidim/content_blocks/last_activity_cell.rb +11 -0
  60. data/app/cells/decidim/content_blocks/metrics_cell.rb +0 -6
  61. data/app/cells/decidim/content_blocks/stats_cell.rb +0 -6
  62. data/app/cells/decidim/date/show.erb +31 -0
  63. data/app/cells/decidim/date_cell.rb +50 -0
  64. data/app/cells/decidim/endorsement_buttons_cell.rb +3 -3
  65. data/app/cells/decidim/flag_modal/flag_user.erb +24 -0
  66. data/app/cells/decidim/flag_modal/show.erb +24 -0
  67. data/app/cells/decidim/flag_modal_cell.rb +25 -0
  68. data/app/cells/decidim/profile/inaccessible.erb +9 -0
  69. data/app/cells/decidim/profile_cell.rb +9 -1
  70. data/app/cells/decidim/profile_sidebar/show.erb +10 -1
  71. data/app/cells/decidim/profile_sidebar_cell.rb +1 -0
  72. data/app/cells/decidim/reported_content/show.erb +5 -0
  73. data/app/cells/decidim/reported_content_cell.rb +44 -0
  74. data/app/cells/decidim/scopes_picker/scope_picker_prompt.erb +3 -0
  75. data/app/cells/decidim/scopes_picker/scope_picker_values.erb +5 -0
  76. data/app/cells/decidim/scopes_picker/show.erb +14 -0
  77. data/app/cells/decidim/scopes_picker_cell.rb +93 -0
  78. data/app/cells/decidim/tos_page/announcement.erb +1 -1
  79. data/app/cells/decidim/tos_page/form.erb +15 -13
  80. data/app/cells/decidim/tos_page_cell.rb +10 -8
  81. data/app/cells/decidim/translation_bar_cell.rb +1 -1
  82. data/app/cells/decidim/user_conversation/conversation_header.erb +1 -1
  83. data/app/cells/decidim/user_conversations_cell.rb +1 -1
  84. data/app/commands/decidim/create_report.rb +11 -1
  85. data/app/commands/decidim/create_user_report.rb +67 -0
  86. data/app/commands/decidim/gallery_methods.rb +2 -2
  87. data/app/commands/decidim/multiple_attachments_methods.rb +14 -10
  88. data/app/commands/decidim/search.rb +5 -2
  89. data/app/commands/decidim/update_notifications_settings.rb +1 -0
  90. data/app/commands/decidim/update_user_group.rb +1 -0
  91. data/app/controllers/concerns/decidim/devise_controllers.rb +2 -0
  92. data/app/controllers/concerns/decidim/flaggable.rb +5 -1
  93. data/app/controllers/concerns/decidim/force_authentication.rb +11 -3
  94. data/app/controllers/concerns/decidim/locale_switcher.rb +5 -0
  95. data/app/controllers/concerns/decidim/needs_permission.rb +7 -1
  96. data/app/controllers/concerns/decidim/orderable.rb +3 -1
  97. data/app/controllers/concerns/decidim/paginable.rb +8 -1
  98. data/app/controllers/concerns/decidim/user_blocked_checker.rb +26 -0
  99. data/app/controllers/decidim/application_controller.rb +22 -0
  100. data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +3 -1
  101. data/app/controllers/decidim/devise/sessions_controller.rb +10 -6
  102. data/app/controllers/decidim/errors_controller.rb +1 -1
  103. data/app/controllers/decidim/locales_controller.rb +1 -1
  104. data/app/controllers/decidim/profiles_controller.rb +6 -0
  105. data/app/controllers/decidim/report_users_controller.rb +42 -0
  106. data/app/controllers/decidim/scopes_controller.rb +19 -10
  107. data/app/controllers/decidim/timeouts_controller.rb +28 -0
  108. data/app/controllers/decidim/user_activities_controller.rb +5 -0
  109. data/app/controllers/decidim/user_timeline_controller.rb +1 -0
  110. data/app/events/decidim/demoted_membership_event.rb +2 -2
  111. data/app/events/decidim/invited_to_group_event.rb +2 -2
  112. data/app/events/decidim/join_request_accepted_event.rb +2 -2
  113. data/app/events/decidim/join_request_created_event.rb +2 -2
  114. data/app/events/decidim/join_request_rejected_event.rb +2 -2
  115. data/app/events/decidim/promoted_to_admin_event.rb +2 -2
  116. data/app/events/decidim/removed_from_group_event.rb +2 -2
  117. data/app/forms/decidim/account_form.rb +2 -2
  118. data/app/forms/decidim/invite_user_form.rb +2 -2
  119. data/app/forms/decidim/messaging/conversation_form.rb +1 -1
  120. data/app/forms/decidim/messaging/message_form.rb +1 -1
  121. data/app/forms/decidim/notifications_settings_form.rb +20 -0
  122. data/app/forms/url_validator.rb +20 -0
  123. data/app/helpers/decidim/action_authorization_helper.rb +2 -0
  124. data/app/helpers/decidim/application_helper.rb +2 -2
  125. data/app/helpers/decidim/cache_helper.rb +14 -0
  126. data/app/helpers/decidim/cells_helper.rb +6 -0
  127. data/app/helpers/decidim/filters_helper.rb +9 -0
  128. data/app/helpers/decidim/messaging/conversation_helper.rb +11 -1
  129. data/app/helpers/decidim/newsletters_helper.rb +7 -9
  130. data/app/helpers/decidim/scopes_helper.rb +1 -1
  131. data/app/jobs/decidim/block_user_job.rb +11 -0
  132. data/app/jobs/decidim/export_job.rb +2 -2
  133. data/app/jobs/decidim/find_and_update_descendants_job.rb +48 -0
  134. data/app/jobs/decidim/machine_translation_resource_job.rb +3 -0
  135. data/app/jobs/decidim/machine_translation_save_job.rb +29 -0
  136. data/app/jobs/decidim/update_search_indexes_job.rb +11 -0
  137. data/app/jobs/decidim/user_report_job.rb +11 -0
  138. data/app/mailers/concerns/decidim/localised_mailer.rb +4 -2
  139. data/app/mailers/decidim/block_user_mailer.rb +21 -0
  140. data/app/mailers/decidim/notification_mailer.rb +0 -2
  141. data/app/mailers/decidim/reported_mailer.rb +33 -3
  142. data/app/mailers/decidim/user_report_mailer.rb +21 -0
  143. data/app/models/decidim/area.rb +0 -1
  144. data/app/models/decidim/area_type.rb +1 -1
  145. data/app/models/decidim/attachment.rb +3 -2
  146. data/app/models/decidim/attachment_collection.rb +1 -1
  147. data/app/models/decidim/authorization.rb +4 -0
  148. data/app/models/decidim/category.rb +6 -1
  149. data/app/models/decidim/follow.rb +1 -1
  150. data/app/models/decidim/impersonation_log.rb +5 -7
  151. data/app/models/decidim/metric.rb +2 -2
  152. data/app/models/decidim/moderation.rb +12 -0
  153. data/app/models/decidim/organization.rb +5 -1
  154. data/app/models/decidim/scope.rb +5 -2
  155. data/app/models/decidim/scope_type.rb +1 -1
  156. data/app/models/decidim/share_token.rb +1 -1
  157. data/app/models/decidim/static_page.rb +11 -1
  158. data/app/models/decidim/static_page_topic.rb +4 -0
  159. data/app/models/decidim/user.rb +19 -2
  160. data/app/models/decidim/user_base_entity.rb +13 -13
  161. data/app/models/decidim/user_block.rb +10 -0
  162. data/app/models/decidim/user_group.rb +5 -0
  163. data/app/models/decidim/user_moderation.rb +22 -0
  164. data/app/models/decidim/user_report.rb +31 -0
  165. data/app/permissions/decidim/permissions.rb +1 -3
  166. data/app/permissions/decidim/report_user_permissions.rb +13 -0
  167. data/app/presenters/decidim/admin_log/impersonation_log_presenter.rb +39 -0
  168. data/app/presenters/decidim/admin_log/organization_presenter.rb +1 -2
  169. data/app/presenters/decidim/admin_log/user_moderation_presenter.rb +63 -0
  170. data/app/presenters/decidim/admin_log/user_presenter.rb +18 -9
  171. data/app/presenters/decidim/home_stats_presenter.rb +3 -3
  172. data/app/presenters/decidim/log/diff_presenter.rb +4 -3
  173. data/app/presenters/decidim/log/resource_presenter.rb +4 -4
  174. data/app/presenters/decidim/log/user_presenter.rb +1 -1
  175. data/app/presenters/decidim/menu_presenter.rb +12 -7
  176. data/app/presenters/decidim/nil_presenter.rb +0 -2
  177. data/app/presenters/decidim/user_presenter.rb +1 -1
  178. data/app/queries/decidim/metrics/blocked_users_metric_manage.rb +26 -0
  179. data/app/queries/decidim/metrics/followers_metric_manage.rb +3 -0
  180. data/app/queries/decidim/metrics/participants_metric_manage.rb +3 -0
  181. data/app/queries/decidim/metrics/reported_users_metric_manage.rb +26 -0
  182. data/app/queries/decidim/metrics/user_reports_metric_manage.rb +26 -0
  183. data/app/queries/decidim/user_groups/accepted_memberships.rb +1 -1
  184. data/app/queries/decidim/user_groups/admin_memberships.rb +1 -1
  185. data/app/queries/decidim/user_groups/member_memberships.rb +1 -1
  186. data/app/services/decidim/activity_search.rb +1 -3
  187. data/app/services/decidim/base_diff_renderer.rb +1 -1
  188. data/app/services/decidim/data_portability_exporter.rb +1 -0
  189. data/app/services/decidim/email_notification_generator.rb +2 -2
  190. data/app/services/decidim/events_manager.rb +1 -1
  191. data/app/services/decidim/open_data_exporter.rb +36 -7
  192. data/app/services/decidim/zip_stream/zip_stream_writer.rb +3 -3
  193. data/app/uploaders/decidim/application_uploader.rb +22 -2
  194. data/app/uploaders/decidim/attachment_uploader.rb +2 -4
  195. data/app/uploaders/decidim/downloader.rb +9 -0
  196. data/app/uploaders/decidim/image_uploader.rb +9 -21
  197. data/app/uploaders/decidim/open_data_uploader.rb +5 -0
  198. data/app/uploaders/decidim/record_image_uploader.rb +2 -2
  199. data/app/validators/etiquette_validator.rb +0 -7
  200. data/app/validators/uploader_content_type_validator.rb +4 -2
  201. data/app/views/decidim/application/_document.html.erb +1 -1
  202. data/app/views/decidim/block_user_mailer/notify.html.erb +7 -0
  203. data/app/views/decidim/devise/confirmations/new.html.erb +1 -1
  204. data/app/views/decidim/devise/registrations/edit.html.erb +1 -1
  205. data/app/views/decidim/devise/unlocks/new.html.erb +1 -1
  206. data/app/views/decidim/messaging/conversations/_conversation.html.erb +1 -1
  207. data/app/views/decidim/messaging/conversations/_messages.html.erb +1 -1
  208. data/app/views/decidim/messaging/conversations/_show.html.erb +4 -4
  209. data/app/views/decidim/notifications_settings/show.html.erb +11 -0
  210. data/app/views/decidim/pages/_standalone.html.erb +3 -1
  211. data/app/views/decidim/reported_mailer/report.html.erb +17 -9
  212. data/app/views/decidim/searches/_filters_small_view.html.erb +1 -1
  213. data/app/views/decidim/shared/_check_boxes_tree.html.erb +3 -3
  214. data/app/views/decidim/shared/_component_announcement.html.erb +2 -2
  215. data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +1 -1
  216. data/app/views/decidim/user_report_mailer/notify.html.erb +7 -0
  217. data/app/views/decidim/widgets/_data_picker.html.erb +1 -1
  218. data/app/views/layouts/decidim/_application.html.erb +1 -0
  219. data/app/views/layouts/decidim/_js_configuration.html.erb +1 -1
  220. data/app/views/layouts/decidim/_main_footer.html.erb +6 -4
  221. data/app/views/layouts/decidim/_timeout_modal.html.erb +21 -0
  222. data/config/initializers/active_support.rb +7 -0
  223. data/config/initializers/devise.rb +1 -1
  224. data/config/initializers/omniauth.rb +1 -1
  225. data/config/locales/ar.yml +1 -9
  226. data/config/locales/bg.yml +1 -15
  227. data/config/locales/ca.yml +79 -14
  228. data/config/locales/cs.yml +83 -18
  229. data/config/locales/de.yml +78 -17
  230. data/config/locales/el.yml +1 -20
  231. data/config/locales/en.yml +81 -16
  232. data/config/locales/eo.yml +0 -1
  233. data/config/locales/es-MX.yml +79 -14
  234. data/config/locales/es-PY.yml +79 -14
  235. data/config/locales/es.yml +79 -14
  236. data/config/locales/eu.yml +1 -9
  237. data/config/locales/fi-plain.yml +78 -14
  238. data/config/locales/fi.yml +78 -14
  239. data/config/locales/fr-CA.yml +79 -18
  240. data/config/locales/fr.yml +76 -15
  241. data/config/locales/gl.yml +5 -17
  242. data/config/locales/hu.yml +1 -14
  243. data/config/locales/id-ID.yml +1 -9
  244. data/config/locales/is-IS.yml +0 -2
  245. data/config/locales/it.yml +65 -18
  246. data/config/locales/ja.yml +1 -19
  247. data/config/locales/lv.yml +1 -14
  248. data/config/locales/nl.yml +40 -17
  249. data/config/locales/no.yml +7 -20
  250. data/config/locales/pl.yml +78 -19
  251. data/config/locales/pt-BR.yml +1 -9
  252. data/config/locales/pt.yml +1 -20
  253. data/config/locales/ro-RO.yml +64 -18
  254. data/config/locales/ru.yml +1 -10
  255. data/config/locales/sk.yml +1 -14
  256. data/config/locales/sr-CS.yml +0 -9
  257. data/config/locales/sv.yml +67 -14
  258. data/config/locales/tr-TR.yml +62 -17
  259. data/config/locales/uk.yml +1 -7
  260. data/config/locales/zh-CN.yml +1 -19
  261. data/config/routes.rb +9 -4
  262. data/db/migrate/20170713131206_add_admin_to_users.rb +1 -1
  263. data/db/migrate/20180206143340_fix_reference_for_all_resources.rb +2 -0
  264. data/db/migrate/20180314085339_rename_maximum_votes_per_proposal_to_threshold_per_proposal.rb +2 -2
  265. data/db/migrate/20200929171508_remove_show_statistics_from_organizations.rb +7 -0
  266. data/db/migrate/20201010124755_create_decidim_user_moderations.rb +12 -0
  267. data/db/migrate/20201010124756_create_decidim_user_reports.rb +16 -0
  268. data/db/migrate/20201010224433_add_suspension_fields_to_decidim_users.rb +8 -0
  269. data/db/migrate/20201011074641_create_decidim_user_suspensions.rb +14 -0
  270. data/db/migrate/20201011081626_add_current_suspension_id_to_decidim_users.rb +7 -0
  271. data/db/migrate/20201013071533_add_reported_content_to_moderations.rb +7 -0
  272. data/db/migrate/20201019074554_add_locale_to_moderation_reports.rb +7 -0
  273. data/db/migrate/20201127114444_encrypt_authorization_metadatas.rb +35 -0
  274. data/db/migrate/20201128130723_add_allow_public_access_to_static_pages.rb +17 -0
  275. data/db/migrate/20201218144706_update_table_block_user_functionality.rb +8 -0
  276. data/db/migrate/20201218145252_rename_decidim_user_fields_for_block_functionality.rb +9 -0
  277. data/db/migrate/20210208134328_add_email_on_moderations_to_users.rb +7 -0
  278. data/db/migrate/20210310120640_add_followable_counter_cache_to_users.rb +16 -0
  279. data/db/seeds.rb +14 -13
  280. data/lib/decidim/amendable.rb +3 -2
  281. data/{app/functions/decidim/core → lib/decidim/api/functions}/component_finder_base.rb +1 -1
  282. data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list.rb +4 -4
  283. data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list_base.rb +3 -1
  284. data/lib/decidim/api/functions/needs_api_default_order.rb +24 -0
  285. data/{app/functions/decidim/core → lib/decidim/api/functions}/needs_api_filter_and_order.rb +0 -0
  286. data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_finder_base.rb +2 -2
  287. data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_list_base.rb +3 -1
  288. data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_finder.rb +1 -4
  289. data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_list.rb +1 -3
  290. data/{app/types/decidim/core → lib/decidim/api/input_filters}/base_input_filter.rb +0 -0
  291. data/{app/types/decidim/core → lib/decidim/api/input_filters}/component_input_filter.rb +20 -22
  292. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_hastaggable_input_filter.rb +1 -1
  293. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_localized_input_filter.rb +3 -3
  294. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_publishable_input_filter.rb +6 -6
  295. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_timestamp_input_filter.rb +12 -12
  296. data/{app/types/decidim/core → lib/decidim/api/input_filters}/participatory_space_input_filter.rb +0 -1
  297. data/lib/decidim/api/input_filters/user_entity_input_filter.rb +89 -0
  298. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/base_input_sort.rb +3 -2
  299. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/component_input_sort.rb +10 -11
  300. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_endorsable_input_sort.rb +2 -4
  301. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_localized_input_sort.rb +3 -3
  302. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_publishable_input_sort.rb +1 -1
  303. data/lib/decidim/api/input_sorts/has_timestamp_input_sort.rb +12 -0
  304. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/participatory_space_input_sort.rb +1 -1
  305. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/user_entity_input_sort.rb +4 -4
  306. data/lib/decidim/api/{amendable_entity_interface.rb → interfaces/amendable_entity_interface.rb} +5 -5
  307. data/lib/decidim/api/interfaces/amendable_interface.rb +17 -0
  308. data/lib/decidim/api/{attachable_interface.rb → interfaces/attachable_interface.rb} +3 -3
  309. data/lib/decidim/api/interfaces/author_interface.rb +32 -0
  310. data/lib/decidim/api/interfaces/authorable_interface.rb +23 -0
  311. data/lib/decidim/api/{categorizable_interface.rb → interfaces/categorizable_interface.rb} +3 -3
  312. data/lib/decidim/api/interfaces/coauthorable_interface.rb +30 -0
  313. data/lib/decidim/api/interfaces/component_interface.rb +22 -0
  314. data/lib/decidim/api/interfaces/endorsable_interface.rb +19 -0
  315. data/lib/decidim/api/{fingerprint_interface.rb → interfaces/fingerprint_interface.rb} +3 -3
  316. data/lib/decidim/api/interfaces/participatory_space_interface.rb +48 -0
  317. data/lib/decidim/api/interfaces/participatory_space_resourceable_interface.rb +25 -0
  318. data/lib/decidim/api/{scopable_interface.rb → interfaces/scopable_interface.rb} +3 -3
  319. data/lib/decidim/api/interfaces/timestamps_interface.rb +15 -0
  320. data/lib/decidim/api/interfaces/traceable_interface.rb +14 -0
  321. data/lib/decidim/api/scalars/date_time_type.rb +17 -0
  322. data/lib/decidim/api/scalars/date_type.rb +17 -0
  323. data/lib/decidim/api/types/amendment_type.rb +19 -0
  324. data/lib/decidim/api/types/area_api_type.rb +16 -0
  325. data/lib/decidim/api/types/area_type_type.rb +13 -0
  326. data/lib/decidim/api/types/attachment_type.rb +13 -0
  327. data/lib/decidim/api/types/category_type.rb +14 -0
  328. data/{app/types/decidim/core → lib/decidim/api/types}/component_type.rb +2 -4
  329. data/lib/decidim/api/types/coordinates_type.rb +21 -0
  330. data/lib/decidim/api/types/decidim_type.rb +13 -0
  331. data/lib/decidim/api/types/fingerprint_type.rb +12 -0
  332. data/lib/decidim/api/types/hashtag_type.rb +13 -0
  333. data/lib/decidim/api/types/localized_string_type.rb +13 -0
  334. data/lib/decidim/api/types/metric_history_type.rb +18 -0
  335. data/lib/decidim/api/types/metric_type.rb +13 -0
  336. data/lib/decidim/api/types/organization_type.rb +17 -0
  337. data/lib/decidim/api/types/participatory_space_link_type.rb +22 -0
  338. data/lib/decidim/api/types/participatory_space_type.rb +10 -0
  339. data/lib/decidim/api/types/scope_api_type.rb +16 -0
  340. data/lib/decidim/api/types/session_type.rb +22 -0
  341. data/lib/decidim/api/types/statistic_type.rb +20 -0
  342. data/lib/decidim/api/types/trace_version_type.rb +21 -0
  343. data/lib/decidim/api/types/translated_field_type.rb +36 -0
  344. data/lib/decidim/api/types/user_group_type.rb +64 -0
  345. data/lib/decidim/api/types/user_type.rb +67 -0
  346. data/lib/decidim/attachment_attributes.rb +57 -0
  347. data/lib/decidim/attribute_encryptor.rb +9 -1
  348. data/lib/decidim/attributes.rb +1 -0
  349. data/lib/decidim/attributes/clean_string.rb +37 -0
  350. data/lib/decidim/coauthorable.rb +3 -3
  351. data/lib/decidim/component_manifest.rb +17 -0
  352. data/lib/decidim/content_block_manifest.rb +1 -1
  353. data/lib/decidim/content_parsers/hashtag_parser.rb +3 -6
  354. data/lib/decidim/content_parsers/user_group_parser.rb +2 -5
  355. data/lib/decidim/content_parsers/user_parser.rb +2 -5
  356. data/lib/decidim/content_processor.rb +1 -1
  357. data/lib/decidim/content_renderers/hashtag_renderer.rb +3 -6
  358. data/lib/decidim/core.rb +11 -3
  359. data/lib/decidim/core/api.rb +71 -16
  360. data/lib/decidim/core/engine.rb +35 -6
  361. data/lib/decidim/core/test.rb +2 -1
  362. data/lib/decidim/core/test/factories.rb +53 -15
  363. data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +1 -1
  364. data/lib/decidim/core/test/shared_examples/amendable/amendment_accepted_event_examples.rb +1 -1
  365. data/lib/decidim/core/test/shared_examples/amendable/amendment_promoted_event_examples.rb +1 -1
  366. data/lib/decidim/core/test/shared_examples/amendable/amendment_rejected_event_examples.rb +1 -1
  367. data/lib/decidim/core/test/shared_examples/comments_examples.rb +11 -9
  368. data/lib/decidim/core/test/shared_examples/component_type.rb +1 -1
  369. data/lib/decidim/core/test/shared_examples/controller_render_views.rb +33 -0
  370. data/lib/decidim/core/test/shared_examples/follows_examples.rb +1 -1
  371. data/lib/decidim/core/test/shared_examples/localised_email.rb +8 -0
  372. data/lib/decidim/core/test/shared_examples/logo_email.rb +1 -1
  373. data/lib/decidim/core/test/shared_examples/map_examples.rb +1 -1
  374. data/lib/decidim/core/test/shared_examples/process_announcements_examples.rb +1 -1
  375. data/lib/decidim/core/test/shared_examples/reportable.rb +8 -0
  376. data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +1 -1
  377. data/lib/decidim/core/test/shared_examples/searchable_participatory_space_examples.rb +2 -3
  378. data/lib/decidim/core/test/shared_examples/searchable_results_examples.rb +46 -0
  379. data/lib/decidim/core/test/shared_examples/static_pages_examples.rb +43 -0
  380. data/lib/decidim/core/version.rb +1 -1
  381. data/lib/decidim/diffy_extension.rb +2 -2
  382. data/lib/decidim/exporters/csv.rb +4 -3
  383. data/lib/decidim/exporters/export_data.rb +1 -1
  384. data/lib/decidim/faker/internet.rb +17 -0
  385. data/lib/decidim/faker/localized.rb +43 -20
  386. data/lib/decidim/file_validator_humanizer.rb +6 -4
  387. data/lib/decidim/followable.rb +6 -1
  388. data/lib/decidim/form_builder.rb +33 -22
  389. data/lib/decidim/gamification/badge_scorer.rb +3 -2
  390. data/lib/decidim/gamification/base_event.rb +2 -2
  391. data/lib/decidim/geocodable.rb +2 -0
  392. data/lib/decidim/has_category.rb +1 -1
  393. data/lib/decidim/has_private_users.rb +1 -1
  394. data/lib/decidim/importers/import_manifest.rb +36 -0
  395. data/lib/decidim/map/autocomplete.rb +11 -1
  396. data/lib/decidim/metric_operation.rb +5 -6
  397. data/lib/decidim/participatory_space_resourceable.rb +1 -3
  398. data/lib/decidim/query_extensions.rb +90 -69
  399. data/lib/decidim/randomable.rb +6 -1
  400. data/lib/decidim/record_encryptor.rb +149 -0
  401. data/lib/decidim/reportable.rb +26 -0
  402. data/lib/decidim/resource_manifest.rb +3 -0
  403. data/lib/decidim/resourceable.rb +6 -6
  404. data/lib/decidim/scopable.rb +1 -1
  405. data/lib/decidim/search_resource_fields_mapper.rb +1 -1
  406. data/lib/decidim/searchable.rb +9 -0
  407. data/lib/decidim/settings_manifest.rb +2 -1
  408. data/lib/decidim/shareable_with_token.rb +0 -1
  409. data/lib/decidim/translatable_attributes.rb +2 -1
  410. data/lib/decidim/translatable_resource.rb +10 -0
  411. data/lib/decidim/user_reportable.rb +33 -0
  412. data/lib/decidim/view_model.rb +26 -0
  413. data/lib/premailer/adapter/decidim.rb +4 -4
  414. data/lib/tasks/decidim_data_portability_tasks.rake +4 -4
  415. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.ko.js +18 -0
  416. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.vi.js +14 -0
  417. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-CN.js +14 -0
  418. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-TW.js +14 -0
  419. metadata +193 -100
  420. data/app/functions/decidim/core/participatory_space_finder.rb +0 -11
  421. data/app/functions/decidim/core/participatory_space_list.rb +0 -11
  422. data/app/types/decidim/core/amendment_type.rb +0 -26
  423. data/app/types/decidim/core/area_api_type.rb +0 -16
  424. data/app/types/decidim/core/area_type_type.rb +0 -14
  425. data/app/types/decidim/core/attachment_type.rb +0 -14
  426. data/app/types/decidim/core/category_type.rb +0 -16
  427. data/app/types/decidim/core/coordinates_type.rb +0 -19
  428. data/app/types/decidim/core/date_time_type.rb +0 -12
  429. data/app/types/decidim/core/date_type.rb +0 -13
  430. data/app/types/decidim/core/decidim_type.rb +0 -19
  431. data/app/types/decidim/core/fingerprint_type.rb +0 -15
  432. data/app/types/decidim/core/has_timestamp_input_sort.rb +0 -12
  433. data/app/types/decidim/core/hashtag_type.rb +0 -13
  434. data/app/types/decidim/core/localized_string_type.rb +0 -14
  435. data/app/types/decidim/core/metric_history_type.rb +0 -17
  436. data/app/types/decidim/core/metric_type.rb +0 -14
  437. data/app/types/decidim/core/organization_type.rb +0 -20
  438. data/app/types/decidim/core/participatory_space_link_type.rb +0 -24
  439. data/app/types/decidim/core/participatory_space_type.rb +0 -12
  440. data/app/types/decidim/core/scope_api_type.rb +0 -16
  441. data/app/types/decidim/core/session_type.rb +0 -19
  442. data/app/types/decidim/core/statistic_type.rb +0 -22
  443. data/app/types/decidim/core/trace_version_type.rb +0 -29
  444. data/app/types/decidim/core/translated_field_type.rb +0 -45
  445. data/app/types/decidim/core/user_entity_input_filter.rb +0 -81
  446. data/app/types/decidim/core/user_group_type.rb +0 -51
  447. data/app/types/decidim/core/user_type.rb +0 -52
  448. data/app/views/decidim/shared/_announcement.html.erb +0 -1
  449. data/app/views/decidim/shared/_flag_modal.html.erb +0 -20
  450. data/lib/decidim/api/amendable_interface.rb +0 -18
  451. data/lib/decidim/api/author_interface.rb +0 -29
  452. data/lib/decidim/api/authorable_interface.rb +0 -22
  453. data/lib/decidim/api/coauthorable_interface.rb +0 -29
  454. data/lib/decidim/api/component_interface.rb +0 -20
  455. data/lib/decidim/api/endorsable_interface.rb +0 -22
  456. data/lib/decidim/api/participatory_space_interface.rb +0 -47
  457. data/lib/decidim/api/participatory_space_resourceable_interface.rb +0 -21
  458. data/lib/decidim/api/timestamps_interface.rb +0 -21
  459. data/lib/decidim/api/traceable_interface.rb +0 -14
  460. data/lib/decidim/core/test/shared_examples/user_localised_email_examples.rb +0 -25
@@ -0,0 +1,9 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ class Downloader < CarrierWave::Downloader::Base
5
+ def skip_ssrf_protection?(_uri)
6
+ true
7
+ end
8
+ end
9
+ end
@@ -3,15 +3,13 @@
3
3
  module Decidim
4
4
  # This class deals with uploading hero images to ParticipatoryProcesses.
5
5
  class ImageUploader < ApplicationUploader
6
- include CarrierWave::MiniMagick
7
-
8
6
  process :validate_size, :validate_dimensions, :strip
9
7
  process quality: Decidim.image_uploader_quality
10
8
 
11
9
  # CarrierWave automatically calls this method and validates the content
12
10
  # type fo the temp file to match against any of these options.
13
- def content_type_whitelist
14
- extension_whitelist.map { |ext| "image/#{ext}" }
11
+ def content_type_allowlist
12
+ extension_allowlist.map { |ext| "image/#{ext}" }
15
13
  end
16
14
 
17
15
  # Strips out all embedded information from the image
@@ -25,15 +23,12 @@ module Decidim
25
23
  # Fetches info about different versions, their processors and dimensions
26
24
  def dimensions_info
27
25
  if versions.any?
28
- versions.map do |version, info|
29
- [
30
- version,
31
- {
32
- processor: info.processors[0][0],
33
- dimensions: info.processors[0][1]
34
- }
35
- ]
36
- end.to_h
26
+ versions.transform_values do |info|
27
+ {
28
+ processor: info.processors[0][0],
29
+ dimensions: info.processors[0][1]
30
+ }
31
+ end
37
32
  else
38
33
  processors.map do |info|
39
34
  [:default, { processor: info[0], dimensions: info[1] }]
@@ -43,7 +38,7 @@ module Decidim
43
38
 
44
39
  # Add a white list of extensions which are allowed to be uploaded.
45
40
  # For images you might use something like this:
46
- def extension_whitelist
41
+ def extension_allowlist
47
42
  Decidim.organization_settings(model).upload_allowed_file_extensions_image
48
43
  end
49
44
 
@@ -69,13 +64,6 @@ module Decidim
69
64
  3840
70
65
  end
71
66
 
72
- def manipulate!
73
- super
74
- rescue CarrierWave::ProcessingError => e
75
- Rails.logger.error(e)
76
- raise CarrierWave::ProcessingError, I18n.t("carrierwave.errors.general")
77
- end
78
-
79
67
  private
80
68
 
81
69
  def validation_error!(text)
@@ -14,5 +14,10 @@ module Decidim
14
14
 
15
15
  default_path
16
16
  end
17
+
18
+ # Sets the validation that the associated model is always within an organization to true
19
+ def validate_inside_organization
20
+ true
21
+ end
17
22
  end
18
23
  end
@@ -4,11 +4,11 @@ module Decidim
4
4
  # This class deals with uploading record specific images that have more
5
5
  # limited content types than the defaults.
6
6
  class RecordImageUploader < ImageUploader
7
- def content_type_whitelist
7
+ def content_type_allowlist
8
8
  %w(image/jpeg image/png)
9
9
  end
10
10
 
11
- def extension_whitelist
11
+ def extension_allowlist
12
12
  %w(jpeg jpg png)
13
13
  end
14
14
  end
@@ -9,7 +9,6 @@ class EtiquetteValidator < ActiveModel::EachValidator
9
9
  validate_caps(record, attribute, value)
10
10
  validate_marks(record, attribute, value)
11
11
  validate_caps_first(record, attribute, value)
12
- validate_length(record, attribute, value)
13
12
  end
14
13
 
15
14
  private
@@ -31,10 +30,4 @@ class EtiquetteValidator < ActiveModel::EachValidator
31
30
 
32
31
  record.errors.add(attribute, options[:message] || :must_start_with_caps)
33
32
  end
34
-
35
- def validate_length(record, attribute, value)
36
- return if value.length > 15
37
-
38
- record.errors.add(attribute, options[:message] || :too_short)
39
- end
40
33
  end
@@ -4,6 +4,7 @@
4
4
  # content types. This prevents CarrierWave from uploading the records before
5
5
  # they pass the content type validations.
6
6
  class UploaderContentTypeValidator < ActiveModel::Validations::FileContentTypeValidator
7
+ # rubocop: disable Metrics/CyclomaticComplexity
7
8
  def validate_each(record, attribute, value)
8
9
  begin
9
10
  values = parse_values(value)
@@ -19,8 +20,8 @@ class UploaderContentTypeValidator < ActiveModel::Validations::FileContentTypeVa
19
20
  return unless uploader.is_a?(Decidim::ApplicationUploader)
20
21
 
21
22
  mode = option_value(record, :mode)
22
- allowed_types = uploader.content_type_whitelist || []
23
- forbidden_types = uploader.content_type_blacklist || []
23
+ allowed_types = uploader.content_type_allowlist || []
24
+ forbidden_types = uploader.content_type_denylist || []
24
25
 
25
26
  values.each do |val|
26
27
  val_mode = mode
@@ -39,6 +40,7 @@ class UploaderContentTypeValidator < ActiveModel::Validations::FileContentTypeVa
39
40
  validate_blacklist(record, attribute, content_type, forbidden_types)
40
41
  end
41
42
  end
43
+ # rubocop: enable Metrics/CyclomaticComplexity
42
44
 
43
45
  def check_validity!; end
44
46
  end
@@ -1,7 +1,7 @@
1
1
  <div class="card--list__item">
2
2
  <div class="card--list__text">
3
3
  <div>
4
- <a href="<%= document.url %>" class="card__link">
4
+ <a href="<%= document.url %>" class="card__link" target="_blank">
5
5
  <h4 class="card--list__heading heading6">
6
6
  <%= attachment_title(document) %> <small><%= document.file_type %> <%= number_to_human_size(document.file_size) %></small>
7
7
  </h4>
@@ -0,0 +1,7 @@
1
+ <p><%= t ".hello" %></p>
2
+
3
+ <p><%= t ".body_1", organization_name: h(@organization.name) %></p>
4
+
5
+ <p><%= t ".body_2", justification: h(@justification) %></p>
6
+
7
+ <p><%= t(".greetings", organization_name: h(@organization.name), organization_url: decidim.root_url(host: @organization.host)).html_safe %></p>
@@ -13,7 +13,7 @@
13
13
  <div class="card">
14
14
  <div class="card__content">
15
15
  <%= decidim_form_for(resource, namespace: "confirmation", as: resource_name, url: confirmation_path(resource_name), html: { method: :post, class: "register-form new_user" }) do |f| %>
16
- <%= devise_error_messages! %>
16
+ <%= render "devise/shared/error_messages", resource: resource %>
17
17
 
18
18
  <div class="field">
19
19
  <%= f.email_field :email, autofocus: true, value: (resource.pending_reconfirmation? ? resource.unconfirmed_email : resource.email) %>
@@ -1,7 +1,7 @@
1
1
  <h2><%= t("devise.registrations.edit.title", resource: resource_class.model_name.human) %></h2>
2
2
 
3
3
  <%= decidim_form_for(resource, namespace: "registration", as: resource_name, url: registration_path(resource_name), html: { method: :put }) do |f| %>
4
- <%= devise_error_messages! %>
4
+ <%= render "devise/shared/error_messages", resource: resource %>
5
5
  <%= form_required_explanation %>
6
6
  <%= invisible_captcha %>
7
7
 
@@ -13,7 +13,7 @@
13
13
  <div class="card">
14
14
  <div class="card__content">
15
15
  <%= decidim_form_for(resource, namespace: "unlock", as: resource_name, url: unlock_path(resource_name), html: { method: :post, class: "register-form new_user" }) do |f| %>
16
- <%= devise_error_messages! %>
16
+ <%= render "devise/shared/error_messages", resource: resource %>
17
17
 
18
18
  <div class="field">
19
19
  <%= f.email_field :email, autofocus: true, autocomplete: "email" %>
@@ -17,7 +17,7 @@
17
17
  <% if conversation.interlocutors(current_user).count == 1 %>
18
18
  <%= t("from", scope: "decidim.messaging.conversations.index") %>: <strong><%= conversation.interlocutors(current_user).first.name %> <span class="muted">@<%= conversation.interlocutors(current_user).first.nickname %></span></strong>
19
19
  <% else %>
20
- <%= t("from", scope: "decidim.messaging.conversations.index") %>: <strong><%= username_list(conversation.interlocutors(current_user), true) %></strong>
20
+ <%= t("from", scope: "decidim.messaging.conversations.index") %>: <strong><%= username_list(conversation.interlocutors(current_user), shorten: true) %></strong>
21
21
  <% end %>
22
22
  <br>
23
23
  <span class="muted">
@@ -1,5 +1,5 @@
1
1
  <div class="conversation-chat<%= " conversation-chat--offset" if sender_is_user?(sender) %>">
2
- <%= link_to sender.personal_url do %>
2
+ <%= link_to profile_path(sender.nickname) do %>
3
3
  <%= image_tag sender.avatar_url, alt: t("decidim.author.avatar") %>
4
4
  <% end %>
5
5
  <div>
@@ -15,12 +15,12 @@
15
15
  <%= icon "chevron-left", role: "img", aria_label: t(".back") %>
16
16
  <% end %>
17
17
  </div>
18
- <%= link_to decidim.conversations_path do %>
19
- <% if participants.count == 1 %>
18
+ <% if participants.count == 1 %>
19
+ <%= link_to profile_path(participants.first.nickname) do %>
20
20
  <%= image_tag participants.first.avatar_url, alt: t("decidim.author.avatar") %>
21
- <% else %>
22
- <%= image_tag current_user.avatar.default_multiuser_url, alt: t("decidim.author.avatar") %>
23
21
  <% end %>
22
+ <% else %>
23
+ <%= image_tag current_user.avatar.default_multiuser_url, alt: t("decidim.author.avatar") %>
24
24
  <% end %>
25
25
 
26
26
  <div class="ml-s">
@@ -46,6 +46,17 @@
46
46
  </label>
47
47
  </div>
48
48
 
49
+ <% if @notifications_settings.user_is_moderator?(current_user) %>
50
+ <p><strong><%= t(".administrators") %></strong></p>
51
+ <div class="switch tiny switch-with-label email_on_moderations">
52
+ <label>
53
+ <%= f.check_box :email_on_moderations, label: false, class: "switch-input" %>
54
+ <span class="switch-paddle"></span>
55
+ <span class="switch-label"><%= t(".email_on_moderations") %></span>
56
+ </label>
57
+ </div>
58
+ <% end %>
59
+
49
60
  <%= f.submit t(".update_notifications_settings") %>
50
61
  <% end %>
51
62
  </div>
@@ -15,7 +15,9 @@
15
15
  </div>
16
16
  </div>
17
17
 
18
- <%= cell "decidim/tos_page", :form %>
18
+ <div class="columns small-12">
19
+ <%= cell "decidim/tos_page", :form %>
20
+ </div>
19
21
  </main>
20
22
  </div>
21
23
  </div>
@@ -10,7 +10,7 @@
10
10
  <p><%= l @report.created_at, format: :short %></p>
11
11
 
12
12
  <p><b><%= t(".participatory_space") %></b></p>
13
- <p><%= translated_attribute @participatory_space.title %></p>
13
+ <p><%= link_to translated_attribute(@participatory_space.title), resource_locator(@participatory_space).url %></p>
14
14
 
15
15
  <p><b><%= t(".reason") %></b></p>
16
16
  <p><%= t(@report.reason, organization_name: @participatory_space.organization.name, scope: "decidim.shared.flag_modal") %></p>
@@ -22,20 +22,28 @@
22
22
  </blockquote>
23
23
  <% end %>
24
24
 
25
- <% if @content.present? %>
26
- <p><b><%= t(".content") %></b></p>
27
- <blockquote>
28
- <h5><%= translated_attribute @content[:title] %></h5>
29
- <p><%= translated_attribute @content[:body] %></p>
30
- </blockquote>
25
+ <% if @original_language.present? %>
26
+ <p><b><%= t(".content_original_language") %></b></p>
27
+ <p><%= I18n.t("locale.name", locale: @original_language) %></p>
31
28
  <% end %>
32
29
 
30
+ <p><b><%= t(".content") %></b> (<%= t(".id") %>: <%= @reportable.id %>)</p>
31
+ <%= reported_content_cell %>
32
+
33
33
  <% if @author.present? %>
34
34
  <p><b><%= t(".authors") %></b></p>
35
35
  <% if author_profile_url.present? %>
36
36
  <p><%= link_to @author.name, author_profile_url, target: :blank %></p>
37
37
  <% else %>
38
- <p><%= @author.name %></p>
38
+ <p>
39
+ <%=
40
+ if @author.respond_to?(:name)
41
+ @author.name
42
+ elsif @author.respond_to?(:title)
43
+ translated_attribute(@author.title)
44
+ end
45
+ %>
46
+ </p>
39
47
  <% end %>
40
48
  <% end %>
41
49
  <br>
@@ -46,7 +54,7 @@
46
54
  <table>
47
55
  <tr>
48
56
  <td>
49
- <%= link_to t(".manage_moderations"), manage_moderations_url, class: "button", target: "_blank" %>
57
+ <%= link_to t(".see_report"), report_url, class: "button", target: "_blank" %>
50
58
  </td>
51
59
  </tr>
52
60
  </table>
@@ -13,6 +13,6 @@
13
13
  </button>
14
14
  </div>
15
15
  <div class="filters">
16
- <%= render partial: "filters" %>
16
+ <%= render partial: "filters", locals: { type: :small } %>
17
17
  </div>
18
18
  </div>
@@ -12,10 +12,10 @@
12
12
  check_boxes_tree_options(
13
13
  collection.leaf.value,
14
14
  collection.leaf.label,
15
- {
15
+ **({
16
16
  "data-checkboxes-tree": data_checkboxes_tree_id,
17
17
  is_root_check_box: is_root_check_box
18
- }.merge(options)),
18
+ }.merge(options))),
19
19
  collection.leaf.value.to_s, nil %>
20
20
 
21
21
  <% unless is_root_check_box %>
@@ -46,7 +46,7 @@
46
46
  check_boxes_tree_options(
47
47
  item.value,
48
48
  item.label,
49
- options
49
+ **options
50
50
  ),
51
51
  item.value, nil %>
52
52
  <% end %>
@@ -1,5 +1,5 @@
1
1
  <% if translated_attribute(current_settings.announcement).present? %>
2
- <%= render partial: "decidim/shared/announcement", locals: { announcement: current_settings.announcement } %>
2
+ <%= cell("decidim/announcement", current_settings.announcement) %>
3
3
  <% elsif translated_attribute(component_settings.announcement).present? %>
4
- <%= render partial: "decidim/shared/announcement", locals: { announcement: component_settings.announcement } %>
4
+ <%= cell("decidim/announcement", component_settings.announcement) %>
5
5
  <% end %>
@@ -1,6 +1,6 @@
1
1
  <%= filter_form_for filter do |form| %>
2
2
  <div class="columns mediumlarge-6 large-5">
3
- <%= scopes_picker_filter form, :scope_id, checkboxes_on_top %>
3
+ <%= scopes_picker_filter form, :scope_id, checkboxes_on_top: checkboxes_on_top %>
4
4
  </div>
5
5
  <div class="columns mediumlarge-6 large-5">
6
6
  <%= form.areas_select :area_id,
@@ -0,0 +1,7 @@
1
+ <p><%= t ".hello", admin: h(@admin.name) %></p>
2
+
3
+ <p><%= t ".body_1", user: h(@user.name), token: h(@token.name) %></p>
4
+
5
+ <p><%= t ".body_2", reason: h(@reason) %></p>
6
+
7
+ <p><%= t(".greetings", organization_name: h(@organization.name), organization_url: decidim.root_url(host: @organization.host)).html_safe %></p>
@@ -1,6 +1,6 @@
1
1
  <div id="<%= picker_options[:id] %>" class="data-picker <%= picker_options[:class] %>" data-picker-name="<%= picker_options[:name] %>">
2
2
  <div class="picker-values"><% items.each do |item, params| %>
3
- <div><a href="<%= params[:url] %>" data-picker-value="<%= item.id %>"><%= params[:text] %></a></div>
3
+ <div><a href="<%= params[:url] %>" class="label primary" data-picker-value="<%= item.id %>"><span aria-hidden="true">×</span> <%= params[:text] %></a></div>
4
4
  <% end %></div>
5
5
  <div class="picker-prompt"><a href="<%= prompt_params[:url] %>"><%= prompt_params[:text] %></a></div>
6
6
  </div>
@@ -21,6 +21,7 @@
21
21
  <%= render partial: "layouts/decidim/impersonation_warning" %>
22
22
  <%= render partial: "layouts/decidim/cookie_warning" %>
23
23
  <%= render partial: "layouts/decidim/omnipresent_banner" %>
24
+ <%= render partial: "layouts/decidim/timeout_modal" %>
24
25
 
25
26
  <%= render "layouts/decidim/wrapper" do %>
26
27
  <%= yield %>
@@ -10,7 +10,7 @@ js_configs = {
10
10
  }
11
11
  character_messages = {
12
12
  "charactersAtLeast": {
13
- one: t("forms.length_validator.minimum.one", count: "%count%"),
13
+ one: t("forms.length_validator.minimum.one", count: "%count%", default: "forms.length_validator.minimum.other"),
14
14
  other: t("forms.length_validator.minimum.other", count: "%count%")
15
15
  },
16
16
  "charactersLeft": {
@@ -8,14 +8,16 @@
8
8
  <div class="medium-8 large-6 large-offset-3 column">
9
9
  <nav class="main__footer__nav">
10
10
  <ul class="footer-nav">
11
- <% if current_organization.static_pages.any? %>
11
+ <% organization_pages = current_organization.static_pages_accessible_for(current_user) %>
12
+ <% if organization_pages.any? %>
12
13
  <% current_organization.static_page_topics.where(show_in_footer: true).each do |page_topic| %>
13
- <% if page_topic.pages.any? %>
14
- <li><%= link_to translated_attribute(page_topic.title), decidim.page_path(page_topic.pages.first) %></li>
14
+ <% topic_pages = page_topic.accessible_pages_for(current_user) %>
15
+ <% if topic_pages.any? %>
16
+ <li><%= link_to translated_attribute(page_topic.title), decidim.page_path(topic_pages.first) %></li>
15
17
  <% end %>
16
18
  <% end %>
17
19
 
18
- <% current_organization.static_pages.where(show_in_footer: true).each do |page| %>
20
+ <% organization_pages.where(show_in_footer: true).each do |page| %>
19
21
  <li><%= link_to translated_attribute(page.title), decidim.page_path(page) %></li>
20
22
  <% end %>
21
23
  <% end %>
@@ -0,0 +1,21 @@
1
+ <% if current_user %>
2
+ <% timeout_time_seconds = Devise.timeout_in.to_i %>
3
+ <div class="reveal" id="timeoutModal" data-close-on-click="false" data-close-on-esc="false"
4
+ data-seconds-until-timeout-path="<%= decidim.seconds_until_timeout_path %>"
5
+ data-session-timeout="<%= timeout_time_seconds %>"
6
+ data-session-timeouter-interval="<%= Decidim.config.session_timeouter_interval %>" data-reveal>
7
+ <h2><%= t(".title") %></h2>
8
+ <p><%= t(".body", minutes: (timeout_time_seconds / 60) - 2) %></p>
9
+
10
+ <div class="reveal__buttons">
11
+ <%= link_to t(".sign_out"), decidim.destroy_user_session_path, method: :delete, class: "button warning" %>
12
+ <%= link_to "", decidim.destroy_user_session_path(translation_suffix: :timed_out), method: :delete, id: "reveal-hidden-sign-out", class: "hide" %>
13
+ <%= button_to t(".continue_session"),
14
+ decidim.heartbeat_path,
15
+ id: "continueSession",
16
+ class: "button primary",
17
+ remote: true,
18
+ method: :post %>
19
+ </div>
20
+ </div>
21
+ <% end %>