decidim-decidim_awesome 0.7.2 → 0.8.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (235) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +62 -35
  3. data/Rakefile +11 -12
  4. data/app/cells/decidim/decidim_awesome/content_blocks/map/error.erb +11 -0
  5. data/app/cells/decidim/decidim_awesome/content_blocks/map/show.erb +1 -61
  6. data/app/cells/decidim/decidim_awesome/content_blocks/map_cell.rb +11 -0
  7. data/app/cells/decidim/decidim_awesome/content_blocks/map_form/show.erb +8 -4
  8. data/app/commands/decidim/decidim_awesome/admin/create_custom_redirect.rb +51 -0
  9. data/app/commands/decidim/decidim_awesome/admin/destroy_custom_redirect.rb +47 -0
  10. data/app/commands/decidim/decidim_awesome/admin/update_custom_redirect.rb +49 -0
  11. data/app/commands/decidim/decidim_awesome/create_editor_image.rb +12 -5
  12. data/app/controllers/concerns/decidim/decidim_awesome/not_found_redirect.rb +58 -0
  13. data/app/controllers/decidim/decidim_awesome/admin/checks_controller.rb +15 -22
  14. data/app/controllers/decidim/decidim_awesome/admin/config_controller.rb +9 -1
  15. data/app/controllers/decidim/decidim_awesome/admin/custom_redirects_controller.rb +91 -0
  16. data/app/controllers/decidim/decidim_awesome/admin/menu_hacks_controller.rb +5 -8
  17. data/app/controllers/decidim/decidim_awesome/blank_component_controller.rb +19 -0
  18. data/app/controllers/decidim/decidim_awesome/editor_images_controller.rb +2 -3
  19. data/app/controllers/decidim/decidim_awesome/iframe_component/iframe_controller.rb +1 -1
  20. data/app/controllers/decidim/decidim_awesome/map_component/map_controller.rb +2 -6
  21. data/app/forms/decidim/decidim_awesome/admin/config_form.rb +2 -0
  22. data/app/forms/decidim/decidim_awesome/admin/custom_redirect_form.rb +45 -0
  23. data/app/forms/decidim/decidim_awesome/editor_image_form.rb +3 -2
  24. data/app/forms/decidim/decidim_awesome/proposals/proposal_wizard_create_step_form_override.rb +38 -0
  25. data/app/helpers/decidim/decidim_awesome/admin/config_constraints_helpers.rb +22 -9
  26. data/app/helpers/decidim/decidim_awesome/admin/system_checker_helpers.rb +36 -0
  27. data/app/helpers/decidim/decidim_awesome/map_helper.rb +18 -12
  28. data/app/helpers/decidim/decidim_awesome/proposals/application_helper_override.rb +2 -2
  29. data/app/jobs/decidim/decidim_awesome/migrate_legacy_images_job.rb +106 -0
  30. data/app/models/decidim/decidim_awesome/editor_image.rb +4 -9
  31. data/app/packs/entrypoints/decidim_admin_decidim_awesome.js +5 -0
  32. data/app/packs/entrypoints/decidim_admin_decidim_awesome.scss +1 -0
  33. data/app/packs/entrypoints/decidim_admin_decidim_awesome_custom_fields.js +2 -0
  34. data/app/packs/entrypoints/decidim_decidim_awesome.js +9 -0
  35. data/app/packs/entrypoints/decidim_decidim_awesome.scss +1 -0
  36. data/app/packs/entrypoints/decidim_decidim_awesome_admin_form_exit_warn.js +1 -0
  37. data/app/packs/entrypoints/decidim_decidim_awesome_custom_fields.js +1 -0
  38. data/app/packs/entrypoints/decidim_decidim_awesome_iframe.scss +1 -0
  39. data/app/packs/entrypoints/decidim_decidim_awesome_map.js +5 -0
  40. data/app/packs/entrypoints/decidim_decidim_awesome_map.scss +1 -0
  41. data/app/{assets → packs}/images/decidim/decidim_awesome/platoniq-logo.png +0 -0
  42. data/app/{assets/javascripts/decidim/decidim_awesome/admin/auto_edit.js.es6 → packs/src/decidim/decidim_awesome/admin/auto_edit.js} +39 -34
  43. data/app/packs/src/decidim/decidim_awesome/admin/check_redirections.js +48 -0
  44. data/app/{assets/javascripts/decidim/decidim_awesome/admin/codemirror.js.es6 → packs/src/decidim/decidim_awesome/admin/codemirror.js} +4 -4
  45. data/app/packs/src/decidim/decidim_awesome/admin/constraints.js +55 -0
  46. data/app/{assets/javascripts/decidim/decidim_awesome/admin/form_builder.js.es6 → packs/src/decidim/decidim_awesome/admin/custom_fields_builder.js} +23 -26
  47. data/app/{assets/javascripts/decidim/decidim_awesome/admin/form_exit_warn.js.es6 → packs/src/decidim/decidim_awesome/admin/form_exit_warn.js} +0 -2
  48. data/app/{assets/javascripts/decidim/decidim_awesome/admin/user_picker.js.es6 → packs/src/decidim/decidim_awesome/admin/user_picker.js} +3 -3
  49. data/app/packs/src/decidim/decidim_awesome/awesome_admin.js +23 -0
  50. data/app/packs/src/decidim/decidim_awesome/awesome_application.js +17 -0
  51. data/app/{assets/javascripts/decidim/decidim_awesome/awesome_map/api_fetcher.js.es6 → packs/src/decidim/decidim_awesome/awesome_map/api/api_fetcher.js} +1 -15
  52. data/app/packs/src/decidim/decidim_awesome/awesome_map/api/fetcher.js +131 -0
  53. data/app/packs/src/decidim/decidim_awesome/awesome_map/api/meetings_fetcher.js +59 -0
  54. data/app/packs/src/decidim/decidim_awesome/awesome_map/api/proposals_fetcher.js +52 -0
  55. data/app/packs/src/decidim/decidim_awesome/awesome_map/awesome_map.js +130 -0
  56. data/app/packs/src/decidim/decidim_awesome/awesome_map/controllers/controller.js +112 -0
  57. data/app/packs/src/decidim/decidim_awesome/awesome_map/controllers/meetings_controller.js +31 -0
  58. data/app/packs/src/decidim/decidim_awesome/awesome_map/controllers/proposals_controller.js +88 -0
  59. data/app/packs/src/decidim/decidim_awesome/awesome_map/controls_ui.js +221 -0
  60. data/app/packs/src/decidim/decidim_awesome/awesome_map/load_map.js +51 -0
  61. data/app/packs/src/decidim/decidim_awesome/editors/editor.js +190 -0
  62. data/app/{assets/javascripts/decidim/decidim_awesome/editors/tabs_focus.js.es6 → packs/src/decidim/decidim_awesome/editors/tabs_focus.js} +4 -6
  63. data/app/{assets/javascripts/decidim/decidim_awesome/forms/autosave.js.es6 → packs/src/decidim/decidim_awesome/forms/autosave.js} +20 -17
  64. data/app/packs/src/decidim/decidim_awesome/forms/custom_fields_renderer.js +207 -0
  65. data/app/{assets/javascripts/decidim/decidim_awesome/forms/rich_text_plugin.js.es6 → packs/src/decidim/decidim_awesome/forms/rich_text_plugin.js} +21 -20
  66. data/app/packs/src/decidim/decidim_awesome/proposals/custom_fields.js +22 -0
  67. data/app/packs/src/decidim/decidim_awesome/proposals/images.js +25 -0
  68. data/{vendor/assets/javascripts → app/packs/src/vendor}/image-resize.min.js +0 -0
  69. data/{vendor/assets/javascripts → app/packs/src/vendor}/image-upload.min.js +0 -0
  70. data/{vendor/assets/javascripts → app/packs/src/vendor}/jquery.truncate.js +0 -0
  71. data/app/packs/src/vendor/leaflet.featuregroup.subgroup.js +184 -0
  72. data/app/{assets → packs}/stylesheets/decidim/decidim_awesome/admin/auto_edits.scss +2 -1
  73. data/app/packs/stylesheets/decidim/decidim_awesome/admin/check_redirections.scss +28 -0
  74. data/app/{assets → packs}/stylesheets/decidim/decidim_awesome/admin/codemirror.scss +8 -6
  75. data/app/{assets → packs}/stylesheets/decidim/decidim_awesome/admin/constraints.scss +13 -13
  76. data/app/{assets → packs}/stylesheets/decidim/decidim_awesome/admin/custom_fields.scss +37 -10
  77. data/app/packs/stylesheets/decidim/decidim_awesome/admin/user_picker.scss +41 -0
  78. data/app/packs/stylesheets/decidim/decidim_awesome/awesome_admin.scss +71 -0
  79. data/app/packs/stylesheets/decidim/decidim_awesome/awesome_application.scss +19 -0
  80. data/app/{assets → packs}/stylesheets/decidim/decidim_awesome/awesome_iframe/iframe.scss +3 -3
  81. data/app/packs/stylesheets/decidim/decidim_awesome/awesome_map/map.scss +176 -0
  82. data/app/{assets → packs}/stylesheets/decidim/decidim_awesome/editors/markdown_editor.scss +6 -4
  83. data/app/packs/stylesheets/decidim/decidim_awesome/editors/quill_editor.scss +58 -0
  84. data/app/{assets → packs}/stylesheets/decidim/decidim_awesome/forms/autosave.scss +2 -2
  85. data/app/packs/stylesheets/vendor/select2-foundation-theme.scss +348 -0
  86. data/app/presenters/decidim/decidim_awesome/menu_item_presenter_override.rb +25 -0
  87. data/app/presenters/decidim/decidim_awesome/menu_presenter_override.rb +23 -0
  88. data/app/uploaders/decidim/cw/decidim_awesome/image_uploader.rb +26 -0
  89. data/app/uploaders/decidim/decidim_awesome/image_uploader.rb +4 -16
  90. data/app/views/decidim/decidim_awesome/admin/checks/index.html.erb +28 -22
  91. data/app/views/decidim/decidim_awesome/admin/config/_constraints.html.erb +1 -1
  92. data/app/views/decidim/decidim_awesome/admin/config/_form_admins.html.erb +1 -1
  93. data/app/views/decidim/decidim_awesome/admin/config/_form_editors.html.erb +1 -0
  94. data/app/views/decidim/decidim_awesome/admin/config/_form_proposal_custom_fields.html.erb +1 -1
  95. data/app/views/decidim/decidim_awesome/admin/config/_form_styles.html.erb +7 -6
  96. data/app/views/decidim/decidim_awesome/admin/config/_modal.html.erb +1 -1
  97. data/app/views/decidim/decidim_awesome/admin/config/show.html.erb +3 -3
  98. data/app/views/decidim/decidim_awesome/admin/constraints/new.html.erb +1 -1
  99. data/app/views/decidim/decidim_awesome/admin/custom_redirects/_form.html.erb +6 -0
  100. data/app/views/decidim/decidim_awesome/admin/custom_redirects/edit.html.erb +13 -0
  101. data/app/views/decidim/decidim_awesome/admin/custom_redirects/index.html.erb +37 -0
  102. data/app/views/decidim/decidim_awesome/admin/custom_redirects/new.html.erb +13 -0
  103. data/app/views/decidim/decidim_awesome/admin/menu_hacks/edit.html.erb +1 -1
  104. data/app/views/decidim/decidim_awesome/admin/menu_hacks/new.html.erb +1 -1
  105. data/app/views/decidim/decidim_awesome/admin/proposals/_editor.html.erb +5 -3
  106. data/app/views/decidim/decidim_awesome/iframe_component/iframe/show.html.erb +1 -1
  107. data/app/views/decidim/decidim_awesome/map_component/map/_api_ready.html.erb +3 -0
  108. data/app/views/decidim/decidim_awesome/map_component/map/_map_template.html.erb +68 -0
  109. data/app/views/decidim/decidim_awesome/map_component/map/{error.erb → error.html.erb} +2 -0
  110. data/app/views/decidim/decidim_awesome/map_component/map/show.html.erb +3 -67
  111. data/app/views/decidim/proposals/admin/proposals/_form.html.erb +1 -1
  112. data/app/views/layouts/decidim/admin/decidim_awesome.html.erb +13 -9
  113. data/app/views/layouts/decidim/decidim_awesome/_awesome_config.html.erb +0 -2
  114. data/app/views/{v0.24 → v0.25}/decidim/proposals/collaborative_drafts/_show.html.erb +0 -0
  115. data/app/views/{v0.23 → v0.25}/layouts/decidim/_head.html.erb +12 -10
  116. data/app/views/v0.25/layouts/decidim/admin/_header.html.erb +11 -0
  117. data/app/views/{v0.23 → v0.26}/decidim/proposals/collaborative_drafts/_show.html.erb +1 -7
  118. data/app/views/{v0.24 → v0.26}/layouts/decidim/_head.html.erb +16 -10
  119. data/app/views/v0.26/layouts/decidim/admin/_header.html.erb +11 -0
  120. data/config/assets.rb +46 -0
  121. data/config/i18n-tasks.yml +6 -0
  122. data/config/locales/ca.yml +75 -13
  123. data/config/locales/cs.yml +63 -1
  124. data/config/locales/en.yml +67 -1
  125. data/config/locales/es.yml +63 -1
  126. data/config/locales/eu.yml +0 -232
  127. data/config/locales/fr.yml +115 -53
  128. data/config/locales/it.yml +63 -1
  129. data/config/locales/ja.yml +64 -3
  130. data/config/locales/nl.yml +5 -46
  131. data/config/locales/pt-BR.yml +346 -0
  132. data/config/locales/pt-PT.yml +7 -0
  133. data/config/locales/pt.yml +7 -0
  134. data/config/locales/sv.yml +67 -182
  135. data/lib/decidim/decidim_awesome/admin_engine.rb +10 -15
  136. data/lib/decidim/decidim_awesome/awesome.rb +214 -0
  137. data/lib/decidim/decidim_awesome/awesome_helpers.rb +0 -7
  138. data/lib/decidim/decidim_awesome/checksums.yml +13 -16
  139. data/lib/decidim/decidim_awesome/config.rb +1 -0
  140. data/lib/decidim/decidim_awesome/content_parsers/editor_images_parser.rb +39 -0
  141. data/lib/decidim/decidim_awesome/engine.rb +27 -55
  142. data/lib/decidim/decidim_awesome/iframe_component/admin_engine.rb +23 -0
  143. data/lib/decidim/decidim_awesome/iframe_component/component.rb +5 -5
  144. data/lib/decidim/decidim_awesome/map_component/admin_engine.rb +23 -0
  145. data/lib/decidim/decidim_awesome/map_component/component.rb +5 -4
  146. data/lib/decidim/decidim_awesome/map_component/engine.rb +34 -0
  147. data/lib/decidim/decidim_awesome/menu_hacker.rb +1 -0
  148. data/lib/decidim/decidim_awesome/test/factories.rb +2 -2
  149. data/lib/decidim/decidim_awesome/test/initializer.rb +25 -0
  150. data/lib/decidim/decidim_awesome/test/layouts/decidim/_head.html.erb +30 -2
  151. data/lib/decidim/decidim_awesome/test/layouts/decidim/admin/_header.html.erb +7 -2
  152. data/lib/decidim/decidim_awesome/test/shared_examples/config_examples.rb +18 -0
  153. data/lib/decidim/decidim_awesome/test/shared_examples/controller_examples.rb +13 -0
  154. data/lib/decidim/decidim_awesome/test/shared_examples/custom_redirects_contexts.rb +47 -0
  155. data/lib/decidim/decidim_awesome/test/shared_examples/menu_hack_contexts.rb +0 -17
  156. data/lib/decidim/decidim_awesome/test/shared_examples/scoped_admins_examples.rb +9 -17
  157. data/lib/decidim/decidim_awesome/test/shared_examples/summary_examples.rb +202 -0
  158. data/lib/decidim/decidim_awesome/version.rb +2 -2
  159. data/lib/decidim/decidim_awesome.rb +4 -152
  160. data/lib/tasks/decidim_awesome_active_storage_migrations_tasks.rake +37 -0
  161. data/lib/tasks/decidim_awesome_webpacker_tasks.rake +62 -0
  162. metadata +111 -113
  163. data/app/assets/config/decidim_admin_decidim_awesome_manifest.css +0 -3
  164. data/app/assets/config/decidim_admin_decidim_awesome_manifest.js +0 -2
  165. data/app/assets/config/decidim_decidim_awesome_manifest.css +0 -5
  166. data/app/assets/config/decidim_decidim_awesome_manifest.js +0 -4
  167. data/app/assets/config/legacy_decidim_admin_decidim_awesome_manifest.js +0 -2
  168. data/app/assets/config/legacy_decidim_decidim_awesome_manifest.js +0 -4
  169. data/app/assets/javascripts/decidim/decidim_awesome/admin/constraints.js.es6 +0 -54
  170. data/app/assets/javascripts/decidim/decidim_awesome/admin/legacy_form_builder.js.es6 +0 -80
  171. data/app/assets/javascripts/decidim/decidim_awesome/awesome_admin.js +0 -7
  172. data/app/assets/javascripts/decidim/decidim_awesome/awesome_application.js +0 -3
  173. data/app/assets/javascripts/decidim/decidim_awesome/awesome_map/categories.js.es6 +0 -25
  174. data/app/assets/javascripts/decidim/decidim_awesome/awesome_map/hashtags.js.es6 +0 -48
  175. data/app/assets/javascripts/decidim/decidim_awesome/awesome_map/layers.js.es6 +0 -107
  176. data/app/assets/javascripts/decidim/decidim_awesome/awesome_map/load_map.js.es6 +0 -15
  177. data/app/assets/javascripts/decidim/decidim_awesome/awesome_map/map.js.es6 +0 -207
  178. data/app/assets/javascripts/decidim/decidim_awesome/awesome_map/markers.js.es6 +0 -56
  179. data/app/assets/javascripts/decidim/decidim_awesome/awesome_map/meetings.js.es6 +0 -132
  180. data/app/assets/javascripts/decidim/decidim_awesome/awesome_map/proposals.js.es6 +0 -107
  181. data/app/assets/javascripts/decidim/decidim_awesome/awesome_map/utilities.js.es6 +0 -57
  182. data/app/assets/javascripts/decidim/decidim_awesome/editors/legacy_quill_editor.js.es6 +0 -172
  183. data/app/assets/javascripts/decidim/decidim_awesome/editors/quill_editor.js.es6 +0 -185
  184. data/app/assets/javascripts/decidim/decidim_awesome/forms/custom_fields_builder.js.es6 +0 -211
  185. data/app/assets/javascripts/decidim/decidim_awesome/legacy_admin.js +0 -7
  186. data/app/assets/javascripts/decidim/decidim_awesome/legacy_application.js +0 -3
  187. data/app/assets/javascripts/decidim/decidim_awesome/proposals/custom_fields.js.es6 +0 -21
  188. data/app/assets/javascripts/decidim/decidim_awesome/proposals/images.js.es6 +0 -25
  189. data/app/assets/stylesheets/decidim/decidim_awesome/admin/user_picker.scss +0 -35
  190. data/app/assets/stylesheets/decidim/decidim_awesome/awesome_admin.scss +0 -64
  191. data/app/assets/stylesheets/decidim/decidim_awesome/awesome_application.scss +0 -22
  192. data/app/assets/stylesheets/decidim/decidim_awesome/awesome_map/leaflet.scss.erb +0 -18
  193. data/app/assets/stylesheets/decidim/decidim_awesome/awesome_map/map.scss +0 -160
  194. data/app/assets/stylesheets/decidim/decidim_awesome/editors/quill_editor.scss +0 -22
  195. data/app/awesome_overrides/forms/decidim/proposals/proposal_wizard_create_step_form_override.rb +0 -28
  196. data/app/awesome_overrides/presenters/decidim/menu_presenter_override.rb +0 -39
  197. data/app/controllers/concerns/decidim/decidim_awesome/admin_not_found_redirect.rb +0 -39
  198. data/app/controllers/decidim/decidim_awesome/iframe_component/application_controller.rb +0 -15
  199. data/app/controllers/decidim/decidim_awesome/map_component/application_controller.rb +0 -15
  200. data/app/views/v0.23/layouts/decidim/admin/_header.html.erb +0 -12
  201. data/app/views/v0.24/layouts/decidim/admin/_header.html.erb +0 -12
  202. data/lib/decidim/decidim_awesome/test/themes/css.lvh.me.css +0 -3
  203. data/lib/decidim/decidim_awesome/test/themes/erb.lvh.me.scss.erb +0 -2
  204. data/lib/decidim/decidim_awesome/test/themes/scss.lvh.me.scss +0 -1
  205. data/lib/decidim/decidim_awesome/test/themes/test-theme/body.scss +0 -4
  206. data/vendor/assets/images/layers-2x.png +0 -0
  207. data/vendor/assets/images/layers.png +0 -0
  208. data/vendor/assets/images/marker-icon.png +0 -0
  209. data/vendor/assets/javascripts/codemirror-4.inline-attachment.js +0 -89
  210. data/vendor/assets/javascripts/codemirror.js +0 -9801
  211. data/vendor/assets/javascripts/delta.min.js +0 -405
  212. data/vendor/assets/javascripts/delta.min.js.map +0 -1
  213. data/vendor/assets/javascripts/europa.min.js +0 -4
  214. data/vendor/assets/javascripts/form-builder.min.js +0 -19
  215. data/vendor/assets/javascripts/form-render.min.js +0 -19
  216. data/vendor/assets/javascripts/form-storage.js +0 -824
  217. data/vendor/assets/javascripts/highlight.min.js +0 -44
  218. data/vendor/assets/javascripts/inline-attachment.js +0 -399
  219. data/vendor/assets/javascripts/inscrybmde.min.js +0 -7
  220. data/vendor/assets/javascripts/jquery-ui.min.js +0 -13
  221. data/vendor/assets/javascripts/jquery.inline-attachment.js +0 -66
  222. data/vendor/assets/javascripts/jsrender.min.js +0 -4
  223. data/vendor/assets/javascripts/keymap/sublime.js +0 -720
  224. data/vendor/assets/javascripts/leaflet.featuregroup.subgroup.js +0 -6
  225. data/vendor/assets/javascripts/mode/css/css.js +0 -864
  226. data/vendor/assets/javascripts/select2.js +0 -6147
  227. data/vendor/assets/langs/en-US.lang +0 -110
  228. data/vendor/assets/stylesheets/codemirror.css +0 -350
  229. data/vendor/assets/stylesheets/default.min.css +0 -1
  230. data/vendor/assets/stylesheets/foundation.min.css +0 -1
  231. data/vendor/assets/stylesheets/github.min.css +0 -2
  232. data/vendor/assets/stylesheets/inscrybmde.min.scss +0 -194
  233. data/vendor/assets/stylesheets/jquery-ui.min.css +0 -7
  234. data/vendor/assets/stylesheets/select2-foundation-theme.css +0 -249
  235. data/vendor/assets/stylesheets/select2.css +0 -515
