decidim-decidim_awesome 0.11.3 → 0.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +24 -6
  3. data/README.md +9 -25
  4. data/app/cells/decidim/decidim_awesome/voting/voting_cards_proposal/show.erb +1 -1
  5. data/app/cells/decidim/decidim_awesome/voting/voting_cards_proposal_cell.rb +3 -5
  6. data/app/commands/concerns/decidim/decidim_awesome/proposals/update_proposal_override.rb +1 -1
  7. data/app/commands/concerns/decidim/decidim_awesome/system/{register_organization_override.rb → create_organization_override.rb} +1 -1
  8. data/app/commands/concerns/decidim/decidim_awesome/update_account_override.rb +4 -4
  9. data/app/commands/decidim/decidim_awesome/admin/create_constraint.rb +1 -1
  10. data/app/commands/decidim/decidim_awesome/create_editor_image.rb +2 -2
  11. data/app/controllers/concerns/decidim/decidim_awesome/check_login_authorizations.rb +1 -1
  12. data/app/controllers/decidim/decidim_awesome/admin/checks_controller.rb +0 -6
  13. data/app/forms/concerns/decidim/decidim_awesome/proposals/{proposal_wizard_create_step_form_override.rb → proposal_form_customizations.rb} +1 -1
  14. data/app/forms/concerns/decidim/decidim_awesome/system/organization_form_override.rb +2 -2
  15. data/app/packs/entrypoints/decidim_admin_decidim_awesome_search_form.scss +1 -0
  16. data/app/packs/src/decidim/decidim_awesome/awesome_map/awesome_map.js +1 -1
  17. data/app/packs/stylesheets/decidim/decidim_awesome/admin/admin_accountability.scss +67 -0
  18. data/app/permissions/decidim/decidim_awesome/permissions.rb +3 -2
  19. data/app/uploaders/decidim/decidim_awesome/image_uploader.rb +12 -0
  20. data/app/views/decidim/decidim_awesome/admin/admin_accountability/index.html.erb +1 -0
  21. data/app/views/decidim/decidim_awesome/admin/shared/_filters_with_date.html.erb +41 -32
  22. data/app/views/decidim/decidim_awesome/map_component/map/_map_template.html.erb +1 -1
  23. data/config/assets.rb +2 -1
  24. data/config/locales/de.yml +79 -0
  25. data/lib/decidim/decidim_awesome/awesome.rb +22 -21
  26. data/lib/decidim/decidim_awesome/checksums.yml +32 -2
  27. data/lib/decidim/decidim_awesome/context_analyzers/request_analyzer.rb +2 -2
  28. data/lib/decidim/decidim_awesome/engine.rb +5 -4
  29. data/lib/decidim/decidim_awesome/test/shared_examples/box_label_editor_examples.rb +14 -14
  30. data/lib/decidim/decidim_awesome/test/shared_examples/config_examples.rb +1 -1
  31. data/lib/decidim/decidim_awesome/test/shared_examples/custom_fields_examples.rb +8 -8
  32. data/lib/decidim/decidim_awesome/test/shared_examples/custom_styles_examples.rb +6 -6
  33. data/lib/decidim/decidim_awesome/test/shared_examples/editor_examples.rb +3 -3
  34. data/lib/decidim/decidim_awesome/test/shared_examples/scoped_admins_examples.rb +5 -5
  35. data/lib/decidim/decidim_awesome/test/shared_examples/summary_examples.rb +8 -8
  36. data/lib/decidim/decidim_awesome/version.rb +2 -2
  37. data/lib/decidim/decidim_awesome.rb +0 -1
  38. data/lib/tasks/decidim_awesome_upgrade_tasks.rake +0 -4
  39. data/package.json +8 -16
  40. metadata +20 -19
  41. data/app/jobs/decidim/decidim_awesome/migrate_legacy_images_job.rb +0 -107
  42. data/app/uploaders/decidim/cw/decidim_awesome/image_uploader.rb +0 -26
  43. data/lib/decidim/decidim_awesome/content_parsers/editor_images_parser.rb +0 -39
  44. data/lib/tasks/decidim_awesome_active_storage_migrations_tasks.rake +0 -35
  45. /data/{app/middleware/decidim/decidim_awesome → lib/decidim/decidim_awesome/middleware}/current_config.rb +0 -0
@@ -7,6 +7,9 @@ de:
7
7
  allow_images_in_proposals: Bilder im Vorschlags-Editor erlauben
8
8
  allow_videos_in_editors: Videos im HTML-Editor erlauben
9
9
  auto_save_forms: Formulare automatisch lokal speichern
10
+ force_authorization_after_login: Autorisierung nach Anmelden/Registrierung erzwingen
11
+ force_authorization_help_text: Hilfetext für die Autorisierungsseite
12
+ force_authorization_with_any_method: Erlaube Zugriff, wenn eine der Genehmigungen erteilt wird (standardmäßig sind alle erforderlich)
10
13
  intergram_auto_no_response: Diese Nachricht wird verschickt, sobald eine Minute seit der letzten vom Benutzer verfasste Nachricht verschickt wurde und keine Antwort eingetroffen ist
11
14
  intergram_auto_response: Eine Nachricht, die unmittelbar nach dem Senden der ersten Nachricht des Benutzers gesendet wird
12
15
  intergram_chat_id: Chat ID
@@ -19,6 +22,7 @@ de:
19
22
  intergram_use_floating_button: Wenn aktiviert, ist der geschlossene Chat immer ein Button statt eines Textes
20
23
  proposal_custom_fields: 'Eingabefeld #%{id}'
21
24
  proposal_private_custom_fields: 'Privates Eingabefeld #%{id}'
25
+ scoped_admin_styles: Eigene Styles %{id}
22
26
  scoped_admins: Eingeschränkte Admin-Gruppe %{id}
23
27
  scoped_styles: Eigene Eingabefelder %{id}
24
28
  user_timezone: Erlauben Sie Benutzern, ihre Zeitzone in ihrem Profil einzustellen
@@ -47,6 +51,8 @@ de:
47
51
  target: Öffnet in
48
52
  url: URL
49
53
  visibility: Sichtbarkeit
