decidim-core 0.20.1 → 0.21.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 (213) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/fonts/decidim/Roboto-Regular.eot +0 -0
  3. data/app/assets/fonts/decidim/Roboto-Regular.svg +10520 -0
  4. data/app/assets/fonts/decidim/Roboto-Regular.ttf +0 -0
  5. data/app/assets/fonts/decidim/Roboto-Regular.woff +0 -0
  6. data/app/assets/fonts/decidim/Roboto-Regular.woff2 +0 -0
  7. data/app/assets/images/decidim/brands/google.svg +1 -0
  8. data/app/assets/javascripts/decidim.js.es6 +5 -0
  9. data/app/assets/javascripts/decidim/check_boxes_tree.js.es6 +190 -0
  10. data/app/assets/javascripts/decidim/core/bundle.js +1 -1
  11. data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
  12. data/app/assets/javascripts/decidim/delayed.js.es6 +26 -0
  13. data/app/assets/javascripts/decidim/diff_mode_dropdown.js.es6 +25 -4
  14. data/app/assets/javascripts/decidim/form_filter.component.js.es6 +86 -38
  15. data/app/assets/javascripts/decidim/form_filter.component.test.js +40 -6
  16. data/app/assets/javascripts/decidim/history.js.es6 +16 -1
  17. data/app/assets/javascripts/decidim/vizzs/orgchart.js.es6 +1 -1
  18. data/app/assets/stylesheets/decidim/_variables.scss +1 -1
  19. data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +0 -1
  20. data/app/assets/stylesheets/decidim/modules/_buttons.scss +76 -3
  21. data/app/assets/stylesheets/decidim/modules/_comments.scss +78 -2
  22. data/app/assets/stylesheets/decidim/modules/_filters.scss +36 -2
  23. data/app/assets/stylesheets/decidim/modules/_layout.scss +13 -0
  24. data/app/assets/stylesheets/decidim/modules/_modules.scss +1 -0
  25. data/app/assets/stylesheets/decidim/modules/_navbar.scss +11 -5
  26. data/app/assets/stylesheets/decidim/modules/_process-stats.scss +53 -0
  27. data/app/assets/stylesheets/decidim/modules/_status-labels.scss +5 -0
  28. data/app/assets/stylesheets/decidim/modules/_tags.scss +7 -1
  29. data/app/assets/stylesheets/decidim/modules/_typography.scss +49 -4
  30. data/app/assets/stylesheets/decidim/utils/_fontface.scss +10 -0
  31. data/app/assets/stylesheets/decidim/utils/_toggle-expand.scss +14 -0
  32. data/app/cells/decidim/activity/show.erb +1 -1
  33. data/app/cells/decidim/author/profile_inline.erb +2 -2
  34. data/app/cells/decidim/diff/attribute.erb +15 -5
  35. data/app/cells/decidim/diff/diff_mode_html.erb +31 -0
  36. data/app/cells/decidim/diff/diff_split.erb +1 -1
  37. data/app/cells/decidim/diff/diff_unified.erb +1 -1
  38. data/app/cells/decidim/diff/show.erb +1 -0
  39. data/app/cells/decidim/diff_cell.rb +21 -8
  40. data/app/cells/decidim/follow_button/show.erb +20 -7
  41. data/app/cells/decidim/navbar_admin_link/show.erb +6 -0
  42. data/app/cells/decidim/navbar_admin_link_cell.rb +43 -0
  43. data/app/cells/decidim/tags_cell.rb +2 -2
  44. data/app/commands/decidim/amendable/accept.rb +9 -4
  45. data/app/commands/decidim/amendable/publish_draft.rb +5 -0
  46. data/app/commands/decidim/amendable/reject.rb +5 -0
  47. data/app/commands/decidim/amendable/withdraw.rb +3 -12
  48. data/app/commands/decidim/create_registration.rb +5 -6
  49. data/app/controllers/concerns/decidim/use_organization_time_zone.rb +32 -0
  50. data/app/controllers/decidim/application_controller.rb +3 -0
  51. data/app/controllers/decidim/components/base_controller.rb +1 -0
  52. data/app/controllers/decidim/data_portability_controller.rb +12 -19
  53. data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +1 -1
  54. data/app/controllers/decidim/devise/registrations_controller.rb +1 -0
  55. data/app/controllers/decidim/scopes_controller.rb +41 -7
  56. data/app/forms/decidim/registration_form.rb +5 -0
  57. data/app/functions/decidim/core/component_finder_base.rb +33 -0
  58. data/app/functions/decidim/core/component_list.rb +38 -0
  59. data/app/functions/decidim/core/component_list_base.rb +61 -0
  60. data/app/functions/decidim/core/needs_api_filter_and_order.rb +52 -0
  61. data/app/functions/decidim/core/participatory_space_finder.rb +11 -0
  62. data/app/functions/decidim/core/participatory_space_finder_base.rb +29 -0
  63. data/app/functions/decidim/core/participatory_space_list.rb +11 -0
  64. data/app/functions/decidim/core/participatory_space_list_base.rb +34 -0
  65. data/app/helpers/decidim/amendments_helper.rb +27 -1
  66. data/app/helpers/decidim/application_helper.rb +31 -3
  67. data/app/helpers/decidim/categories_helper.rb +26 -0
  68. data/app/helpers/decidim/check_boxes_tree_helper.rb +115 -0
  69. data/app/helpers/decidim/omniauth_helper.rb +6 -13
  70. data/app/helpers/decidim/resource_versions_helper.rb +29 -0
  71. data/app/helpers/decidim/rich_text_editor_helper.rb +22 -0
  72. data/app/helpers/decidim/sanitize_helper.rb +3 -1
  73. data/app/helpers/decidim/scopes_helper.rb +3 -2
  74. data/app/jobs/decidim/data_portability_export_job.rb +18 -10
  75. data/app/jobs/decidim/export_job.rb +1 -1
  76. data/app/mailers/decidim/export_mailer.rb +9 -5
  77. data/app/models/decidim/omniauth_provider.rb +28 -0
  78. data/app/models/decidim/organization.rb +41 -0
  79. data/app/models/decidim/participatory_space_role_config/admin.rb +8 -0
  80. data/app/models/decidim/participatory_space_role_config/base.rb +31 -0
  81. data/app/models/decidim/participatory_space_role_config/collaborator.rb +8 -0
  82. data/app/models/decidim/participatory_space_role_config/moderator.rb +11 -0
  83. data/app/models/decidim/participatory_space_role_config/null_object.rb +11 -0
  84. data/app/models/decidim/participatory_space_role_config/participatory_space_admin.rb +8 -0
  85. data/app/models/decidim/participatory_space_role_config/valuator.rb +11 -0
  86. data/app/models/decidim/scope.rb +4 -2
  87. data/app/models/decidim/user.rb +19 -3
  88. data/app/presenters/decidim/home_stats_presenter.rb +5 -2
  89. data/app/presenters/decidim/resource_locator_presenter.rb +9 -0
  90. data/app/serializers/decidim/exporters/participatory_space_components_serializer.rb +1 -1
  91. data/app/serializers/decidim/importers/participatory_space_components_importer.rb +14 -5
  92. data/app/services/decidim/data_portability_exporter.rb +72 -0
  93. data/app/services/decidim/resource_search.rb +29 -13
  94. data/app/services/decidim/zip_stream/zip_stream_writer.rb +56 -0
  95. data/app/types/decidim/core/amendment_type.rb +26 -0
  96. data/app/types/decidim/core/area_api_type.rb +16 -0
  97. data/app/types/decidim/core/area_type_type.rb +14 -0
  98. data/app/types/decidim/core/base_input_filter.rb +8 -0
  99. data/app/types/decidim/core/base_input_sort.rb +22 -0
  100. data/app/types/decidim/core/component_input_filter.rb +50 -0
  101. data/app/types/decidim/core/component_input_sort.rb +32 -0
  102. data/app/types/decidim/core/fingerprint_type.rb +15 -0
  103. data/app/types/decidim/core/has_hastaggable_input_filter.rb +15 -0
  104. data/app/types/decidim/core/has_localized_input_filter.rb +21 -0
  105. data/app/types/decidim/core/has_localized_input_sort.rb +21 -0
  106. data/app/types/decidim/core/has_publishable_input_filter.rb +34 -0
  107. data/app/types/decidim/core/has_publishable_input_sort.rb +13 -0
  108. data/app/types/decidim/core/participatory_space_input_filter.rb +26 -0
  109. data/app/types/decidim/core/participatory_space_input_sort.rb +14 -0
  110. data/app/types/decidim/core/participatory_space_link_type.rb +24 -0
  111. data/app/types/decidim/core/trace_version_type.rb +29 -0
  112. data/app/uploaders/decidim/data_portability_uploader.rb +2 -7
  113. data/app/validators/time_zone_validator.rb +10 -0
  114. data/app/views/decidim/amendments/_edit_form_fields.html.erb +5 -13
  115. data/app/views/decidim/amendments/preview_draft.html.erb +1 -1
  116. data/app/views/decidim/devise/shared/_omniauth_buttons.html.erb +10 -12
  117. data/app/views/decidim/devise/shared/_omniauth_buttons_mini.html.erb +6 -8
  118. data/app/views/decidim/export_mailer/data_portability_export.html.erb +2 -2
  119. data/app/views/decidim/scopes/picker.html.erb +7 -3
  120. data/app/views/decidim/shared/_check_boxes_tree.html.erb +54 -0
  121. data/app/views/decidim/shared/_extended_navigation_bar.html.erb +1 -1
  122. data/app/views/decidim/widgets/show.html.erb +4 -0
  123. data/app/views/layouts/decidim/_admin_links.html.erb +2 -0
  124. data/app/views/layouts/decidim/_wrapper.html.erb +4 -3
  125. data/app/views/layouts/decidim/widget.html.erb +1 -43
  126. data/config/initializers/browser.rb +5 -0
  127. data/config/initializers/devise.rb +0 -22
  128. data/config/initializers/omniauth.rb +50 -0
  129. data/config/locales/ar.yml +6 -3
  130. data/config/locales/ca.yml +15 -6
  131. data/config/locales/cs.yml +12 -3
  132. data/config/locales/de.yml +5 -3
  133. data/config/locales/el-GR.yml +0 -2
  134. data/config/locales/el.yml +153 -0
  135. data/config/locales/en.yml +16 -7
  136. data/config/locales/eo-UY.yml +2 -2
  137. data/config/locales/es-MX.yml +12 -3
  138. data/config/locales/es-PY.yml +12 -3
  139. data/config/locales/es.yml +15 -6
  140. data/config/locales/eu.yml +4 -3
  141. data/config/locales/fi-plain.yml +12 -3
  142. data/config/locales/fi.yml +12 -3
  143. data/config/locales/fr.yml +5 -3
  144. data/config/locales/gl.yml +4 -3
  145. data/config/locales/hu.yml +12 -3
  146. data/config/locales/id-ID.yml +4 -3
  147. data/config/locales/it.yml +11 -3
  148. data/config/locales/nl.yml +8 -3
  149. data/config/locales/no.yml +12 -3
  150. data/config/locales/pl.yml +4 -3
  151. data/config/locales/pt-BR.yml +4 -3
  152. data/config/locales/pt.yml +4 -3
  153. data/config/locales/ru.yml +5 -3
  154. data/config/locales/sv.yml +5 -3
  155. data/config/locales/tr-TR.yml +4 -3
  156. data/config/locales/uk.yml +1 -3
  157. data/db/migrate/20191113092826_add_omniauth_settings_to_decidim_organization.rb +7 -0
  158. data/db/migrate/20191113144432_add_rich_text_editor_in_public_views_to_organizations.rb +10 -0
  159. data/db/migrate/20191118123154_add_admin_terms_of_use_body_field_to_organization.rb +9 -0
  160. data/db/migrate/20200107142226_add_organization_timezone.rb +7 -0
  161. data/db/seeds.rb +2 -1
  162. data/lib/decidim/amendable.rb +7 -4
  163. data/lib/decidim/api/amendable_entity_interface.rb +18 -0
  164. data/lib/decidim/api/amendable_interface.rb +18 -0
  165. data/lib/decidim/api/attachable_interface.rb +1 -1
  166. data/lib/decidim/api/categorizable_interface.rb +1 -1
  167. data/lib/decidim/api/coauthorable_interface.rb +29 -0
  168. data/lib/decidim/api/fingerprint_interface.rb +13 -0
  169. data/lib/decidim/api/participatory_space_interface.rb +9 -9
  170. data/lib/decidim/api/participatory_space_resourceable_interface.rb +21 -0
  171. data/lib/decidim/api/scopable_interface.rb +1 -1
  172. data/lib/decidim/api/timestamps_interface.rb +21 -0
  173. data/lib/decidim/api/traceable_interface.rb +14 -0
  174. data/lib/decidim/coauthorable.rb +9 -2
  175. data/lib/decidim/component_manifest.rb +1 -1
  176. data/lib/decidim/content_processor.rb +4 -2
  177. data/lib/decidim/content_renderers/link_renderer.rb +1 -1
  178. data/lib/decidim/core.rb +3 -3
  179. data/lib/decidim/core/api.rb +7 -0
  180. data/lib/decidim/core/test.rb +1 -0
  181. data/lib/decidim/core/test/factories.rb +16 -0
  182. data/lib/decidim/core/test/shared_examples/amendable_interface_examples.rb +14 -0
  183. data/lib/decidim/core/test/shared_examples/amendable_proposals_interface_examples.rb +50 -0
  184. data/lib/decidim/core/test/shared_examples/authorable_interface_examples.rb +3 -0
  185. data/lib/decidim/core/test/shared_examples/coauthorable_interface_examples.rb +60 -0
  186. data/lib/decidim/core/test/shared_examples/comments_examples.rb +8 -8
  187. data/lib/decidim/core/test/shared_examples/fingerprintable_interface_examples.rb +17 -0
  188. data/lib/decidim/core/test/shared_examples/follows_examples.rb +16 -0
  189. data/lib/decidim/core/test/shared_examples/input_filter_examples.rb +118 -0
  190. data/lib/decidim/core/test/shared_examples/input_sort_examples.rb +105 -0
  191. data/lib/decidim/core/test/shared_examples/participatory_space_resourcable_interface_examples.rb +43 -0
  192. data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +59 -0
  193. data/lib/decidim/core/test/shared_examples/timestamps_interface_examples.rb +21 -0
  194. data/lib/decidim/core/test/shared_examples/traceable_interface_examples.rb +47 -0
  195. data/lib/decidim/core/version.rb +1 -1
  196. data/lib/decidim/deprecations.rb +19 -0
  197. data/lib/decidim/diffy_extension.rb +26 -0
  198. data/lib/decidim/exporters/export_manifest.rb +6 -2
  199. data/lib/decidim/filter_form_builder.rb +25 -7
  200. data/lib/decidim/form_builder.rb +2 -2
  201. data/lib/decidim/has_settings.rb +10 -4
  202. data/lib/decidim/participatory_space_manifest.rb +20 -0
  203. data/lib/decidim/participatory_space_resourceable.rb +35 -1
  204. data/lib/decidim/query_extensions.rb +9 -23
  205. data/lib/decidim/scopable.rb +10 -0
  206. data/lib/tasks/decidim_data_portability_tasks.rake +66 -5
  207. data/lib/tasks/decidim_metrics_tasks.rake +18 -7
  208. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.el.js +14 -0
  209. metadata +142 -16
  210. data/app/models/decidim/participatory_process_user_role.rb +0 -32
  211. data/app/views/layouts/decidim/_edit_link.html.erb +0 -8
  212. data/lib/decidim/data_portability_file_reader.rb +0 -56
  213. data/lib/decidim/data_portability_file_zipper.rb +0 -67