@@ -9,10 +9,17 @@ module Decidim
9
9
  class ChecksController < DecidimAwesome::Admin::ApplicationController
10
10
  include NeedsAwesomeConfig
11
11
  helper ConfigConstraintsHelpers
12
+ helper SystemCheckerHelpers
12
13
 
13
14
  layout "decidim/admin/decidim_awesome"
14
15
 
15
- helper_method :overrides, :valid?, :decidim_version, :decidim_version_valid?, :head, :admin_head, :head_addons, :admin_addons
16
+ helper_method :head, :admin_head, :head_addons, :admin_addons
17
+
18
+ def migrate_images
19
+ Decidim::DecidimAwesome::MigrateLegacyImagesJob.perform_later(current_organization.id)
20
+ flash[:notice] = I18n.t("image_migrations_started", scope: "decidim.decidim_awesome.admin.checks.index")
21
+ redirect_to checks_path
22
+ end
16
23
 
17
24
  private
18
25
 
@@ -24,39 +31,25 @@ module Decidim
24
31
  @admin_head = Nokogiri::HTML(render_to_string(partial: "layouts/decidim/admin/header"))
25
32
  end
26
33
 
27
- def overrides
28
- SystemChecker.to_h
29
- end
30
-
31
- def valid?(spec, file)
32
- SystemChecker.valid?(spec, file)
33
- end
34
-
35
- def decidim_version
36
- Decidim.version
37
- end
38
-
39
- def decidim_version_valid?
40
- Gem::Dependency.new("", DecidimAwesome::COMPAT_DECIDIM_VERSION).match?("", decidim_version, true)
41
- end
42
-
43
34
  def head_addons(part)
