decidim-elections 0.26.2 → 0.27.0.rc2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (197) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/app/cells/decidim/votings/content_blocks/highlighted_votings/show.erb +2 -2
  4. data/app/cells/decidim/votings/content_blocks/highlighted_votings_cell.rb +1 -4
  5. data/app/cells/decidim/votings/content_blocks/landing_page/description/show.erb +1 -1
  6. data/app/cells/decidim/votings/content_blocks/landing_page/header/show.erb +2 -2
  7. data/app/cells/decidim/votings/content_blocks/landing_page/header_cell.rb +1 -1
  8. data/app/commands/decidim/elections/admin/add_user_as_trustee.rb +1 -1
  9. data/app/commands/decidim/elections/admin/create_answer.rb +1 -1
  10. data/app/commands/decidim/elections/admin/create_election.rb +1 -1
  11. data/app/commands/decidim/elections/admin/create_question.rb +1 -2
  12. data/app/commands/decidim/elections/admin/destroy_answer.rb +1 -1
  13. data/app/commands/decidim/elections/admin/destroy_election.rb +1 -1
  14. data/app/commands/decidim/elections/admin/destroy_question.rb +1 -1
  15. data/app/commands/decidim/elections/admin/end_vote.rb +1 -1
  16. data/app/commands/decidim/elections/admin/import_proposals_to_elections.rb +1 -1
  17. data/app/commands/decidim/elections/admin/publish_election.rb +1 -1
  18. data/app/commands/decidim/elections/admin/publish_results.rb +1 -1
  19. data/app/commands/decidim/elections/admin/remove_trustee_from_participatory_space.rb +1 -1
  20. data/app/commands/decidim/elections/admin/report_missing_trustee.rb +1 -1
  21. data/app/commands/decidim/elections/admin/setup_election.rb +4 -2
  22. data/app/commands/decidim/elections/admin/start_key_ceremony.rb +1 -1
  23. data/app/commands/decidim/elections/admin/start_tally.rb +1 -1
  24. data/app/commands/decidim/elections/admin/start_vote.rb +1 -1
  25. data/app/commands/decidim/elections/admin/unpublish_election.rb +1 -1
  26. data/app/commands/decidim/elections/admin/update_action_status.rb +1 -1
  27. data/app/commands/decidim/elections/admin/update_answer.rb +1 -1
  28. data/app/commands/decidim/elections/admin/update_answer_selection.rb +1 -1
  29. data/app/commands/decidim/elections/admin/update_election.rb +1 -1
  30. data/app/commands/decidim/elections/admin/update_question.rb +1 -2
  31. data/app/commands/decidim/elections/admin/update_trustee_participatory_space.rb +1 -1
  32. data/app/commands/decidim/elections/trustee_zone/update_election_bulletin_board_status.rb +1 -1
  33. data/app/commands/decidim/elections/trustee_zone/update_trustee.rb +1 -1
  34. data/app/commands/decidim/elections/voter/cast_vote.rb +1 -1
  35. data/app/commands/decidim/elections/voter/update_vote_status.rb +2 -2
  36. data/app/commands/decidim/votings/admin/create_ballot_style.rb +1 -1
  37. data/app/commands/decidim/votings/admin/create_monitoring_committee_member.rb +1 -1
  38. data/app/commands/decidim/votings/admin/create_polling_officer.rb +1 -1
  39. data/app/commands/decidim/votings/admin/create_voting.rb +3 -2
  40. data/app/commands/decidim/votings/admin/destroy_ballot_style.rb +1 -1
  41. data/app/commands/decidim/votings/admin/destroy_monitoring_committee_member.rb +1 -1
  42. data/app/commands/decidim/votings/admin/destroy_polling_officer.rb +1 -1
  43. data/app/commands/decidim/votings/admin/destroy_polling_station.rb +1 -1
  44. data/app/commands/decidim/votings/admin/manage_polling_station.rb +2 -2
  45. data/app/commands/decidim/votings/admin/monitoring_committee_validate_polling_station_closure.rb +1 -1
  46. data/app/commands/decidim/votings/admin/publish_voting.rb +1 -1
  47. data/app/commands/decidim/votings/admin/unpublish_voting.rb +1 -1
  48. data/app/commands/decidim/votings/admin/update_ballot_style.rb +1 -1
  49. data/app/commands/decidim/votings/admin/update_voting.rb +3 -2
  50. data/app/commands/decidim/votings/census/admin/create_dataset.rb +32 -21
  51. data/app/commands/decidim/votings/census/admin/create_datum.rb +1 -1
  52. data/app/commands/decidim/votings/census/admin/destroy_dataset.rb +1 -1
  53. data/app/commands/decidim/votings/census/admin/increment_dataset_processed_rows.rb +1 -1
  54. data/app/commands/decidim/votings/census/admin/launch_access_codes_export.rb +4 -2
  55. data/app/commands/decidim/votings/census/admin/launch_access_codes_generation.rb +2 -2
  56. data/app/commands/decidim/votings/census/admin/update_dataset.rb +1 -1
  57. data/app/commands/decidim/votings/certify_polling_station_closure.rb +1 -1
  58. data/app/commands/decidim/votings/check_census.rb +1 -1
  59. data/app/commands/decidim/votings/create_polling_station_closure.rb +1 -1
  60. data/app/commands/decidim/votings/create_polling_station_results.rb +1 -1
  61. data/app/commands/decidim/votings/send_access_code.rb +1 -1
  62. data/app/commands/decidim/votings/sign_polling_station_closure.rb +1 -1
  63. data/app/commands/decidim/votings/voter/in_person_vote.rb +1 -1
  64. data/app/commands/decidim/votings/voter/update_in_person_vote_status.rb +1 -1
  65. data/app/controllers/decidim/elections/admin/steps_controller.rb +2 -2
  66. data/app/controllers/decidim/elections/elections_controller.rb +10 -12
  67. data/app/controllers/decidim/elections/trustee_zone/elections_controller.rb +1 -1
  68. data/app/controllers/decidim/votings/census/admin/census_controller.rb +6 -2
  69. data/app/controllers/decidim/votings/votings_controller.rb +10 -13
  70. data/app/forms/decidim/elections/admin/question_form.rb +0 -2
  71. data/app/forms/decidim/elections/admin/setup_form.rb +46 -3
  72. data/app/forms/decidim/elections/admin/vote_period_form.rb +2 -2
  73. data/app/forms/decidim/votings/admin/ballot_style_form.rb +1 -1
  74. data/app/forms/decidim/votings/admin/voting_form.rb +4 -3
  75. data/app/forms/decidim/votings/census/admin/dataset_form.rb +2 -5
  76. data/app/forms/decidim/votings/census/admin/datum_form.rb +1 -1
  77. data/app/helpers/decidim/elections/application_helper.rb +1 -1
  78. data/app/helpers/decidim/votings/votings_helper.rb +1 -1
  79. data/app/models/decidim/elections/answer.rb +1 -6
  80. data/app/models/decidim/elections/election.rb +15 -4
  81. data/app/models/decidim/elections/question.rb +2 -7
  82. data/app/models/decidim/votings/census/dataset.rb +1 -1
  83. data/app/models/decidim/votings/polling_station.rb +2 -3
  84. data/app/models/decidim/votings/voting.rb +15 -0
  85. data/app/packs/entrypoints/{decidim_elections_trustee_tally.js → decidim_elections_trustee_tally_started.js} +0 -0
  86. data/app/packs/src/decidim/elections/admin/pending_action.js +2 -0
  87. data/app/packs/src/decidim/elections/admin/trustees_process.js +2 -0
  88. data/app/packs/src/decidim/elections/broken_promises_handler.js +11 -0
  89. data/app/packs/src/decidim/elections/trustee/key_ceremony.js +3 -0
  90. data/app/packs/src/decidim/elections/trustee/tally.js +4 -1
  91. data/app/packs/src/decidim/elections/voter/casting-vote.js +3 -0
  92. data/app/packs/src/decidim/elections/voter/setup-vote.js +3 -0
  93. data/app/packs/src/decidim/votings/admin/update_census_dataset_status.js +2 -2
  94. data/app/packs/src/decidim/votings/in-person-vote.js +3 -0
  95. data/app/permissions/decidim/votings/admin/permissions.rb +2 -14
  96. data/app/permissions/decidim/votings/permissions.rb +1 -3
  97. data/app/presenters/decidim/votings/voting_stats_presenter.rb +4 -1
  98. data/app/queries/decidim/elections/admin/pending_actions.rb +1 -1
  99. data/app/queries/decidim/elections/admin/votes_for_statistics.rb +1 -1
  100. data/app/queries/decidim/elections/elections_finished_to_end.rb +1 -1
  101. data/app/queries/decidim/elections/elections_ready_to_start.rb +1 -1
  102. data/app/queries/decidim/elections/filtered_elections.rb +1 -1
  103. data/app/queries/decidim/elections/trustees/by_participatory_space.rb +1 -1
  104. data/app/queries/decidim/elections/trustees/by_participatory_space_trustee_ids.rb +1 -1
  105. data/app/queries/decidim/elections/votes/last_vote_for_voter.rb +1 -1
  106. data/app/queries/decidim/elections/votes/pending_votes.rb +1 -1
  107. data/app/queries/decidim/votings/admin/admin_users.rb +1 -1
  108. data/app/queries/decidim/votings/admin/ballot_style_by_voting_code.rb +1 -1
  109. data/app/queries/decidim/votings/admin/polling_officers_join_polling_stations.rb +1 -1
  110. data/app/queries/decidim/votings/admin/polling_officers_join_polling_stations_and_user.rb +2 -2
  111. data/app/queries/decidim/votings/admin/polling_officers_join_user.rb +1 -1
  112. data/app/queries/decidim/votings/organization_prioritized_votings.rb +2 -2
  113. data/app/queries/decidim/votings/organization_promoted_votings.rb +1 -1
  114. data/app/queries/decidim/votings/organization_published_votings.rb +2 -2
  115. data/app/queries/decidim/votings/organization_votings.rb +1 -1
  116. data/app/queries/decidim/votings/prioritized_votings.rb +1 -1
  117. data/app/queries/decidim/votings/published_votings.rb +1 -1
  118. data/app/queries/decidim/votings/votes/in_person_vote_for_voter.rb +1 -1
  119. data/app/queries/decidim/votings/votes/pending_in_person_votes.rb +1 -1
  120. data/app/services/decidim/votings/census_vote_flow.rb +1 -3
  121. data/app/views/decidim/elections/admin/questions/_form.html.erb +0 -4
  122. data/app/views/decidim/elections/admin/steps/_create_election.html.erb +14 -1
  123. data/app/views/decidim/elections/admin/steps/{_tally.html.erb → _tally_started.html.erb} +1 -1
  124. data/app/views/decidim/elections/admin/steps/index.html.erb +2 -0
  125. data/app/views/decidim/elections/elections/_filters.html.erb +2 -2
  126. data/app/views/decidim/elections/elections/election_log.html.erb +3 -1
  127. data/app/views/decidim/elections/shared/_broken_promises_modal.html.erb +33 -0
  128. data/app/views/decidim/elections/trustee_zone/elections/{_tally_steps.html.erb → _tally_started_steps.html.erb} +0 -0
  129. data/app/views/decidim/elections/trustee_zone/elections/show.html.erb +5 -1
  130. data/app/views/decidim/elections/trustee_zone/trustees/show.html.erb +3 -1
  131. data/app/views/decidim/elections/votes/_onboarding_modal.html.erb +3 -1
  132. data/app/views/decidim/elections/votes/_show_casting.html.erb +5 -1
  133. data/app/views/decidim/elections/votes/new.html.erb +11 -5
  134. data/app/views/decidim/elections/votes/verify.html.erb +4 -1
  135. data/app/views/decidim/votings/admin/votings/_form.html.erb +9 -0
  136. data/app/views/decidim/votings/census/admin/census/_creating_data.html.erb +1 -1
  137. data/app/views/decidim/votings/census/admin/census/_exporting_codes.html.erb +1 -1
  138. data/app/views/decidim/votings/census/admin/census/_freeze.html.erb +2 -0
  139. data/app/views/decidim/votings/census/admin/census/_generate_codes.html.erb +14 -4
  140. data/app/views/decidim/votings/census/admin/census/show.html.erb +1 -1
  141. data/app/views/decidim/votings/polling_officer_zone/closures/_certify_form.html.erb +3 -1
  142. data/app/views/decidim/votings/polling_officer_zone/closures/_sign_form.html.erb +3 -1
  143. data/app/views/decidim/votings/polling_officer_zone/closures/edit.html.erb +3 -1
  144. data/app/views/decidim/votings/polling_officer_zone/closures/new.html.erb +3 -1
  145. data/app/views/decidim/votings/polling_officer_zone/in_person_votes/_complete_voting.html.erb +8 -2
  146. data/app/views/decidim/votings/polling_officer_zone/in_person_votes/new.html.erb +5 -1
  147. data/app/views/decidim/votings/polling_officer_zone/in_person_votes/show.html.erb +5 -1
  148. data/app/views/decidim/votings/votings/_filters.html.erb +2 -3
  149. data/app/views/decidim/votings/votings/_promoted_voting.html.erb +1 -1
  150. data/app/views/layouts/decidim/election_votes.html.erb +3 -1
  151. data/config/assets.rb +1 -1
  152. data/config/locales/ar.yml +2 -3
  153. data/config/locales/bg.yml +1 -0
  154. data/config/locales/ca.yml +64 -30
  155. data/config/locales/cs.yml +66 -27
  156. data/config/locales/de.yml +53 -30
  157. data/config/locales/el.yml +1 -1
  158. data/config/locales/en.yml +63 -27
  159. data/config/locales/es-MX.yml +65 -31
  160. data/config/locales/es-PY.yml +65 -31
  161. data/config/locales/es.yml +67 -33
  162. data/config/locales/eu.yml +5 -40
  163. data/config/locales/fi-plain.yml +64 -29
  164. data/config/locales/fi.yml +66 -31
  165. data/config/locales/fr-CA.yml +64 -29
  166. data/config/locales/fr.yml +62 -27
  167. data/config/locales/ga-IE.yml +1 -15
  168. data/config/locales/gl.yml +22 -32
  169. data/config/locales/hu.yml +28 -13
  170. data/config/locales/it.yml +5 -34
  171. data/config/locales/ja.yml +65 -33
  172. data/config/locales/lb.yml +1 -0
  173. data/config/locales/lt.yml +1445 -0
  174. data/config/locales/lv.yml +1 -1
  175. data/config/locales/nl.yml +10 -51
  176. data/config/locales/no.yml +11 -39
  177. data/config/locales/pl.yml +16 -35
  178. data/config/locales/pt-BR.yml +6 -34
  179. data/config/locales/pt.yml +12 -40
  180. data/config/locales/ro-RO.yml +11 -25
  181. data/config/locales/sl.yml +1 -0
  182. data/config/locales/sv.yml +60 -11
  183. data/config/locales/tr-TR.yml +4 -14
  184. data/config/locales/zh-CN.yml +1 -5
  185. data/db/migrate/20220404112802_rename_bb_status_tally_to_tally_started.rb +19 -0
  186. data/db/migrate/20220424121541_add_show_check_census_to_votings.rb +7 -0
  187. data/db/migrate/20220615102642_remove_description_from_elections_questions.rb +7 -0
  188. data/db/migrate/20220711112802_rename_dataset_file_to_filename.rb +7 -0
  189. data/lib/decidim/api/election_question_type.rb +0 -1
  190. data/lib/decidim/elections/component.rb +4 -16
  191. data/lib/decidim/elections/test/factories.rb +4 -5
  192. data/lib/decidim/elections/version.rb +1 -1
  193. data/lib/decidim/votings/participatory_space.rb +3 -3
  194. data/lib/decidim/votings/test/factories.rb +3 -2
  195. metadata +31 -27
  196. data/app/services/decidim/elections/election_search.rb +0 -35
  197. data/app/services/decidim/votings/voting_search.rb +0 -46
