decidim-core 0.21.0 → 0.22.0

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 (544) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/config/decidim_core_manifest.js +3 -0
  3. data/app/assets/fonts/decidim/Roboto-Regular.svg +1 -10520
  4. data/app/assets/fonts/decidim/Source_Sans_Pro_400.svg +1 -345
  5. data/app/assets/fonts/decidim/Source_Sans_Pro_600.svg +1 -339
  6. data/app/assets/fonts/decidim/Source_Sans_Pro_900.svg +1 -342
  7. data/app/assets/images/decidim/avatar-multiuser.png +0 -0
  8. data/app/assets/images/decidim/brands/google.svg +1 -1
  9. data/app/assets/images/decidim/decidim-logo.svg +1 -71
  10. data/app/assets/images/decidim/default-avatar.svg +1 -14
  11. data/app/assets/images/decidim/gamification/badges/followers.svg +1 -115
  12. data/app/assets/images/decidim/gamification/badges/invitations.svg +1 -117
  13. data/app/assets/images/decidim/icons.svg +1 -259
  14. data/app/assets/images/decidim/placeholder.jpg +0 -0
  15. data/app/assets/javascripts/decidim.js.es6 +23 -1
  16. data/app/assets/javascripts/decidim/ajax_modals.js.es6 +3 -0
  17. data/app/assets/javascripts/decidim/assets.js.erb +5 -0
  18. data/app/assets/javascripts/decidim/callout.js.es6 +18 -0
  19. data/app/assets/javascripts/decidim/configuration.js.es6 +23 -0
  20. data/app/assets/javascripts/decidim/confirm.js.es6 +178 -0
  21. data/app/assets/javascripts/decidim/conversations.js.es6 +17 -0
  22. data/app/assets/javascripts/decidim/core/bundle.js +1 -1
  23. data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
  24. data/app/assets/javascripts/decidim/core/extrapoly.js +6 -0
  25. data/app/assets/javascripts/decidim/data_picker.js.es6 +128 -50
  26. data/app/assets/javascripts/decidim/diff_mode_dropdown.js.es6 +5 -7
  27. data/app/assets/javascripts/decidim/dropdowns_menus.js.es6 +32 -0
  28. data/app/assets/javascripts/decidim/external_link.js.es6 +69 -0
  29. data/app/assets/javascripts/decidim/floating_help.js.es6 +7 -0
  30. data/app/assets/javascripts/decidim/form_filter.component.js.es6 +1 -1
  31. data/app/assets/javascripts/decidim/form_filter.component.test.js +4 -4
  32. data/app/assets/javascripts/decidim/form_validator.es6 +61 -0
  33. data/app/assets/javascripts/decidim/foundation.js.es6 +28 -28
  34. data/app/assets/javascripts/decidim/icon.js.es6 +42 -0
  35. data/app/assets/javascripts/decidim/identity_selector_dialog.js.es6 +61 -0
  36. data/app/assets/javascripts/decidim/input_character_counter.js.es6 +115 -0
  37. data/app/assets/javascripts/decidim/input_mentions.js.es6 +34 -9
  38. data/app/assets/javascripts/decidim/input_multiple_mentions.js.es6 +195 -0
  39. data/app/assets/javascripts/decidim/map.js.es6 +40 -3
  40. data/app/assets/javascripts/decidim/orders.js.es6 +9 -28
  41. data/app/assets/javascripts/decidim/responsive_horizontal_tabs.js.es6 +12 -0
  42. data/app/assets/javascripts/decidim/results_listing.js.es6 +44 -0
  43. data/app/assets/javascripts/decidim/start_conversation_dialog.js +13 -0
  44. data/app/assets/javascripts/decidim/vizzs.js.es6 +1 -0
  45. data/app/assets/stylesheets/decidim/_decidim-settings.scss +5 -0
  46. data/app/assets/stylesheets/decidim/_decidim.scss +13 -11
  47. data/app/assets/stylesheets/decidim/_properties.scss +25 -0
  48. data/app/assets/stylesheets/decidim/_variables.scss +6 -24
  49. data/app/assets/stylesheets/decidim/application.scss.erb +2 -2
  50. data/app/assets/stylesheets/decidim/editor.scss +2 -2
  51. data/app/assets/stylesheets/decidim/email.scss +1771 -0
  52. data/app/assets/stylesheets/decidim/extras/_external-links.scss +29 -0
  53. data/app/assets/stylesheets/decidim/extras/_extras.scss +17 -0
  54. data/app/assets/stylesheets/decidim/extras/_label-required.scss +9 -0
  55. data/app/assets/stylesheets/decidim/extras/_process_stats.scss +1 -1
  56. data/app/assets/stylesheets/decidim/extras/_quill.scss +5 -0
  57. data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +8 -0
  58. data/app/assets/stylesheets/decidim/layouts/_home.scss +31 -7
  59. data/app/assets/stylesheets/decidim/layouts/_layouts.scss +5 -0
  60. data/app/assets/stylesheets/decidim/layouts/_logo.scss +26 -0
  61. data/app/assets/stylesheets/decidim/layouts/_user.scss +4 -0
  62. data/app/assets/stylesheets/decidim/modules/_author-avatar.scss +9 -13
  63. data/app/assets/stylesheets/decidim/modules/_buttons.scss +198 -26
  64. data/app/assets/stylesheets/decidim/modules/_cards.scss +174 -23
  65. data/app/assets/stylesheets/decidim/modules/_collapsible-list.scss +21 -0
  66. data/app/assets/stylesheets/decidim/modules/_comments.scss +25 -1
  67. data/app/assets/stylesheets/decidim/modules/_conference-programme.scss +0 -1
  68. data/app/assets/stylesheets/decidim/modules/_confirm.scss +5 -0
  69. data/app/assets/stylesheets/decidim/modules/_conversation.scss +50 -0
  70. data/app/assets/stylesheets/decidim/modules/_data-picker.scss +9 -11
  71. data/app/assets/stylesheets/decidim/modules/_definition-data.scss +6 -1
  72. data/app/assets/stylesheets/decidim/modules/_docs-manager.scss +0 -1
  73. data/app/assets/stylesheets/decidim/modules/_extra.scss +0 -2
  74. data/app/assets/stylesheets/decidim/modules/_filters.scss +25 -1
  75. data/app/assets/stylesheets/decidim/modules/_floating-helper.scss +20 -8
  76. data/app/assets/stylesheets/decidim/modules/_footer.scss +8 -4
  77. data/app/assets/stylesheets/decidim/modules/_forms.scss +63 -4
  78. data/app/assets/stylesheets/decidim/modules/_horizontal-tabs.scss +64 -1
  79. data/app/assets/stylesheets/decidim/modules/_inline-filters.scss +6 -3
  80. data/app/assets/stylesheets/decidim/modules/_input-gallery.scss +10 -0
  81. data/app/assets/stylesheets/decidim/modules/_input-mentions.scss +25 -7
  82. data/app/assets/stylesheets/decidim/modules/_input-multiple-mentions.scss +5 -0
  83. data/app/assets/stylesheets/decidim/modules/_map.scss +11 -0
  84. data/app/assets/stylesheets/decidim/modules/_margins.scss +8 -7
  85. data/app/assets/stylesheets/decidim/modules/_messages.scss +18 -18
  86. data/app/assets/stylesheets/decidim/modules/_modules.scss +75 -72
  87. data/app/assets/stylesheets/decidim/modules/_navbar.scss +176 -26
  88. data/app/assets/stylesheets/decidim/modules/_notification.scss +5 -0
  89. data/app/assets/stylesheets/decidim/modules/_order-by.scss +5 -0
  90. data/app/assets/stylesheets/decidim/modules/_process-nav.scss +5 -2
  91. data/app/assets/stylesheets/decidim/modules/_process-phase.scss +2 -4
  92. data/app/assets/stylesheets/decidim/modules/_process-stats.scss +2 -2
  93. data/app/assets/stylesheets/decidim/modules/_progress-bar.scss +1 -1
  94. data/app/assets/stylesheets/decidim/modules/_reveal.scss +6 -0
  95. data/app/assets/stylesheets/decidim/modules/_signup.scss +6 -5
  96. data/app/assets/stylesheets/decidim/modules/_static-pages.scss +0 -1
  97. data/app/assets/stylesheets/decidim/modules/_sticky.scss +5 -0
  98. data/app/assets/stylesheets/decidim/modules/_tags.scss +4 -0
  99. data/app/assets/stylesheets/decidim/modules/_timeline.scss +1 -2
  100. data/app/assets/stylesheets/decidim/modules/_typography.scss +47 -8
  101. data/app/assets/stylesheets/decidim/modules/_versions.scss +0 -1
  102. data/app/assets/stylesheets/decidim/utils/_helpers.scss +8 -0
  103. data/app/assets/stylesheets/decidim/utils/_mixins.scss +86 -7
  104. data/app/assets/stylesheets/decidim/utils/_settings.scss +81 -69
  105. data/app/assets/stylesheets/decidim/vizzs.scss +8 -0
  106. data/app/assets/stylesheets/decidim/vizzs/_areachart.scss +0 -1
  107. data/app/assets/stylesheets/decidim/vizzs/_linechart.scss +0 -1
  108. data/app/assets/stylesheets/decidim/vizzs/_rowchart.scss +0 -1
  109. data/app/assets/stylesheets/decidim/vizzs/_vizzs.scss +5 -0
  110. data/app/assets/stylesheets/foundation-overrides/components/_button-group.scss +319 -0
  111. data/app/cells/decidim/activity/show.erb +24 -21
  112. data/app/cells/decidim/activity_cell.rb +2 -0
  113. data/app/cells/decidim/address_cell.rb +1 -1
  114. data/app/cells/decidim/amendable/amend_button_card_cell.rb +1 -5
  115. data/app/cells/decidim/amendable/promote_button_card_cell.rb +1 -1
  116. data/app/cells/decidim/announcement/show.erb +1 -1
  117. data/app/cells/decidim/author/comments.erb +1 -1
  118. data/app/cells/decidim/author/endorsements.erb +6 -0
  119. data/app/cells/decidim/author/flag.erb +5 -2
  120. data/app/cells/decidim/author/profile_inline.erb +0 -1
  121. data/app/cells/decidim/author/show.erb +2 -0
  122. data/app/cells/decidim/author/withdraw.erb +2 -2
  123. data/app/cells/decidim/author_cell.rb +9 -13
  124. data/app/cells/decidim/badge/show.erb +6 -6
  125. data/app/cells/decidim/badge/small.erb +2 -1
  126. data/app/cells/decidim/card/show.erb +4 -4
  127. data/app/cells/decidim/card_m/comments_counter.erb +1 -1
  128. data/app/cells/decidim/card_m/header.erb +4 -4
  129. data/app/cells/decidim/card_m/image.erb +1 -1
  130. data/app/cells/decidim/card_m/show.erb +2 -2
  131. data/app/cells/decidim/card_m_cell.rb +3 -2
  132. data/app/cells/decidim/collapsible_list/show.erb +3 -3
  133. data/app/cells/decidim/content_blocks/footer_sub_hero/show.erb +4 -4
  134. data/app/cells/decidim/content_blocks/hero_settings_form/show.erb +2 -2
  135. data/app/cells/decidim/content_blocks/how_to_participate/show.erb +8 -8
  136. data/app/cells/decidim/content_blocks/last_activity_cell.rb +1 -1
  137. data/app/cells/decidim/content_blocks/stats/show.erb +1 -1
  138. data/app/cells/decidim/content_blocks/sub_hero/show.erb +3 -3
  139. data/app/cells/decidim/diff/attribute.erb +10 -10
  140. data/app/cells/decidim/diff_cell.rb +11 -1
  141. data/app/cells/decidim/endorsement_buttons/select_identity_button.erb +10 -0
  142. data/app/cells/decidim/endorsement_buttons/show.erb +4 -0
  143. data/app/cells/decidim/endorsement_buttons_cell.rb +208 -0
  144. data/app/cells/decidim/endorsers_list/show.erb +16 -0
  145. data/app/cells/decidim/endorsers_list_cell.rb +29 -0
  146. data/app/cells/decidim/fingerprint_cell.rb +1 -0
  147. data/app/cells/decidim/follow_button/show.erb +13 -5
  148. data/app/cells/decidim/follow_button_cell.rb +29 -5
  149. data/app/cells/decidim/navbar_admin_link/show.erb +1 -1
  150. data/app/cells/decidim/navbar_admin_link_cell.rb +6 -0
  151. data/app/cells/decidim/newsletter_templates/base_cell.rb +30 -0
  152. data/app/cells/decidim/newsletter_templates/base_settings_form_cell.rb +13 -0
  153. data/app/cells/decidim/newsletter_templates/basic_only_text/show.erb +86 -0
  154. data/app/cells/decidim/newsletter_templates/basic_only_text_cell.rb +21 -0
  155. data/app/cells/decidim/newsletter_templates/basic_only_text_settings_form/show.erb +7 -0
  156. data/app/cells/decidim/newsletter_templates/basic_only_text_settings_form_cell.rb +8 -0
  157. data/app/cells/decidim/newsletter_templates/image_text_cta/show.erb +125 -0
  158. data/app/cells/decidim/newsletter_templates/image_text_cta_cell.rb +61 -0
  159. data/app/cells/decidim/newsletter_templates/image_text_cta_settings_form/show.erb +17 -0
  160. data/app/cells/decidim/newsletter_templates/image_text_cta_settings_form_cell.rb +8 -0
  161. data/app/cells/decidim/notifications/show.erb +1 -1
  162. data/app/cells/decidim/profile/show.erb +2 -2
  163. data/app/cells/decidim/profile/user_group_tabs.erb +10 -5
  164. data/app/cells/decidim/profile/user_tabs.erb +16 -14
  165. data/app/cells/decidim/profile_cell.rb +18 -0
  166. data/app/cells/decidim/profile_sidebar/show.erb +16 -16
  167. data/app/cells/decidim/profile_sidebar_cell.rb +1 -0
  168. data/app/cells/decidim/search_results_section/show.erb +1 -1
  169. data/app/cells/decidim/tags_cell.rb +32 -2
  170. data/app/cells/decidim/user_activity/show.erb +19 -1
  171. data/app/cells/decidim/user_activity_cell.rb +6 -0
  172. data/app/cells/decidim/user_conversation/conversation_header.erb +14 -0
  173. data/app/cells/decidim/user_conversation/messages.erb +15 -0
  174. data/app/cells/decidim/user_conversation/new.erb +15 -0
  175. data/app/cells/decidim/user_conversation/reply.erb +17 -0
  176. data/app/cells/decidim/user_conversation/show.erb +20 -0
  177. data/app/cells/decidim/user_conversation_cell.rb +75 -0
  178. data/app/cells/decidim/user_conversations/add_conversation_users.erb +25 -0
  179. data/app/cells/decidim/user_conversations/conversation_item.erb +38 -0
  180. data/app/cells/decidim/user_conversations/show.erb +58 -0
  181. data/app/cells/decidim/user_conversations_cell.rb +40 -0
  182. data/app/cells/decidim/user_group_admin_membership_profile/footer.erb +3 -3
  183. data/app/cells/decidim/user_profile/footer.erb +1 -1
  184. data/app/cells/decidim/user_profile/unlinked_user_data.erb +16 -0
  185. data/app/cells/decidim/user_profile/user_data.erb +1 -1
  186. data/app/cells/decidim/user_profile_cell.rb +7 -1
  187. data/app/cells/decidim/user_timeline_cell.rb +4 -0
  188. data/app/cells/decidim/version/show.erb +31 -0
  189. data/app/{views/decidim/shared/_version_author.html.erb → cells/decidim/version_author/show.erb} +1 -1
  190. data/app/cells/decidim/version_author_cell.rb +9 -0
  191. data/app/cells/decidim/version_cell.rb +83 -0
  192. data/app/cells/decidim/versions_list/show.erb +32 -0
  193. data/app/cells/decidim/versions_list_cell.rb +64 -0
  194. data/app/cells/decidim/versions_list_item/show.erb +20 -0
  195. data/app/cells/decidim/versions_list_item_cell.rb +51 -0
  196. data/app/cells/decidim/wizard_step_form/wizard_aside.erb +1 -1
  197. data/app/cells/decidim/wizard_step_form/wizard_header.erb +2 -2
  198. data/app/cells/decidim/wizard_step_form_cell.rb +4 -1
  199. data/app/commands/decidim/attachment_methods.rb +40 -0
  200. data/app/commands/decidim/create_registration.rb +2 -1
  201. data/app/commands/decidim/create_user_group.rb +12 -0
  202. data/app/commands/decidim/destroy_account.rb +12 -0
  203. data/app/commands/decidim/endorse_resource.rb +64 -0
  204. data/app/commands/decidim/gallery_methods.rb +64 -0
  205. data/app/commands/decidim/invite_user_again.rb +2 -4
  206. data/app/commands/decidim/messaging/reply_to_conversation.rb +34 -3
  207. data/app/commands/decidim/messaging/start_conversation.rb +36 -5
  208. data/app/commands/decidim/unendorse_resource.rb +38 -0
  209. data/app/commands/decidim/update_notifications_settings.rb +1 -0
  210. data/app/commands/decidim/update_user_group.rb +14 -1
  211. data/app/controllers/concerns/decidim/impersonate_users.rb +13 -0
  212. data/app/controllers/concerns/decidim/resource_versions_concern.rb +28 -0
  213. data/app/controllers/decidim/devise/registrations_controller.rb +2 -4
  214. data/app/controllers/decidim/devise/sessions_controller.rb +5 -0
  215. data/app/controllers/decidim/endorsements_controller.rb +71 -0
  216. data/app/controllers/decidim/messaging/conversations_controller.rb +52 -12
  217. data/app/controllers/decidim/newsletters_controller.rb +2 -2
  218. data/app/controllers/decidim/profiles_controller.rb +6 -0
  219. data/app/controllers/decidim/scopes_controller.rb +1 -0
  220. data/app/controllers/decidim/user_activities_controller.rb +19 -2
  221. data/app/controllers/decidim/user_conversations_controller.rb +142 -0
  222. data/app/controllers/decidim/user_timeline_controller.rb +19 -2
  223. data/app/events/decidim/resource_endorsed_event.rb +35 -0
  224. data/app/events/decidim/user_group_admin_event.rb +37 -0
  225. data/app/events/decidim/user_group_created_event.rb +6 -0
  226. data/app/events/decidim/user_group_updated_event.rb +6 -0
  227. data/app/forms/decidim/attachment_form.rb +1 -0
  228. data/app/forms/decidim/messaging/conversation_form.rb +10 -4
  229. data/app/forms/decidim/notifications_settings_form.rb +6 -0
  230. data/app/forms/decidim/registration_form.rb +1 -0
  231. data/app/functions/decidim/core/component_finder_base.rb +10 -3
  232. data/app/functions/decidim/core/component_list_base.rb +8 -2
  233. data/app/functions/decidim/core/user_entity_finder.rb +33 -0
  234. data/app/functions/decidim/core/user_entity_list.rb +31 -0
  235. data/app/helpers/concerns/decidim/flash_helper_extensions.rb +47 -0
  236. data/app/helpers/decidim/action_authorization_helper.rb +24 -2
  237. data/app/helpers/decidim/amendments_helper.rb +5 -3
  238. data/app/helpers/decidim/application_helper.rb +7 -1
  239. data/app/helpers/decidim/check_boxes_tree_helper.rb +4 -5
  240. data/app/helpers/decidim/cta_button_helper.rb +1 -1
  241. data/app/helpers/decidim/decidim_form_helper.rb +23 -0
  242. data/app/helpers/decidim/endorsable_helper.rb +93 -0
  243. data/app/helpers/decidim/filters_helper.rb +15 -5
  244. data/app/helpers/decidim/followable_helper.rb +11 -0
  245. data/app/helpers/decidim/layout_helper.rb +23 -5
  246. data/app/helpers/decidim/map_helper.rb +15 -2
  247. data/app/helpers/decidim/markup_helper.rb +9 -0
  248. data/app/helpers/decidim/messaging/conversation_helper.rb +61 -7
  249. data/app/helpers/decidim/orders_helper.rb +10 -1
  250. data/app/helpers/decidim/participatory_space_helpers.rb +1 -1
  251. data/app/helpers/decidim/resource_versions_helper.rb +24 -7
  252. data/app/helpers/decidim/rich_text_editor_helper.rb +1 -0
  253. data/app/helpers/decidim/sanitize_helper.rb +10 -2
  254. data/app/helpers/decidim/tooltip_helper.rb +1 -1
  255. data/app/helpers/decidim/traceability_helper.rb +2 -8
  256. data/app/helpers/decidim/user_profile_helper.rb +1 -1
  257. data/app/helpers/decidim/widget_urls_helper.rb +4 -2
  258. data/app/jobs/decidim/event_publisher_job.rb +1 -1
  259. data/app/mailers/concerns/decidim/multitenant_asset_host.rb +33 -0
  260. data/app/mailers/decidim/application_mailer.rb +1 -0
  261. data/app/mailers/decidim/messaging/conversation_mailer.rb +53 -4
  262. data/app/mailers/decidim/newsletter_mailer.rb +22 -4
  263. data/app/middleware/decidim/strip_x_forwarded_host.rb +14 -0
  264. data/app/models/decidim/action_log.rb +1 -1
  265. data/app/models/decidim/amendment.rb +0 -18
  266. data/app/models/decidim/authorization.rb +24 -0
  267. data/app/models/decidim/component.rb +7 -0
  268. data/app/models/decidim/content_block.rb +5 -3
  269. data/app/models/decidim/endorsement.rb +30 -0
  270. data/app/models/decidim/messaging/conversation.rb +39 -11
  271. data/app/models/decidim/messaging/message.rb +31 -5
  272. data/app/models/decidim/messaging/participation.rb +1 -1
  273. data/app/models/decidim/messaging/receipt.rb +8 -0
  274. data/app/models/decidim/newsletter.rb +7 -1
  275. data/app/models/decidim/organization.rb +16 -7
  276. data/app/models/decidim/user.rb +32 -0
  277. data/app/models/decidim/user_group.rb +23 -0
  278. data/app/permissions/decidim/permissions.rb +19 -6
  279. data/app/presenters/decidim/admin_log/user_presenter.rb +1 -1
  280. data/app/presenters/decidim/metric_charts_presenter.rb +33 -13
  281. data/app/presenters/decidim/nil_presenter.rb +29 -0
  282. data/app/presenters/decidim/resource_locator_presenter.rb +2 -1
  283. data/app/presenters/decidim/user_group_presenter.rb +1 -1
  284. data/app/presenters/decidim/user_presenter.rb +6 -0
  285. data/app/queries/decidim/metric_manage.rb +5 -0
  286. data/app/queries/decidim/metrics/followers_metric_manage.rb +1 -6
  287. data/app/queries/decidim/user_groups/admin_memberships.rb +3 -3
  288. data/app/services/decidim/activity_search.rb +1 -0
  289. data/app/services/decidim/base_diff_renderer.rb +25 -3
  290. data/app/services/decidim/events_manager.rb +4 -1
  291. data/app/types/decidim/core/decidim_type.rb +0 -4
  292. data/app/types/decidim/core/has_endorsable_input_sort.rb +17 -0
  293. data/app/types/decidim/core/has_timestamp_input_filter.rb +52 -0
  294. data/app/types/decidim/core/has_timestamp_input_sort.rb +12 -0
  295. data/app/types/decidim/core/user_entity_input_filter.rb +81 -0
  296. data/app/types/decidim/core/user_entity_input_sort.rb +24 -0
  297. data/app/types/decidim/core/user_group_type.rb +17 -5
  298. data/app/types/decidim/core/user_type.rb +17 -6
  299. data/app/uploaders/decidim/attachment_uploader.rb +1 -1
  300. data/app/uploaders/decidim/avatar_uploader.rb +4 -0
  301. data/app/uploaders/decidim/image_uploader.rb +28 -4
  302. data/app/uploaders/decidim/newsletter_template_image_uploader.rb +36 -0
  303. data/app/views/decidim/account/delete.html.erb +6 -3
  304. data/app/views/decidim/account/show.html.erb +17 -10
  305. data/app/views/decidim/amendments/_edit_form_fields.html.erb +2 -0
  306. data/app/views/decidim/amendments/_similar_emendation.html.erb +4 -4
  307. data/app/views/decidim/amendments/compare_draft.html.erb +2 -2
  308. data/app/views/decidim/amendments/edit_draft.html.erb +2 -2
  309. data/app/views/decidim/amendments/new.html.erb +2 -2
  310. data/app/views/decidim/amendments/preview_draft.html.erb +2 -2
  311. data/app/views/decidim/amendments/review.html.erb +3 -3
  312. data/app/views/decidim/application/_collection.html.erb +2 -2
  313. data/app/views/decidim/application/_document.html.erb +4 -4
  314. data/app/views/decidim/application/_documents.html.erb +1 -1
  315. data/app/views/decidim/application/_photos.html.erb +1 -1
  316. data/app/views/decidim/authorization_modals/show.html.erb +1 -1
  317. data/app/views/decidim/data_portability/show.html.erb +3 -0
  318. data/app/views/decidim/devise/confirmations/new.html.erb +3 -3
  319. data/app/views/decidim/devise/invitations/edit.html.erb +13 -13
  320. data/app/views/decidim/devise/omniauth_registrations/new.html.erb +5 -3
  321. data/app/views/decidim/devise/passwords/edit.html.erb +5 -3
  322. data/app/views/decidim/devise/passwords/new.html.erb +3 -3
  323. data/app/views/decidim/devise/registrations/edit.html.erb +2 -1
  324. data/app/views/decidim/devise/registrations/new.html.erb +7 -8
  325. data/app/views/decidim/devise/sessions/new.html.erb +4 -6
  326. data/app/views/decidim/devise/shared/_newsletter_modal.html.erb +3 -3
  327. data/app/views/decidim/devise/shared/_omniauth_buttons.html.erb +3 -1
  328. data/app/views/decidim/devise/shared/_omniauth_buttons_mini.html.erb +4 -1
  329. data/app/views/decidim/devise/unlocks/new.html.erb +3 -3
  330. data/app/views/decidim/doorkeeper/authorizations/new.html.erb +2 -2
  331. data/app/views/decidim/endorsements/_identity.html.erb +9 -0
  332. data/app/views/decidim/endorsements/identities.html.erb +12 -0
  333. data/app/views/decidim/endorsements/update_buttons_and_counters.js.erb +20 -0
  334. data/app/views/decidim/errors/internal_server_error.html.erb +2 -2
  335. data/app/views/decidim/errors/not_found.html.erb +2 -2
  336. data/app/views/decidim/gamification/badges/index.html.erb +4 -4
  337. data/app/views/decidim/group_admins/index.html.erb +6 -4
  338. data/app/views/decidim/group_invites/index.html.erb +5 -2
  339. data/app/views/decidim/group_members/index.html.erb +6 -4
  340. data/app/views/decidim/groups/_form.html.erb +2 -0
  341. data/app/views/decidim/groups/edit.html.erb +4 -2
  342. data/app/views/decidim/groups/new.html.erb +2 -2
  343. data/app/views/decidim/last_activities/index.html.erb +2 -0
  344. data/app/views/decidim/messaging/conversation_mailer/comanagers_new_conversation.html.erb +17 -0
  345. data/app/views/decidim/messaging/conversation_mailer/comanagers_new_message.html.erb +17 -0
  346. data/app/views/decidim/messaging/conversation_mailer/new_conversation.html.erb +2 -2
  347. data/app/views/decidim/messaging/conversation_mailer/new_group_conversation.html.erb +17 -0
  348. data/app/views/decidim/messaging/conversation_mailer/new_group_message.html.erb +17 -0
  349. data/app/views/decidim/messaging/conversation_mailer/new_message.html.erb +2 -2
  350. data/app/views/decidim/messaging/conversations/_add_conversation_users.html.erb +24 -0
  351. data/app/views/decidim/messaging/conversations/_conversation.html.erb +54 -0
  352. data/app/views/decidim/messaging/conversations/_messages.html.erb +15 -0
  353. data/app/views/decidim/messaging/conversations/_new_conversation_button.html.erb +33 -0
  354. data/app/views/decidim/messaging/conversations/_reply.html.erb +3 -3
  355. data/app/views/decidim/messaging/conversations/_show.html.erb +34 -15
  356. data/app/views/decidim/messaging/conversations/_start.html.erb +7 -1
  357. data/app/views/decidim/messaging/conversations/create.js.erb +1 -1
  358. data/app/views/decidim/messaging/conversations/index.html.erb +34 -29
  359. data/app/views/decidim/messaging/conversations/new.html.erb +1 -1
  360. data/app/views/decidim/messaging/conversations/show.html.erb +8 -4
  361. data/app/views/decidim/messaging/conversations/update.js.erb +1 -1
  362. data/app/views/decidim/newsletter_mailer/newsletter.html.erb +2 -2
  363. data/app/views/decidim/newsletters/show.html.erb +8 -1
  364. data/app/views/decidim/notifications/index.html.erb +4 -2
  365. data/app/views/decidim/notifications_settings/show.html.erb +14 -1
  366. data/app/views/decidim/own_user_groups/index.html.erb +4 -0
  367. data/app/views/decidim/pages/_standalone.html.erb +1 -1
  368. data/app/views/decidim/pages/_tabbed.html.erb +5 -5
  369. data/app/views/decidim/pages/index.html.erb +22 -13
  370. data/app/views/decidim/profiles/_user_follow.erb +3 -3
  371. data/app/views/decidim/profiles/show.html.erb +2 -0
  372. data/app/views/decidim/scopes/_scopes_picker_input.html.erb +11 -4
  373. data/app/views/decidim/scopes/picker.html.erb +26 -16
  374. data/app/views/decidim/searches/_count.html.erb +14 -11
  375. data/app/views/decidim/searches/_filters.html.erb +2 -2
  376. data/app/views/decidim/searches/index.html.erb +5 -3
  377. data/app/views/decidim/shared/_check_boxes_tree.html.erb +5 -3
  378. data/app/views/decidim/shared/_confirm_modal.html.erb +18 -0
  379. data/app/views/decidim/shared/_embed_modal.html.erb +4 -1
  380. data/app/views/decidim/shared/_extended_navigation_bar.html.erb +2 -2
  381. data/app/views/decidim/shared/_filter_form_help.erb +8 -0
  382. data/app/views/decidim/shared/_floating_help.html.erb +7 -7
  383. data/app/views/decidim/shared/_login_modal.html.erb +4 -4
  384. data/app/views/decidim/shared/_orders.html.erb +16 -5
  385. data/app/views/decidim/shared/_results_per_page.html.erb +16 -6
  386. data/app/views/decidim/shared/_share_modal.html.erb +8 -4
  387. data/app/views/decidim/shared/_static_map.html.erb +1 -1
  388. data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +1 -1
  389. data/app/views/decidim/user_activities/index.html.erb +4 -0
  390. data/app/views/decidim/user_activities/index.js.erb +14 -0
  391. data/app/views/decidim/user_conversations/index.html.erb +4 -0
  392. data/app/views/decidim/user_conversations/show.html.erb +4 -0
  393. data/app/views/decidim/user_conversations/update.js.erb +8 -0
  394. data/app/views/decidim/user_interests/_scopes.html.erb +12 -10
  395. data/app/views/decidim/user_interests/show.html.erb +4 -1
  396. data/app/views/decidim/user_timeline/index.html.erb +5 -1
  397. data/app/views/decidim/user_timeline/index.js.erb +14 -0
  398. data/app/views/kaminari/decidim/_first_page.html.erb +5 -1
  399. data/app/views/kaminari/decidim/_last_page.html.erb +5 -1
  400. data/app/views/kaminari/decidim/_next_page.html.erb +6 -1
  401. data/app/views/kaminari/decidim/_page.html.erb +2 -2
  402. data/app/views/kaminari/decidim/_paginator.html.erb +16 -14
  403. data/app/views/kaminari/decidim/_prev_page.html.erb +6 -1
  404. data/app/views/layouts/decidim/_application.html.erb +4 -2
  405. data/app/views/layouts/decidim/_cookie_warning.html.erb +1 -1
  406. data/app/views/layouts/decidim/_edit_link.html.erb +0 -0
  407. data/app/views/layouts/decidim/_head.html.erb +2 -0
  408. data/app/views/layouts/decidim/_js_configuration.html.erb +28 -0
  409. data/app/views/layouts/decidim/_language_chooser.html.erb +10 -5
  410. data/app/views/layouts/decidim/_logo.html.erb +2 -22
  411. data/app/views/layouts/decidim/_mailer_logo.html.erb +2 -22
  412. data/app/views/layouts/decidim/_main_footer.html.erb +3 -1
  413. data/app/views/layouts/decidim/_mini_footer.html.erb +7 -7
  414. data/app/views/layouts/decidim/_omnipresent_banner.html.erb +1 -1
  415. data/app/views/layouts/decidim/_organization_colors.html.erb +4 -3
  416. data/app/views/layouts/decidim/_social_media_links.html.erb +15 -10
  417. data/app/views/layouts/decidim/_topbar_search.html.erb +12 -2
  418. data/app/views/layouts/decidim/_user_menu.html.erb +6 -6
  419. data/app/views/layouts/decidim/_wrapper.html.erb +21 -16
  420. data/app/views/layouts/decidim/newsletter_base.html.erb +46 -0
  421. data/app/views/layouts/decidim/user_profile.html.erb +8 -3
  422. data/app/views/layouts/decidim/widget.html.erb +1 -0
  423. data/config/initializers/devise.rb +11 -3
  424. data/config/initializers/invisible_captcha.rb +1 -0
  425. data/config/initializers/omniauth.rb +7 -1
  426. data/config/initializers/rack_attack.rb +25 -16
  427. data/config/locales/ar.yml +7 -5
  428. data/config/locales/bg-BG.yml +1512 -0
  429. data/config/locales/ca.yml +258 -6
  430. data/config/locales/cs.yml +297 -37
  431. data/config/locales/da-DK.yml +9 -0
  432. data/config/locales/de.yml +279 -5
  433. data/config/locales/el.yml +1443 -5
  434. data/config/locales/en.yml +263 -11
  435. data/config/locales/es-MX.yml +257 -5
  436. data/config/locales/es-PY.yml +257 -5
  437. data/config/locales/es.yml +257 -5
  438. data/config/locales/et-EE.yml +9 -0
  439. data/config/locales/eu.yml +7 -2
  440. data/config/locales/fi-plain.yml +258 -6
  441. data/config/locales/fi.yml +319 -67
  442. data/config/locales/fr-CA.yml +1585 -0
  443. data/config/locales/fr.yml +263 -5
  444. data/config/locales/ga-IE.yml +9 -0
  445. data/config/locales/gl.yml +7 -2
  446. data/config/locales/hr-HR.yml +9 -0
  447. data/config/locales/hu.yml +87 -5
  448. data/config/locales/id-ID.yml +7 -2
  449. data/config/locales/is-IS.yml +1 -0
  450. data/config/locales/it.yml +279 -27
  451. data/config/locales/ja-JP.yml +1578 -0
  452. data/config/locales/lt-LT.yml +9 -0
  453. data/config/locales/lv-LV.yml +1485 -0
  454. data/config/locales/mt-MT.yml +9 -0
  455. data/config/locales/nl.yml +261 -6
  456. data/config/locales/no.yml +117 -41
  457. data/config/locales/pl.yml +755 -406
  458. data/config/locales/pt-BR.yml +8 -4
  459. data/config/locales/pt.yml +875 -536
  460. data/config/locales/ro-RO.yml +1603 -0
  461. data/config/locales/ru.yml +6 -1
  462. data/config/locales/sk-SK.yml +1426 -0
  463. data/config/locales/sk.yml +1441 -0
  464. data/config/locales/sl.yml +71 -0
  465. data/config/locales/sr-CS.yml +129 -0
  466. data/config/locales/sv.yml +323 -24
  467. data/config/locales/tr-TR.yml +7 -2
  468. data/config/locales/uk.yml +6 -1
  469. data/config/routes.rb +5 -0
  470. data/db/migrate/20180810092428_move_organization_fields_to_hero_content_block.rb +2 -2
  471. data/db/migrate/20191130151925_create_decidim_endorsements.rb +13 -0
  472. data/db/migrate/20191204075509_add_session_token_to_users.rb +7 -0
  473. data/db/migrate/20200211173227_add_direct_message_types_to_users.rb +12 -0
  474. data/db/migrate/20200320105904_index_foreign_keys_in_decidim_action_logs.rb +9 -0
  475. data/db/migrate/20200320105905_index_foreign_keys_in_decidim_amendments.rb +7 -0
  476. data/db/migrate/20200320105909_index_foreign_keys_in_decidim_authorizations.rb +7 -0
  477. data/db/migrate/20200320105917_index_foreign_keys_in_decidim_contextual_help_sections.rb +7 -0
  478. data/db/migrate/20200320105919_index_foreign_keys_in_decidim_endorsements.rb +7 -0
  479. data/db/migrate/20200320105923_index_foreign_keys_in_decidim_notifications.rb +7 -0
  480. data/db/migrate/20200320105927_index_foreign_keys_in_oauth_access_grants.rb +7 -0
  481. data/db/migrate/20200323094443_add_id_to_content_blocks_scope.rb +7 -0
  482. data/db/migrate/20200326102407_rename_scope_column.rb +7 -0
  483. data/db/migrate/20200327082257_migrate_newsletters_to_templates.rb +33 -0
  484. data/db/migrate/20200327082954_remove_newsletter_body.rb +7 -0
  485. data/db/migrate/20200401073419_add_index_on_content_block_scope_id.rb +11 -0
  486. data/db/seeds.rb +1 -1
  487. data/{app/controllers/concerns → lib}/decidim/action_authorization.rb +0 -0
  488. data/lib/decidim/api/author_interface.rb +4 -0
  489. data/lib/decidim/api/endorsable_interface.rb +22 -0
  490. data/lib/decidim/api/participatory_space_interface.rb +2 -0
  491. data/lib/decidim/api/timestamps_interface.rb +2 -2
  492. data/lib/decidim/coauthorable.rb +1 -1
  493. data/lib/decidim/component_manifest.rb +14 -0
  494. data/lib/decidim/content_parsers.rb +1 -0
  495. data/lib/decidim/content_parsers/user_group_parser.rb +61 -0
  496. data/lib/decidim/content_parsers/user_parser.rb +3 -5
  497. data/lib/decidim/content_renderers.rb +1 -0
  498. data/lib/decidim/content_renderers/user_group_renderer.rb +30 -0
  499. data/lib/decidim/core.rb +65 -21
  500. data/lib/decidim/core/api.rb +1 -0
  501. data/lib/decidim/core/engine.rb +88 -6
  502. data/lib/decidim/core/test.rb +8 -0
  503. data/lib/decidim/core/test/factories.rb +103 -3
  504. data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +79 -0
  505. data/lib/decidim/core/test/shared_examples/back_to_list_button_examples.rb +17 -0
  506. data/lib/decidim/core/test/shared_examples/comments_examples.rb +17 -2
  507. data/lib/decidim/core/test/shared_examples/edit_link_shared_examples.rb +5 -1
  508. data/lib/decidim/core/test/shared_examples/endorsable_interface_examples.rb +22 -0
  509. data/lib/decidim/core/test/shared_examples/endorsements_controller_shared_context.rb +22 -0
  510. data/lib/decidim/core/test/shared_examples/follows_examples.rb +1 -1
  511. data/lib/decidim/core/test/shared_examples/input_sort_examples.rb +21 -0
  512. data/lib/decidim/core/test/shared_examples/logo_email.rb +20 -0
  513. data/lib/decidim/core/test/shared_examples/metric_manage_shared_context.rb +9 -0
  514. data/lib/decidim/core/test/shared_examples/permissions.rb +143 -0
  515. data/lib/decidim/core/test/shared_examples/reports_examples.rb +4 -4
  516. data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +3 -3
  517. data/lib/decidim/core/test/shared_examples/simple_event.rb +1 -0
  518. data/lib/decidim/core/test/shared_examples/system_endorse_resource_examples.rb +165 -0
  519. data/lib/decidim/core/test/shared_examples/traceable_interface_examples.rb +3 -3
  520. data/lib/decidim/core/test/shared_examples/with_endorsable_permissions_examples.rb +89 -0
  521. data/lib/decidim/core/version.rb +1 -1
  522. data/lib/decidim/endorsable.rb +25 -0
  523. data/lib/decidim/events.rb +1 -0
  524. data/lib/decidim/events/user_group_event.rb +45 -0
  525. data/lib/decidim/exporters/csv.rb +1 -1
  526. data/lib/decidim/filter_form_builder.rb +15 -6
  527. data/lib/decidim/form_builder.rb +209 -23
  528. data/lib/decidim/has_attachments.rb +1 -1
  529. data/lib/decidim/participable.rb +6 -0
  530. data/lib/decidim/participatory_space_manifest.rb +15 -0
  531. data/lib/decidim/query_extensions.rb +9 -15
  532. data/lib/decidim/settings_manifest.rb +15 -1
  533. data/lib/decidim/view_model.rb +4 -0
  534. data/lib/tasks/decidim_tasks.rake +1 -0
  535. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.ro.js +15 -0
  536. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.sk.js +14 -0
  537. data/vendor/assets/javascripts/svg4everybody.min.js +1 -2
  538. data/vendor/assets/javascripts/tribute.js +11 -4
  539. metadata +187 -31
  540. data/app/assets/javascripts/decidim/vizzs/orgchart.js.es6 +0 -699
  541. data/app/assets/stylesheets/decidim/email.css +0 -1403
  542. data/app/assets/stylesheets/decidim/modules/_input-hashtags.scss +0 -124
  543. data/app/resolvers/decidim/core/user_resolver.rb +0 -61
  544. data/app/views/decidim/messaging/conversations/_message.html.erb +0 -14