44
35
  case part
45
36
  when :CSS
46
- ['<%= stylesheet_link_tag "decidim/decidim_awesome/application", media: "all" %>',
47
- '<%= stylesheet_link_tag(tenant_stylesheets, media: "all") if tenant_stylesheets %>'].join("\n")
37
+ ['<%= stylesheet_pack_tag "decidim_decidim_awesome", media: "all" %>',
38
+ '<%= render(partial: "layouts/decidim/decidim_awesome/custom_styles") if awesome_custom_styles %>'].join("\n")
48
39
  when :JavaScript
49
40
  ['<%= render partial: "layouts/decidim/decidim_awesome/awesome_config" %>',
50
- '<%= javascript_include_tag "decidim/decidim_awesome/application" %>'].join("\n")
41
+ '<%= javascript_pack_tag "decidim_decidim_awesome" %>',
42
+ '<%= javascript_pack_tag "decidim_decidim_awesome_custom_fields" if awesome_proposal_custom_fields %>'].join("\n")
51
43
  end
52
44
  end
53
45
 
54
46
  def admin_addons(part)
55
47
  case part
56
48
  when :CSS
57
- '<%= stylesheet_link_tag "decidim/decidim_awesome/admin", media: "all" %>'
49
+ '<%= stylesheet_pack_tag "decidim_admin_decidim_awesome", media: "all" %>'
58
50
  when :JavaScript