@@ -14,10 +14,11 @@ module Decidim
14
14
  include Traceable
15
15
  include Loggable
16
16
  include Decidim::Forms::HasQuestionnaire
17
+ include Decidim::FilterableResource
17
18
 
18
19
  translatable_fields :title, :description
19
20
 
20
- enum bb_status: [:created, :key_ceremony, :key_ceremony_ended, :vote, :vote_ended, :tally, :tally_ended, :results_published].index_with(&:to_s), _prefix: :bb
21
+ enum bb_status: [:created, :key_ceremony, :key_ceremony_ended, :vote, :vote_ended, :tally_started, :tally_ended, :results_published].index_with(&:to_s), _prefix: :bb
21
22
 
22
23
  component_manifest_name "elections"
23
24
 
@@ -43,6 +44,8 @@ module Decidim
43
44
  .where("end_time < ?", Time.current)
44
45
  }
45
46
 
47
+ scope_search_multi :with_any_date, [:active, :upcoming, :finished]
48
+
46
49
  def self.log_presenter_class_for(_log)
47
50
  Decidim::Elections::AdminLog::ElectionPresenter
48
51
  end
@@ -86,7 +89,7 @@ module Decidim
86
89
  #
87
90
  # Returns a boolean.
88
91
  def minimum_answers?