54
+ organization:
55
+ awesome_admins_available_authorizations: Administratoren erlauben, Benutzer mit diesen Berechtigungen manuell zu verifizieren
50
56
  user:
51
57
  user_time_zone: Eigene Zeitzone
52
58
  decidim:
@@ -176,6 +182,26 @@ de:
176
182
  collaborator: Mitarbeiter
177
183
  moderator: Moderator
178
184
  valuator: Schätzer
185
+ admin_authorizations:
186
+ authorization:
187
+ confirm_destroy: Sind Sie sicher, dass Sie diese Berechtigung löschen möchten? Dies kann den Zugriff des Benutzers auf die Plattform beeinflussen.
188
+ destroy: Löschen
189
+ granted_at: Bewilligt am %{date}
190
+ metadata: Enthält Metadaten? %{metadata}
191
+ authorization_destroyed: Autorisierung erfolgreich gelöscht.
192
+ authorization_not_destroyed: Autorisierung konnte nicht gelöscht werden!
193
+ authorization_transferred: 'Warnung: Es gab einen Verifizierungskonflikt und die Verifizierung wurde an %{user} übertragen'
194
+ conflict: Es gibt einen Konflikt mit einer bestehenden Autorisierung
195
+ conflict_help_html: "Sie müssen den Konflikt mit dem Benutzer %{user} lösen, bevor Sie den Benutzer mit dieser Berechtigung autorisieren können.\n<br><br>\nEin Verifizierungskonflikt tritt auf, wenn ein anderer Benutzer die gleichen Daten hat wie der Benutzer, den Sie autorisieren möchten. \nSie können diesen Konflikt lösen, indem Sie die widersprüchliche Autorisierung des anderen Benutzers entfernen oder andere Daten für diesen Benutzer verwenden.\n"
196
+ edit:
197
+ authorize: '%{user} mit %{name} autorisieren'
198
+ do_it_if_sure: Tun Sie dies nur, wenn Sie sicher sind, dass der Benutzer diese Berechtigung hat.
199
+ force_verification: Verifizierung mit den aktuellen Daten erzwingen
200
+ force_verification_help: Überprüfung ist fehlgeschlagen, aber Sie können sie erzwingen, wenn Sie sicher sind, dass der Benutzer diese Berechtigung hat.
201
+ force_verification_reason: 'Geben Sie einen Grund an, um die Überprüfung zu erzwingen:'
202
+ warning: 'Warnung: Indem Sie diese Autorisierung erzwingen, überschreiben Sie den aktuellen Autorisierungsstatus des Benutzers.'
203
+ user_authorized: "%{user} erfolgreich autorisiert mit %{name}"
204
+ user_not_authorized: "%{user} konnte nicht mit %{name} autorisiert werden"
179
205
  checks:
180
206
  index:
181
207
  admin_head_tags: Angezeigte Awesome Tags im Admin Application Header
@@ -236,6 +262,8 @@ de:
236
262
  allow_videos_in_editors: Dies fügt ein Video-Upload-Symbol in allen WYSIWYG-Editoren hinzu
237
263
  auto_save_forms: Formulare automatisch speichern
238
264
  drag_and_drop_supported: Drag and Drop unterstützen
265
+ force_authorization_after_login: 'Wenn aktiviert, werden Benutzer nach Login oder Registrierung auf die Autorisierungsseite weitergeleitet, wenn einige der angegebenen Autorisierungen nicht gewährt werden. Dies ist nützlich, wenn Sie Benutzer mit einer bestimmten Berechtigung verifizieren wollen, bevor sie sich überhaupt einloggen können (z. B. um Spam zu verhindern).'
266
+ force_authorization_help_text: Fügen Sie einen benutzerdefinierten Text hinzu, um zu erklären, warum eine Autorisierung erforderlich ist. Stellen Sie auch sicher, dass Sie eine Kontaktmethode hinzufügen, falls Benutzer Hilfe benötigen.
239
267
  intergram_about: Über Intergram
240
268
  intergram_config: Intergram Konfiguration
241
269
  original_editor_override: Seit Version 0.26 ist es für Administratoren möglich Bilder in die Editoren hochzuladen. Daher betreffen die Bildeinstellungen hier nur die öffentlich sichtbaren Editoren. Administratoren steht diese Funktion immer zur Verfügung.
@@ -248,6 +276,9 @@ de:
248
276
  %{warning}
249
277
  Dieser Text kann mit einer benutzerdefinierten Übersetzung durch Verwendung des Schlüssels angepasst werden:
250
278
  %{key}
279
+ scoped_admin_styles: Seien Sie sich bewusst, dass das Verstecken von Dingen den Administrator unbrauchbar machen könnte. Bitte handeln Sie mit Vorsicht.
280
+ scoped_admin_styles_variables: 'Sie können die folgenden CSS-Variablen für die benutzerdefinierter Farben der Organisation verwenden:'
281
+ scoped_admin_styles_warning: "<strong>Warnung</strong>: Fügen Sie hier benutzerdefiniertes CSS hinzu, das nur in diesem Admin-Backend gilt."
251
282
  scoped_admins: Befördern Sie normale Benutzer zu Administratoren, die nur bestimmte Teile der öffentlichen Seite verwalten können (verwenden Sie dazu den Editor für Einschränkungen). Beachten Sie, dass Benutzer, die bereits reguläre Administratorrechte haben, ignoriert werden. For instance, if having configured /my-origin => /my-destination, a request to /my-origin?locale=ca will be redirected to "/my-destination?locale=ca".
252
283
  scoped_styles: Erstellen Sie benutzerdefinierte CSS, die nur in bestimmten Bereichen der öffentlichen Seite gelten (vewenden Sie dazu die Einschränkungen)
253
284
  scoped_styles_variables: 'Sie können die folgenden CSS-Variablen für die benutzerdefinierter Farben der Organisation verwenden:'
@@ -258,6 +289,10 @@ de:
258
289
  validate_title_max_caps_percent: 0 lässt keinen Großbuchstaben zu, 100 lässt ausschliesslich Großbuchstaben zu