59
- '<%= javascript_include_tag "decidim/decidim_awesome/admin" %>'
51
+ ['<%= javascript_pack_tag "decidim_admin_decidim_awesome", defer: false %>',
52
+ '<%= javascript_pack_tag "decidim_decidim_awesome_custom_fields" if awesome_proposal_custom_fields %>'].join("\n")
60
53
  end
61
54
  end
62
55
  end
@@ -11,13 +11,15 @@ module Decidim
11
11
 
12
12
  layout "decidim/admin/decidim_awesome"
13
13
 
14
- helper_method :constraints_for, :users_for
14
+ helper_method :constraints_for, :users_for, :config_var
15
15
  before_action do
16
16
  enforce_permission_to :edit_config, configs
17
17
  end
18
18
 
19
19
  def show
20
20
  @form = form(ConfigForm).from_params(organization_awesome_config)
21
+
22
+ redirect_to decidim_admin_decidim_awesome.checks_path unless config_var
21
23
  end
22
24
 
23
25
  def update
@@ -70,6 +72,12 @@ module Decidim
70
72
 
71
73
  private
72
74
 
75
+ def config_var
76
+ return params[:var] if menus.has_key?(params[:var].try(:to_sym))
77
+
78
+ menus.key(true)
79
+ end
80
+
73
81
  def constraints_for(key)