@@ -61,6 +61,7 @@
61
61
  @import "inline-filters";
62
62
  @import "reference";
63
63
  @import "status-labels";
64
+ @import "process-stats";
64
65
 
65
66
  //Conference elements
66
67
  @import "conference-nav";
@@ -348,12 +348,18 @@ $navbar-active-shadow-medium: inset 0 4px 0 0 var(--primary);
348
348
  }
349
349
  }
350
350
 
351
- .topbar__edit__link a{
352
- color: $medium-gray;
351
+ .topbar__admin__link{
352
+ a{
353
+ color: $medium-gray;
353
354
 
354
- &:hover{
355
- background: $navbar-bg-hover;
356
- color: $navbar-color-hover;
355
+ &:hover{
356
+ background: $navbar-bg-hover;
357
+ color: $navbar-color-hover;
358
+ }
359
+ }
360
+
361
+ ~ .topbar__admin__link{
362
+ margin-left: 1rem;
357
363
  }
358
364
  }
359
365
 
@@ -0,0 +1,53 @@
1
+ .process-stats{
2
+ overflow: hidden;
3
+ margin: 2rem 0;
4
+ display: flex;
5
+ flex-wrap: wrap;
6
+
7
+ &__title{
8
+ color: $muted;
9
+ text-transform: uppercase;
10
+ font-size: .9rem;
11
+ letter-spacing: .01em;
12
+ font-weight: 600;
13
+ margin-bottom: 0;
14
+ }
15
+
16
+ &__data{
17
+ text-align: center;
18
+ padding: 1rem .25rem;
19
+ width: calc(50% - 1rem);
20
+ margin: .5rem;
21
+ position: relative;
22
+
23
+ &::after{
24
+ content: "";
25
+ display: inline-block;
26
+ border-left: 2px solid $primary;
27
+ height: 2rem;
28
+ position: absolute;
29
+ left: 0;
30
+ top: calc(50% - 1rem);
31
+ }
32
+
33
+ @include breakpoint(medium down){
34
+ &:nth-child(odd)::after{
35
+ border: none;
36
+ }
37
+ }
38
+
39
+ @include breakpoint(mediumlarge){
40
+ width: calc(25% - 1rem);
41
+
42
+ &:nth-child(4n+1)::after{
43
+ border: none;
44
+ }
45
+ }
46
+ }
47
+
48
+ &__number{
49
+ font-weight: 800;
50
+ font-size: 2rem;
51
+ line-height: 1;
52
+ }
53
+ }
@@ -25,3 +25,8 @@
25
25
  .label.light{
26
26
  color: $white;
27
27
  }
28
+
29
+ .label.muted{
30
+ background: $muted;
31
+ color: $white;
32
+ }
@@ -16,7 +16,7 @@ $tags-border: $border;
16
16
  }
17
17
 
18
18
  a{
19
- display: block;
19
+ display: inline-block;
20
20
  border: $tags-border;
21
21
  padding: 0 .5rem;
22
22
  }
@@ -29,3 +29,9 @@ $tags-border: $border;
29
29
  .tags--inline{
30
30
  display: inline;
31
31
  }
32
+
33
+ .tags--list{
34
+ li{
35
+ display: block;
36
+ }
37
+ }
@@ -8,10 +8,18 @@ input{
8
8
 
9
9
  @mixin heading($heading){
10
10
  line-height: 1.2;
11
- font-size: map-get(map-get(map-get($header-styles, small), $heading), 'font-size') / 16 + em;
11
+ font-size:
12
+ map-get(
13
+ map-get(map-get($header-styles, small), $heading),
14
+ "font-size"
15
+ ) / 16 + em;
12
16
 
13
17
  @include breakpoint(medium){
14
- font-size: map-get(map-get(map-get($header-styles, medium), $heading), 'font-size') / 16 + em;
18
+ font-size:
19
+ map-get(
20
+ map-get(map-get($header-styles, medium), $heading),
21
+ "font-size"
22
+ ) / 16 + em;
15
23
  }
16
24
  }
17
25
 
@@ -116,6 +124,33 @@ hr{
116
124
  }
117
125
  }
118
126
 
127
+ .data-title{
128
+ &__over{
129
+ color: $muted;
130
+ text-transform: uppercase;
131
+ font-size: .9rem;
132
+ letter-spacing: .01em;
133
+ font-weight: 800;
134
+ margin-bottom: .5rem;
135
+ }
136
+
137
+ &__main{
138
+ font-size: 2rem;
139
+ line-height: 1;
140
+ letter-spacing: .01em;
141
+ font-weight: 800;
142
+ margin-bottom: 0;
143
+ }
144
+
145
+ &__sub{
146
+ color: $muted;
147
+ text-transform: uppercase;
148
+ font-size: .9rem;
149
+ letter-spacing: .01em;
150
+ line-height: 1;
151
+ }
152
+ }
153
+
119
154
  .page-title{
120
155
  margin-bottom: 3rem;
121
156
  }
@@ -139,7 +174,12 @@ hr{
139
174
  }
140
175
 
141
176
  // text status-color
142
- $map: map-merge($foundation-palette, (muted: $muted));
177
+ $map: map-merge(
178
+ $foundation-palette,
179
+ (
180
+ muted: $muted,
181
+ )
182
+ );
143
183
 
144
184
  @each $key, $value in $map{
145
185
  .text-#{$key}{
@@ -218,5 +258,10 @@ textarea,
218
258
  time,
219
259
  tt,
220
260
  var{
221
- @include modifiers(color, (muted: $muted));
261
+ @include modifiers(
262
+ color,
263
+ (
264
+ muted: $muted,
265
+ )
266
+ );
222
267
  }
@@ -27,3 +27,13 @@
27
27
  font-url('decidim/Source_Sans_Pro_900.woff') format('woff'),
28
28
  font-url('decidim/Source_Sans_Pro_900.ttf') format('truetype');
29
29
  }
30
+
31
+ @font-face{
32
+ font-family: 'Roboto';
33
+ font-style: normal;
34
+ font-weight: 900;
35
+ src:
36
+ asset-data-url('decidim/Roboto-Regular.woff2') format('woff2'),
37
+ font-url('decidim/Roboto-Regular.woff') format('woff'),
38
+ font-url('decidim/Roboto-Regular.ttf') format('truetype');
39
+ }
@@ -7,3 +7,17 @@
7
7
  display: block;
8
8
  }