259
290
  validate_title_max_marks_together: 'Begrenzt die Anzahl der Frage- und Ausrufezeichen, die zusammen geschrieben werden können. Zum Beispiel: Der Wert 2 führt dazu, dass ''!!!'' im Text nicht erlaubt ist'
260
291
  validate_title_min_length: Der Titel ist immer obligatorisch und diese Zahl kann nicht Null sein
292
+ verifications_html: |
293
+ Hier können Sie einige Änderungen am Verifizierungsprozess vornehmen.<br>
294
+ <b>HINWEIS:</b> Beachten Sie, dass das Ändern dieser Einstellungen einige Benutzer am Zugriff auf die Plattform hindern könnte. Verwenden Sie es mit Vorsicht!<br><br>
295
+ Beachten Sie auch, dass diese Einstellungen auf alle Benutzer angewendet werden. Administratoren haben jedoch immer Zugriff auf das Admin-Backend.
261
296
  validators:
262
297
  body: Eingabevalidierungen für das Feld "Textkörper"
263
298
  title: Eingabevalidierungen für das Feld "Titel"
@@ -271,6 +306,11 @@ de:
271
306
  new: Neues privates Eingabefeld hinzufügen
272
307
  remove: Privates Eingabefeld entfernen
273
308
  sure_to_remove: Bist du sicher, dass du dieses private Eingabefeld entfernen möchtest?
309
+ form_scoped_admin_styles:
310
+ delete: Löschen
311
+ new: Füge ein neues "Admin-Panel" CSS-Feld hinzu
312
+ remove: CSS Box entfernen
313
+ sure_to_remove: Sind Sie sicher, dass Sie diese CSS-Box entfernen möchten?
274
314
  form_scoped_admins:
275
315
  delete: Löschen
276
316
  new: Hinzufügen einer neuen "Eingeschränkte Admins"-Gruppe
@@ -294,8 +334,11 @@ de:
294
334
  proposal_custom_fields: 'Benutzerdefinierte Felder: Öffentliche Felder'
295
335
  proposal_private_custom_fields: 'Benutzerdefinierte Felder: Private Felder'
296
336
  proposals: Vorschläge
337
+ scoped_admin_styles: 'Benutzerdefinierte Stile: Admin-Panel'
338
+ scoped_styles: 'Benutzerdefinierte Stile: Öffentliches Frontend'
297
339
  styles: Eigene Styles
298
340
  surveys: Umfragen
341
+ verifications: Überprüfungen / Autorisierungshacks
299
342
  update:
300
343
  error: Fehler beim Aktualisieren der Konfiguration! %{error}
301
344
  success: Konfiguration erfolgreich aktualisiert
@@ -395,6 +438,7 @@ de:
395
438
  proposals: Vorschläge
396
439
  styles: Eigene Styles
397
440
  surveys: Umfragen
441
+ verifications: Verifizierungen
398
442
  menu_hacks:
399
443
  create:
400
444
  error: Fehler beim Erstellen des Menüpunkts! %{error}
@@ -433,6 +477,11 @@ de:
433
477
  error: Fehler beim Aktualisieren des Menüpunkts! %{error}
434
478
  success: Menüpunkt erfolgreich aktualisiert
435
479
  url_exists: Die gleiche URL ist bereits konfiguriert. bitte bearbeiten Sie diese, anstatt sie neu zu erstellen.
480
+ officializations:
481
+ authorizations: Autorisierungen
482
+ verification_modal:
483
+ authorizations_for: Autorisierungen für %{user}
484
+ close: Schliessen
436
485
  proposal_custom_fields:
437
486
  menu:
438
487
  title: Öffentlich sichtbare Felder
@@ -441,9 +490,19 @@ de:
441
490
  private_data_last_update: Diese Daten wurden vor %{time_ago} gelöscht.
442
491
  proposal_private_custom_fields: Private Felder
443
492
  remove_private_data: "👉 Sie können es entfernen"
493
+ scoped_admin_styles:
494
+ menu:
495
+ title: Admin Panel
496
+ scoped_styles:
497
+ menu:
498
+ title: Öffentliches Frontend
444
499
  admin_log:
445
500
  component:
446
501
  destroy_private_data: "%{user_name} hat %{count} private Daten für %{resource_name} in %{space_name} gelöscht"
502
+ user:
503
+ admin_creates_authorization: "%{user_name} verifizierte %{resource_name} mit %{handler_name}"
504
+ admin_destroys_authorization: "%{user_name} hat die Verifizierung %{handler_name} auf %{resource_name} gelöscht"
505
+ admin_forces_authorization: "%{user_name} erzwang die Verifizierung %{handler_name} auf %{resource_name}. Grund: %{reason}"
447
506
  amendments:
448
507
  modal:
449
508
  amendment_exists: Eine Änderung existiert bereits
@@ -500,6 +559,26 @@ de:
500
559
  view_meeting: Sitzung ansehen
501
560
  view_proposal: Vorschlag ansehen
502
561
  proposal_private_custom_fields_disclosure: Diese Informationen werden nicht veröffentlicht
562
+ required_authorizations:
563
+ index:
564
+ cancel: Ich werde das in einem anderen Moment tun, %{link}.
565
+ granted_title: Gewährte Verifizierungen
566
+ logout: abmelden lassen
567
+ missing_title: Noch nicht verifiziert
568
+ resume_title: Ausstehende Verifizierungen
569
+ resume_with_method: Verifizierung mit %{name} fortsetzen
570
+ title: Verifizieren Sie Ihre Identität
571
+ verify_with_all_these_options: 'Bitte verifizieren Sie sich mit all diesen Methoden, bevor Sie auf die Plattform zugreifen können:'
572
+ verify_with_any_of_these_options: 'Bitte verifizieren Sie sich mit mindestens einer dieser Optionen, bevor Sie auf die Plattform zugreifen können:'
573
+ verify_with_method: Mit %{name} verifizieren
574
+ session:
575
+ authorization_is_required: Um an dieser Plattform teilzunehmen, müssen Sie Ihr Konto mit einer gültigen Berechtigung autorisieren (%{authorizations}).
576
+ system:
577
+ organizations:
578
+ admin_allowed_authoritzations_help_html: |
579
+ Admins können Benutzer mit diesen Berechtigungen manuell verifizieren.
580
+ <br>Diese Funktion mit Vorsicht nutzen, da dies zu Sicherheitsproblemen führen kann.
581
+ awesome_tweaks: Decidim Awesome Optimierungen
503
582
  validators:
504
583
  too_much_caps: Es werden zu viele Großbuchstaben verwendet (über %{percent}% des Textes)
505
584
  voting:
@@ -132,7 +132,7 @@ module Decidim
132
132
  # allows admins to created specific CSS snippets affecting only some public frontend specific parts
133
133
  # Valid values differ a little from the previous convention:
134
134
  # :disabled => false and non available, hidden from admins
135
- # Hash => hash of different css text, each key will be used for the contraints
135
+ # Hash => hash of different css text, each key will be used for the constraints
136
136
  # Admins create this hash dynamically but some pre-defined css boxes can be created here as:
137
137
  # {
138
138
  # some_identifier: ".wrapper { background: red; }"
@@ -144,7 +144,7 @@ module Decidim
144
144
  # allows admins to created specific CSS snippets affecting only some admin specific parts
145
145
  # Valid values differ a little from the previous convention:
146
146
  # :disabled => false and non available, hidden from admins
147
- # Hash => hash of different css text, each key will be used for the contraints
147
+ # Hash => hash of different css text, each key will be used for the constraints
148
148
  # Admins create this hash dynamically but some pre-defined css boxes can be created here as:
149
149
  # {
150
150
  # some_identifier: ".wrapper { background: red; }"
@@ -157,7 +157,7 @@ module Decidim
157
157
  # https://github.com/jsonform/jsonform/wiki
158
158
  # Valid values uses the same structure as :scoped_styles
159
159
  # :disabled => false and non available, hidden from admins
160
- # Hash => hash of different JSON texts, each key will be used for the contraints
160
+ # Hash => hash of different JSON texts, each key will be used for the constraints
161
161
  # Admins can create this hash dynamically but some pre-defined css boxes can be created here as:
162
162
  # {
163
163
  # some_identifier: "{ ... some definition... }"
@@ -173,14 +173,14 @@ module Decidim
173
173
 
174
174
  # whether to add a select to user's profile to allow them to select their preferred time zone
175
175
  # if set to false, the select won't be shown but it can still be configured by the admins
176
- # if set to :disabled the feature will be completly removed
176
+ # if set to :disabled the feature will be completely removed
177
177
  config_accessor :user_timezone do
178
178
  false
179
179
  end
180
180
 
181
181
  # Forces the user to authorize using some registered verification flow in order to access the platform
182
182
  # if set to an empty array, the user will be able to access the platform without any verification but admins can still enforce it
183
- # if set to :disabled the feature will be completly removed
183
+ # if set to :disabled the feature will be completely removed
184
184
  # You can initialize some default verification workflow manifests
185
185
  config_accessor :force_authorization_after_login do
186
186
  []
@@ -199,14 +199,15 @@ module Decidim
199
199
 
200
200
  # Allows admins to manually authorize users with the specified methods
201
201
  # if set to an empty array, the admins will not be able to authorize users but the system admin can still configure it
202
- # if set to :disabled the feature will be completly removed
202
+ # if set to :disabled the feature will be completely removed
203
203
  config_accessor :admins_available_authorizations do
204
204
  []
205
205
  end
206
206
 
207
207
  # This controllers will be skipped from the authorization check
208
+ # Included automatically: required_authorizations authorizations upload_validations timeouts editor_images locales pages tos
208
209
  config_accessor :force_authorization_allowed_controller_names do
209
- %w(account pages)
210
+ %w(account)
210
211
  end
211
212
 
212
213
  # How old must be the private data to be considered expired and therefore presented to the admins for deletion
@@ -220,7 +221,7 @@ module Decidim
220
221
  end
221
222
 
222
223
  # allows to keep modifications for the main menu
223
- # can return :disabled to completly remove this feature
224
+ # can return :disabled to completely remove this feature
224
225
  # otherwise it should be an array (some overrides can be specified by default):
225
226
  # [
226
227
  # {
@@ -237,16 +238,16 @@ module Decidim
237
238
  []
238
239
  end
239
240
 
240
- # Allows admins to assignate "fake" admins scoped to some admin zones using the
241
+ # Allows admins to assign "fake" admins scoped to some admin zones using the
241
242
  # same scope editor as :scoped_styles, valid values uses the same convention:
242
243
  # :disabled => false and non available, hidden from admins
243
- # Hash => hash of different admin ids, each key will be used for the contraints
244
+ # Hash => hash of different admin ids, each key will be used for the constraints
244
245
  # Admins create this hash dynamically but some pre-defined admin boxes can be created here as:
245
246
  # {
246
247
  # some_identifier: [1234, 5678, 90123]
247
248
  # }
248
249
  #
249
- # To test this feature in development, ensure that config/environmnets/development.rb is configured as:
250
+ # To test this feature in development, ensure that config/environments/development.rb is configured as:
250
251
  # config.action_dispatch.show_exceptions = true
251
252
  # config.action_dispatch.show_detailed_exceptions = false
252
253
  # config.consider_all_requests_local = false
@@ -255,13 +256,13 @@ module Decidim
255
256
  end
256
257
 
257
258
  # Allow to configure custom redirections
258
- # can return :disabled to completly remove this feature
259
+ # can return :disabled to completely remove this feature
259
260
  # You can initialize some default redirection if desired as follows:
260
261
  # {
261
262
  # "/decidim-docs" => { destination: "http://docs.decidim.org", active: true }
262
263
  # }
263
264
  #
264
- # To test this feature in development, ensure that config/environmnets/development.rb is configured as:
265
+ # To test this feature in development, ensure that config/environments/development.rb is configured as:
265
266
  # config.action_dispatch.show_exceptions = true
266
267
  # config.action_dispatch.show_detailed_exceptions = false
267
268
  # config.consider_all_requests_local = false
@@ -307,20 +308,20 @@ module Decidim
307
308
  # additional correspondences between participatory spaces manifests and routes