74
82
  awesome_config_instance.setting_for(key)&.constraints
75
83
  end
@@ -0,0 +1,91 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ module DecidimAwesome
5
+ module Admin
6
+ # Editing menu items
7
+ class CustomRedirectsController < DecidimAwesome::Admin::ApplicationController
8
+ include NeedsAwesomeConfig
9
+ include ConfigConstraintsHelpers
10
+
11
+ layout "decidim/admin/decidim_awesome"
12
+
13
+ before_action do
14
+ enforce_permission_to :edit_config, :menu
15
+ end
16
+
17
+ helper ConfigConstraintsHelpers
18
+ helper_method :current_config
19
+
20
+ def index; end
21
+
22
+ def new
23
+ @form = form(CustomRedirectForm).instance
24
+ end
25
+
26
+ def create
27
+ @form = form(CustomRedirectForm).from_params(params)
28
+ CreateCustomRedirect.call(@form) do
29
+ on(:ok) do
30
+ flash[:notice] = I18n.t("custom_redirects.create.success", scope: "decidim.decidim_awesome.admin")
31
+ redirect_to decidim_admin_decidim_awesome.custom_redirects_path
32
+ end
33
+
34
+ on(:invalid) do |message|
35
+ flash.now[:alert] = I18n.t("custom_redirects.create.error", error: message, scope: "decidim.decidim_awesome.admin")
36
+ render :new
37
+ end
38
+ end
39
+ end
40
+
41
+ def edit
42
+ @form = form(CustomRedirectForm).from_model(redirect_item)
43
+ end
44
+
45
+ def update
46
+ @form = form(CustomRedirectForm).from_params(params)
47
+ UpdateCustomRedirect.call(@form, redirect_item) do
48
+ on(:ok) do
49
+ flash[:notice] = I18n.t("custom_redirects.update.success", scope: "decidim.decidim_awesome.admin")
50
+ redirect_to decidim_admin_decidim_awesome.custom_redirects_path
51
+ end
52
+
53
+ on(:invalid) do |message|
54
+ flash.now[:alert] = I18n.t("custom_redirects.update.error", error: message, scope: "decidim.decidim_awesome.admin")
55
+ render :new
56
+ end
57
+ end
58
+ end
59
+
60
+ def destroy
61
+ DestroyCustomRedirect.call(redirect_item, current_organization) do
62
+ on(:ok) do
63
+ flash[:notice] = I18n.t("custom_redirects.destroy.success", scope: "decidim.decidim_awesome.admin")
64
+ end
65
+ on(:invalid) do |error|
66
+ flash[:alert] = I18n.t("custom_redirects.destroy.error", scope: "decidim.decidim_awesome.admin", error: error)
67
+ end
68
+ end
69
+ redirect_to decidim_admin_decidim_awesome.custom_redirects_path
70
+ end
71
+
72
+ private
73
+
74
+ def redirect_item
75
+ origin, item = current_config.find { |origin, _| md5(origin) == params[:id] }
76
+ raise ActiveRecord::RecordNotFound unless item
77
+
78
+ OpenStruct.new(
79
+ origin: origin,
80
+ destination: item["destination"],
81
+ active: item["active"]
82
+ )
83
+ end
84
+
85
+ def current_config
86
+ @current_config ||= (AwesomeConfig.find_by(var: :custom_redirects, organization: current_organization)&.value || {})
87
+ end
88
+ end
89
+ end
90
+ end
91
+ end
@@ -6,11 +6,12 @@ module Decidim
6
6
  # Editing menu items
