decidim 0.0.6 → 0.0.7

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of decidim might be problematic. Click here for more details.

Files changed (308) hide show
  1. checksums.yaml +4 -4
  2. data/.babelrc +2 -1
  3. data/.ruby-version +1 -1
  4. data/.travis.yml +4 -6
  5. data/Dockerfile +2 -2
  6. data/Gemfile +1 -1
  7. data/Gemfile.lock +48 -48
  8. data/README.md +6 -1
  9. data/decidim-admin/app/assets/stylesheets/decidim/admin/_decidim.scss +9 -0
  10. data/decidim-admin/app/assets/stylesheets/decidim/admin/_variables.scss +7 -0
  11. data/decidim-admin/app/assets/stylesheets/decidim/admin/application.scss +2 -19
  12. data/decidim-admin/app/assets/stylesheets/decidim/admin/extra/_categories.scss +5 -0
  13. data/decidim-admin/app/assets/stylesheets/decidim/admin/{_email_preview.scss → extra/_email_preview.scss} +0 -0
  14. data/decidim-admin/app/assets/stylesheets/decidim/admin/{_login.scss → extra/_login.scss} +0 -0
  15. data/decidim-admin/app/assets/stylesheets/decidim/admin/extra/_select_multiple.scss +3 -0
  16. data/decidim-admin/app/assets/stylesheets/decidim/admin/extra/_title_bar.scss +5 -0
  17. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_action-icon.scss +13 -0
  18. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_buttons.scss +44 -0
  19. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_callouts.scss +32 -0
  20. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_cards.scss +36 -0
  21. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_char-counter.scss +20 -0
  22. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_component-counter.scss +17 -0
  23. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_forms.scss +80 -0
  24. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_icons.scss +65 -0
  25. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_layout.scss +67 -0
  26. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_main-nav.scss +41 -0
  27. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_modules.scss +24 -0
  28. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_process-header.scss +11 -0
  29. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_secondary-nav.scss +95 -0
  30. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_table-list.scss +78 -0
  31. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_tabs.scss +49 -0
  32. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_title-bar.scss +32 -0
  33. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_typography.scss +15 -0
  34. data/decidim-admin/app/assets/stylesheets/decidim/admin/modules/_user-login.scss +23 -0
  35. data/decidim-admin/app/assets/stylesheets/decidim/admin/utils/_fontface.scss +27 -0
  36. data/decidim-admin/app/assets/stylesheets/decidim/admin/utils/_helpers.scss +25 -0
  37. data/decidim-admin/app/assets/stylesheets/decidim/admin/utils/_keyframes.scss +21 -0
  38. data/decidim-admin/app/assets/stylesheets/decidim/admin/utils/_mixins.scss +20 -0
  39. data/decidim-admin/app/assets/stylesheets/decidim/admin/utils/_settings.scss +590 -0
  40. data/decidim-admin/app/assets/stylesheets/decidim/admin/utils/_toggle-expand.scss +8 -0
  41. data/decidim-admin/app/commands/decidim/admin/create_attachment.rb +13 -4
  42. data/decidim-admin/app/commands/decidim/admin/update_participatory_process.rb +3 -3
  43. data/decidim-admin/app/commands/decidim/admin/update_participatory_process_admin.rb +40 -0
  44. data/decidim-admin/app/controllers/decidim/admin/application_controller.rb +7 -1
  45. data/decidim-admin/app/controllers/decidim/admin/newsletters_controller.rb +1 -1
  46. data/decidim-admin/app/controllers/decidim/admin/organization_controller.rb +2 -0
  47. data/decidim-admin/app/controllers/decidim/admin/participatory_process_user_roles_controller.rb +29 -0
  48. data/decidim-admin/app/controllers/decidim/admin/participatory_processes_controller.rb +2 -2
  49. data/decidim-admin/app/controllers/decidim/admin/scopes_controller.rb +2 -0
  50. data/decidim-admin/app/controllers/decidim/admin/static_pages_controller.rb +2 -0
  51. data/decidim-admin/app/controllers/decidim/admin/user_groups_controller.rb +3 -1
  52. data/decidim-admin/app/controllers/decidim/admin/users_controller.rb +1 -1
  53. data/decidim-admin/app/helpers/decidim/admin/application_helper.rb +8 -0
  54. data/decidim-admin/app/helpers/decidim/admin/icon_link_helper.rb +30 -0
  55. data/decidim-admin/app/jobs/decidim/admin/newsletter_job.rb +1 -1
  56. data/decidim-admin/app/queries/decidim/admin/process_admin_roles_for_process.rb +1 -1
  57. data/decidim-admin/app/views/decidim/admin/attachments/_form.html.erb +29 -8
  58. data/decidim-admin/app/views/decidim/admin/attachments/edit.html.erb +3 -5
  59. data/decidim-admin/app/views/decidim/admin/attachments/index.html.erb +45 -35
  60. data/decidim-admin/app/views/decidim/admin/attachments/new.html.erb +3 -5
  61. data/decidim-admin/app/views/decidim/admin/categories/_form.html.erb +18 -10
  62. data/decidim-admin/app/views/decidim/admin/categories/edit.html.erb +3 -5
  63. data/decidim-admin/app/views/decidim/admin/categories/index.html.erb +57 -42
  64. data/decidim-admin/app/views/decidim/admin/categories/new.html.erb +3 -5
  65. data/decidim-admin/app/views/decidim/admin/dashboard/show.html.erb +6 -3
  66. data/decidim-admin/app/views/decidim/admin/features/_feature.html.erb +11 -11
  67. data/decidim-admin/app/views/decidim/admin/features/_form.html.erb +56 -48
  68. data/decidim-admin/app/views/decidim/admin/features/edit.html.erb +3 -5
  69. data/decidim-admin/app/views/decidim/admin/features/index.html.erb +21 -19
  70. data/decidim-admin/app/views/decidim/admin/features/new.html.erb +3 -4
  71. data/decidim-admin/app/views/decidim/admin/moderations/index.html.erb +71 -61
  72. data/decidim-admin/app/views/decidim/admin/newsletters/_form.html.erb +7 -1
  73. data/decidim-admin/app/views/decidim/admin/newsletters/edit.html.erb +10 -8
  74. data/decidim-admin/app/views/decidim/admin/newsletters/index.html.erb +50 -43
  75. data/decidim-admin/app/views/decidim/admin/newsletters/new.html.erb +10 -8
  76. data/decidim-admin/app/views/decidim/admin/newsletters/show.html.erb +20 -12
  77. data/decidim-admin/app/views/decidim/admin/organization/_form.html.erb +98 -62
  78. data/decidim-admin/app/views/decidim/admin/organization/edit.html.erb +11 -8
  79. data/decidim-admin/app/views/decidim/admin/participatory_process_groups/_form.html.erb +4 -4
  80. data/decidim-admin/app/views/decidim/admin/participatory_process_groups/edit.html.erb +15 -9
  81. data/decidim-admin/app/views/decidim/admin/participatory_process_groups/index.html.erb +37 -35
  82. data/decidim-admin/app/views/decidim/admin/participatory_process_groups/new.html.erb +10 -8
  83. data/decidim-admin/app/views/decidim/admin/participatory_process_steps/_form.html.erb +21 -11
  84. data/decidim-admin/app/views/decidim/admin/participatory_process_steps/edit.html.erb +3 -4
  85. data/decidim-admin/app/views/decidim/admin/participatory_process_steps/index.html.erb +60 -51
  86. data/decidim-admin/app/views/decidim/admin/participatory_process_steps/new.html.erb +4 -5
  87. data/decidim-admin/app/views/decidim/admin/participatory_process_user_roles/_form.html.erb +23 -0
  88. data/decidim-admin/app/views/decidim/admin/participatory_process_user_roles/edit.html.erb +7 -0
  89. data/decidim-admin/app/views/decidim/admin/participatory_process_user_roles/index.html.erb +46 -34
  90. data/decidim-admin/app/views/decidim/admin/participatory_process_user_roles/new.html.erb +7 -0
  91. data/decidim-admin/app/views/decidim/admin/participatory_processes/_form.html.erb +103 -72
  92. data/decidim-admin/app/views/decidim/admin/participatory_processes/edit.html.erb +15 -17
  93. data/decidim-admin/app/views/decidim/admin/participatory_processes/index.html.erb +52 -43
  94. data/decidim-admin/app/views/decidim/admin/participatory_processes/new.html.erb +6 -5
  95. data/decidim-admin/app/views/decidim/admin/scopes/edit.html.erb +9 -7
  96. data/decidim-admin/app/views/decidim/admin/scopes/index.html.erb +37 -36
  97. data/decidim-admin/app/views/decidim/admin/scopes/new.html.erb +9 -6
  98. data/decidim-admin/app/views/decidim/admin/static_pages/_form.html.erb +3 -3
  99. data/decidim-admin/app/views/decidim/admin/static_pages/edit.html.erb +10 -8
  100. data/decidim-admin/app/views/decidim/admin/static_pages/index.html.erb +38 -37
  101. data/decidim-admin/app/views/decidim/admin/static_pages/new.html.erb +10 -8
  102. data/decidim-admin/app/views/decidim/admin/user_groups/index.html.erb +37 -31
  103. data/decidim-admin/app/views/decidim/admin/users/_form.html.erb +5 -4
  104. data/decidim-admin/app/views/decidim/admin/users/index.html.erb +57 -52
  105. data/decidim-admin/app/views/decidim/admin/users/new.html.erb +10 -7
  106. data/decidim-admin/app/views/layouts/decidim/admin/_application.html.erb +23 -36
  107. data/decidim-admin/app/views/layouts/decidim/admin/_callouts_full.html.erb +10 -0
  108. data/decidim-admin/app/views/layouts/decidim/admin/_language_chooser.html.erb +9 -9
  109. data/decidim-admin/app/views/layouts/decidim/admin/_main_nav.html.erb +11 -0
  110. data/decidim-admin/app/views/layouts/decidim/admin/_template_bottom.html.erb +2 -0
  111. data/decidim-admin/app/views/layouts/decidim/admin/_template_top.html.erb +3 -0
  112. data/decidim-admin/app/views/layouts/decidim/admin/_title_bar.html.erb +20 -0
  113. data/decidim-admin/app/views/layouts/decidim/admin/newsletters.erb +14 -0
  114. data/decidim-admin/app/views/layouts/decidim/admin/pages.html.erb +14 -0
  115. data/decidim-admin/app/views/layouts/decidim/admin/participatory_process.html.erb +55 -53
  116. data/decidim-admin/app/views/layouts/decidim/admin/participatory_process_groups.html.erb +14 -0
  117. data/decidim-admin/app/views/layouts/decidim/admin/participatory_processes.html.erb +14 -0
  118. data/decidim-admin/app/views/layouts/decidim/admin/settings.html.erb +19 -0
  119. data/decidim-admin/app/views/layouts/decidim/admin/users.html.erb +21 -0
  120. data/decidim-admin/config/i18n-tasks.yml +1 -0
  121. data/decidim-admin/config/locales/ca.yml +77 -22
  122. data/decidim-admin/config/locales/en.yml +75 -20
  123. data/decidim-admin/config/locales/es.yml +77 -22
  124. data/decidim-admin/config/locales/eu.yml +191 -16
  125. data/decidim-admin/config/locales/fi.yml +0 -29
  126. data/decidim-admin/config/routes.rb +1 -1
  127. data/decidim-admin/lib/decidim/admin/test/manage_attachments_examples.rb +11 -11
  128. data/decidim-admin/spec/commands/deliver_newsletter_spec.rb +4 -1
  129. data/decidim-admin/spec/commands/update_participatory_process_spec.rb +117 -0
  130. data/decidim-admin/spec/features/admin_invite_spec.rb +5 -1
  131. data/decidim-admin/spec/features/admin_manages_feature_permissions_spec.rb +1 -1
  132. data/decidim-admin/spec/features/admin_manages_features_spec.rb +10 -10
  133. data/decidim-admin/spec/features/admin_manages_newsletters_spec.rb +11 -9
  134. data/decidim-admin/spec/features/admin_manages_organization_admins_spec.rb +8 -5
  135. data/decidim-admin/spec/features/admin_manages_organization_scopes_spec.rb +7 -6
  136. data/decidim-admin/spec/features/admin_manages_organization_spec.rb +14 -0
  137. data/decidim-admin/spec/features/admin_manages_participatory_process_groups_spec.rb +6 -6
  138. data/decidim-admin/spec/features/admin_manages_participatory_processes_spec.rb +27 -5
  139. data/decidim-admin/spec/features/admin_manages_user_groups_spec.rb +1 -1
  140. data/decidim-admin/spec/features/participatory_process_admin_manages_participatory_process_admins_spec.rb +2 -2
  141. data/decidim-admin/spec/features/static_pages_spec.rb +9 -7
  142. data/decidim-admin/spec/jobs/newsletter_job_spec.rb +2 -0
  143. data/decidim-admin/spec/queries/process_admin_roles_for_process_spec.rb +4 -3
  144. data/decidim-admin/spec/shared/manage_process_admins_examples.rb +31 -8
  145. data/decidim-admin/spec/shared/manage_process_attachments_examples.rb +1 -1
  146. data/decidim-admin/spec/shared/manage_process_categories_examples.rb +11 -26
  147. data/decidim-admin/spec/shared/manage_process_steps_examples.rb +8 -23
  148. data/decidim-admin/spec/shared/manage_processes_examples.rb +5 -33
  149. data/decidim-admin/spec/support/processes_menu_links_helpers.rb +1 -1
  150. data/decidim-admin/yarn.lock +4 -0
  151. data/decidim-api/app/controllers/decidim/api/application_controller.rb +2 -1
  152. data/decidim-budgets/app/controllers/decidim/budgets/admin/projects_controller.rb +1 -1
  153. data/decidim-budgets/app/controllers/decidim/budgets/line_items_controller.rb +21 -15
  154. data/decidim-budgets/app/views/decidim/budgets/admin/projects/_form.html.erb +34 -24
  155. data/decidim-budgets/app/views/decidim/budgets/admin/projects/edit.html.erb +3 -5
  156. data/decidim-budgets/app/views/decidim/budgets/admin/projects/index.html.erb +52 -34
  157. data/decidim-budgets/app/views/decidim/budgets/admin/projects/new.html.erb +4 -5
  158. data/decidim-budgets/app/views/decidim/budgets/projects/_filters.html.erb +1 -1
  159. data/decidim-budgets/config/i18n-tasks.yml +1 -0
  160. data/decidim-budgets/config/locales/ca.yml +5 -0
  161. data/decidim-budgets/config/locales/en.yml +5 -0
  162. data/decidim-budgets/config/locales/es.yml +5 -0
  163. data/decidim-budgets/config/locales/eu.yml +27 -0
  164. data/decidim-budgets/spec/features/orders_spec.rb +22 -0
  165. data/decidim-budgets/spec/shared/manage_attachments_examples.rb +1 -1
  166. data/decidim-budgets/spec/shared/manage_projects_examples.rb +10 -8
  167. data/decidim-comments/README.md +33 -0
  168. data/decidim-comments/app/assets/javascripts/decidim/comments/bundle.js +0 -0
  169. data/decidim-comments/app/assets/javascripts/decidim/comments/comments.js.erb +2 -0
  170. data/decidim-comments/app/frontend/application/{apollo_client.js → apollo_client.ts} +5 -5
  171. data/decidim-comments/app/frontend/application/application.component.test.tsx +36 -0
  172. data/decidim-comments/app/frontend/application/application.component.tsx +37 -0
  173. data/decidim-comments/app/frontend/application/icon.component.test.tsx +49 -0
  174. data/decidim-comments/app/frontend/application/icon.component.tsx +35 -0
  175. data/decidim-comments/app/frontend/comments/{add_comment_form.component.test.jsx → add_comment_form.component.test.tsx} +98 -92
  176. data/decidim-comments/app/frontend/comments/{add_comment_form.component.jsx → add_comment_form.component.tsx} +152 -153
  177. data/decidim-comments/app/frontend/comments/{comment.component.test.jsx → comment.component.test.tsx} +59 -71
  178. data/decidim-comments/app/frontend/comments/{comment.component.jsx → comment.component.tsx} +114 -116
  179. data/decidim-comments/app/frontend/comments/comment_order_selector.component.test.tsx +21 -0
  180. data/decidim-comments/app/frontend/comments/comment_order_selector.component.tsx +88 -0
  181. data/decidim-comments/app/frontend/comments/comment_thread.component.test.tsx +65 -0
  182. data/decidim-comments/app/frontend/comments/comment_thread.component.tsx +70 -0
  183. data/decidim-comments/app/frontend/comments/{comments.component.test.jsx → comments.component.test.tsx} +38 -81
  184. data/decidim-comments/app/frontend/comments/{comments.component.jsx → comments.component.tsx} +49 -63
  185. data/decidim-comments/app/frontend/comments/down_vote_button.component.test.tsx +39 -0
  186. data/decidim-comments/app/frontend/comments/down_vote_button.component.tsx +89 -0
  187. data/decidim-comments/app/frontend/comments/up_vote_button.component.test.tsx +39 -0
  188. data/decidim-comments/app/frontend/comments/up_vote_button.component.tsx +89 -0
  189. data/decidim-comments/app/frontend/comments/vote_button.component.tsx +36 -0
  190. data/decidim-comments/app/frontend/comments/{vote_button_component.test.jsx → vote_button_component.test.tsx} +16 -20
  191. data/decidim-comments/app/frontend/entry.ts +19 -0
  192. data/decidim-comments/app/frontend/{comments → fragments}/add_comment_form_commentable.fragment.graphql +1 -1
  193. data/decidim-comments/app/frontend/{comments → fragments}/add_comment_form_session.fragment.graphql +1 -1
  194. data/decidim-comments/app/frontend/{comments → fragments}/comment.fragment.graphql +3 -1
  195. data/decidim-comments/app/frontend/{comments → fragments}/comment_data.fragment.graphql +6 -3
  196. data/decidim-comments/app/frontend/{comments → fragments}/comment_thread.fragment.graphql +3 -1
  197. data/decidim-comments/app/frontend/{comments/down_vote.fragment.graphql → fragments/down_vote_button.fragment.graphql} +2 -2
  198. data/decidim-comments/app/frontend/{comments/up_vote.fragment.graphql → fragments/up_vote_button.fragment.graphql} +2 -2
  199. data/decidim-comments/app/frontend/{comments/add_comment_form.mutation.graphql → mutations/add_comment.mutation.graphql} +3 -1
  200. data/decidim-comments/app/frontend/{comments → mutations}/down_vote.mutation.graphql +3 -1
  201. data/decidim-comments/app/frontend/{comments → mutations}/up_vote.mutation.graphql +3 -1
  202. data/decidim-comments/app/frontend/{comments → queries}/comments.query.graphql +4 -1
  203. data/decidim-comments/app/frontend/support/{asset_url.js → asset_url.ts} +1 -1
  204. data/decidim-comments/app/frontend/support/{generate_comments_data.js → generate_comments_data.ts} +11 -6
  205. data/decidim-comments/app/frontend/support/{generate_user_data.js → generate_user_data.ts} +2 -2
  206. data/decidim-comments/app/frontend/support/{generate_user_group_data.js → generate_user_group_data.ts} +2 -2
  207. data/decidim-comments/app/frontend/support/graphql_transformer.js +32 -0
  208. data/decidim-comments/app/frontend/support/load_translations.ts +44 -0
  209. data/decidim-comments/app/frontend/support/{require_all.js → require_all.ts} +1 -1
  210. data/decidim-comments/app/frontend/support/{resolve_graphql_query.js → resolve_graphql_query.ts} +7 -7
  211. data/decidim-comments/app/frontend/support/schema.ts +119 -0
  212. data/decidim-comments/config/locales/eu.yml +29 -5
  213. data/decidim-dev/Rakefile +2 -0
  214. data/decidim-dev/config/locales/eu.yml +1 -1
  215. data/decidim-dev/decidim-dev.gemspec +1 -1
  216. data/decidim-dev/lib/decidim/dev/test/rspec_support/capybara.rb +1 -4
  217. data/decidim-dev/lib/decidim/dev/test/rspec_support/feature.rb +1 -0
  218. data/decidim-dev/lib/decidim/dev/test/rspec_support/helpers.rb +1 -1
  219. data/decidim-dev/lib/decidim/dev/test/rspec_support/phantomjs_polyfills/phantomjs-shim.js +215 -0
  220. data/decidim-dev/lib/decidim/dev/test/rspec_support/translation_helpers.rb +1 -1
  221. data/decidim-dev/lib/generators/decidim/dummy_generator.rb +5 -0
  222. data/decidim-meetings/app/controllers/decidim/meetings/admin/application_controller.rb +1 -1
  223. data/decidim-meetings/app/views/decidim/meetings/admin/meeting_closes/_form.html.erb +30 -19
  224. data/decidim-meetings/app/views/decidim/meetings/admin/meeting_closes/edit.html.erb +3 -5
  225. data/decidim-meetings/app/views/decidim/meetings/admin/meetings/_form.html.erb +46 -35
  226. data/decidim-meetings/app/views/decidim/meetings/admin/meetings/edit.html.erb +5 -6
  227. data/decidim-meetings/app/views/decidim/meetings/admin/meetings/index.html.erb +72 -51
  228. data/decidim-meetings/app/views/decidim/meetings/admin/meetings/new.html.erb +4 -6
  229. data/decidim-meetings/app/views/decidim/meetings/meetings/_filters.html.erb +1 -1
  230. data/decidim-meetings/config/locales/ca.yml +2 -1
  231. data/decidim-meetings/config/locales/en.yml +2 -1
  232. data/decidim-meetings/config/locales/es.yml +2 -1
  233. data/decidim-meetings/config/locales/eu.yml +25 -5
  234. data/decidim-meetings/config/locales/fi.yml +0 -1
  235. data/decidim-meetings/spec/shared/manage_attachments_examples.rb +1 -1
  236. data/decidim-meetings/spec/shared/manage_meetings_examples.rb +18 -16
  237. data/decidim-pages/app/views/decidim/pages/admin/pages/_form.html.erb +10 -3
  238. data/decidim-pages/app/views/decidim/pages/admin/pages/edit.html.erb +3 -5
  239. data/decidim-pages/config/locales/eu.yml +4 -2
  240. data/decidim-pages/spec/features/admin_spec.rb +1 -1
  241. data/decidim-proposals/app/controllers/decidim/proposals/admin/proposals_controller.rb +1 -1
  242. data/decidim-proposals/app/views/decidim/proposals/admin/proposal_answers/edit.html.erb +14 -8
  243. data/decidim-proposals/app/views/decidim/proposals/admin/proposals/_form.html.erb +28 -20
  244. data/decidim-proposals/app/views/decidim/proposals/admin/proposals/index.html.erb +60 -43
  245. data/decidim-proposals/app/views/decidim/proposals/admin/proposals/new.html.erb +3 -5
  246. data/decidim-proposals/app/views/decidim/proposals/proposals/_filters.html.erb +1 -1
  247. data/decidim-proposals/config/locales/ca.yml +3 -0
  248. data/decidim-proposals/config/locales/en.yml +4 -1
  249. data/decidim-proposals/config/locales/es.yml +3 -0
  250. data/decidim-proposals/config/locales/eu.yml +42 -19
  251. data/decidim-proposals/config/locales/fi.yml +0 -1
  252. data/decidim-proposals/spec/shared/manage_proposals_examples.rb +15 -13
  253. data/decidim-results/README.md +1 -1
  254. data/decidim-results/app/controllers/decidim/results/admin/results_controller.rb +1 -1
  255. data/decidim-results/app/views/decidim/results/admin/results/_form.html.erb +30 -21
  256. data/decidim-results/app/views/decidim/results/admin/results/edit.html.erb +4 -5
  257. data/decidim-results/app/views/decidim/results/admin/results/index.html.erb +40 -25
  258. data/decidim-results/app/views/decidim/results/admin/results/new.html.erb +4 -5
  259. data/decidim-results/app/views/decidim/results/results/_filters.html.erb +1 -1
  260. data/decidim-results/config/locales/ca.yml +2 -0
  261. data/decidim-results/config/locales/en.yml +2 -0
  262. data/decidim-results/config/locales/es.yml +2 -0
  263. data/decidim-results/config/locales/eu.yml +22 -4
  264. data/decidim-results/spec/shared/manage_results_examples.rb +10 -8
  265. data/decidim-system/config/locales/eu.yml +60 -2
  266. data/lib/generators/decidim/app_generator.rb +0 -4
  267. data/lib/generators/decidim/install_generator.rb +0 -4
  268. data/lib/generators/decidim/templates/README.md.erb +18 -18
  269. data/package.json +47 -22
  270. data/tsconfig.json +17 -0
  271. data/tslint.json +12 -0
  272. data/webpack.config.js +8 -6
  273. data/webpack.d.ts +5 -0
  274. data/yarn.lock +1461 -781
  275. metadata +119 -83
  276. data/decidim-admin/app/assets/stylesheets/decidim/admin/_actions.scss +0 -8
  277. data/decidim-admin/app/assets/stylesheets/decidim/admin/_forms.scss +0 -10
  278. data/decidim-admin/app/assets/stylesheets/decidim/admin/_foundation_and_overrides.scss +0 -53
  279. data/decidim-admin/app/assets/stylesheets/decidim/admin/_icons.scss +0 -9
  280. data/decidim-admin/app/assets/stylesheets/decidim/admin/_layout.scss +0 -27
  281. data/decidim-admin/app/assets/stylesheets/decidim/admin/_settings.scss +0 -566
  282. data/decidim-admin/app/assets/stylesheets/decidim/admin/_tables.scss +0 -21
  283. data/decidim-admin/app/views/layouts/decidim/admin/_login_items.html.erb +0 -8
  284. data/decidim-admin/app/views/layouts/decidim/admin/_sidebar.html.erb +0 -22
  285. data/decidim-comments/app/frontend/application/application.component.jsx +0 -37
  286. data/decidim-comments/app/frontend/application/application.component.test.jsx +0 -33
  287. data/decidim-comments/app/frontend/application/icon.component.jsx +0 -26
  288. data/decidim-comments/app/frontend/application/icon.component.test.jsx +0 -53
  289. data/decidim-comments/app/frontend/comments/comment_order_selector.component.jsx +0 -72
  290. data/decidim-comments/app/frontend/comments/comment_order_selector.component.test.jsx +0 -20
  291. data/decidim-comments/app/frontend/comments/comment_thread.component.jsx +0 -75
  292. data/decidim-comments/app/frontend/comments/comment_thread.component.test.jsx +0 -83
  293. data/decidim-comments/app/frontend/comments/down_vote_button.component.jsx +0 -98
  294. data/decidim-comments/app/frontend/comments/down_vote_button.component.test.jsx +0 -48
  295. data/decidim-comments/app/frontend/comments/featured_comment.component.jsx +0 -23
  296. data/decidim-comments/app/frontend/comments/featured_comment.component.test.jsx +0 -15
  297. data/decidim-comments/app/frontend/comments/up_vote_button.component.jsx +0 -98
  298. data/decidim-comments/app/frontend/comments/up_vote_button.component.test.jsx +0 -48
  299. data/decidim-comments/app/frontend/comments/vote_button.component.jsx +0 -32
  300. data/decidim-comments/app/frontend/entry.js +0 -17
  301. data/decidim-comments/app/frontend/entry.test.js +0 -31
  302. data/decidim-comments/app/frontend/support/load_translations.js +0 -23
  303. data/decidim-comments/app/frontend/support/stub_component.js +0 -29
  304. data/decidim-dev/lib/decidim/dev/test/rspec_support/phantomjs_polyfills/bind-polyfill.js +0 -18
  305. data/decidim-dev/lib/decidim/dev/test/rspec_support/phantomjs_polyfills/object-assign-polyfill.js +0 -24
  306. data/karma.conf.js +0 -45
  307. data/lib/generators/decidim/review_app_generator.rb +0 -53
  308. data/lib/generators/decidim/templates/app.json.erb +0 -16