89
- questions.all? { |question| question.answers.size > 1 }
92
+ questions.any? && questions.all? { |question| question.answers.size > 1 }
90
93
  end
91
94
 
92
95
  # Public: Checks if the election results are published and election finished
@@ -107,7 +110,7 @@ module Decidim
107
110
  #
108
111
  # Returns a boolean.
109
112
  def valid_questions?
110
- questions.all?(&:valid_max_selection?)
113
+ questions.any? && questions.all?(&:valid_max_selection?)
111
114
  end
112
115
 
113
116
  # Public: Gets the voting period status of the election
@@ -124,7 +127,7 @@ module Decidim
124
127
  end
125
128
 
126
129
  def trustee_action_required?
127
- bb_key_ceremony? || bb_tally?
130
+ bb_key_ceremony? || bb_tally_started?
128
131
  end
129
132
 
130
133
  # Public: Checks if the election has a blocked_at value
@@ -138,6 +141,14 @@ module Decidim
138
141
  def allow_resource_permissions?
139
142
  true
140
143
  end
144
+
145
+ # Create i18n ransackers for :title and :description.
146
+ # Create the :search_text ransacker alias for searching from both of these.
147
+ ransacker_i18n_multi :search_text, [:title, :description]
148
+
149
+ def self.ransackable_scopes(_auth_object = nil)
150
+ [:with_any_date]
151
+ end
141
152
  end