308
309
  # ie: /admin/assemblies and /admin/assemblies_types are both treated as a "assembly" participatory space in terms of permission scoping
309
310
  # This can be tuned in a initialized if some other hacks over routes are applied
310
- # if a registered participatory space is not listed here then the name manifest will be used as a default route /manifest_name /admin/manifes_name
311
+ # if a registered participatory space is not listed here then the name manifest will be used as a default route /manifest_name /admin/manifest_name
311
312
  config_accessor :participatory_spaces_routes_context do
312
313
  {
313
- # route in admin is diferent than in the frontend: /processes, /admin/participatory_processes
314
+ # route in admin is different than in the frontend: /processes, /admin/participatory_processes
314
315
  participatory_processes: [:participatory_processes, :processes],
315
316
  # both /admin/assemblies and /admin/assemblies_types are considered assemblies
316
317
  assemblies: [:assemblies, :assemblies_types],
317
- # route in admin is diferent than in the frontend: /process_groups, /admin/participatory_process_groups
318
+ # route in admin is different than in the frontend: /process_groups, /admin/participatory_process_groups
318
319
  process_groups: [:processes_groups, :participatory_process_groups]
319
320
  }
320
321
  end
321
322
 
322
323
  # If true, enables a new section in "Participants" where to audit all the admin roles that have been enabled/disabled historically in Decidim
323
- # Set to :disabled to completly remove this feature
324
+ # Set to :disabled to completely remove this feature
324
325
  config_accessor :admin_accountability do
325
326
  [:participatory_space_roles, :admin_roles]
326
327
  end
@@ -336,7 +337,7 @@ module Decidim
336
337
 
337
338
  # Which components will be tampered to add the voting registry override
338
339
  config_accessor :voting_components do
339
- [:proposals, :reporting_propposals]
340
+ [:proposals, :reporting_proposals]
340
341
  end
341
342
 
342
343
  # A URL where to obtain the translations for the FormBuilder component
@@ -377,7 +378,7 @@ module Decidim
377
378
 
378
379
  # prepends to a hash a new value in a specified position so that the hash becomes:
379
380
  # { a: 1, b: 2, c: 3 } => prepend_hash(hash, :b, :d, 4) => { a: 1, d: 4, b: 2, c: 3 }
380
- # if key is not found then it will be inserted at the beggining
381
+ # if key is not found then it will be inserted at the beginning
381
382
  def self.hash_prepend!(hash, before_key, key, value)
382
383
  insert_at = hash.to_a.index(hash.assoc(before_key))
383
384
  insert_at = 0 if insert_at.nil?
@@ -411,9 +412,9 @@ module Decidim
411
412
  registered_components << [manifest, block]
412
413
  end
413
414
 
414
- # version 0.11 is compatible only with decidim 0.28
415
+ # version 0.12 is compatible only with decidim 0.29
415
416
  def self.legacy_version?
416
- # Decidim.version[0..3] == "0.28"
417
+ # Decidim.version[0..3] == "0.29"
417
418
  false
418
419
  end
419
420
  end
@@ -3,73 +3,103 @@ decidim-admin:
3
3
  decidim-0.28: 25bf272ac5a70eb8a975f4889fa46095
4
4
  decidim-0.28.c4d3889: 6391da1f357f9b260622ddd404a47987
5
5
  decidim-0.28.1: b2ae319d5bcf43954bbe0edb9a4e3ffb
6
+ decidim-0.29.1: b2ae319d5bcf43954bbe0edb9a4e3ffb
6
7
  decidim-core:
7
8
  /app/packs/entrypoints/decidim_editor.js:
8
9
  decidim-0.28: beddd77e3893fd0b7cd2679a7ee6e536
10
+ decidim-0.29.1: beddd77e3893fd0b7cd2679a7ee6e536
9
11
  /app/packs/src/decidim/editor/index.js:
10
12
  decidim-0.28: 90dfac3acae97202dec083955e2249e4
13
+ decidim-0.29.1: 90dfac3acae97202dec083955e2249e4
11
14
  /app/validators/etiquette_validator.rb:
12
15
  decidim-0.28: e9ad91d824ad48ac2075a088a0d21349
16
+ decidim-0.29.1: e9ad91d824ad48ac2075a088a0d21349
13
17
  /app/views/layouts/decidim/_head.html.erb:
14
18
  decidim-0.28: e51e400a98821f4ca0fff26ebd4d0741
15
19
  decidim-0.28.1: 8ac1af4e223d9a7a98136760b6194a75
16
20
  decidim-0.28.4: 59abccd8b1c5315d5c0b772be0c26d45
21
+ decidim-0.29.1: 8ac1af4e223d9a7a98136760b6194a75
17
22
  /app/views/layouts/decidim/_decidim_javascript.html.erb:
18
23
  decidim-0.28: dc60ed8abf7649611f18804b67b1408d
24
+ decidim-0.29.1: 8d51790de859ee66f305d9111cdfb324
19
25
  /app/presenters/decidim/menu_presenter.rb:
20
26
  decidim-0.28: 220c8865a43bd8b7b12a7f926f7f4324
27
+ decidim-0.29.1: 220c8865a43bd8b7b12a7f926f7f4324
21
28
  /app/presenters/decidim/menu_item_presenter.rb:
22
29
  decidim-0.28: 4e4cd366a8a313079ac5fab466bd3679
23
30
  decidim-0.28.4: f04f0f5112499a86079119d5f9ae8487
31
+ decidim-0.29.1: f04f0f5112499a86079119d5f9ae8487
24
32
  /app/helpers/decidim/amendments_helper.rb:
25
33
  decidim-0.28: df28f9321d1bc07757746ed608274e3d
34
+ decidim-0.29.1: 36072334cba7a58841a6b2fb007d24a6
26
35
  /app/presenters/decidim/admin_log/component_presenter.rb:
27
36
  decidim-0.28: 77e80d527727acdf117a0c4517a69a7c
37
+ decidim-0.29.1: 77e80d527727acdf117a0c4517a69a7c
28
38
  /app/forms/decidim/account_form.rb:
29
39
  decidim-0.28: 11a022ae6ae18ad89da168bec4207935