9
9
  }
10
+
11
+ .expanded-text{
12
+ .text-toggle__short{
13
+ display: none;
14
+ }
15
+
16
+ .text-toggle__long{
17
+ display: block;
18
+ }
19
+ }
20
+
21
+ .text-toggle__long{
22
+ display: none;
23
+ }
@@ -14,7 +14,7 @@
14
14
  <% end %>
15
15
  <%= link_to resource_link_path, class: "card__link" do %>
16
16
  <h5 class="card__title mb-none">
17
- <%= html_truncate resource_link_text, length: 100 %>
17
+ <%= html_truncate resource_link_text, length: 80 %>
18
18
  </h5>
19
19
  <% end %>
20
20
  <%= description %>
@@ -1,5 +1,5 @@
1
1
  <span class="author__avatar">
2
- <%= image_tag model.avatar_url %>
2
+ <%= image_tag model.avatar_url, alt: t("decidim.author.avatar") %>
3
3
  </span>
4
4
 
5
5
  <% if model.deleted? %>
@@ -17,7 +17,7 @@
17
17
  data-keep-on-hover="true"
18
18
  data-allow-html="true"
19
19
  data-template-classes="light expanded"
20
- tabindex="1"
20
+ tabindex="0"
21
21
  data-tip-text='<%= h render(:profile_minicard) %>'>