@@ -5,8 +5,7 @@ module Decidim
5
5
  # A parser that searches user mentions in content.
6
6
  #
7
7
  # A word starting with `@` will be considered as a possible mention if
8
- # they only contains letters, numbers or underscores. If the `@` is
9
- # followed with an underscore, then it is not considered.
8
+ # they only contains letters, numbers or underscores.
10
9
  #
11
10
  # @see BaseParser Examples of how to use a content parser
12
11
  class UserParser < BaseParser
@@ -16,9 +15,8 @@ module Decidim
16
15
  # @return [Array] an array of Decidim::User mentioned in content
17
16
  Metadata = Struct.new(:users)
18
17
 
19
- # Matches a nickname if it starts with a letter or number
20
- # and only contains letters, numbers or underscores.
21
- MENTION_REGEX = /\B@([a-zA-Z0-9]\w*)\b/.freeze
18
+ # Matches a nickname if contains letters, numbers or underscores.
19
+ MENTION_REGEX = /\B@(\w*)\b/.freeze
22
20
 
23
21
  # Replaces found mentions matching a nickname of an existing
24
22
  # user in the current organization with a global id. Other
@@ -4,6 +4,7 @@ module Decidim
4
4
  module ContentRenderers
5
5
  autoload :BaseRenderer, "decidim/content_renderers/base_renderer"