7
7
  class MenuHacksController < DecidimAwesome::Admin::ApplicationController
8
8
  include NeedsAwesomeConfig
9
- helper ConfigConstraintsHelpers
9
+ include ConfigConstraintsHelpers
10
10
 
11
11
  layout "decidim/admin/decidim_awesome"
12
12
 
13
- helper_method :current_items, :md5, :visibility_options, :target_options
13
+ helper ConfigConstraintsHelpers
14
+ helper_method :current_items, :visibility_options, :target_options
14
15
 
15
16
  before_action do
16
17
  enforce_permission_to :edit_config, :menu
@@ -96,18 +97,14 @@ module Decidim
96
97
  :menu
97
98
  end
98
99
 
99
- def md5(text)
100
- Digest::MD5.hexdigest(text)
101
- end
102
-
103
100
  def visibility_options
104
101
  MenuForm::VISIBILITY_STATES.index_by { |key| I18n.t(".menu_hacks.form.visibility.#{key}", scope: "decidim.decidim_awesome.admin") }
105
102
  end
106
103
 
107
104
  def target_options
108
105
  {
109
- I18n.t(".menu_hacks.form.target.self", scope: "decidim.decidim_awesome.admin") => "",
110
- I18n.t(".menu_hacks.form.target.blank", scope: "decidim.decidim_awesome.admin") => "_blank"
106
+ I18n.t("menu_hacks.form.target.self", scope: "decidim.decidim_awesome.admin") => "",
107
+ I18n.t("menu_hacks.form.target.blank", scope: "decidim.decidim_awesome.admin") => "_blank"
111
108
  }
112
109
  end
113
110
  end
@@ -0,0 +1,19 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ module DecidimAwesome
5
+ # Abstract component class for components without any admin controllers (only settings)
6
+ class BlankComponentController < Decidim::Components::BaseController
7
+ # just redirects to settings
8
+ def settings
9
+ redirect_to EngineRouter.admin_proxy(component.participatory_space).edit_component_path(id: component)
10
+ end
11
+
12
+ private
13
+
14
+ def component
15
+ Decidim::Component.find(params[:component_id])
16
+ end
17
+ end
18
+ end
19
+ end
@@ -14,10 +14,9 @@ module Decidim
14
14
  enforce_permission_to :create, :editor_image, awesome_config: awesome_config
15
15
 
16
16
  @form = form(EditorImageForm).from_params(form_values)
17
-
18
17
  CreateEditorImage.call(@form) do
19
18
  on(:ok) do |image|
20
- url = image.url
19
+ url = image.attached_uploader(:file).path
21
20
  url = "#{request.base_url}#{url}" unless url&.start_with?("http")
22
21
  render json: { url: url, message: I18n.t("decidim_awesome.editor_images.create.success", scope: "decidim") }
23
22
  end
@@ -40,7 +39,7 @@ module Decidim
40
39
 
41
40
  def form_values
42
41
  {
43
- image: params[:image],
42
+ file: params[:image],
44
43
  author_id: current_user.id,
45
44
  path: request.referer
46
45
  }
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module DecidimAwesome
5
5
  module IframeComponent
6
- class IframeController < DecidimAwesome::IframeComponent::ApplicationController
6
+ class IframeController < DecidimAwesome::BlankComponentController
7
7
  ALLOWED_ATTRIBUTES = %w(src width height frameborder title allow allowpaymentrequest name referrerpolicy sandbox srcdoc allowfullscreen).freeze
8
8
  helper_method :iframe, :remove_margins?, :viewport_width?
9
9
 
@@ -3,20 +3,16 @@
3
3
  module Decidim
4
4
  module DecidimAwesome
5
5
  module MapComponent
6
- class MapController < DecidimAwesome::MapComponent::ApplicationController
6
+ class MapController < DecidimAwesome::BlankComponentController
7
7
  helper Decidim::DecidimAwesome::MapHelper
8
8
  helper_method :map_components
9
9
 
10
10
  def show
11
- render :error unless maps_enabled?
11
+ render :error unless Decidim::Map.configured?
12
12
  end
13
13
 
14
14
  private
15
15
 
16
- def maps_enabled?
17
- Decidim::Map.configured?
18
- end
19
-
20
16
  def map_components
21
17
  @map_components ||= current_participatory_space.components.published.filter do |component|
22
18
  case component.manifest.name
@@ -1,5 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require "sassc"
4
+
3
5
  module Decidim
4
6
  module DecidimAwesome