22
22
  <%= model.name %>
23
23
  </span>
@@ -5,13 +5,23 @@
5
5
  </h3>
6
6
  </div>
7
7
 
8
- <div class="row" id="diff_unified">
9
- <%= diff_unified(data) %>
8
+ <div class="row" id="diff_view_unified_escaped">
9
+ <%= diff_unified(data, :html) %>
10
10
  </div>
11
11
 
12
- <div class="row hide" id="diff_split">
13
- <%= diff_split(data, "left") %>
12
+ <div class="row hide" id="diff_view_unified_unescaped">
13
+ <%= diff_unified(data, :unescaped_html) %>
14
+ </div>
15
+
16
+ <div class="row hide" id="diff_view_split_escaped">
17
+ <%= diff_split(data, "left", :html) %>
18
+
19
+ <%= diff_split(data, "right", :html) %>
20
+ </div>
21
+
22
+ <div class="row hide" id="diff_view_split_unescaped">
23
+ <%= diff_split(data, "left", :unescaped_html) %>
14
24
 
15
- <%= diff_split(data, "right") %>
25
+ <%= diff_split(data, "right", :unescaped_html) %>
16
26
  </div>
17
27
  </div>
@@ -0,0 +1,31 @@
1
+ <% if show_html_view_dropdown? %>
2
+ <div class="diff-view-by diff-view-html" style="margin-left: 0;">
3
+ <div class="diff-view-by__dropdown">
4
+ <span class="diff-view-by__text">
5
+ <%= t("versions.dropdown.choose_diff_view_html") %>
6
+ </span>
7
+
8
+ <ul class="dropdown menu" data-dropdown-menu>
9
+ <li class="is-dropdown-submenu-parent">
10
+ <a id="diff-view-selected">
11
+ <%= t("versions.dropdown.option_escaped") %>
12
+ </a>
13
+
14
+ <ul class="menu">
15
+ <li>
16
+ <%= link_to "#escaped-html", class: "diff-view-html", id:"escaped-html" do %>
17
+ <%= t("versions.dropdown.option_escaped") %>
18
+ <% end %>
19
+ </li>
20
+
21
+ <li>
22
+ <%= link_to "#unescaped-html", class: "diff-view-html", id:"unescaped-html" do %>
23
+ <%= t("versions.dropdown.option_unescaped") %>
24
+ <% end %>
25
+ </li>
26
+ </ul>
27
+ </li>
28
+ </ul>
29
+ </div>
30
+ </div>
31
+ <% end %>
@@ -5,7 +5,7 @@
5
5
 