@@ -0,0 +1,36 @@
1
+ import * as React from "react";
2
+ import Icon from "../application/icon.component";
3
+
4
+ interface VoteButtonProps {
5
+ buttonClassName: string;
6
+ iconName: string;
7
+ votes: number;
8
+ voteAction?: () => void;
9
+ disabled?: boolean;
10
+ selectedClass?: string;
11
+ }
12
+
13
+ const VoteButton: React.SFC<VoteButtonProps> = ({
14
+ buttonClassName,
15
+ iconName,
16
+ votes,
17
+ voteAction,
18
+ disabled,
19
+ selectedClass,
20
+ }) => (
21
+ <button
22
+ className={`${buttonClassName} ${selectedClass}`}
23
+ onClick={voteAction}
24
+ disabled={disabled}
25
+ >
26
+ <Icon name={iconName} iconExtraClassName="icon--small" />
27
+ {` ${votes}`}
28
+ </button>
29
+ );
30
+
31
+ VoteButton.defaultProps = {
32
+ selectedClass: "selected",
33
+ disabled: false,
34
+ };
35
+
36
+ export default VoteButton;
@@ -1,43 +1,39 @@
1
- /* eslint-disable no-unused-expressions */
2
- import { shallow } from 'enzyme';
3
-
4
- import VoteButton from './vote_button.component';
5
- import Icon from '../application/icon.component';
6
-
7
- import stubComponent from '../support/stub_component';
1
+ import { shallow } from "enzyme";
2
+ import * as React from "react";
3
+ import Icon from "../application/icon.component";
4
+ import VoteButton from "./vote_button.component";
8
5
 