142
153
  end
143
154
  end
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module Elections
5
5
  # The data store for a Question in the Decidim::Elections component. It stores a
6
- # title, description and a maximum number of selection that voters can choose.
6
+ # title and a maximum number of selection that voters can choose.
7
7
  class Question < ApplicationRecord
8
8
  include Decidim::Resourceable
9
9
  include Traceable
@@ -41,12 +41,7 @@ module Decidim
41
41
  # A result percentage relative to the question
42
42
  # Returns a Float.
43
43
  def blank_votes_percentage
44
- @blank_votes_percentage ||= begin
45
- return 0 unless results_total.positive?
46
-
47
- result = blank_votes.to_f / results_total * 100.0
48
- result.round
49
- end
44
+ @blank_votes_percentage ||= results_total.positive? ? (blank_votes.to_f / results_total * 100.0).round : 0
50
45
  end
51
46
 
52
47
  def slug
@@ -21,7 +21,7 @@ module Decidim
21
21
 
22
22
  enum status: [:init_data, :creating_data, :data_created, :generating_codes, :codes_generated, :exporting_codes, :freeze]
23
23
 
24
- validates :file, presence: true
24
+ validates :filename, presence: true
25
25
 
26
26
  alias participatory_space voting
27
27
 
@@ -7,6 +7,7 @@ module Decidim
7
7
  include Traceable