6
6
  <div class="card">
7
7
  <div class="diff-data">
8
- <%= output_split_diff(data, direction) %>
8
+ <%= output_split_diff(data, direction, format) %>
9
9
  </div>
10
10
  </div>
11
11
  </div>
@@ -1,7 +1,7 @@
1
1
  <div class="mediumlarge-12 columns">
2
2
  <div class="card">
3
3
  <div class="diff-data">
4
- <%= output_unified_diff(data) %>
4
+ <%= output_unified_diff(data, format) %>
5
5
  </div>
6
6
  </div>
7
7
  </div>
@@ -1,4 +1,5 @@
1
1
  <%= render :diff_mode_dropdown %>
2
+ <%= render :diff_mode_html %>
2
3
 
3
4
  <% diff_data.each do |data| %>
4
5
  <%= attribute(data) %>
@@ -1,5 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
+ require "decidim/diffy_extension"
4
+
3
5
  module Decidim
4
6
  # This cell renders the diff between `:old_data` and `:new_data`.
5
7
  class DiffCell < Decidim::ViewModel
@@ -10,12 +12,12 @@ module Decidim
10
12
  render locals: { data: data }
11
13
  end
12
14
 
13
- def diff_unified(data)
14
- render locals: { data: data }
15
+ def diff_unified(data, format)
16
+ render locals: { data: data, format: format }
15
17
  end