9
6
  describe("<VoteButton />", () => {
10
- const voteAction = sinon.spy();
11
- stubComponent(Icon);
7
+ const voteAction: jasmine.Spy = jasmine.createSpy("voteAction");
12
8
 
13
9
  it("should render the number of votes passed as a prop", () => {
14
10
  const wrapper = shallow(<VoteButton votes={10} buttonClassName="vote-button" iconName="vote-icon" voteAction={voteAction} />);
15
- expect(wrapper.find('button').text()).to.match(/10/);
11
+ expect(wrapper.find("button").text()).toMatch(/10/);
16
12
  });
17
13
 
18
14
  it("should render a button with the given buttonClassName", () => {
19
15
  const wrapper = shallow(<VoteButton votes={10} buttonClassName="vote-button" iconName="vote-icon" voteAction={voteAction} />);
20
- expect(wrapper.find('button.vote-button')).to.be.present();
16
+ expect(wrapper.find("button.vote-button").exists()).toBeTruthy();
21
17
  });
22
18
 
23
19
  it("should render a Icon component with the correct name prop", () => {
24
20
  const wrapper = shallow(<VoteButton votes={10} buttonClassName="vote-button" iconName="vote-icon" voteAction={voteAction} />);
25
- expect(wrapper.find(Icon)).to.have.prop("name").equal('vote-icon');
21
+ expect(wrapper.find(Icon).prop("name")).toEqual("vote-icon");
26
22
  });
27
23
 
28
24
  it("should call the voteAction prop on click", () => {
29
25
  const wrapper = shallow(<VoteButton votes={10} buttonClassName="vote-button" iconName="vote-icon" voteAction={voteAction} />);
30
- wrapper.find('button').simulate('click');
31
- expect(voteAction).to.have.been.called;
26
+ wrapper.find("button").simulate("click");
27
+ expect(voteAction).toHaveBeenCalled();
32
28
  });
33
29
 
34
30
  it("should disable the button based on the disabled prop", () => {
35
- const wrapper = shallow(<VoteButton votes={10} buttonClassName="vote-button" iconName="vote-icon" voteAction={voteAction} disabled />);
36
- expect(wrapper.find('button')).to.be.disabled();
37
- })
31
+ const wrapper = shallow(<VoteButton votes={10} buttonClassName="vote-button" iconName="vote-icon" voteAction={voteAction} disabled={true} />);
32
+ expect(wrapper.find("button").props()).toHaveProperty("disabled");
33
+ });
38
34
 