40
+ decidim-0.29.1: 11a022ae6ae18ad89da168bec4207935
30
41
  /app/commands/decidim/update_account.rb:
31
42
  decidim-0.28: 363872116fb99372c046b7394d618333
43
+ decidim-0.29.1: d24090fdd9358c38e6e15c4607a78e18
32
44
  /app/views/decidim/account/show.html.erb:
33
45
  decidim-0.28: a0647f1740d696018f73ec8db8c7587a
46
+ decidim-0.29.1: f13218e2358a2d611996c2a197c0de25
34
47
  decidim-proposals:
35
48
  /lib/decidim/proposals/proposal_serializer.rb:
36
49
  decidim-0.28: bbd33bdc60defb734b3fb814666bb622
37
50
  decidim-0.28.1: 7bd5cadb1127a4e81bd5f333670351bd
38
51
  decidim-0.28.2: ab146c54850a4486d96cf50211679671
52
+ decidim-0.29.1: 58915ff3a7528463587d3762a93ff51b
39
53
  /lib/decidim/api/proposal_type.rb:
40
54
  decidim-0.26: e38e4875e408ec4f658e28725c5a94d4
41
- /app/forms/decidim/proposals/proposal_wizard_create_step_form.rb:
42
- decidim-0.27: b495d37088ecebcbe4ac9563bb3498d5
55
+ decidim-0.29.1: 25d61a67a4b969ac8c472237d3f64b66
56
+ /app/forms/decidim/proposals/proposal_form.rb:
57
+ decidim-0.29.1: 0b19bfeb4f7bd15cd378a69c3935de6b
43
58
  /app/forms/decidim/proposals/admin/proposal_form.rb:
44
59
  decidim-0.28: 422632395194b19beed4c7c65f127ff5
60
+ decidim-0.29.1: 422632395194b19beed4c7c65f127ff5
45
61
  /app/helpers/decidim/proposals/application_helper.rb:
46
62
  decidim-0.28: 89df14045349cc2eaaec78f79f6140b1
47
63
  decidim-0.28.2: 317b0347528e697fa405a792bcfa3db8
64
+ decidim-0.29.1: 940488938f644b63a2ef6177f3757ca2
48
65
  /app/controllers/decidim/proposals/proposal_votes_controller.rb:
49
66
  decidim-0.28: f983e72c1ee8d31222d537533c762cd2
67
+ decidim-0.29.1: f983e72c1ee8d31222d537533c762cd2
50
68
  /app/views/decidim/proposals/admin/proposals/_form.html.erb:
51
69
  decidim-0.28: 824463b320562c15fdb530bfebbf2f0f
70
+ decidim-0.29.1: 667c2ef6ffbf3369f59bd1e8eb0ba421
52
71
  /app/views/decidim/proposals/proposals/_vote_button.html.erb:
53
72
  decidim-0.27: 3d087d807238f33b71e6b385db8ffc70
73
+ decidim-0.29.1: 06dd4c9bf7fc4953fc330b7ba081b2f6
54
74
  /app/views/decidim/proposals/proposals/_votes_count.html.erb:
55
75
  decidim-0.27: 6e663e5c82c27291b63f29f346df8737
76
+ decidim-0.29.1: 6e663e5c82c27291b63f29f346df8737
56
77
  /app/cells/decidim/proposals/proposal_l_cell.rb:
57
78
  decidim-0.27.4: 5e111ed30bca9475bed8247e5e056747
58
79
  decidim-0.28.3: 6d955d56d9d9f0cba46ba157fa923cfc
80
+ decidim-0.29.1: e38d1cd0ea6c7f14c8f8b56d3ceb0db5
59
81
  /app/cells/decidim/proposals/proposal_metadata_cell.rb:
60
82
  decidim-0.26: eedfd7f813aedbd819b519e03ae4a680
83
+ decidim-0.29.1: 6859b77805227c4cf71ae0a1351a4551
61
84
  /app/commands/decidim/proposals/create_proposal.rb:
62
85
  decidim-0.28: 95c7bba44dbe477abdfbf450b7eee258
86
+ decidim-0.29.1: 02a6f54a032457e68be580e6a539c47b
63
87
  /app/commands/decidim/proposals/create_collaborative_draft.rb:
64
88
  decidim-0.28: ab3f937f15c6ed945e776fef34b18abf
89
+ decidim-0.29.1: ab3f937f15c6ed945e776fef34b18abf
65
90
  /app/commands/decidim/proposals/admin/create_proposal.rb:
66
91
  decidim-0.28: aa0c093cb10b3ccfb046edd0018eae1d
67
92
  decidim-0.28.3: 8d73a8c852f473c118f978ddfab323b1
93
+ decidim-0.29.1: 837d86d2eb1f2d7579a0cef82d68caf7
68
94
  /app/commands/decidim/proposals/update_proposal.rb:
69
95
  decidim-0.28: 1cc15b946512f4d5a54d1cf5aea8450a
96
+ decidim-0.29.1: e81268a1f9b3770387944d44d7704291
70
97
  /app/commands/decidim/proposals/update_collaborative_draft.rb:
71
98
  decidim-0.28: 7df5266382bd57db72832da391fe7e11
99
+ decidim-0.29.1: 7df5266382bd57db72832da391fe7e11
72
100
  /app/commands/decidim/proposals/admin/update_proposal.rb:
73
101
  decidim-0.28: 67b691b6d1ce61cb198592ac25f76f74
102
+ decidim-0.29.1: 67b691b6d1ce61cb198592ac25f76f74
74
103
  /app/presenters/decidim/proposals/proposal_presenter.rb:
75
104
  decidim-0.28: 72910541010305f25baf297f4a58497b
105
+ decidim-0.29.1: bbc7cee02125c1f8cf909219e48af337
@@ -14,8 +14,8 @@ module Decidim
14
14
 
15
15
  # In the frontend there's no a 100% correspondence between url and manifest name
16
16
  def participatory_spaces_routes