16
18
 
17
- def diff_split(data, direction)
18
- render locals: { data: data, direction: direction }
19
+ def diff_split(data, direction, format)
20
+ render locals: { data: data, direction: direction, format: format }
19
21
  end
20
22
 
21
23
  private
@@ -25,6 +27,11 @@ module Decidim
25
27
  model
26
28
  end
27
29
 
30
+ # The item associated with the current_version.
31
+ def item
32
+ current_version.item
33
+ end
34
+
28
35
  # DiffRenderer class for the current_version's item; falls back to `BaseDiffRenderer`.
29
36
  def diff_renderer_class
30
37
  "#{current_version.item_type.deconstantize}::DiffRenderer".constantize
@@ -50,13 +57,13 @@ module Decidim
50
57
  # changes between lines.
51
58
  #
52
59
  # Returns an HTML-safe string.
53
- def output_unified_diff(data)
60
+ def output_unified_diff(data, format)
54
61
  Diffy::Diff.new(
55
62
  data[:old_value].to_s,
56
63
  data[:new_value].to_s,
57
64
  allow_empty_diff: false,
58
65
  include_plus_and_minus_in_html: true
59
- ).to_s(:html).html_safe
66
+ ).to_s(format)
60
67
  end
61
68
 
62
69
  # Outputs the diff as HTML with side-by-side changes between lines.
