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.
- checksums.yaml +4 -4
- data/app/assets/fonts/decidim/Roboto-Regular.eot +0 -0
- data/app/assets/fonts/decidim/Roboto-Regular.svg +10520 -0
- data/app/assets/fonts/decidim/Roboto-Regular.ttf +0 -0
- data/app/assets/fonts/decidim/Roboto-Regular.woff +0 -0
- data/app/assets/fonts/decidim/Roboto-Regular.woff2 +0 -0
- data/app/assets/images/decidim/brands/google.svg +1 -0
- data/app/assets/javascripts/decidim.js.es6 +5 -0
- data/app/assets/javascripts/decidim/check_boxes_tree.js.es6 +190 -0
- data/app/assets/javascripts/decidim/core/bundle.js +1 -1
- data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
- data/app/assets/javascripts/decidim/delayed.js.es6 +26 -0
- data/app/assets/javascripts/decidim/diff_mode_dropdown.js.es6 +25 -4
- data/app/assets/javascripts/decidim/form_filter.component.js.es6 +86 -38
- data/app/assets/javascripts/decidim/form_filter.component.test.js +40 -6
- data/app/assets/javascripts/decidim/history.js.es6 +16 -1
- data/app/assets/javascripts/decidim/vizzs/orgchart.js.es6 +1 -1
- data/app/assets/stylesheets/decidim/_variables.scss +1 -1
- data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +0 -1
- data/app/assets/stylesheets/decidim/modules/_buttons.scss +76 -3
- data/app/assets/stylesheets/decidim/modules/_comments.scss +78 -2
- data/app/assets/stylesheets/decidim/modules/_filters.scss +36 -2
- data/app/assets/stylesheets/decidim/modules/_layout.scss +13 -0
- data/app/assets/stylesheets/decidim/modules/_modules.scss +1 -0
- data/app/assets/stylesheets/decidim/modules/_navbar.scss +11 -5
- data/app/assets/stylesheets/decidim/modules/_process-stats.scss +53 -0
- data/app/assets/stylesheets/decidim/modules/_status-labels.scss +5 -0
- data/app/assets/stylesheets/decidim/modules/_tags.scss +7 -1
- data/app/assets/stylesheets/decidim/modules/_typography.scss +49 -4
- data/app/assets/stylesheets/decidim/utils/_fontface.scss +10 -0
- data/app/assets/stylesheets/decidim/utils/_toggle-expand.scss +14 -0
- data/app/cells/decidim/activity/show.erb +1 -1
- data/app/cells/decidim/author/profile_inline.erb +2 -2
- data/app/cells/decidim/diff/attribute.erb +15 -5
- data/app/cells/decidim/diff/diff_mode_html.erb +31 -0
- data/app/cells/decidim/diff/diff_split.erb +1 -1
- data/app/cells/decidim/diff/diff_unified.erb +1 -1
- data/app/cells/decidim/diff/show.erb +1 -0
- data/app/cells/decidim/diff_cell.rb +21 -8
- data/app/cells/decidim/follow_button/show.erb +20 -7
- data/app/cells/decidim/navbar_admin_link/show.erb +6 -0
- data/app/cells/decidim/navbar_admin_link_cell.rb +43 -0
- data/app/cells/decidim/tags_cell.rb +2 -2
- data/app/commands/decidim/amendable/accept.rb +9 -4
- data/app/commands/decidim/amendable/publish_draft.rb +5 -0
- data/app/commands/decidim/amendable/reject.rb +5 -0
- data/app/commands/decidim/amendable/withdraw.rb +3 -12
- data/app/commands/decidim/create_registration.rb +5 -6
- data/app/controllers/concerns/decidim/use_organization_time_zone.rb +32 -0
- data/app/controllers/decidim/application_controller.rb +3 -0
- data/app/controllers/decidim/components/base_controller.rb +1 -0
- data/app/controllers/decidim/data_portability_controller.rb +12 -19
- data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +1 -1
- data/app/controllers/decidim/devise/registrations_controller.rb +1 -0
- data/app/controllers/decidim/scopes_controller.rb +41 -7
- data/app/forms/decidim/registration_form.rb +5 -0
- data/app/functions/decidim/core/component_finder_base.rb +33 -0
- data/app/functions/decidim/core/component_list.rb +38 -0
- data/app/functions/decidim/core/component_list_base.rb +61 -0
- data/app/functions/decidim/core/needs_api_filter_and_order.rb +52 -0
- data/app/functions/decidim/core/participatory_space_finder.rb +11 -0
- data/app/functions/decidim/core/participatory_space_finder_base.rb +29 -0
- data/app/functions/decidim/core/participatory_space_list.rb +11 -0
- data/app/functions/decidim/core/participatory_space_list_base.rb +34 -0
- data/app/helpers/decidim/amendments_helper.rb +27 -1
- data/app/helpers/decidim/application_helper.rb +31 -3
- data/app/helpers/decidim/categories_helper.rb +26 -0
- data/app/helpers/decidim/check_boxes_tree_helper.rb +115 -0
- data/app/helpers/decidim/omniauth_helper.rb +6 -13
- data/app/helpers/decidim/resource_versions_helper.rb +29 -0
- data/app/helpers/decidim/rich_text_editor_helper.rb +22 -0
- data/app/helpers/decidim/sanitize_helper.rb +3 -1
- data/app/helpers/decidim/scopes_helper.rb +3 -2
- data/app/jobs/decidim/data_portability_export_job.rb +18 -10
- data/app/jobs/decidim/export_job.rb +1 -1
- data/app/mailers/decidim/export_mailer.rb +9 -5
- data/app/models/decidim/omniauth_provider.rb +28 -0
- data/app/models/decidim/organization.rb +41 -0
- data/app/models/decidim/participatory_space_role_config/admin.rb +8 -0
- data/app/models/decidim/participatory_space_role_config/base.rb +31 -0
- data/app/models/decidim/participatory_space_role_config/collaborator.rb +8 -0
- data/app/models/decidim/participatory_space_role_config/moderator.rb +11 -0
- data/app/models/decidim/participatory_space_role_config/null_object.rb +11 -0
- data/app/models/decidim/participatory_space_role_config/participatory_space_admin.rb +8 -0
- data/app/models/decidim/participatory_space_role_config/valuator.rb +11 -0
- data/app/models/decidim/scope.rb +4 -2
- data/app/models/decidim/user.rb +19 -3
- data/app/presenters/decidim/home_stats_presenter.rb +5 -2
- data/app/presenters/decidim/resource_locator_presenter.rb +9 -0
- data/app/serializers/decidim/exporters/participatory_space_components_serializer.rb +1 -1
- data/app/serializers/decidim/importers/participatory_space_components_importer.rb +14 -5
- data/app/services/decidim/data_portability_exporter.rb +72 -0
- data/app/services/decidim/resource_search.rb +29 -13
- data/app/services/decidim/zip_stream/zip_stream_writer.rb +56 -0
- data/app/types/decidim/core/amendment_type.rb +26 -0
- data/app/types/decidim/core/area_api_type.rb +16 -0
- data/app/types/decidim/core/area_type_type.rb +14 -0
- data/app/types/decidim/core/base_input_filter.rb +8 -0
- data/app/types/decidim/core/base_input_sort.rb +22 -0
- data/app/types/decidim/core/component_input_filter.rb +50 -0
- data/app/types/decidim/core/component_input_sort.rb +32 -0
- data/app/types/decidim/core/fingerprint_type.rb +15 -0
- data/app/types/decidim/core/has_hastaggable_input_filter.rb +15 -0
- data/app/types/decidim/core/has_localized_input_filter.rb +21 -0
- data/app/types/decidim/core/has_localized_input_sort.rb +21 -0
- data/app/types/decidim/core/has_publishable_input_filter.rb +34 -0
- data/app/types/decidim/core/has_publishable_input_sort.rb +13 -0
- data/app/types/decidim/core/participatory_space_input_filter.rb +26 -0
- data/app/types/decidim/core/participatory_space_input_sort.rb +14 -0
- data/app/types/decidim/core/participatory_space_link_type.rb +24 -0
- data/app/types/decidim/core/trace_version_type.rb +29 -0
- data/app/uploaders/decidim/data_portability_uploader.rb +2 -7
- data/app/validators/time_zone_validator.rb +10 -0
- data/app/views/decidim/amendments/_edit_form_fields.html.erb +5 -13
- data/app/views/decidim/amendments/preview_draft.html.erb +1 -1
- data/app/views/decidim/devise/shared/_omniauth_buttons.html.erb +10 -12
- data/app/views/decidim/devise/shared/_omniauth_buttons_mini.html.erb +6 -8
- data/app/views/decidim/export_mailer/data_portability_export.html.erb +2 -2
- data/app/views/decidim/scopes/picker.html.erb +7 -3
- data/app/views/decidim/shared/_check_boxes_tree.html.erb +54 -0
- data/app/views/decidim/shared/_extended_navigation_bar.html.erb +1 -1
- data/app/views/decidim/widgets/show.html.erb +4 -0
- data/app/views/layouts/decidim/_admin_links.html.erb +2 -0
- data/app/views/layouts/decidim/_wrapper.html.erb +4 -3
- data/app/views/layouts/decidim/widget.html.erb +1 -43
- data/config/initializers/browser.rb +5 -0
- data/config/initializers/devise.rb +0 -22
- data/config/initializers/omniauth.rb +50 -0
- data/config/locales/ar.yml +6 -3
- data/config/locales/ca.yml +15 -6
- data/config/locales/cs.yml +12 -3
- data/config/locales/de.yml +5 -3
- data/config/locales/el-GR.yml +0 -2
- data/config/locales/el.yml +153 -0
- data/config/locales/en.yml +16 -7
- data/config/locales/eo-UY.yml +2 -2
- data/config/locales/es-MX.yml +12 -3
- data/config/locales/es-PY.yml +12 -3
- data/config/locales/es.yml +15 -6
- data/config/locales/eu.yml +4 -3
- data/config/locales/fi-plain.yml +12 -3
- data/config/locales/fi.yml +12 -3
- data/config/locales/fr.yml +5 -3
- data/config/locales/gl.yml +4 -3
- data/config/locales/hu.yml +12 -3
- data/config/locales/id-ID.yml +4 -3
- data/config/locales/it.yml +11 -3
- data/config/locales/nl.yml +8 -3
- data/config/locales/no.yml +12 -3
- data/config/locales/pl.yml +4 -3
- data/config/locales/pt-BR.yml +4 -3
- data/config/locales/pt.yml +4 -3
- data/config/locales/ru.yml +5 -3
- data/config/locales/sv.yml +5 -3
- data/config/locales/tr-TR.yml +4 -3
- data/config/locales/uk.yml +1 -3
- data/db/migrate/20191113092826_add_omniauth_settings_to_decidim_organization.rb +7 -0
- data/db/migrate/20191113144432_add_rich_text_editor_in_public_views_to_organizations.rb +10 -0
- data/db/migrate/20191118123154_add_admin_terms_of_use_body_field_to_organization.rb +9 -0
- data/db/migrate/20200107142226_add_organization_timezone.rb +7 -0
- data/db/seeds.rb +2 -1
- data/lib/decidim/amendable.rb +7 -4
- data/lib/decidim/api/amendable_entity_interface.rb +18 -0
- data/lib/decidim/api/amendable_interface.rb +18 -0
- data/lib/decidim/api/attachable_interface.rb +1 -1
- data/lib/decidim/api/categorizable_interface.rb +1 -1
- data/lib/decidim/api/coauthorable_interface.rb +29 -0
- data/lib/decidim/api/fingerprint_interface.rb +13 -0
- data/lib/decidim/api/participatory_space_interface.rb +9 -9
- data/lib/decidim/api/participatory_space_resourceable_interface.rb +21 -0
- data/lib/decidim/api/scopable_interface.rb +1 -1
- data/lib/decidim/api/timestamps_interface.rb +21 -0
- data/lib/decidim/api/traceable_interface.rb +14 -0
- data/lib/decidim/coauthorable.rb +9 -2
- data/lib/decidim/component_manifest.rb +1 -1
- data/lib/decidim/content_processor.rb +4 -2
- data/lib/decidim/content_renderers/link_renderer.rb +1 -1
- data/lib/decidim/core.rb +3 -3
- data/lib/decidim/core/api.rb +7 -0
- data/lib/decidim/core/test.rb +1 -0
- data/lib/decidim/core/test/factories.rb +16 -0
- data/lib/decidim/core/test/shared_examples/amendable_interface_examples.rb +14 -0
- data/lib/decidim/core/test/shared_examples/amendable_proposals_interface_examples.rb +50 -0
- data/lib/decidim/core/test/shared_examples/authorable_interface_examples.rb +3 -0
- data/lib/decidim/core/test/shared_examples/coauthorable_interface_examples.rb +60 -0
- data/lib/decidim/core/test/shared_examples/comments_examples.rb +8 -8
- data/lib/decidim/core/test/shared_examples/fingerprintable_interface_examples.rb +17 -0
- data/lib/decidim/core/test/shared_examples/follows_examples.rb +16 -0
- data/lib/decidim/core/test/shared_examples/input_filter_examples.rb +118 -0
- data/lib/decidim/core/test/shared_examples/input_sort_examples.rb +105 -0
- data/lib/decidim/core/test/shared_examples/participatory_space_resourcable_interface_examples.rb +43 -0
- data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +59 -0
- data/lib/decidim/core/test/shared_examples/timestamps_interface_examples.rb +21 -0
- data/lib/decidim/core/test/shared_examples/traceable_interface_examples.rb +47 -0
- data/lib/decidim/core/version.rb +1 -1
- data/lib/decidim/deprecations.rb +19 -0
- data/lib/decidim/diffy_extension.rb +26 -0
- data/lib/decidim/exporters/export_manifest.rb +6 -2
- data/lib/decidim/filter_form_builder.rb +25 -7
- data/lib/decidim/form_builder.rb +2 -2
- data/lib/decidim/has_settings.rb +10 -4
- data/lib/decidim/participatory_space_manifest.rb +20 -0
- data/lib/decidim/participatory_space_resourceable.rb +35 -1
- data/lib/decidim/query_extensions.rb +9 -23
- data/lib/decidim/scopable.rb +10 -0
- data/lib/tasks/decidim_data_portability_tasks.rake +66 -5
- data/lib/tasks/decidim_metrics_tasks.rake +18 -7
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.el.js +14 -0
- metadata +142 -16
- data/app/models/decidim/participatory_process_user_role.rb +0 -32
- data/app/views/layouts/decidim/_edit_link.html.erb +0 -8
- data/lib/decidim/data_portability_file_reader.rb +0 -56
- data/lib/decidim/data_portability_file_zipper.rb +0 -67
@@ -348,12 +348,18 @@ $navbar-active-shadow-medium: inset 0 4px 0 0 var(--primary);
|
|
348
348
|
}
|
349
349
|
}
|
350
350
|
|
351
|
-
.
|
352
|
-
|
351
|
+
.topbar__admin__link{
|
352
|
+
a{
|
353
|
+
color: $medium-gray;
|
353
354
|
|
354
|
-
|
355
|
-
|
356
|
-
|
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
|
+
}
|
@@ -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:
|
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:
|
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(
|
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(
|
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
|
+
}
|
@@ -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:
|
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="
|
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="
|
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="
|
13
|
-
<%=
|
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 %>
|
@@ -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(
|
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:
|
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
|
-
|
6
|
-
|
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
|
-
|
13
|
-
|
14
|
-
<%=
|
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
|
-
|
28
|
-
|
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 %>
|