5
7
  module Admin
@@ -0,0 +1,45 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ module DecidimAwesome
5
+ module Admin
6
+ class CustomRedirectForm < Decidim::Form
7
+ include Decidim::TranslatableAttributes
8
+ attribute :origin, String
9
+ attribute :destination, String
10
+ attribute :active, Boolean
11
+ attribute :pass_query, Boolean
12
+
13
+ validates :origin, :destination, presence: true
14
+ validate :different_origin_destination
15
+
16
+ def to_params
17
+ [
18
+ sanitize_url(origin),
19
+ {
20
+ destination: sanitize_url(destination, strip_host: false),
21
+ active: active,
22
+ pass_query: pass_query
23
+ }
24
+ ]
25
+ end
26
+
27
+ def sanitize_url(url, strip_host: true)
28
+ url = url.strip.downcase
29
+ parsed = Addressable::URI.parse(url)
30
+ url = parsed.path if strip_host && parsed.host == current_organization.host
31
+ url = "/#{url}" unless url.match?(%r{^https?://|^/})
32
+ url
33
+ end
34
+
35
+ private
36
+
37
+ def different_origin_destination
38
+ return if sanitize_url(origin) != sanitize_url(destination)
39
+
40
+ errors.add(:destination, :invalid)
41
+ end
42
+ end
43
+ end
44
+ end
45
+ end
@@ -5,12 +5,13 @@ module Decidim
5
5
  class EditorImageForm < Decidim::Form
6
6
  mimic :editor_image
7
7
 
8
- attribute :image
8
+ attribute :file
9
9
  attribute :author_id, Integer
10
10
  attribute :path, String
11
11
 
12
12
  validates :author_id, presence: true
13
- validates :image, presence: true
13
+ validates :file, presence: true
14
+ validates :file, passthru: { to: Decidim::DecidimAwesome::EditorImage }
14
15
 
15
16
  alias organization current_organization
16
17
  end
@@ -0,0 +1,38 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Recreate validations to take into account custom fields and ignore the length limit in proposals
4
+ module Decidim
5
+ module DecidimAwesome
6
+ module Proposals
7
+ module ProposalWizardCreateStepFormOverride
8
+ extend ActiveSupport::Concern
9
+
10
+ included do
11
+ clear_validators!
12
+
13
+ validates :title, presence: true, etiquette: true
14
+ validates :title, length: { in: 15..150 }
15
+ validates :body, presence: true, etiquette: true, unless: ->(form) { form.override_validations? }
16
+ validates :body, proposal_length: {
17
+ minimum: 15,
18
+ maximum: ->(record) { record.override_validations? ? 0 : record.component.settings.proposal_length }
19
+ }
20
+
21
+ validate :body_is_not_bare_template, unless: ->(form) { form.override_validations? }
22
+
23
+ def override_validations?
24
+ return false if context.current_component.settings.participatory_texts_enabled
25
+
26
+ custom_fields.present?
27
+ end
28
+
29
+ def custom_fields
30
+ awesome_config = Decidim::DecidimAwesome::Config.new(context.current_organization)
31
+ awesome_config.context_from_component(context.current_component)
32
+ awesome_config.collect_sub_configs_values("proposal_custom_field")
33
+ end
34
+ end
35
+ end
36
+ end
37
+ end
38
+ end
@@ -9,7 +9,21 @@ module Decidim
9
9
  include Decidim::TranslatableAttributes
10
10
 
11
11
  def check(status)
12
- content_tag(:span, icon("check", class: "icon", aria_label: status, role: "img"), class: "text-#{status == :ok ? "success" : "alert"}")
12
+ content_tag(:span, icon(status ? "check" : "x", class: "icon", aria_label: status, role: "img"), class: "text-#{status ? "success" : "alert"}")
13
+ end
14
+
15
+ def menus
16
+ @menus ||= {
17
+ editors: config_enabled?([:allow_images_in_full_editor, :allow_images_in_small_editor, :use_markdown_editor, :allow_images_in_markdown_editor]),
18
+ proposals: config_enabled?(:allow_images_in_proposals),
19
+ surveys: config_enabled?(:auto_save_forms),
20
+ styles: config_enabled?(:scoped_styles),
21
+ proposal_custom_fields: config_enabled?(:proposal_custom_fields),
22
+ admins: config_enabled?(:scoped_admins),
23
+ menu_hacks: config_enabled?(:menu),
24
+ custom_redirects: config_enabled?(:custom_redirects),
25
+ livechat: config_enabled?([:intergram_for_admins, :intergram_for_public])
26
+ }
13
27
  end
14
28
 
15
29
  # returns only non :disabled vars in config
@@ -19,18 +33,13 @@ module Decidim
19
33
  end
20
34
  end
21
35
 
36
+ # ensure boolean value
22
37
  def config_enabled?(var)
23
- unless var.is_a?(Array)
24
- return false unless DecidimAwesome.config.has_key?(var.to_sym)
25
-
26
- return DecidimAwesome.config.send(var) != :disabled
27
- end
28
-
29
- var.detect { |v| DecidimAwesome.config.send(v) != :disabled }
38
+ DecidimAwesome.enabled?(var) ? true : false
30
39
  end
31
40
 
32
41
  def participatory_space_manifests
33
- manifests = OTHER_MANIFESTS.map { |m| [m, I18n.t("decidim.decidim_awesome.admin.config.#{m}")] }.to_h
42
+ manifests = OTHER_MANIFESTS.index_with { |m| I18n.t("decidim.decidim_awesome.admin.config.#{m}") }
34
43
  Decidim.participatory_space_manifests.pluck(:name).each do |name|
35
44
  manifests[name.to_sym] = I18n.t("decidim.admin.menu.#{name}")
36
45
  end
@@ -84,6 +93,10 @@ module Decidim
84
93
  end
85
94
  end
86
95
 
96
+ def md5(text)
97
+ Digest::MD5.hexdigest(text)
98
+ end
99
+
87
100
  private
88
101
 
89
102
  def model_for_manifest(manifest)
@@ -0,0 +1,36 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ module DecidimAwesome
5
+ module Admin
6
+ module SystemCheckerHelpers
7
+ def decidim_version
8
+ Decidim.version
9
+ end
10
+
11
+ def decidim_version_valid?
12
+ @decidim_version_valid ||= Gem::Dependency.new("", DecidimAwesome::COMPAT_DECIDIM_VERSION).match?("", decidim_version, true)
13
+ end
14
+
15
+ def overrides
16
+ SystemChecker.to_h
17
+ end
18
+
19
+ def valid?(spec, file)
20
+ SystemChecker.valid?(spec, file)
21
+ end
22
+
23
+ def images_migrated?
24
+ pending_image_migrations.zero?
25
+ end
26
+
27
+ def pending_image_migrations
28
+ @pending_image_migrations ||= begin
29
+ images = Decidim::DecidimAwesome::EditorImage.where(organization: current_organization)
30
+ images.count - images.joins(:file_attachment).count
31
+ end
32
+ end
33
+ end
34
+ end
35
+ end
36
+ end
@@ -5,12 +5,16 @@ module Decidim
5
5
  module MapHelper
6
6
  include Decidim::MapHelper
7
7
 
8
+ def api_ready?
9
+ Decidim::Api::Schema.max_complexity >= 1300
10
+ end
11
+
8
12
  # rubocop:disable Metrics/CyclomaticComplexity
9
13
  # rubocop:disable Metrics/PerceivedComplexity:
10
14
  def awesome_map_for(components, &block)
11
15
  return unless map_utility_dynamic
12
16
 
13
- map = awesome_builder.map_element({ class: "google-map" }, &block)
17
+ map = awesome_builder.map_element({ class: "google-map", id: "awesome-map-container" }, &block)
14
18
  help = content_tag(:div, class: "map__help") do
15
19
  sr_content = content_tag(:p, t("screen_reader_explanation", scope: "decidim.map.dynamic"), class: "show-for-sr")
16
20
 
@@ -34,8 +38,10 @@ module Decidim
34
38
  "data-truncate" => global_settings.truncate || 255,
35
39
  "data-map-center" => global_settings.map_center,
36
40
  "data-map-zoom" => global_settings.map_zoom || 8,
41
+ "data-menu-merge-components" => global_settings.menu_merge_components,
37
42
  "data-menu-amendments" => global_settings.menu_amendments,
38
43
  "data-menu-meetings" => global_settings.menu_meetings,
44
+ "data-menu-categories" => global_settings.menu_categories,
39
45
  "data-menu-hashtags" => global_settings.menu_hashtags,
40
46
  "data-show-not-answered" => step_settings&.show_not_answered,
41
47
  "data-show-accepted" => step_settings&.show_accepted,
@@ -66,14 +72,14 @@ module Decidim
66
72
  end
67
73
 
68
74
  # rubocop:disable Rails/HelperInstanceVariable
69
- def current_categories
75
+ def current_categories(categories)
70
76
  return @current_categories if @current_categories
71
77
 
72
78
  @golden_ratio_conjugate = 0.618033988749895
73
79
  # @h = rand # use random start value
74
- @h = 0.4
80
+ @h = 0.41
75
81
  @current_categories = []
76
- current_participatory_space.categories.first_class.each do |category|
82
+ categories.first_class.each do |category|
77
83
  append_category category
78
84
  category.subcategories.each do |subcat|
79
85
  append_category subcat
@@ -91,19 +97,19 @@ module Decidim
91
97
  }
92
98
  builder = map_utility_dynamic.create_builder(self, options)
93
99
 
100
+ # We need awesome map listeners before initialize the official map
101
+ unless snippets.any?(:awesome_map)
102
+ snippets.add(:awesome_map, javascript_pack_tag("decidim_decidim_awesome_map", defer: false))
103
+ snippets.add(:awesome_map, stylesheet_pack_tag("decidim_decidim_awesome_map"))
104
+ snippets.add(:head, snippets.for(:awesome_map))
105
+ end
106
+
94
107
  unless snippets.any?(:map)
95
108
  snippets.add(:map, builder.stylesheet_snippets)
96
109
  snippets.add(:map, builder.javascript_snippets)
97
110
  snippets.add(:head, snippets.for(:map))
98
111
  end
99
112
 
100
- unless snippets.any?(:awesome_map)
101
- snippets.add(:awesome_map, stylesheet_link_tag("decidim/decidim_awesome/awesome_map/map"))
102
- snippets.add(:awesome_map, javascript_include_tag("decidim/decidim_awesome/awesome_map/map"))
103
- snippets.add(:awesome_map, javascript_include_tag("decidim/decidim_awesome/awesome_map/load_map"))
104
- snippets.add(:head, snippets.for(:awesome_map))
105
- end
106
-
107
113
  builder
108
114
  end
109
115
 
@@ -112,7 +118,7 @@ module Decidim
112
118
  @h += @golden_ratio_conjugate
113
119
  @h %= 1
114
120
  # r,g,b = hsv_to_rgb(@h, 0.5, 0.95)
115
- r, g, b = hsv_to_rgb(@h, 0.99, 0.96)
121
+ r, g, b = hsv_to_rgb(@h, 0.99, 0.95)
116
122
  @current_categories.append(
117
123
  id: category.id,
118
124
  name: translated_attribute(category.name),
@@ -61,8 +61,8 @@ module Decidim
61
61
  custom_fields = Decidim::DecidimAwesome::CustomFields.new(fields)
62
62
  custom_fields.translate!
63
63
 
64
- body = if form_presenter.proposal.body.is_a?(Hash) && locale
65
- form_presenter.body(extras: false, all_locales: true)[locale]
64
+ body = if form_presenter.proposal.body.is_a?(Hash) && locale.present?
65
+ form_presenter.body(extras: false, all_locales: true).with_indifferent_access[locale]
66
66
  else
67
67
  form_presenter.body(extras: false)
68
68
  end