@@ -64,14 +71,20 @@ module Decidim
64
71
  # The left side represents deletions while the right side represents insertions.
65
72
  #
66
73
  # Returns an HTML-safe string.
67
- def output_split_diff(data, direction)
74
+ def output_split_diff(data, direction, format)
68
75
  Diffy::SplitDiff.new(
69
76
  data[:old_value].to_s,
70
77
  data[:new_value].to_s,
71
78
  allow_empty_diff: false,
72
- format: :html,
79
+ format: format,
73
80
  include_plus_and_minus_in_html: true
74
81
  ).send(direction)
75
82
  end
83
+
84
+ # Gives the option to view HTML unescaped for better user experience.
85
+ # Official means created from admin (where rich text editor is enabled).
86
+ def show_html_view_dropdown?
87
+ item.try(:official?) || current_organization.rich_text_editor_in_public_views?
88
+ end
76
89
  end
77
90
  end
@@ -2,16 +2,26 @@
2
2
  <% if current_user %>
3
3
  <% if current_user.follows?(model) %>
4
4
  <%= button_to decidim.follow_path, class: button_classes, params: { follow: { followable_gid: model.to_sgid.to_s, inline: inline? } }, data: { disable: true }, method: :delete, remote: true do %>
5
- <%= icon "bell", icon_options %>
6
- <span>
5
+ <span class="icon-wrap">
6
+ <%= icon "bell", icon_options %>
7
+ <%= model.followers.count %>
8
+ </span>
9
+ <span class="text-wrap">
7
10
  <%= t("follows.destroy.button", scope: "decidim") %>