17
- spaces = Decidim.participatory_space_manifests \
18
- .filter { |space| !DecidimAwesome.config.participatory_spaces_routes_context.has_key?(space.name) } \
17
+ spaces = Decidim.participatory_space_manifests
18
+ .filter { |space| !DecidimAwesome.config.participatory_spaces_routes_context.has_key?(space.name) }
19
19
  .to_h { |space| [space.name.to_s, space.name.to_s] }
20
20
  DecidimAwesome.config.participatory_spaces_routes_context.each do |manifest, routes|
21
21
  routes.each do |route|
@@ -5,6 +5,7 @@ require "deface"
5
5
  require "decidim/core"
6
6
  require "decidim/decidim_awesome/awesome_helpers"
7
7
  require "decidim/decidim_awesome/menu"
8
+ require "decidim/decidim_awesome/middleware/current_config"
8
9
 
9
10
  module Decidim
10
11
  module DecidimAwesome
@@ -47,11 +48,11 @@ module Decidim
47
48
  :validate_body_max_caps_percent,
48
49
  :validate_body_max_marks_together,
49
50
  :validate_body_start_with_caps)
50
- Decidim::Proposals::ProposalWizardCreateStepForm.include(Decidim::DecidimAwesome::Proposals::ProposalWizardCreateStepFormOverride)
51
+ Decidim::Proposals::ProposalForm.include(Decidim::DecidimAwesome::Proposals::ProposalFormCustomizations)
51
52
  end
52
53
 
53
54
  if DecidimAwesome.enabled?(:proposal_custom_fields, :proposal_private_custom_fields)
54
- Decidim::Proposals::ProposalWizardCreateStepForm.include(Decidim::DecidimAwesome::Proposals::ProposalFormOverride)
55
+ Decidim::Proposals::ProposalForm.include(Decidim::DecidimAwesome::Proposals::ProposalFormOverride)
55
56
  Decidim::Proposals::Admin::ProposalForm.include(Decidim::DecidimAwesome::Proposals::ProposalFormOverride)
56
57
  Decidim::Proposals::ProposalPresenter.include(Decidim::DecidimAwesome::Proposals::ProposalPresenterOverride)
57
58
  Decidim::Proposals::CreateProposal.include(Decidim::DecidimAwesome::Proposals::CreateProposalOverride)
@@ -67,7 +68,7 @@ module Decidim
67
68
  Decidim::System::RegisterOrganizationForm.include(Decidim::DecidimAwesome::System::OrganizationFormOverride)
68
69
  Decidim::System::UpdateOrganizationForm.include(Decidim::DecidimAwesome::System::OrganizationFormOverride)
69
70
  Decidim::System::UpdateOrganization.include(Decidim::DecidimAwesome::System::UpdateOrganizationOverride)
70
- Decidim::System::RegisterOrganization.include(Decidim::DecidimAwesome::System::RegisterOrganizationOverride)
71
+ Decidim::System::CreateOrganization.include(Decidim::DecidimAwesome::System::CreateOrganizationOverride)
71
72
  end
72
73
 
73
74
  if DecidimAwesome.enabled?(:proposal_custom_fields, :proposal_private_custom_fields, :weighted_proposal_voting)
@@ -229,7 +230,7 @@ module Decidim
229
230
  component.settings(:global) do |settings|