39
35
  it("should render a button with the given selectedClass", () => {
40
- const wrapper = shallow(<VoteButton votes={10} buttonClassName="vote-button" iconName="vote-icon" voteAction={voteAction} disabled selectedClass="is-vote-selected" />);
41
- expect(wrapper.find('.is-vote-selected')).to.be.present();
42
- })
36
+ const wrapper = shallow(<VoteButton votes={10} buttonClassName="vote-button" iconName="vote-icon" voteAction={voteAction} disabled={true} selectedClass="is-vote-selected" />);
37
+ expect(wrapper.find(".is-vote-selected").exists()).toBeTruthy();
38
+ });
43
39
  });
@@ -0,0 +1,19 @@
1
+ import * as React from "react";
2
+ import * as ReactDOM from "react-dom";
3
+
4
+ import Comments, { CommentsApplicationProps } from "./comments/comments.component";
5
+ import loadTranslations from "./support/load_translations";
6
+
7
+ window.DecidimComments = window.DecidimComments || {};
8
+
9
+ window.DecidimComments.renderCommentsComponent = (nodeId: string, props: CommentsApplicationProps) => {
10
+ let node = window.$(`#${nodeId}`)[0];
11
+
12
+ ReactDOM.render(
13
+ React.createElement(Comments, props),
14
+ node,
15
+ );
16
+ };
17
+
18
+ // Load component locales from yaml files
19
+ loadTranslations();
@@ -1,4 +1,4 @@
1
1
  fragment AddCommentFormCommentable on Commentable {
2
2
  id
3
3
  type
4
- }
4
+ }
@@ -3,4 +3,4 @@ fragment AddCommentFormSession on Session {
3
3
  id
4
4
  name
5
5
  }