8
11
  </span>
9
12
  <% end %>
10
13
  <% else %>
11
14
  <%= button_to decidim.follow_path, class: button_classes, params: { follow: { followable_gid: model.to_sgid.to_s, inline: inline? } }, data: { disable: true }, remote: true do %>
12
- <%= icon "bell", icon_options %>
13
- <span>
14
- <%= t("follows.create.button", scope: "decidim") %>
15
+ <span class="icon-wrap">
16
+ <%= icon "bell", icon_options %>
17
+ <%= model.followers.count %>
18
+ </span>
19
+ <span class="text-wrap">
20
+ <% if current_user.follows?(model.try(:participatory_space)) %>
21
+ <%= t("follows.create.participatory_space", scope: "decidim") %>
22
+ <% else %>
23
+ <%= t("follows.create.button", scope: "decidim") %>
24
+ <% end %>
15
25
  </span>
16
26
  <% end %>
17
27
  <% end %>
@@ -24,8 +34,11 @@
24
34
  :'aria-haspopup' => true,
25
35
  title: t("decidim.shared.follow_button.sign_in_before_follow"),
26
36
  remote: true) do %>
27
- <%= icon "bell", icon_options %>
28
- <span>
37
+ <span class="icon-wrap">
38
+ <%= icon "bell", icon_options %>
39
+ <%= model.followers.count %>
40
+ </span>
41
+ <span class="text-wrap">
29
42
  <%= t("follows.create.button", scope: "decidim") %>
30
43
  </span>
31
44
  <% end %>