230
231
  DecidimAwesome.hash_append!(
231
232
  settings.attributes,
232
- :can_accumulate_supports_beyond_threshold,
233
+ :can_accumulate_votes_beyond_threshold,
233
234
  :awesome_voting_manifest,
234
235
  Decidim::SettingsManifest::Attribute.new(
235
236
  type: :select,
@@ -5,16 +5,16 @@ shared_examples "edits box label inline" do |test_case, key|
5
5
 
6
6
  it "updates the label when no changes" do
7
7
  link = find("[data-key=#{key}] a.awesome-auto-edit", match: :first)
8
- expect(page).not_to have_field(class: "awesome-auto-edit")
8
+ expect(page).to have_no_field(class: "awesome-auto-edit")
9
9
  link.click
10
10
  expect(page).to have_field(class: "awesome-auto-edit")
11
11
  find("body").click
12
- expect(page).not_to have_field(class: "awesome-auto-edit")
12
+ expect(page).to have_no_field(class: "awesome-auto-edit")
13
13
  link.click
14
14
  input = find("[data-key=#{key}] input.awesome-auto-edit")
15
15
  input.fill_in with: "A new làbel\n"
16
16
  sleep 1
17
- expect(page).not_to have_field(class: "awesome-auto-edit")
17
+ expect(page).to have_no_field(class: "awesome-auto-edit")
18
18
  expect(page).to have_css("span.awesome-auto-edit[data-key=a_new_label]")
19
19
 
20
20
  click_link_or_button "Update configuration"
@@ -24,14 +24,14 @@ shared_examples "edits box label inline" do |test_case, key|
24
24
  when :fields
25
25
  expect(page).to have_content("Occupation")
26
26
  expect(page).to have_content("Street Sweeper")
27
- expect(page).not_to have_content("Short Bio")
27
+ expect(page).to have_no_content("Short Bio")
28
28
  when :admins
29
- expect(page).not_to have_content(user.name.to_s)
29
+ expect(page).to have_no_content(user.name.to_s)
30
30
  expect(page).to have_content(user2.name.to_s)
31
31
  expect(page).to have_content(user3.name.to_s)
32
32
  end
33
33
  expect(page).to have_css("span.awesome-auto-edit[data-key=a_new_label]")
34
- expect(page).not_to have_css("span.awesome-auto-edit[data-key=#{key}]")
34
+ expect(page).to have_no_css("span.awesome-auto-edit[data-key=#{key}]")
35
35
  end
36
36
 
37
37
  it "updates the label with previous changes" do
@@ -48,16 +48,16 @@ shared_examples "edits box label inline" do |test_case, key|
48
48
  end
49
49
 
50
50
  link = find("[data-key=#{key}] a.awesome-auto-edit", match: :first)
51
- expect(page).not_to have_field(class: "awesome-auto-edit")
51
+ expect(page).to have_no_field(class: "awesome-auto-edit")
52
52
  link.click
53
53
  expect(page).to have_field(class: "awesome-auto-edit")
54
54
  find("body").click
55
- expect(page).not_to have_field(class: "awesome-auto-edit")
55
+ expect(page).to have_no_field(class: "awesome-auto-edit")
56
56
  link.click
57
57
  input = find("[data-key=#{key}] input.awesome-auto-edit")
58
58
  input.fill_in with: "A new làbel\n"
59
59
  sleep 1
60
- expect(page).not_to have_field(class: "awesome-auto-edit")
60
+ expect(page).to have_no_field(class: "awesome-auto-edit")
61
61
  expect(page).to have_css("span.awesome-auto-edit[data-key=a_new_label]")
62
62
 
63
63
  click_link_or_button "Update configuration"
@@ -73,21 +73,21 @@ shared_examples "edits box label inline" do |test_case, key|
73
73
  expect(page).to have_content(user3.name.to_s)
74
74
  end
75
75
  expect(page).to have_css("span.awesome-auto-edit[data-key=a_new_label]")
76
- expect(page).not_to have_css("span.awesome-auto-edit[data-key=#{key}]")
76
+ expect(page).to have_no_css("span.awesome-auto-edit[data-key=#{key}]")
77
77
  end
78
78
 
79
79
  it "updates the label with post changes" do
80
80
  link = find("[data-key=#{key}] a.awesome-auto-edit", match: :first)
81
- expect(page).not_to have_field(class: "awesome-auto-edit")
81
+ expect(page).to have_no_field(class: "awesome-auto-edit")
82
82
  link.click
83
83
  expect(page).to have_field(class: "awesome-auto-edit")
84
84
  find("body").click
85
- expect(page).not_to have_field(class: "awesome-auto-edit")
85
+ expect(page).to have_no_field(class: "awesome-auto-edit")
86
86
  link.click
87
87
  input = find("[data-key=#{key}] input.awesome-auto-edit")
88
88
  input.fill_in with: "A new làbel\n"
89
89
  sleep 1
90
- expect(page).not_to have_field(class: "awesome-auto-edit")
90
+ expect(page).to have_no_field(class: "awesome-auto-edit")
91
91
  expect(page).to have_css("span.awesome-auto-edit[data-key=a_new_label]")
92
92
 
93
93
  case test_case
@@ -111,6 +111,6 @@ shared_examples "edits box label inline" do |test_case, key|
111
111
  expect(page).to have_content(user3.name.to_s)
112
112
  end
113
113
  expect(page).to have_css("span.awesome-auto-edit[data-key=a_new_label]")
114
- expect(page).not_to have_css("span.awesome-auto-edit[data-key=#{key}]")
114
+ expect(page).to have_no_css("span.awesome-auto-edit[data-key=#{key}]")
115
115
  end
116
116
  end
@@ -22,7 +22,7 @@ shared_examples "do not have menu link" do |item|
22
22
  let(:prefix) { "config/" }
23
23
  it "do not show the feature link" do
24
24
  within ".sidebar-menu" do
25
- expect(page).not_to have_link(href: "/admin/decidim_awesome/#{prefix}#{item}")
25
+ expect(page).to have_no_link(href: "/admin/decidim_awesome/#{prefix}#{item}")
26
26
  end
27
27
  end
28
28
  end
@@ -26,7 +26,7 @@ shared_examples "updates a box" do
26
26
  expect(page).to have_content("Full Name")
27
27
  expect(page).to have_content("Occupation")
28
28
  expect(page).to have_content("Street Sweeper")
29
- expect(page).not_to have_content("Short Bio")
29
+ expect(page).to have_no_content("Short Bio")
30
30
 
31
31
  page.execute_script("$('.proposal_custom_fields_container[data-key=\"foo\"] .proposal_custom_fields_editor')[0].FormBuilder.actions.setData(#{data})")
32
32
  click_on "Update configuration"
@@ -34,8 +34,8 @@ shared_examples "updates a box" do
34
34
  sleep 2
35
35
  expect(page).to have_admin_callout("updated successfully")
36
36
  expect(page).to have_content("Full Name")
37
- expect(page).not_to have_content("Occupation")
38
- expect(page).not_to have_content("Street Sweeper")
37
+ expect(page).to have_no_content("Occupation")
38
+ expect(page).to have_no_content("Street Sweeper")
39
39
  expect(page).to have_content("Short Bio")
40
40
  end
41
41
  end
@@ -53,7 +53,7 @@ shared_examples "removes a box" do |name|
53
53
  expect(page).to have_content("Full Name")
54
54
  expect(page).to have_content("Occupation")
55
55
  expect(page).to have_content("Street Sweeper")
56
- expect(page).not_to have_content("Short Bio")
56
+ expect(page).to have_no_content("Short Bio")
57
57
 
58
58
  within ".proposal_custom_fields_container[data-key=\"foo\"]" do
59
59
  accept_confirm { click_on "Remove this \"#{name}\" box" }
@@ -61,10 +61,10 @@ shared_examples "removes a box" do |name|
61
61
 
62
62
  sleep 2
63
63
  expect(page).to have_admin_callout("removed successfully")
64
- expect(page).not_to have_content("Full Name")
64
+ expect(page).to have_no_content("Full Name")
65
65
  expect(page).to have_content("Occupation")
66
66
  expect(page).to have_content("Street Sweeper")
67
- expect(page).not_to have_content("Short Bio")
67
+ expect(page).to have_no_content("Short Bio")
68
68
 
69
69
  expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_foo")).not_to be_present
70
70
  expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar")).to be_present
@@ -121,13 +121,13 @@ shared_examples "removes a constraint" do
121
121
  end
122
122
 
123
123
  within ".proposal_custom_fields_container[data-key=\"bar\"] .constraints-editor" do
124
- expect(page).not_to have_content("Proposals")
124
+ expect(page).to have_no_content("Proposals")
125
125
  end
126
126
 
127
127
  visit decidim_admin_decidim_awesome.config_path("#{var_name}s")
128
128
 
129
129
  within ".proposal_custom_fields_container[data-key=\"bar\"] .constraints-editor" do
130
- expect(page).not_to have_content("Proposals")
130
+ expect(page).to have_no_content("Proposals")
131
131
  end
132
132
 
133
133
  expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar")).to be_present