8
8
  include Loggable
9
9
  include Decidim::TranslatableResource
10
+ include Decidim::FilterableResource
10
11
 
11
12
  translatable_fields :title, :location, :location_hints
12
13
 
@@ -37,9 +38,7 @@ module Decidim
37
38
  alias participatory_space voting
38
39
 
39
40
  # Allow ransacker to search for a key in a hstore column (`title`.`en`)
40
- ransacker :title do |parent|
41
- Arel::Nodes::InfixOperation.new("->>", parent.table[:title], Arel::Nodes.build_quoted(I18n.locale.to_s))
42
- end
41
+ ransacker_i18n :title
43
42
 
44
43
  [:manager, :president].each do |role|
45
44
  [:name, :email, :nickname].each do |field|
@@ -16,6 +16,7 @@ module Decidim
16
16
  include Decidim::HasUploadValidations
17
17
  include Decidim::HasAttachments
18
18
  include Decidim::HasAttachmentCollections
19
+ include Decidim::FilterableResource
19
20
 
20
21
  enum voting_type: [:in_person, :online, :hybrid].index_with(&:to_s), _suffix: :voting
21
22
 
@@ -62,6 +63,8 @@ module Decidim
62
63
  scope :order_by_most_recent, -> { order(created_at: :desc) }
63
64
  scope :promoted, -> { published.where(promoted: true) }
64
65
 
66
+ scope_search_multi :with_any_date, [:active, :upcoming, :finished]
67
+
65
68
  def upcoming?
66
69
  start_time > Time.now.utc
67
70
  end
@@ -135,6 +138,10 @@ module Decidim
135
138
  ballot_styles.exists?
136
139
  end
137
140
 
141
+ def check_census_enabled?
142
+ dataset.present? && show_check_census?
143
+ end
144
+
138
145
  def elections
139
146
  Decidim::Elections::Election.where(component: components)
140
147
  end
@@ -156,6 +163,14 @@ module Decidim
156
163
  def vote_flow_for(election)
157
164
  Decidim::Votings::CensusVoteFlow.new(election)
158
165
  end
166
+
167
+ # Create i18n ransackers for :title and :description.
168
+ # Create the :search_text ransacker alias for searching from both of these.
169
+ ransacker_i18n_multi :search_text, [:title, :description]
170
+
171
+ def self.ransackable_scopes(_auth_object = nil)
172
+ [:with_any_date]
173
+ end
159
174
  end
160
175
  end
161
176
  end
@@ -1,3 +1,5 @@
1
+ // show a message to the user if comunication is lost
2
+ import "src/decidim/elections/broken_promises_handler";
1
3
  import { Client } from "@decidim/decidim-bulletin_board";
2
4
 