6
- }
6
+ }
@@ -1,3 +1,5 @@
1
+ #import "../fragments/comment_data.fragment.graphql"
2
+
1
3
  fragment Comment on Comment {
2
4
  ...CommentData
3
5
  comments {
@@ -9,4 +11,4 @@ fragment Comment on Comment {
9
11
  }
10
12
  }
11
13
  }
12
- }
14
+ }
@@ -1,3 +1,6 @@
1
+ #import "../fragments/up_vote_button.fragment.graphql"
2
+ #import "../fragments/down_vote_button.fragment.graphql"
3
+
1
4
  fragment CommentData on Comment {
2
5
  id
3
6
  sgid
@@ -12,6 +15,6 @@ fragment CommentData on Comment {
12
15
  acceptsNewComments
13
16
  alignment
14
17
  alreadyReported
15
- ...UpVote
16
- ...DownVote
17
- }
18
+ ...UpVoteButton
19
+ ...DownVoteButton
20
+ }
@@ -1,7 +1,9 @@
1
+ #import "../fragments/comment.fragment.graphql"
2
+
1
3
  fragment CommentThread on Comment {
2
4
  author {
3
5
  name
4
6
  }
5
7
  hasComments
6
8
  ...Comment
7
- }
9
+ }
@@ -1,6 +1,6 @@
1
- fragment DownVote on Comment {
1
+ fragment DownVoteButton on Comment {
2
2
  id
3
3
  downVotes
4
4
  downVoted
5
5
  upVoted
6
- }
6
+ }
@@ -1,6 +1,6 @@
1
- fragment UpVote on Comment {
1
+ fragment UpVoteButton on Comment {
2
2
  id
3
3
  upVotes
4
4
  upVoted
5
5
  downVoted
6
- }
6
+ }
@@ -1,7 +1,9 @@
1
+ #import "../fragments/comment_thread.fragment.graphql"
2
+
1
3
  mutation addComment($commentableId: String!, $commentableType: String!, $body: String!, $alignment: Int, $userGroupId: ID) {
2
4
  commentable(id: $commentableId, type: $commentableType) {
3
5
  addComment(body: $body, alignment: $alignment, userGroupId: $userGroupId) {
4
6
  ...CommentThread
5
7
  }
6
8
  }
7
- }
9
+ }
@@ -1,7 +1,9 @@
1
+ #import "../fragments/comment.fragment.graphql"
2
+
1
3
  mutation DownVote($id: ID!) {
2
4
  comment(id: $id) {
3
5
  downVote {
4
6
  ...Comment
5
7
  }
6
8
  }
7
- }
9
+ }
@@ -1,7 +1,9 @@
1
+ #import "../fragments/comment.fragment.graphql"
2
+
1
3
  mutation UpVote($id: ID!) {
2
4
  comment(id: $id) {
3
5
  upVote {
4
6
  ...Comment
5
7
  }
6
8
  }
7
- }
9
+ }
@@ -1,3 +1,6 @@
1
+ #import "../fragments/add_comment_form_session.fragment.graphql"
2
+ #import "../fragments/comment_thread.fragment.graphql"
3
+ #import "../fragments/add_comment_form_commentable.fragment.graphql"
1
4
  query GetComments($commentableId: String!, $commentableType: String!, $orderBy: String) {
2
5
  session {
3
6
  user {
@@ -17,4 +20,4 @@ query GetComments($commentableId: String!, $commentableType: String!, $orderBy:
17
20
  }
18
21
  ...AddCommentFormCommentable
19
22
  }
20
- }
23
+ }
@@ -1,4 +1,4 @@
1
- const assetUrl = (name) => {
1
+ const assetUrl = (name: string): string => {
2
2
  const url = window.DecidimComments.assets[name];
3
3
 
4
4
  if (!url) {
@@ -1,4 +1,6 @@
1
- import { random, name, date, image } from 'faker/locale/en';
1
+ import { date, image, lorem, name, random } from "faker/locale/en";
2
+
3
+ import { CommentFragment } from "../support/schema";
2
4
 
3
5
  /**
4
6
  * Generate random comment data to emulate a database real content
@@ -6,16 +8,17 @@ import { random, name, date, image } from 'faker/locale/en';
6
8
  * @returns {Object[]} - An array of objects representing comments data
7
9
  */
8
10
  const generateCommentsData = (num = 1) => {
9
- let commentsData = [];
11
+ let commentsData: CommentFragment[] = [];
10
12
 
11
13
  for (let idx = 0; idx < num; idx += 1) {
12
14
  commentsData.push({
13
15
  id: random.uuid(),
14
- body: random.words(),
16
+ type: "Decidim::Comments::Comment",
17
+ body: lorem.words(),
15
18
  createdAt: date.past().toISOString(),
16
19
  author: {
17
20
  name: name.findName(),
18
- avatarUrl: image.imageUrl()
21
+ avatarUrl: image.imageUrl(),
19
22
  },
20
23
  hasComments: false,
21
24
  comments: [],
@@ -24,8 +27,10 @@ const generateCommentsData = (num = 1) => {
24
27
  upVotes: random.number(),
25
28
  upVoted: false,
26
29
  downVotes: random.number(),
27
- downVoted: false
28
- })
30
+ downVoted: false,
31
+ sgid: random.uuid(),
32
+ alreadyReported: false,
33
+ });
29
34
  }
30
35
 
31
36
  return commentsData;
@@ -1,4 +1,4 @@
1
- import { name } from 'faker/locale/en';
1
+ import { name } from "faker/locale/en";
2
2
 
3
3
  /**
4
4
  * Generate random user data to emulate a database real content
@@ -6,7 +6,7 @@ import { name } from 'faker/locale/en';
6
6
  */
7
7
  const generateUserData = () => {
8
8
  return {
9
- name: name.findName()
9
+ name: name.findName(),
10
10
  };
11
11
  };
12
12
 
@@ -1,4 +1,4 @@
1
- import { random, company } from 'faker/locale/en';
1
+ import { company, random } from "faker/locale/en";
2
2
 
3
3
  /**
4
4
  * Generate random user group data to emulate a database real content
@@ -7,7 +7,7 @@ import { random, company } from 'faker/locale/en';
7
7
  const generateUserGrouprData = () => {
8
8
  return {
9
9
  id: random.uuid(),
10
- name: company.companyName()
10
+ name: company.companyName(),
11
11
  };
12
12
  };
13
13
 
@@ -0,0 +1,32 @@
1
+ /* eslint-env node */
2
+ const gql = require('graphql-tag');
3
+
4
+ // Takes `source` (the source GraphQL query string)
5
+ // and `doc` (the parsed GraphQL document) and tacks on
6
+ // the imported definitions.
7
+ const expandImports = (source) => {
8
+ const lines = source.split('\n');
9
+ let outputCode = "";
10
+
11
+ lines.some((line) => {
12
+ if (line[0] === '#' && line.slice(1).split(' ')[0] === 'import') {
13
+ const importFile = line.slice(1).split(' ')[1];
14
+ const parseDocument = `require(${importFile})`;
15
+ const appendDef = `doc.definitions = doc.definitions.concat(${parseDocument}.definitions);`;
16
+ outputCode += `${appendDef}\n`;
17
+ }
18
+ return (line.length !== 0 && line[0] !== '#');
19
+ });
20
+
21
+ return outputCode;
22
+ }
23
+
24
+ module.exports = {
25
+ process(src) {
26
+ const doc = gql`${src}`;
27
+ const outputCode = `var doc = ${JSON.stringify(doc)};`;
28
+ const importOutputCode = expandImports(src, doc);
29
+
30
+ return `${outputCode}\n${importOutputCode}\nmodule.exports = doc;`;
31
+ }
32
+ };
@@ -0,0 +1,44 @@
1
+ /* eslint-disable no-param-reassign */
2
+ import requireAll from "./require_all";
3
+
4
+ const { I18n } = require("react-i18nify");
5
+
6
+ /**
7
+ * Load components translations from yaml files and import them into
8
+ * react-i18ify system so they can be used via `I18n.t` method.
9
+ * @returns {Void} - Nothing
10
+ */
11
+ const loadTranslations = () => {
12
+ const translationsContext = (<any> require).context("../../../config/locales/", true, /\.yml$/);
13
+ const translationFiles = requireAll(translationsContext);
14
+
15
+ const translations = translationsContext.keys().reduce((acc: any, key: string, index: number) => {
16
+ const match = key.match(/\.\/(.*)\.yml/);
17
+
18
+ if (match) {
19
+ let locale = match[1];
20
+ acc[locale] = translationFiles[index][locale].decidim;
21
+ }
22
+
23
+ return acc;
24
+ }, {});
25
+
26
+ I18n.setTranslations(translations);
27
+ };
28
+
29
+ /**
30
+ * Load components translations from a locale files and import them into
31
+ * react-i18ify system so they can be used via `I18n.t` method.
32
+ * @returns {Void} - Nothing
33
+ */
34
+ export const loadLocaleTranslations = (locale: string) => {
35
+ const translationFile = require(`./../../../config/locales/${locale}.yml`);
36
+ const translations = Object.keys(translationFile).reduce((acc: any, key: string) => {
37
+ acc[locale] = translationFile[locale].decidim;
38
+ return acc;
39
+ }, {});
40
+
41
+ I18n.setTranslations(translations);
42
+ };
43
+
44
+ export default loadTranslations;
@@ -3,7 +3,7 @@
3
3
  * @param {Object} requireContext - A webpack require context
4
4
  * @returns {Object[]} - An array of webpack modules
5
5
  */
6
- const requireAll = (requireContext) => {
6
+ const requireAll = (requireContext: any) => {
7
7
  return requireContext.keys().map(requireContext);
8
8
  };
9
9
 
@@ -1,5 +1,5 @@
1
- import graphql, { filter } from 'graphql-anywhere';
2
-
1
+ import graphql, { filter } from "graphql-anywhere";
2
+
3
3
  /**
4
4
  * A simple resolver which returns object properties to easily
5
5
  * traverse a graphql response
@@ -7,9 +7,9 @@ import graphql, { filter } from 'graphql-anywhere';
7
7
  * @param {Object} root - An object
8
8
  * @returns {any} - An object's property value
9
9
  */
10
- const resolver = (fieldName, root) => root[fieldName];
10
+ const resolver = (fieldName: string, root: any) => root[fieldName];
11
11
 
12
- /**
12
+ /**
13
13
  * A helper function to mock a graphql api request and return its
14
14
  * result. The result can be filtered by the same query so it just
15
15
  * returns a data subset.
@@ -17,7 +17,7 @@ const resolver = (fieldName, root) => root[fieldName];
17
17
  * @param {options} options - An object with optional options
18
18
  * @returns {Object} - The result of the query filtered or not
19
19
  */
20
- const resolveGraphQLQuery = (document, options = {}) => {
20
+ const resolveGraphQLQuery = (document: any, options: any = {}) => {
21
21
  const { filterResult, rootValue, context, variables } = options;
22
22
 
23
23
  let result = graphql(
@@ -25,13 +25,13 @@ const resolveGraphQLQuery = (document, options = {}) => {
25
25
  document,
26
26
  rootValue,
27
27
  context,
28
- variables
28
+ variables,
29
29
  );
30
30
 
31
31
  if (filterResult) {
32
32
  return filter(document, result);
33
33
  }
34
34
  return result;
35
- }
35
+ };
36
36
 
37
37
  export default resolveGraphQLQuery;