6
6
  autoload :UserRenderer, "decidim/content_renderers/user_renderer"
7
+ autoload :UserGroupRenderer, "decidim/content_renderers/user_group_renderer"
7
8
  autoload :HashtagRenderer, "decidim/content_renderers/hashtag_renderer"
8
9
  autoload :LinkRenderer, "decidim/content_renderers/link_renderer"
9
10
  end
@@ -0,0 +1,30 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ module ContentRenderers
5
+ # A renderer that searches Global IDs representing users in content
6
+ # and replaces it with a link to their profile with the nickname.
7
+ #
8
+ # e.g. gid://<APP_NAME>/Decidim::UserGroup/1
9
+ #
10
+ # @see BaseRenderer Examples of how to use a content renderer
11
+ class UserGroupRenderer < BaseRenderer
12
+ # Matches a global id representing a Decidim::UserGroup
13
+ GLOBAL_ID_REGEX = %r{gid://\S+/Decidim::UserGroup/\d+}.freeze
14
+
15
+ # Replaces found Global IDs matching an existing user with
16
+ # a link to their profile. The Global IDs representing an
17
+ # invalid Decidim::UserGroup are replaced with an empty string.
18
+ #
19
+ # @return [String] the content ready to display (contains HTML)
20
+ def render
21
+ content.gsub(GLOBAL_ID_REGEX) do |user_gid|
22
+ user = GlobalID::Locator.locate(user_gid)
23
+ Decidim::UserGroupPresenter.new(user).display_mention
24
+ rescue ActiveRecord::RecordNotFound => _e
25
+ ""
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -81,6 +81,8 @@ module Decidim
81
81
  autoload :HasResourcePermission, "decidim/has_resource_permission"
82
82
  autoload :PermissionsRegistry, "decidim/permissions_registry"
83
83
  autoload :Randomable, "decidim/randomable"
84
+ autoload :Endorsable, "decidim/endorsable"
85
+ autoload :ActionAuthorization, "decidim/action_authorization"
84
86
 
85
87
  include ActiveSupport::Configurable
86
88
  # Loads seeds from all engines.
@@ -131,9 +133,19 @@ module Decidim
131
133
  # the mails.
132
134
  config_accessor :mailer_sender
133
135
 
136
+ # Whether SSL should be enabled or not.
137
+ config_accessor :force_ssl do
138
+ true
139
+ end
140
+
134
141
  # Exposes a configuration option: The application available locales.
135
142
  config_accessor :available_locales do
136
- %w(en ar ca de el es es-MX es-PY eu fi-pl fi fr gl hu id it nl no pl pt pt-BR ru sv tr uk)
143
+ %w(en ar ca de el es es-MX es-PY eu fi-pl fi fr gl hu id it nl no pl pt pt-BR ro ru sk sv tr uk)
144
+ end
145
+
146
+ # Exposes a configuration option: The application default locale.
147
+ config_accessor :default_locale do
148
+ :en
137
149
  end
138
150
 
139
151
  # Exposes a configuration option: an array of symbols representing processors
@@ -153,11 +165,6 @@ module Decidim
153
165
  []
154
166
  end
155
167
 
156
- # Exposes a configuration option: The application default locale.
157
- config_accessor :default_locale do
158
- :en
159
- end
160
-
161
168
  # Exposes a configuration option: an object to configure geocoder
162
169
  config_accessor :geocoder
163
170
 
@@ -192,6 +199,11 @@ module Decidim
192
199
  end
193
200
  end
194
201
 
202
+ # Exposes a configuration option: the whitelist ips
203
+ config_accessor :system_accesslist_ips do
204
+ []
205
+ end
206
+
195
207
  # Exposes a configuration option: the currency unit
196
208
  config_accessor :currency_unit do
197
209
  "€"
@@ -212,7 +224,7 @@ module Decidim
212
224
  5.megabytes
213
225
  end
214
226
 
215
- # The number of reports which an object can receive before hiding it
227
+ # The number of reports which a resource can receive before hiding it
216
228
  config_accessor :max_reports_before_hiding do
217
229
  3
218
230
  end
@@ -247,39 +259,71 @@ module Decidim
247
259
  2.days
248
260
  end
249
261
 
262
+ # How long can a user remained logged in before the session expires
263
+ config_accessor :expire_session_after do
264
+ 1.day
265
+ end
266
+
250
267
  # Exposes a configuration option: an object to configure Etherpad
251
- config_accessor :etherpad
268
+ config_accessor :etherpad do
269
+ # {
270
+ # server: <your url>,
271
+ # api_key: <your key>,
272
+ # api_version: <your version>
273
+ # }
274
+ end
252
275
 
253
276
  # A base path for the uploads. If set, make sure it ends in a slash.
254
277
  # Uploads will be set to `<base_path>/uploads/`. This can be useful if you
255
278
  # want to use the same uploads place for both staging and production
256
279
  # environments, but in different folders.
257
- config_accessor :base_uploads_path
280
+ config_accessor :base_uploads_path do
281
+ nil
282
+ end
258
283
 
259
- # Exposes a configuration option: an object to deliver SMS codes to users.
260
- config_accessor :sms_gateway_service
284
+ # The name of the class to deliver SMS codes to users.
285
+ #
286
+ # Check the example in `decidim-verifications`.
287
+ config_accessor :sms_gateway_service do
288
+ # "MyGatewayClass"
289
+ end
261
290
 
262
- # Exposes a configuration option: an object to generate a timestamp from a
263
- # document
264
- config_accessor :timestamp_service
291
+ # The name of the class used to generate a timestamp from a document.
292
+ #
293
+ # Check the example in `decidim-initiatives`
294
+ config_accessor :timestamp_service do
295
+ # "MyTimestampService"
296
+ end
265
297
 
266
- # Exposes a configuration option: an object to process a pdf and add a
267
- # signature to the document
268
- config_accessor :pdf_signature_service
298
+ # The name of the class used to process a pdf and add a signature to the
299
+ # document.
300
+ #
301
+ # Check the example in `decidim-initiatives`
302
+ config_accessor :pdf_signature_service do
303
+ # "MyPDFSignatureService"
304
+ end
269
305
 
270
- # Exposes a configuration option: Decidim::Exporters::CSV's default column separator
306
+ # The Decidim::Exporters::CSV's default column separator
271
307
  config_accessor :default_csv_col_sep do
272
308
  ";"
273
309
  end
274
310
 
275
- # Exposes a configuration option: An Array of Strings with the roles of a Decidim::User.
311
+ # Exposes a configuration option: HTTP_X_FORWADED_HOST header follow-up.
312
+ # If a caching system is in place, it can also allow cache and log poisoning attacks,
313
+ # allowing attackers to control the contents of caches and logs that could be used for other attacks.
314
+ config_accessor :follow_http_x_forwarded_host do
315
+ false
316
+ end
317
+
318
+ # The list of roles a user can have, not considering the space-specific roles.
276
319
  config_accessor :user_roles do
277
320
  %w(admin user_manager)
278
321
  end
279
322
 
280
- # Exposes a configuration option: An Array of Strings that serve both as
281
- # locale keys and values to construct the input collection in
323
+ # The list of visibility options for amendments. An Array of Strings that
324
+ # serve both as locale keys and values to construct the input collection in
282
325
  # Decidim::Amendment::VisibilityStepSetting::options.
326
+ #
283
327
  # This collection is used in Decidim::Admin::SettingsHelper to generate a
284
328
  # radio buttons collection input field form for a Decidim::Component
285
329
  # step setting :amendments_visibility.
@@ -17,5 +17,6 @@ module Decidim
17
17
  autoload :AmendableEntityInterface, "decidim/api/amendable_entity_interface"
18
18
  autoload :TraceableInterface, "decidim/api/traceable_interface"
19
19
  autoload :TimestampsInterface, "decidim/api/timestamps_interface"
20
+ autoload :EndorsableInterface, "decidim/api/endorsable_interface"
20
21
  end
21
22
  end
@@ -59,12 +59,14 @@ module Decidim
59
59
 
60
60
  initializer "decidim.middleware" do |app|
61
61
  app.config.middleware.insert_before Warden::Manager, Decidim::CurrentOrganization
62
+ app.config.middleware.insert_before Warden::Manager, Decidim::StripXForwardedHost
62
63
  app.config.middleware.use BatchLoader::Middleware
63
64
  end
64
65
 
65
66
  initializer "decidim.assets" do |app|
66
67
  app.config.assets.paths << File.expand_path("../../../app/assets/stylesheets", __dir__)
67
- app.config.assets.precompile += %w(decidim_core_manifest.js)
68
+ app.config.assets.precompile += %w(decidim_core_manifest.js
69
+ decidim/identity_selector_dialog)
68
70
 
69
71
  Decidim.component_manifests.each do |component|
70
72
  app.config.assets.precompile += [component.icon]
@@ -196,7 +198,7 @@ module Decidim
196
198
 
197
199
  initializer "decidim.content_processors" do |_app|
198
200
  Decidim.configure do |config|
199
- config.content_processors += [:user, :hashtag, :link]
201
+ config.content_processors += [:user, :user_group, :hashtag, :link]
200
202
  end
201
203
  end
202
204
 
@@ -240,9 +242,7 @@ module Decidim
240
242
  # #call can be used in order to allow conditional checks (to allow non-SSL
241
243
  # redirects to localhost for example).
242
244
  #
243
- # force_ssl_in_redirect_uri !Rails.env.development?
244
- #
245
- force_ssl_in_redirect_uri false
245
+ force_ssl_in_redirect_uri !Rails.env.development?
246
246
 
247
247
  # WWW-Authenticate Realm (default "Doorkeeper").
248
248
  realm "Decidim"
@@ -255,6 +255,22 @@ module Decidim
255
255
  end
256
256
  end
257
257
 
258
+ initializer "SSL and HSTS" do
259
+ Rails.application.configure do
260
+ config.force_ssl = Rails.env.production? && Decidim.config.force_ssl
261
+ end
262
+ end
263
+
264
+ initializer "Disable Rack::Runtime" do
265
+ Rails.application.configure do
266
+ config.middleware.delete Rack::Runtime
267
+ end
268
+ end
269
+
270
+ initializer "Expire sessions" do
271
+ Rails.application.config.session_store :cookie_store, expire_after: Decidim.config.expire_session_after
272
+ end
273
+
258
274
  initializer "decidim.core.register_resources" do
259
275
  Decidim.register_resource(:user) do |resource|
260
276
  resource.model_class_name = "Decidim::User"
@@ -302,7 +318,7 @@ module Decidim
302
318
  end
303
319
  end
304
320
 
305
- initializer "decidim.core.content_blocks" do
321
+ initializer "decidim.core.homepage_content_blocks" do
306
322
  Decidim.content_blocks.register(:homepage, :hero) do |content_block|
307
323
  content_block.cell = "decidim/content_blocks/hero"
308
324
  content_block.settings_form_cell = "decidim/content_blocks/hero_settings_form"
@@ -374,6 +390,68 @@ module Decidim
374
390
  end
375
391
  end
376
392
 
393
+ initializer "decidim.core.newsletter_templates" do
394
+ Decidim.content_blocks.register(:newsletter_template, :basic_only_text) do |content_block|
395
+ content_block.cell = "decidim/newsletter_templates/basic_only_text"
396
+ content_block.settings_form_cell = "decidim/newsletter_templates/basic_only_text_settings_form"
397
+ content_block.public_name_key = "decidim.newsletter_templates.basic_only_text.name"
398
+
399
+ content_block.settings do |settings|
400
+ settings.attribute(
401
+ :body,
402
+ type: :text,
403
+ translated: true,
404
+ preview: -> { I18n.t("decidim.newsletter_templates.basic_only_text.body_preview") }
405
+ )
406
+ end
407
+
408
+ content_block.default!
409
+ end
410
+
411
+ Decidim.content_blocks.register(:newsletter_template, :image_text_cta) do |content_block|
412
+ content_block.cell = "decidim/newsletter_templates/image_text_cta"
413
+ content_block.settings_form_cell = "decidim/newsletter_templates/image_text_cta_settings_form"
414
+ content_block.public_name_key = "decidim.newsletter_templates.image_text_cta.name"
415
+
416
+ content_block.images = [
417
+ {
418
+ name: :main_image,
419
+ uploader: "Decidim::NewsletterTemplateImageUploader",
420
+ preview: -> { ActionController::Base.helpers.asset_path("decidim/placeholder.jpg") }
421
+ }
422
+ ]
423
+
424
+ content_block.settings do |settings|
425
+ settings.attribute(
426
+ :introduction,
427
+ type: :text,
428
+ translated: true,
429
+ preview: -> { I18n.t("decidim.newsletter_templates.image_text_cta.introduction_preview") }
430
+ )
431
+ settings.attribute(
432
+ :body,
433
+ type: :text,
434
+ translated: true,
435
+ preview: -> { I18n.t("decidim.newsletter_templates.image_text_cta.body_preview") }
436
+ )
437
+ settings.attribute(
438
+ :cta_text,
439
+ type: :text,
440
+ translated: true,
441
+ preview: -> { I18n.t("decidim.newsletter_templates.image_text_cta.cta_text_preview") }
442
+ )
443
+ settings.attribute(
444
+ :cta_url,
445
+ type: :text,
446
+ translated: true,
447
+ preview: -> { "http://decidim.org" }
448
+ )
449
+ end
450
+
451
+ content_block.default!
452
+ end
453
+ end
454
+
377
455
  initializer "decidim.core.add_badges" do
378
456
  Decidim::Gamification.register_badge(:invitations) do |badge|
379
457
  badge.levels = [1, 5, 10, 30, 50]
@@ -389,6 +467,10 @@ module Decidim
389
467
  initializer "nbspw" do
390
468
  NOBSPW.configuration.use_ruby_grep = true
391
469
  end
470
+
471
+ config.to_prepare do
472
+ FoundationRailsHelper::FlashHelper.send(:include, Decidim::FlashHelperExtensions)
473
+ end
392
474
  end
393
475
  end
394
476
  end
@@ -5,6 +5,7 @@ require "decidim/core/test/shared_examples/authorable"
5
5
  require "decidim/core/test/shared_examples/coauthorable"
6
6
  require "decidim/core/test/shared_examples/publicable"
7
7
  require "decidim/core/test/shared_examples/localised_email"
8
+ require "decidim/core/test/shared_examples/logo_email"
8
9
  require "decidim/core/test/shared_examples/has_attachments"
9
10
  require "decidim/core/test/shared_examples/has_attachment_collections"
10
11
  require "decidim/core/test/shared_examples/has_component"
@@ -28,6 +29,7 @@ require "decidim/core/test/shared_examples/searchable_results_examples"
28
29
  require "decidim/core/test/shared_examples/has_space_in_mcell_examples"
29
30
  require "decidim/core/test/shared_examples/railtie_examples"
30
31
  require "decidim/core/test/shared_examples/edit_link_shared_examples"
32
+ require "decidim/core/test/shared_examples/endorsements_controller_shared_context"
31
33
  require "decidim/core/test/shared_examples/amendable/create_amendment_draft_examples"
32
34
  require "decidim/core/test/shared_examples/amendable/update_amendment_draft_examples"
33
35
  require "decidim/core/test/shared_examples/amendable/destroy_amendment_draft_examples"
@@ -46,4 +48,10 @@ require "decidim/core/test/shared_examples/uncommentable_component_examples"
46
48
  require "decidim/core/test/shared_examples/searchable_resources_shared_context"
47
49
  require "decidim/core/test/shared_examples/searchable_participatory_space_examples"
48
50
  require "decidim/core/test/shared_examples/has_private_users"
51
+ require "decidim/core/test/shared_examples/with_endorsable_permissions_examples"
52
+ require "decidim/core/test/shared_examples/system_endorse_resource_examples"
49
53
  require "decidim/core/test/shared_examples/rich_text_editor_examples"
54
+ require "decidim/core/test/shared_examples/back_to_list_button_examples"
55
+ require "decidim/core/test/shared_examples/permissions"
56
+ require "decidim/core/test/shared_examples/admin_resource_gallery_examples"
57
+ require "decidim/core/test/shared_examples/metric_manage_shared_context"
@@ -335,8 +335,9 @@ FactoryBot.define do
335
335
 
336
336
  trait :with_one_step do
337
337
  step_settings do
338
+ participatory_space_with_steps if participatory_space.active_step.nil?
338
339
  {
339
- 1 => { dummy_step_setting: true }
340
+ participatory_space.active_step.id => { dummy_step_setting: true }
340
341
  }
341
342
  end
342
343
  end
@@ -360,6 +361,44 @@ FactoryBot.define do
360
361
  trait :with_permissions do
361
362
  settings { { Random.rand => Random.new.bytes(5) } }
362
363
  end
364
+
365
+ transient do
366
+ participatory_space_with_steps do
367
+ create(:participatory_process_step,
368
+ active: true,
369
+ end_date: 1.month.from_now,
370
+ participatory_process: participatory_space)
371
+ participatory_space.reload
372
+ participatory_space.steps.reload
373
+ end
374
+ end
375
+
376
+ trait :with_endorsements_enabled do
377
+ step_settings do
378
+ participatory_space_with_steps if participatory_space.active_step.nil?
379
+ {
380
+ participatory_space.active_step.id => { endorsements_enabled: true }
381
+ }
382
+ end
383
+ end
384
+
385
+ trait :with_endorsements_disabled do
386
+ step_settings do
387
+ participatory_space_with_steps if participatory_space.active_step.nil?
388
+ {
389
+ participatory_space.active_step.id => { endorsements_enabled: false }
390
+ }
391
+ end
392
+ end
393
+
394
+ trait :with_endorsements_blocked do
395
+ step_settings do
396
+ participatory_space_with_steps if participatory_space.active_step.nil?
397
+ {
398
+ participatory_space.active_step.id => { endorsements_blocked: true }
399
+ }
400
+ end
401
+ end
363
402
  end
364
403
 
365
404
  factory :scope_type, class: "Decidim::ScopeType" do
@@ -403,6 +442,11 @@ FactoryBot.define do
403
442
  end
404
443
 
405
444
  factory :dummy_resource, class: "Decidim::DummyResources::DummyResource" do
445
+ transient do
446
+ users { nil }
447
+ # user_groups correspondence to users is by sorting order
448
+ user_groups { [] }
449
+ end
406
450
  title { generate(:name) }
407
451
  component { create(:component, manifest_name: "dummy") }
408
452
  author { create(:user, :confirmed, organization: component.organization) }
@@ -411,6 +455,33 @@ FactoryBot.define do
411
455
  trait :published do
412
456
  published_at { Time.current }
413
457
  end
458
+
459
+ trait :with_endorsements do
460
+ after :create do |resource|
461
+ 5.times.collect do
462
+ create(:endorsement, resource: resource, author: build(:user, organization: resource.component.organization))
463
+ end
464
+ end
465
+ end
466
+ end
467
+
468
+ factory :coauthorable_dummy_resource, class: "Decidim::DummyResources::CoauthorableDummyResource" do
469
+ title { generate(:name) }
470
+ component { create(:component, manifest_name: "dummy") }
471
+
472
+ transient do
473
+ authors_list { [create(:user, organization: component.organization)] }
474
+ end
475
+
476
+ after :build do |resource, evaluator|
477
+ evaluator.authors_list.each do |coauthor|
478
+ resource.coauthorships << if coauthor.is_a?(::Decidim::UserGroup)
479
+ build(:coauthorship, author: coauthor.users.first, user_group: coauthor, coauthorable: resource, organization: evaluator.component.organization)
480
+ else
481
+ build(:coauthorship, author: coauthor, coauthorable: resource, organization: evaluator.component.organization)
482
+ end
483
+ end
484
+ end
414
485
  end
415
486
 
416
487
  factory :resource_link, class: "Decidim::ResourceLink" do
@@ -420,12 +491,25 @@ FactoryBot.define do
420
491
  end
421
492
 
422
493
  factory :newsletter, class: "Decidim::Newsletter" do
494
+ transient do
495
+ body { Decidim::Faker::Localized.wrapped("<p>", "</p>") { generate_localized_title } }
496
+ end
497
+
423
498
  author { build(:user, :confirmed, organization: organization) }
424
499
  organization
425
500
 
426
501
  subject { generate_localized_title }
427
502
 
428
- body { Decidim::Faker::Localized.wrapped("<p>", "</p>") { generate_localized_title } }
503
+ after(:create) do |newsletter, evaluator|
504
+ create(
505
+ :content_block,
506
+ :newsletter_template,
507
+ organization: evaluator.organization,
508
+ scoped_resource_id: newsletter.id,
509
+ manifest_name: "basic_only_text",
510
+ settings: evaluator.body.transform_keys { |key| "body_#{key}" }
511
+ )
512
+ end
429
513
 
430
514
  trait :sent do
431
515
  sent_at { Time.current }
@@ -547,10 +631,15 @@ FactoryBot.define do
547
631
 
548
632
  factory :content_block, class: "Decidim::ContentBlock" do
549
633
  organization
550
- scope { :homepage }
634
+ scope_name { :homepage }
551
635
  manifest_name { :hero }
552
636
  weight { 1 }
553
637
  published_at { Time.current }
638
+
639
+ trait :newsletter_template do
640
+ scope_name { :newsletter_template }
641
+ manifest_name { :basic_only_text }
642
+ end
554
643
  end
555
644
 
556
645
  factory :hashtag, class: "Decidim::Hashtag" do
@@ -583,4 +672,15 @@ FactoryBot.define do
583
672
  state { "rejected" }
584
673
  end
585
674
  end
675
+
676
+ factory :endorsement, class: "Decidim::Endorsement" do
677
+ resource { build(:dummy_resource) }
678
+ author { resource.try(:creator_author) || resource.try(:author) || build(:user, organization: resource.organization) }
679
+ end
680
+
681
+ factory :user_group_endorsement, class: "Decidim::Endorsement" do
682
+ resource { build(:dummy_resource) }
683
+ author { build(:user, organization: resource.organization) }
684
+ user_group { create(:user_group, verified_at: Time.current, organization: resource.organization, users: [author]) }
685
+ end
586
686
  end