3
5
  $(() => {
@@ -1,3 +1,5 @@
1
+ // show a message to the user if comunication is lost
2
+ import "src/decidim/elections/broken_promises_handler";
1
3
  import {
2
4
  Client,
3
5
  Election,
@@ -0,0 +1,11 @@
1
+ /* Fallback for non-handled failed promises */
2
+ window.addEventListener("unhandledrejection", (event) => {
3
+ console.log("broken", event)
4
+ $("#server-failure .tech-info").html(event.reason);
5
+ if (event.reason.toString().indexOf("fetch") === -1) {
6
+ $("#server-failure .communication_error").addClass("hide");
7
+ $("#server-failure .generic_error").removeClass("hide");
8
+ }
9
+ $("#server-failure").foundation("open");
10
+ });
11
+
@@ -1,3 +1,6 @@
1
+ // show a message to the user if comunication is lost
2
+ import "src/decidim/elections/broken_promises_handler";
3
+
1
4
  import {
2
5
  KeyCeremonyComponent,
3
6
  MessageIdentifier,
@@ -1,3 +1,6 @@
1
+ // show a message to the user if comunication is lost
2
+ import "src/decidim/elections/broken_promises_handler";
3
+
1
4
  import {
2
5
  TallyComponent,
3
6
  IdentificationKeys,
@@ -112,7 +115,7 @@ $(() => {
112
115
  url: $tally.data("updateElectionStatusUrl"),
113
116
  contentType: "application/json",
114
117
  data: JSON.stringify({
115
- status: "tally"
118
+ status: "tally_started"
116
119
  }),
117
120
  headers: {
118
121
  "X-CSRF-Token": $("meta[name=csrf-token]").attr("content")
@@ -1,3 +1,6 @@
1
+ // show a message to the user if comunication is lost
2
+ import "src/decidim/elections/broken_promises_handler";
3
+
1
4
  import { Client } from "@decidim/decidim-bulletin_board";
2
5
 
3
6
  $(async () => {
@@ -1,5 +1,7 @@
1
1
  /* eslint-disable require-jsdoc */
2
2
 
3
+ // show a message to the user if comunication is lost
4
+ import "src/decidim/elections/broken_promises_handler";
3
5
  import { VoteComponent } from "@decidim/decidim-bulletin_board";
4
6
 
5
7
  import * as VotingSchemesDummy from "@decidim/voting_schemes-dummy";
@@ -48,3 +50,4 @@ export default function setupVoteComponent($voteWrapper) {
48
50
 
49
51
  window.Decidim = window.Decidim || {};
50
52
  window.Decidim.setupVoteComponent = setupVoteComponent;
53
+
@@ -8,6 +8,6 @@ $(() => {
8
8
  }
9
9
  }
10
10
 
11
- // 1 minute
12
- setInterval(updateCensusDatasetStatus, 60000);
11
+ // 10 seconds
12
+ setInterval(updateCensusDatasetStatus, 10000);
13
13
  });
@@ -1,3 +1,6 @@
1
+ // show a message to the user if comunication is lost
2
+ import "src/decidim/elections/broken_promises_handler";
3
+
1
4
  import { Client } from "@decidim/decidim-bulletin_board";
2
5
 
3
6
  $(async () => {
@@ -78,7 +78,7 @@ module Decidim
78
78
  end
79
79
  when :landing_page
80
80
  toggle_allow(user.admin?) if permission_action.action == :update
81
- when :components
81
+ when :ballot_styles, :components, :polling_stations, :polling_officers, :monitoring_committee_members
82
82
  toggle_allow(user.admin?) if permission_action.action == :read
83
83
  when :polling_station
84
84
  case permission_action.action
@@ -87,8 +87,6 @@ module Decidim
87
87
  when :update, :delete
88
88
  toggle_allow(user.admin? && polling_station.present?)
89
89
  end
90
- when :polling_stations
91
- toggle_allow(user.admin?) if permission_action.action == :read
92
90
  when :polling_officer
93
91
  case permission_action.action
94
92
  when :create
@@ -96,8 +94,6 @@ module Decidim
96
94
  when :delete
97
95
  toggle_allow(user.admin? && polling_officer.present?)
98
96
  end
99
- when :polling_officers
100
- toggle_allow(user.admin?) if permission_action.action == :read
101
97
  when :monitoring_committee_member
102
98
  case permission_action.action
103
99
  when :create
@@ -107,18 +103,12 @@ module Decidim
107
103
  end
108
104
  when :monitoring_committee_menu
109
105
  toggle_allow(user_can_read_voting?) if permission_action.action == :read
110
- when :monitoring_committee_members
111
- toggle_allow(user.admin?) if permission_action.action == :read
112
106
  when :monitoring_committee_polling_station_closure
113
107
  toggle_allow(user_monitoring_committee_for_voting? && closure.present?) if [:read, :validate].member?(permission_action.action)
114
- when :monitoring_committee_polling_station_closures
115
- toggle_allow(user_monitoring_committee_for_voting?) if permission_action.action == :read
116
- when :monitoring_committee_verify_elections
108
+ when :monitoring_committee_polling_station_closures, :monitoring_committee_verify_elections, :monitoring_committee_election_results
117
109
  toggle_allow(user_monitoring_committee_for_voting?) if permission_action.action == :read
118
110
  when :monitoring_committee_election_result
119
111
  toggle_allow(user_monitoring_committee_for_voting? && election.present?) if [:read, :validate].member?(permission_action.action)
120
- when :monitoring_committee_election_results
121
- toggle_allow(user_monitoring_committee_for_voting?) if permission_action.action == :read
122
112
  when :census
123
113
  toggle_allow(user.admin?) if permission_action.action == :manage
124
114
  when :ballot_style
@@ -128,8 +118,6 @@ module Decidim
128
118
  when :update, :delete
129
119
  toggle_allow(user.admin? && (voting.dataset.blank? || voting.dataset.init_data?) && ballot_style.present?)
130
120
  end
131
- when :ballot_styles
132
- toggle_allow(user.admin?) if permission_action.action == :read
133
121
  end
134
122
  end
135
123
 
@@ -27,12 +27,10 @@ module Decidim
27
27
  return unless permission_action.scope == :public
28
28
 
29
29
  case permission_action.subject
30
- when :votings
30
+ when :votings, :participatory_space
31
31
  allow!
32
32
  when :voting
33
33
  toggle_allow(voting.published? || user&.admin?)
34
- when :participatory_space
35
- allow!
36
34
  end
37
35
  end
38
36
 
@@ -4,9 +4,12 @@ module Decidim
4
4
  module Votings
5
5
  # A presenter to render statistics in the homepage.
6
6
  class VotingStatsPresenter < Decidim::StatsPresenter
7
- attribute :voting, Decidim::Votings::Voting
8
7
  include Decidim::IconHelper
9
8
 
9
+ def voting
10
+ __getobj__.fetch(:voting)
11
+ end
12
+
10
13
  # Public: returns a collection of stats (Hash) for the Voting Landing.
11
14
  def collection
12
15
  highlighted_stats = voting_participants_stats
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Elections
5
5
  module Admin
6
6
  # A class used to find actions with a pending status
7
- class PendingActions < Rectify::Query
7
+ class PendingActions < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  def self.for
10
10
  new.query
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Elections
5
5
  module Admin
6
6
  # A class used to find election votes for statistics
7
- class VotesForStatistics < Rectify::Query
7
+ class VotesForStatistics < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried object.
9
9
  def self.for(election)
10
10
  new(election).query
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module Elections
5
5
  # A class used to find elections finished to close their voting period
6
- class ElectionsFinishedToEnd < Rectify::Query
6
+ class ElectionsFinishedToEnd < Decidim::Query
7
7
  # Syntactic sugar to initialize the class and return the queried objects.
8
8
  def self.for
9
9
  new.query
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module Elections
5
5
  # A class used to find elections ready and near to start the voting period
6
- class ElectionsReadyToStart < Rectify::Query
6
+ class ElectionsReadyToStart < Decidim::Query
7
7
  # Syntactic sugar to initialize the class and return the queried objects.
8
8
  def self.for
9
9
  new.query
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module Elections
5
5
  # A class used to find elections filtered by its state
6
- class FilteredElections < Rectify::Query
6
+ class FilteredElections < Decidim::Query
7
7
  # Syntactic sugar to initialize the class and return the queried objects.
8
8
  #
9
9
  # components - An array of Decidim::Component
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Elections
5
5
  module Trustees
6
6
  # A class used to find trustees by participatory space.
7
- class ByParticipatorySpace < Rectify::Query
7
+ class ByParticipatorySpace < Decidim::Query
8
8
  # Initializes the class.
9
9
  #
10
10
  def initialize(participatory_space)
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Elections
5
5
  module Trustees
6
6
  # A class used to find trustees by participatory space trustee ids.
7
- class ByParticipatorySpaceTrusteeIds < Rectify::Query
7
+ class ByParticipatorySpaceTrusteeIds < Decidim::Query
8
8
  # Initializes the class.
9
9
  #
10
10
  def initialize(trustee_ids)
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Elections
5
5
  module Votes
6
6
  # A class used to find the last vote casted by a voter in an election
7
- class LastVoteForVoter < Rectify::Query
7
+ class LastVoteForVoter < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  #
10
10
  # election - the election where the vote was casted
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Elections
5
5
  module Votes
6
6
  # A class used to find votes with a pending status
7
- class PendingVotes < Rectify::Query
7
+ class PendingVotes < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  def self.for
10
10
  new.query
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Votings
5
5
  module Admin
6
6
  # A class used to find the admins for a voting or an organization votings.
7
- class AdminUsers < Rectify::Query
7
+ class AdminUsers < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  #
10
10
  # voting - a voting that needs to find its voting admins
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Votings
5
5
  module Admin
6
6
  # A class used to find trustees by participatory space.
7
- class BallotStyleByVotingCode < Rectify::Query
7
+ class BallotStyleByVotingCode < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  #
10
10
  # voting - the voting of the Ballot Style
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Votings
5
5
  module Admin
6
6
  # A class join the polling officers with their respective polling stations.
7
- class PollingOfficersJoinPollingStations < Rectify::Query
7
+ class PollingOfficersJoinPollingStations < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  #
10
10
  # polling_officers - the collection of polling officers
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Votings
5
5
  module Admin
6
6
  # A class join the polling officers with their respective polling stations and users.
7
- class PollingOfficersJoinPollingStationsAndUser < Rectify::Query
7
+ class PollingOfficersJoinPollingStationsAndUser < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  #
10
10
  # polling_officers - the collection of polling officers
@@ -23,7 +23,7 @@ module Decidim
23
23
  #
24
24
  # Returns an ActiveRecord::Relation.
25
25
  def query
26
- Rectify::Query.merge(
26
+ Decidim::Query.merge(
27
27
  PollingOfficersJoinPollingStations.new(@polling_officers),
28
28
  PollingOfficersJoinUser.new(@polling_officers)
29
29
  ).query
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Votings
5
5
  module Admin
6
6
  # A class join the polling officers with their respective decidim user.
7
- class PollingOfficersJoinUser < Rectify::Query
7
+ class PollingOfficersJoinUser < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  #
10
10
  # polling_officers - the collection of polling officers
@@ -4,14 +4,14 @@ module Decidim
4
4
  module Votings
5
5
  # This query class filters public votings given an organization in a
6
6
  # meaningful prioritized order.
7
- class OrganizationPrioritizedVotings < Rectify::Query
7
+ class OrganizationPrioritizedVotings < Decidim::Query
8
8
  def initialize(organization, user = nil)
9
9
  @organization = organization
10
10
  @user = user
11
11
  end
12
12
 
13
13
  def query
14
- Rectify::Query.merge(
14
+ Decidim::Query.merge(
15
15
  OrganizationPublishedVotings.new(@organization),
16
16
  PrioritizedVotings.new
17
17
  ).query
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module Votings
5
5
  # This query selects the promoted votings
6
- class OrganizationPromotedVotings < Rectify::Query
6
+ class OrganizationPromotedVotings < Decidim::Query
7
7
  def initialize(organization)
8
8
  @organization = organization
9
9
  end
@@ -3,13 +3,13 @@
3
3
  module Decidim
4
4
  module Votings
5
5
  # This query class filters published votings given an organization.
6
- class OrganizationPublishedVotings < Rectify::Query
6
+ class OrganizationPublishedVotings < Decidim::Query
7
7
  def initialize(organization)
8
8
  @organization = organization
9
9
  end
10
10
 
11
11
  def query
12
- Rectify::Query.merge(
12
+ Decidim::Query.merge(
13
13
  OrganizationVotings.new(@organization),
14
14
  PublishedVotings.new
15
15
  ).query
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module Votings
5
5
  # This query class filters all votings given an organization.
6
- class OrganizationVotings < Rectify::Query
6
+ class OrganizationVotings < Decidim::Query
7
7
  def initialize(organization)
8
8
  @organization = organization
9
9
  end
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Votings
5
5
  # This query orders votings by importance, prioritizing promoted
6
6
  # votings.
7
- class PrioritizedVotings < Rectify::Query
7
+ class PrioritizedVotings < Decidim::Query
8
8
  def query
9
9
  Decidim::Votings::Voting.order(promoted: :desc)
10
10
  end
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module Votings
5
5
  # This query filters published votings only.
6
- class PublishedVotings < Rectify::Query
6
+ class PublishedVotings < Decidim::Query
7
7
  def query
8
8
  Decidim::Votings::Voting.published
9
9
  end
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Votings
5
5
  module Votes
6
6
  # A class used to find a non-rejected in person vote registered for a voter in an election
7
- class InPersonVoteForVoter < Rectify::Query
7
+ class InPersonVoteForVoter < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  #
10
10
  # election - the election where the vote was casted
@@ -4,7 +4,7 @@ module Decidim
4
4
  module Votings
5
5
  module Votes
6
6
  # A class used to find in person votes with a pending status
7
- class PendingInPersonVotes < Rectify::Query
7
+ class PendingInPersonVotes < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  def self.for
10
10
  new.query
@@ -97,9 +97,7 @@ module Decidim
97
97
  end
98
98
 
99
99
  def valid_token_flow_data?
100
- @valid_token_flow_data ||= begin
101
- has_voter? && received_voter_token_data[:flow].as_json == voter_data.as_json
102
- end
100
+ @valid_token_flow_data ||= has_voter? && received_voter_token_data[:flow].as_json == voter_data.as_json
103
101
  end
104
102
  end
105
103
  end
@@ -8,10 +8,6 @@
8
8
  <%= form.translated :text_field, :title, autofocus: true %>
9
9
  </div>
10
10
 
11
- <div class="row column">
12
- <%= form.translated :editor, :description %>
13
- </div>
14
-
15
11
  <div class="row column">
16
12
  <%= form.number_field :max_selections, step: 1, min: 0 %>
17
13
  </div>
@@ -14,10 +14,23 @@
14
14
  <% end %>
15
15
  </ul>
16
16
 
17
+ <% if form.needs_census? %>
18
+ <h4><%= t(".census") %></h4>
19
+ <ul class="no-bullet-indented">
20
+ <% form.census_messages.each do |key, value| %>
21
+ <% if form.errors.include?(key) %>
22
+ <li><%= icon "x", class: "text-alert", role: "img", "aria-hidden": true %>&nbsp;<%= form.errors.messages[key][0].html_safe %></li>
23
+ <% else %>
24
+ <li><%= icon "check", class: "text-success", role: "img", "aria-hidden": true %>&nbsp;<%= value.html_safe %></li>
25
+ <% end %>
26
+ <% end %>
27
+ </ul>
28
+ <% end %>
29
+
17
30
  <h4><%= t(".trustees") %></h4>
18
31
  <ul class="no-bullet-indented">
19
32
  <% if form.participatory_space_trustees.none? %>
20
- <li><%= t(".no_trustees") %></li>
33
+ <li><%= icon "x", class: "text-alert", role: "img", "aria-hidden": true %>&nbsp;<%= t(".no_trustees") %></li>
21
34
  <% end %>
22
35
 
23
36
  <% form.participatory_space_trustees.map {|trustee| [trustee, form.trustees.none? || form.trustees.include?(trustee)] }
@@ -61,7 +61,7 @@
61
61
  </div>
62
62
 
63
63
  <div class="button--double form-general-submit">
64
- <%= link_to t("steps.tally.continue", scope: "decidim.elections.admin"), election_steps_path(election), class: "button disabled js-continue-link" %>
64
+ <%= link_to t("steps.tally_started.continue", scope: "decidim.elections.admin"), election_steps_path(election), class: "button disabled js-continue-link" %>
65
65
  </div>
66
66
 
67
67
  <%= javascript_pack_tag "decidim_elections_admin_trustees_process" %>