decidim-elections 0.24.3 → 0.25.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +13 -0
- data/app/cells/decidim/elections/election_m/tags.erb +3 -0
- data/app/cells/decidim/elections/election_m_cell.rb +1 -8
- data/app/cells/decidim/elections/election_preview/show.erb +28 -0
- data/app/cells/decidim/elections/election_preview_cell.rb +13 -0
- data/app/cells/decidim/elections/election_results/blank_votes.erb +7 -0
- data/app/cells/decidim/elections/election_results/progress_bar.erb +16 -0
- data/app/cells/decidim/elections/election_results/show.erb +40 -0
- data/app/cells/decidim/elections/election_results_cell.rb +13 -0
- data/app/cells/decidim/elections/election_vote_cta/show.erb +35 -0
- data/app/cells/decidim/elections/election_vote_cta_cell.rb +83 -0
- data/app/cells/decidim/elections/remaining_time_callout/show.erb +5 -0
- data/app/cells/decidim/elections/remaining_time_callout_cell.rb +28 -0
- data/app/cells/decidim/elections/voting_step_navigation/show.erb +1 -1
- data/app/cells/decidim/elections/voting_step_navigation_cell.rb +1 -1
- data/app/cells/decidim/votings/content_blocks/highlighted_votings/show.erb +1 -1
- data/app/cells/decidim/votings/content_blocks/landing_page/attachments_and_folders_cell.rb +8 -1
- data/app/cells/decidim/votings/content_blocks/landing_page/description/show.erb +25 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/description_cell.rb +20 -2
- data/app/cells/decidim/votings/content_blocks/landing_page/elections/show.erb +15 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/elections/single.erb +11 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/elections_cell.rb +33 -1
- data/app/cells/decidim/votings/content_blocks/landing_page/header/show.erb +29 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/header_cell.rb +95 -2
- data/app/cells/decidim/votings/content_blocks/landing_page/header_settings_form/show.erb +4 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/{stats_cell.rb → header_settings_form_cell.rb} +5 -3
- data/app/cells/decidim/votings/content_blocks/landing_page/metrics/show.erb +12 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/metrics_cell.rb +6 -2
- data/app/cells/decidim/votings/content_blocks/landing_page/polling_stations/address.erb +14 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/polling_stations/map.erb +18 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/polling_stations/show.erb +25 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/polling_stations_cell.rb +42 -1
- data/app/cells/decidim/votings/content_blocks/landing_page/statistics_cell.rb +24 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/timeline/show.erb +7 -0
- data/app/cells/decidim/votings/content_blocks/landing_page/timeline_cell.rb +4 -2
- data/app/cells/decidim/votings/polling_officers/polling_officers_picker/show.erb +1 -1
- data/app/cells/decidim/votings/polling_station_closure_certificate/show.erb +9 -0
- data/app/cells/decidim/votings/polling_station_closure_certificate_cell.rb +12 -0
- data/app/cells/decidim/votings/polling_station_closure_recount/show.erb +74 -0
- data/app/cells/decidim/votings/polling_station_closure_recount_cell.rb +9 -0
- data/app/cells/decidim/votings/voting_m_cell.rb +2 -2
- data/app/commands/decidim/elections/admin/add_user_as_trustee.rb +2 -1
- data/app/commands/decidim/elections/admin/create_election.rb +2 -1
- data/app/commands/decidim/elections/admin/publish_results.rb +10 -6
- data/app/commands/decidim/elections/admin/setup_election.rb +73 -67
- data/app/commands/decidim/elections/admin/update_answer_selection.rb +1 -1
- data/app/commands/decidim/elections/trustee_zone/update_election_bulletin_board_status.rb +61 -2
- data/app/commands/decidim/elections/trustee_zone/update_trustee.rb +3 -0
- data/app/commands/decidim/elections/voter/cast_vote.rb +4 -7
- data/app/commands/decidim/elections/voter/update_vote_status.rb +23 -7
- data/app/commands/decidim/votings/admin/create_ballot_style.rb +58 -0
- data/app/commands/decidim/votings/admin/create_voting.rb +2 -1
- data/app/commands/decidim/votings/admin/destroy_ballot_style.rb +33 -0
- data/app/commands/decidim/votings/admin/monitoring_committee_validate_polling_station_closure.rb +37 -0
- data/app/commands/decidim/votings/admin/update_ballot_style.rb +70 -0
- data/app/commands/decidim/votings/admin/update_voting.rb +5 -14
- data/app/commands/decidim/votings/census/admin/create_dataset.rb +82 -0
- data/app/commands/decidim/votings/census/admin/create_datum.rb +55 -0
- data/app/commands/decidim/votings/census/admin/destroy_dataset.rb +45 -0
- data/app/commands/decidim/votings/census/admin/increment_dataset_processed_rows.rb +43 -0
- data/app/commands/decidim/votings/census/admin/launch_access_codes_export.rb +38 -0
- data/app/commands/decidim/votings/census/admin/launch_access_codes_generation.rb +44 -0
- data/app/commands/decidim/votings/census/admin/update_dataset.rb +51 -0
- data/app/commands/decidim/votings/certify_polling_station_closure.rb +46 -0
- data/app/commands/decidim/votings/check_census.rb +35 -0
- data/app/commands/decidim/votings/create_polling_station_closure.rb +53 -0
- data/app/commands/decidim/votings/create_polling_station_results.rb +83 -0
- data/app/commands/decidim/votings/send_access_code.rb +48 -0
- data/app/commands/decidim/votings/sign_polling_station_closure.rb +41 -0
- data/app/commands/decidim/votings/voter/in_person_vote.rb +55 -0
- data/app/commands/decidim/votings/voter/update_in_person_vote_status.rb +52 -0
- data/app/controllers/concerns/decidim/elections/has_vote_flow.rb +43 -0
- data/app/controllers/concerns/decidim/monitoring_committee_polling_station_closures/admin/filterable.rb +72 -0
- data/app/controllers/concerns/decidim/votings/needs_voting.rb +5 -5
- data/app/controllers/decidim/elections/admin/steps_controller.rb +5 -2
- data/app/controllers/decidim/elections/elections_controller.rb +18 -5
- data/app/controllers/decidim/elections/feedbacks_controller.rb +37 -3
- data/app/controllers/decidim/elections/trustee_zone/elections_controller.rb +15 -1
- data/app/controllers/decidim/elections/votes_controller.rb +101 -41
- data/app/controllers/decidim/votings/admin/ballot_styles_controller.rb +93 -0
- data/app/controllers/decidim/votings/admin/monitoring_committee_election_results_controller.rb +69 -0
- data/app/controllers/decidim/votings/admin/monitoring_committee_members_controller.rb +4 -0
- data/app/controllers/decidim/votings/admin/monitoring_committee_polling_station_closures_controller.rb +73 -0
- data/app/controllers/decidim/votings/admin/monitoring_committee_verify_elections_controller.rb +24 -0
- data/app/controllers/decidim/votings/admin/polling_stations_controller.rb +4 -0
- data/app/controllers/decidim/votings/admin/votings_controller.rb +1 -1
- data/app/controllers/decidim/votings/census/admin/application_controller.rb +19 -0
- data/app/controllers/decidim/votings/census/admin/census_controller.rb +191 -0
- data/app/controllers/decidim/votings/polling_officer_zone/closures_controller.rb +131 -0
- data/app/controllers/decidim/votings/polling_officer_zone/in_person_votes_controller.rb +149 -0
- data/app/controllers/decidim/votings/polling_officer_zone/polling_officers_controller.rb +10 -2
- data/app/controllers/decidim/votings/votings_controller.rb +91 -4
- data/app/events/decidim/elections/votes/vote_accepted_event.rb +1 -1
- data/app/forms/decidim/elections/admin/action_form.rb +5 -0
- data/app/forms/decidim/elections/admin/question_form.rb +1 -1
- data/app/forms/decidim/elections/admin/trustees_participatory_space_form.rb +1 -1
- data/app/forms/decidim/elections/{ballot → voter}/verify_vote_form.rb +1 -5
- data/app/forms/decidim/elections/voter/vote_form.rb +50 -0
- data/app/forms/decidim/votings/admin/ballot_style_form.rb +19 -0
- data/app/forms/decidim/votings/admin/monitoring_committee_polling_station_closure_form.rb +11 -0
- data/app/forms/decidim/votings/admin/publish_results_form.rb +64 -0
- data/app/forms/decidim/votings/admin/voting_form.rb +3 -2
- data/app/forms/decidim/votings/answer_result_form.rb +24 -0
- data/app/forms/decidim/votings/ballot_result_form.rb +28 -0
- data/app/forms/decidim/votings/census/admin/dataset_form.rb +25 -0
- data/app/forms/decidim/votings/census/admin/datum_form.rb +30 -0
- data/app/forms/decidim/votings/census/check_fields.rb +28 -0
- data/app/forms/decidim/votings/census/check_form.rb +13 -0
- data/app/forms/decidim/votings/census/frontend_fields.rb +42 -0
- data/app/forms/decidim/votings/census/in_person_fields.rb +48 -0
- data/app/forms/decidim/votings/census/in_person_form.rb +13 -0
- data/app/forms/decidim/votings/census/login_form.rb +13 -0
- data/app/forms/decidim/votings/census/online_fields.rb +28 -0
- data/app/forms/decidim/votings/closure_certify_form.rb +20 -0
- data/app/forms/decidim/votings/closure_result_form.rb +37 -0
- data/app/forms/decidim/votings/closure_sign_form.rb +11 -0
- data/app/forms/decidim/votings/envelopes_result_form.rb +34 -0
- data/app/forms/decidim/votings/question_result_form.rb +24 -0
- data/app/forms/decidim/votings/voter/in_person_vote_form.rb +40 -0
- data/app/jobs/decidim/votings/census/admin/create_datum_job.rb +41 -0
- data/app/jobs/decidim/votings/census/admin/export_access_codes_job.rb +39 -0
- data/app/jobs/decidim/votings/census/admin/generate_access_codes_job.rb +44 -0
- data/app/mailers/decidim/elections/vote_accepted_mailer.rb +29 -0
- data/app/mailers/decidim/votings/access_code_mailer.rb +34 -0
- data/app/mailers/decidim/votings/census/export_mailer.rb +44 -0
- data/app/models/decidim/elections/action.rb +1 -1
- data/app/models/decidim/elections/answer.rb +21 -0
- data/app/models/decidim/elections/bulletin_board_closure.rb +19 -0
- data/app/models/decidim/elections/election.rb +5 -4
- data/app/models/decidim/elections/question.rb +24 -13
- data/app/models/decidim/elections/result.rb +22 -0
- data/app/models/decidim/elections/trustee.rb +10 -1
- data/app/models/decidim/elections/vote.rb +2 -2
- data/app/models/decidim/votings/ballot_style.rb +29 -0
- data/app/models/decidim/votings/ballot_style_question.rb +11 -0
- data/app/models/decidim/votings/census/dataset.rb +32 -0
- data/app/models/decidim/votings/census/datum.rb +34 -0
- data/app/models/decidim/votings/in_person_vote.rb +22 -0
- data/app/models/decidim/votings/polling_station.rb +18 -1
- data/app/models/decidim/votings/polling_station_closure.rb +43 -0
- data/app/models/decidim/votings/voting.rb +38 -15
- data/app/packs/entrypoints/decidim_elections.js +2 -0
- data/app/packs/entrypoints/decidim_elections_admin_pending_action.js +1 -0
- data/app/packs/entrypoints/decidim_elections_admin_vote_statistics.js +1 -0
- data/app/packs/entrypoints/decidim_elections_election_log.js +1 -0
- data/app/packs/entrypoints/decidim_elections_onboarding.js +1 -0
- data/app/packs/entrypoints/decidim_elections_trustee_key_ceremony.js +1 -0
- data/app/packs/entrypoints/decidim_elections_trustee_tally.js +1 -0
- data/app/packs/entrypoints/decidim_elections_trustee_trustee_zone.js +1 -0
- data/app/packs/entrypoints/decidim_elections_trustee_zone.js +1 -0
- data/app/packs/entrypoints/decidim_elections_trustee_zone.scss +1 -0
- data/app/packs/entrypoints/decidim_elections_voter_casting-vote.js +1 -0
- data/app/packs/entrypoints/decidim_elections_voter_new-vote.js +1 -0
- data/app/packs/entrypoints/decidim_elections_voter_setup-preview.js +1 -0
- data/app/packs/entrypoints/decidim_elections_voter_setup-vote.js +1 -0
- data/app/packs/entrypoints/decidim_elections_voter_verify-vote.js +1 -0
- data/app/packs/entrypoints/decidim_votings_admin_monitoring_committee_members_form.js +1 -0
- data/app/packs/entrypoints/decidim_votings_admin_polling_officers_form.js +1 -0
- data/app/packs/entrypoints/decidim_votings_admin_polling_officers_picker.js +1 -0
- data/app/packs/entrypoints/decidim_votings_admin_polling_stations_form.js +1 -0
- data/app/packs/entrypoints/decidim_votings_admin_update_census_dataset_status.js +1 -0
- data/app/packs/entrypoints/decidim_votings_admin_votings.js +1 -0
- data/app/packs/entrypoints/decidim_votings_admin_votings.scss +1 -0
- data/app/packs/entrypoints/decidim_votings_in-person-vote.js +1 -0
- data/app/packs/entrypoints/decidim_votings_voting-description-cell.js +1 -0
- data/app/packs/entrypoints/decidim_votings_voting_polling_officer_zone-edit-closure.js +1 -0
- data/app/packs/entrypoints/decidim_votings_voting_polling_officer_zone-in-person-vote.js +1 -0
- data/app/packs/entrypoints/decidim_votings_voting_polling_officer_zone-new-closure.js +1 -0
- data/app/packs/entrypoints/decidim_votings_voting_polling_officer_zone-sign-closure.js +1 -0
- data/app/{assets/images/decidim/elections/icon.svg → packs/images/decidim/elections/decidim_elections.svg} +0 -0
- data/app/{assets/images/decidim/votings/icon.svg → packs/images/decidim/votings/decidim_votings.svg} +0 -0
- data/app/{assets/javascripts/decidim/elections/admin/pending_action.js.es6 → packs/src/decidim/elections/admin/pending_action.js} +4 -6
- data/app/{assets/javascripts/decidim/elections/admin/vote_statistics.js.es6 → packs/src/decidim/elections/admin/vote_statistics.js} +0 -0
- data/app/packs/src/decidim/elections/election_log.js +145 -0
- data/app/packs/src/decidim/elections/onboarding.js +5 -0
- data/app/{assets/javascripts/decidim/elections/trustee_zone/key_ceremony.js.es6 → packs/src/decidim/elections/trustee/key_ceremony.js} +59 -22
- data/app/{assets/javascripts/decidim/elections/trustee_zone/tally.js.es6 → packs/src/decidim/elections/trustee/tally.js} +48 -12
- data/app/{assets/javascripts/decidim/elections/trustee_zone.js.es6 → packs/src/decidim/elections/trustee/trustee_zone.js} +3 -6
- data/app/packs/src/decidim/elections/voter/casting-vote.js +14 -0
- data/app/packs/src/decidim/elections/voter/new-vote.js +83 -0
- data/app/packs/src/decidim/elections/voter/setup-preview.js +79 -0
- data/app/packs/src/decidim/elections/voter/setup-vote.js +50 -0
- data/app/{assets/javascripts/decidim/elections/vote_verify.js.es6 → packs/src/decidim/elections/voter/verify-vote.js} +22 -21
- data/app/packs/src/decidim/elections/voter/vote_questions.component.js +124 -0
- data/app/{assets/javascripts/decidim/votings/admin/monitoring_committee_members_form.js.es6 → packs/src/decidim/votings/admin/monitoring_committee_members_form.js} +3 -3
- data/app/{assets/javascripts/decidim/votings/admin/polling_officers_form.js.es6 → packs/src/decidim/votings/admin/polling_officers_form.js} +3 -3
- data/app/{assets/javascripts/decidim/votings/admin/polling_officers_picker.js.es6 → packs/src/decidim/votings/admin/polling_officers_picker.js} +0 -0
- data/app/{assets/javascripts/decidim/votings/admin/polling_stations_form.js.es6 → packs/src/decidim/votings/admin/polling_stations_form.js} +4 -3
- data/app/packs/src/decidim/votings/admin/update_census_dataset_status.js +13 -0
- data/app/packs/src/decidim/votings/in-person-vote.js +20 -0
- data/app/packs/src/decidim/votings/polling_officer_zone/edit-closure.js +26 -0
- data/app/packs/src/decidim/votings/polling_officer_zone/in-person-vote.js +5 -0
- data/app/packs/src/decidim/votings/polling_officer_zone/new-closure.js +35 -0
- data/app/packs/src/decidim/votings/polling_officer_zone/sign-closure.js +13 -0
- data/app/packs/src/decidim/votings/voting-description-cell.js +41 -0
- data/app/packs/stylesheets/decidim/elections/elections.scss +8 -0
- data/app/{assets → packs}/stylesheets/decidim/elections/focus/_accordion.scss +0 -0
- data/app/{assets → packs}/stylesheets/decidim/elections/focus/_evote.scss +8 -1
- data/app/{assets → packs}/stylesheets/decidim/elections/focus/_focus.scss +0 -0
- data/app/{assets → packs}/stylesheets/decidim/elections/trustee_zone.scss +0 -0
- data/app/packs/stylesheets/decidim/votings/admin/votings.scss +3 -0
- data/app/packs/stylesheets/decidim/votings/admin/votings/_ballot-styles.scss +16 -0
- data/app/packs/stylesheets/decidim/votings/admin/votings/_monitoring-committee-polling-station-closures.scss +9 -0
- data/app/packs/stylesheets/decidim/votings/admin/votings/_results.scss +3 -0
- data/app/packs/stylesheets/decidim/votings/votings.scss +2 -0
- data/app/packs/stylesheets/decidim/votings/votings/_polling-stations-cell.scss +6 -0
- data/app/packs/stylesheets/decidim/votings/votings/_voting-description-cell.scss +29 -0
- data/app/permissions/decidim/elections/admin/permissions.rb +5 -0
- data/app/permissions/decidim/elections/permissions.rb +18 -33
- data/app/permissions/decidim/votings/admin/permissions.rb +87 -27
- data/app/permissions/decidim/votings/permissions.rb +5 -1
- data/app/permissions/decidim/votings/polling_officer_zone/permissions.rb +8 -2
- data/app/presenters/decidim/votings/census/admin_log/dataset_presenter.rb +30 -0
- data/app/presenters/decidim/votings/voting_presenter.rb +2 -11
- data/app/presenters/decidim/votings/voting_stats_presenter.rb +52 -0
- data/app/queries/decidim/elections/admin/votes_for_statistics.rb +1 -1
- data/app/queries/decidim/elections/votes/last_vote_for_voter.rb +29 -0
- data/app/queries/decidim/votings/admin/admin_users.rb +15 -10
- data/app/queries/decidim/votings/admin/ballot_style_by_voting_code.rb +31 -0
- data/app/queries/decidim/votings/votes/in_person_vote_for_voter.rb +27 -0
- data/app/queries/decidim/votings/votes/pending_in_person_votes.rb +20 -0
- data/app/serializers/decidim/votings/census/datum_serializer.rb +29 -0
- data/app/services/decidim/elections/current_user_vote_flow.rb +68 -0
- data/app/services/decidim/elections/vote_flow.rb +109 -0
- data/app/services/decidim/votings/census/access_codes_exporter.rb +50 -0
- data/app/services/decidim/votings/census_vote_flow.rb +106 -0
- data/app/uploaders/decidim/cw/votings/census/voting_census_uploader.rb +19 -0
- data/app/views/decidim/elections/admin/answers/index.html.erb +23 -4
- data/app/views/decidim/elections/admin/elections/index.html.erb +5 -5
- data/app/views/decidim/elections/admin/questions/index.html.erb +2 -2
- data/app/views/decidim/elections/admin/steps/_results_published.html.erb +62 -0
- data/app/views/decidim/elections/admin/steps/_tally_ended.html.erb +49 -3
- data/app/views/decidim/elections/admin/steps/_vote.html.erb +1 -1
- data/app/views/decidim/elections/admin/steps/_vote_ended.html.erb +4 -0
- data/app/views/decidim/elections/admin/steps/index.html.erb +2 -2
- data/app/views/decidim/elections/admin/trustees_participatory_spaces/index.html.erb +7 -3
- data/app/views/decidim/elections/elections/_filters.html.erb +1 -0
- data/app/views/decidim/elections/elections/election_log.html.erb +182 -0
- data/app/views/decidim/elections/elections/index.html.erb +0 -2
- data/app/views/decidim/elections/elections/show.html.erb +11 -37
- data/app/views/decidim/elections/trustee_zone/elections/_key_ceremony_steps.html.erb +41 -39
- data/app/views/decidim/elections/trustee_zone/elections/show.html.erb +11 -27
- data/app/views/decidim/elections/trustee_zone/elections/update.js.erb +1 -1
- data/app/views/decidim/elections/trustee_zone/trustees/show.html.erb +7 -7
- data/app/views/decidim/elections/vote_accepted_mailer/notification.html.erb +3 -0
- data/app/views/decidim/elections/votes/{_election_votes_header.html.erb → _focus_header.html.erb} +0 -0
- data/app/views/decidim/elections/votes/_new_ballot_decision_step.html.erb +30 -0
- data/app/views/decidim/elections/votes/{_election_votes_confirm.html.erb → _new_confirm_step.html.erb} +5 -5
- data/app/views/decidim/elections/votes/{_election_votes_confirm_footer.html.erb → _new_confirm_step_footer.html.erb} +2 -3
- data/app/views/decidim/elections/votes/{_election_votes_encrypting.html.erb → _new_encrypting_step.html.erb} +1 -1
- data/app/views/decidim/elections/votes/{_election_votes_question.html.erb → _new_question.html.erb} +7 -7
- data/app/views/decidim/elections/votes/{_election_votes_modal.html.erb → _new_question_modal.html.erb} +1 -1
- data/app/views/decidim/elections/votes/_onboarding_modal.html.erb +23 -0
- data/app/views/decidim/elections/votes/_show_casted.html.erb +36 -0
- data/app/views/decidim/elections/votes/_show_casting.html.erb +25 -0
- data/app/views/decidim/elections/votes/{_election_votes_failed.html.erb → _show_failed.html.erb} +6 -4
- data/app/views/decidim/elections/votes/new.html.erb +29 -16
- data/app/views/decidim/elections/votes/show.html.erb +11 -0
- data/app/views/decidim/elections/votes/verify.html.erb +6 -9
- data/app/views/decidim/votings/access_code_mailer/send_access_code.html.erb +5 -0
- data/app/views/decidim/votings/admin/ballot_styles/_form.html.erb +24 -0
- data/app/views/decidim/votings/admin/ballot_styles/edit.html.erb +7 -0
- data/app/views/decidim/votings/admin/ballot_styles/index.html.erb +68 -0
- data/app/views/decidim/votings/admin/ballot_styles/new.html.erb +7 -0
- data/app/views/decidim/votings/admin/monitoring_committee_election_results/_results.html.erb +53 -0
- data/app/views/decidim/votings/admin/monitoring_committee_election_results/index.html.erb +32 -0
- data/app/views/decidim/votings/admin/monitoring_committee_election_results/show.html.erb +24 -0
- data/app/views/decidim/votings/admin/monitoring_committee_members/_form.html.erb +1 -1
- data/app/views/decidim/votings/admin/monitoring_committee_members/index.html.erb +1 -1
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/_closure_certificate_results.erb +9 -0
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/_closures.html.erb +71 -0
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/_elections.html.erb +32 -0
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/edit.html.erb +29 -0
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/index.html.erb +5 -0
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/show.html.erb +10 -0
- data/app/views/decidim/votings/admin/monitoring_committee_verify_elections/index.html.erb +59 -0
- data/app/views/decidim/votings/admin/polling_officers/_form.html.erb +1 -1
- data/app/views/decidim/votings/admin/polling_officers/index.html.erb +1 -1
- data/app/views/decidim/votings/admin/polling_stations/_form.html.erb +1 -1
- data/app/views/decidim/votings/admin/polling_stations/index.html.erb +2 -2
- data/app/views/decidim/votings/admin/votings/_form.html.erb +9 -2
- data/app/views/decidim/votings/admin/votings/edit.html.erb +1 -1
- data/app/views/decidim/votings/admin/votings/index.html.erb +3 -2
- data/app/views/decidim/votings/census/admin/census/_creating_data.html.erb +10 -0
- data/app/views/decidim/votings/census/admin/census/_export_codes.html.erb +8 -0
- data/app/views/decidim/votings/census/admin/census/_exporting_codes.html.erb +3 -0
- data/app/views/decidim/votings/census/admin/census/_freeze.html.erb +3 -0
- data/app/views/decidim/votings/census/admin/census/_generate_codes.html.erb +25 -0
- data/app/views/decidim/votings/census/admin/census/_generating_codes.html.erb +3 -0
- data/app/views/decidim/votings/census/admin/census/_new_census.html.erb +22 -0
- data/app/views/decidim/votings/census/admin/census/_upload_info.html.erb +17 -0
- data/app/views/decidim/votings/census/admin/census/show.html.erb +23 -0
- data/app/views/decidim/votings/census/admin/census/status.js.erb +1 -0
- data/app/views/decidim/votings/census/export_mailer/access_codes_export.erb +7 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/_answer_results_form_fields.html.erb +12 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/_ballot_results_form_fields.html.erb +40 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/_certify_form.html.erb +15 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/_modal_ballots_count_error.html.erb +60 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/_modal_ballots_results_count_error.html.erb +19 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/_question_results_form_fields.html.erb +22 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/_sign_form.html.erb +55 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/edit.html.erb +48 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/new.html.erb +62 -0
- data/app/views/decidim/votings/polling_officer_zone/closures/show.html.erb +35 -0
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/_complete_voting.html.erb +59 -0
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/_in_person_form.html.erb +50 -0
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/_verify_document.html.erb +23 -0
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/new.html.erb +21 -0
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/show.html.erb +25 -0
- data/app/views/decidim/votings/polling_officer_zone/polling_officers/_polling_station.html.erb +60 -0
- data/app/views/decidim/votings/polling_officer_zone/polling_officers/index.html.erb +15 -0
- data/app/views/decidim/votings/votings/_access_code_modal.html.erb +33 -0
- data/app/views/decidim/votings/votings/_check_fields.html.erb +31 -0
- data/app/views/decidim/votings/votings/_filters.html.erb +1 -0
- data/app/views/decidim/votings/votings/_promoted_voting.html.erb +1 -1
- data/app/views/decidim/votings/votings/check_census.html.erb +64 -0
- data/app/views/decidim/votings/votings/elections_log.html.erb +34 -0
- data/app/views/decidim/votings/votings/index.html.erb +0 -2
- data/app/views/decidim/votings/votings/login.html.erb +50 -0
- data/app/views/decidim/votings/votings/show.html.erb +11 -11
- data/app/views/layouts/decidim/_election_votes_header.html.erb +3 -3
- data/app/views/layouts/decidim/admin/voting.html.erb +5 -83
- data/app/views/layouts/decidim/election_votes.html.erb +1 -0
- data/app/views/layouts/decidim/voting_landing.html.erb +13 -0
- data/app/views/layouts/decidim/{voting.html.erb → votings.html.erb} +3 -1
- data/config/assets.rb +35 -0
- data/config/initializers/decidim_bulletin_board.rb +17 -11
- data/config/initializers/rack_attack.rb +15 -0
- data/config/locales/ca.yml +496 -49
- data/config/locales/cs.yml +498 -43
- data/config/locales/de.yml +469 -44
- data/config/locales/el.yml +0 -14
- data/config/locales/en.yml +491 -42
- data/config/locales/es-MX.yml +338 -42
- data/config/locales/es-PY.yml +338 -42
- data/config/locales/es.yml +338 -42
- data/config/locales/fi-plain.yml +489 -42
- data/config/locales/fi.yml +489 -42
- data/config/locales/fr-CA.yml +241 -39
- data/config/locales/fr-LU.yml +890 -0
- data/config/locales/fr.yml +241 -39
- data/config/locales/gl.yml +418 -34
- data/config/locales/hu.yml +29 -0
- data/config/locales/it.yml +1027 -17
- data/config/locales/ja.yml +578 -17
- data/config/locales/lb-LU.yml +1 -0
- data/config/locales/lv.yml +0 -14
- data/config/locales/nl.yml +308 -42
- data/config/locales/no.yml +12 -36
- data/config/locales/pl.yml +670 -215
- data/config/locales/pt-BR.yml +1338 -0
- data/config/locales/pt.yml +0 -19
- data/config/locales/ro-RO.yml +99 -19
- data/config/locales/sv.yml +49 -22
- data/config/locales/tr-TR.yml +3 -24
- data/config/locales/zh-CN.yml +0 -19
- data/db/migrate/20210308104024_add_decidim_votings_census_datasets.rb +17 -0
- data/db/migrate/20210308104154_add_decidim_votings_census_data.rb +23 -0
- data/db/migrate/20210326090435_create_elections_results.rb +16 -0
- data/db/migrate/20210330102348_remove_votes_count_from_answer.rb +7 -0
- data/db/migrate/20210330123606_add_voting_ballot_style.rb +19 -0
- data/db/migrate/20210330183204_add_email_to_votes.rb +10 -0
- data/db/migrate/20210331152729_add_census_contact_information_to_votings.rb +7 -0
- data/db/migrate/20210401095507_add_organization_to_decidim_elections_trustee.rb +11 -0
- data/db/migrate/20210402102215_add_ballot_style_to_decidim_votings_census_data.rb +7 -0
- data/db/migrate/20210402140402_add_salt_to_elections.rb +22 -0
- data/db/migrate/20210412144721_change_elections_results.rb +24 -0
- data/db/migrate/20210412144740_create_elections_bulletin_board_closures.rb +13 -0
- data/db/migrate/20210412144741_create_votings_polling_station_closures.rb +22 -0
- data/db/migrate/20210420112721_create_decidim_votings_in_person_votes.rb +21 -0
- data/db/migrate/20210422124826_add_verifiable_results_to_decidim_elections_election.rb +8 -0
- data/db/migrate/20210426072845_add_signed_at_to_polling_station_closure.rb +7 -0
- data/db/migrate/20210427131742_add_validated_at_to_votings_polling_station_closures.rb +8 -0
- data/db/seeds/Exampledocument.pdf +0 -0
- data/db/seeds/city2.jpeg +0 -0
- data/lib/decidim/api/bulletin_board_closure_type.rb +16 -0
- data/lib/decidim/api/election_answer_type.rb +3 -2
- data/lib/decidim/api/election_result_type.rb +19 -0
- data/lib/decidim/api/polling_station_closure_type.rb +19 -0
- data/lib/decidim/api/polling_station_type.rb +24 -0
- data/lib/decidim/elections.rb +8 -0
- data/lib/decidim/elections/admin_engine.rb +14 -15
- data/lib/decidim/elections/answer_serializer.rb +2 -1
- data/lib/decidim/elections/api.rb +2 -0
- data/lib/decidim/elections/component.rb +85 -19
- data/lib/decidim/elections/engine.rb +4 -6
- data/lib/decidim/elections/test/factories.rb +76 -11
- data/lib/decidim/elections/trustee_zone_engine.rb +5 -4
- data/lib/decidim/elections/version.rb +1 -1
- data/lib/decidim/votings.rb +17 -0
- data/lib/decidim/votings/admin_engine.rb +134 -8
- data/lib/decidim/votings/api.rb +2 -0
- data/lib/decidim/votings/census.rb +16 -0
- data/lib/decidim/votings/census_admin.rb +12 -0
- data/lib/decidim/votings/census_admin_engine.rb +22 -0
- data/lib/decidim/votings/census_engine.rb +19 -0
- data/lib/decidim/votings/engine.rb +25 -20
- data/lib/decidim/votings/participatory_space.rb +149 -2
- data/lib/decidim/votings/polling_officer_zone_engine.rb +15 -6
- data/lib/decidim/votings/test/factories.rb +163 -0
- data/lib/decidim/votings/voting_serializer.rb +1 -0
- data/lib/tasks/decidim_voting_census.rake +26 -0
- metadata +326 -72
- data/app/assets/config/admin/decidim_votings_manifest.css +0 -0
- data/app/assets/config/admin/decidim_votings_manifest.js +0 -4
- data/app/assets/config/decidim_elections_manifest.css +0 -3
- data/app/assets/config/decidim_elections_manifest.js +0 -8
- data/app/assets/config/decidim_votings_manifest.css +0 -3
- data/app/assets/config/decidim_votings_manifest.js +0 -0
- data/app/assets/javascripts/decidim/elections/vote.js.es6 +0 -117
- data/app/assets/javascripts/decidim/elections/vote_questions.component.js.es6 +0 -129
- data/app/assets/stylesheets/decidim/elections/elections.scss +0 -6
- data/app/assets/stylesheets/decidim/votings/votings.scss +0 -1
- data/app/assets/stylesheets/decidim/votings/votings/_votings-header.scss +0 -99
- data/app/assets/stylesheets/decidim/votings/votings/_votings-home-banner.scss +0 -11
- data/app/controllers/decidim/votings/polling_officer_zone/polling_stations_controller.rb +0 -22
- data/app/forms/decidim/elections/voter/encrypted_vote_form.rb +0 -49
- data/app/helpers/decidim/elections/elections_helper.rb +0 -29
- data/app/queries/decidim/elections/votes/election_votes.rb +0 -19
- data/app/queries/decidim/elections/votes/user_election_last_vote.rb +0 -26
- data/app/queries/decidim/elections/votes/user_votes.rb +0 -19
- data/app/views/decidim/elections/elections/_preview.html.erb +0 -26
- data/app/views/decidim/elections/elections/_results.html.erb +0 -47
- data/app/views/decidim/elections/votes/_election_votes_confirmed.html.erb +0 -47
- data/app/views/decidim/elections/votes/_election_votes_steps_header.html.erb +0 -12
- data/app/views/decidim/elections/votes/cast_failed.js.erb +0 -1
- data/app/views/decidim/elections/votes/cast_success.js.erb +0 -1
- data/app/views/decidim/votings/polling_officer_zone/polling_officers/show.html.erb +0 -42
- data/app/views/decidim/votings/polling_officer_zone/polling_stations/show.html.erb +0 -1
- data/app/views/decidim/votings/votings/_voting_details.html.erb +0 -7
- data/app/views/layouts/decidim/_voting_header.html.erb +0 -16
- data/config/locales/ja-JP.yml +0 -216
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/admin/pending_action";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/admin/vote_statistics";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/election_log";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/onboarding";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/trustee/key_ceremony";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/trustee/tally";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/trustee/trustee_zone";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "entrypoints/decidim_elections_trustee_zone.scss";
|
@@ -0,0 +1 @@
|
|
1
|
+
@import "stylesheets/decidim/elections/trustee_zone";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/voter/casting-vote";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/voter/new-vote";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/voter/setup-preview";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/voter/setup-vote";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/elections/voter/verify-vote";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/admin/monitoring_committee_members_form";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/admin/polling_officers_form";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/admin/polling_officers_picker";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/admin/polling_stations_form";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/admin/update_census_dataset_status";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "entrypoints/decidim_votings_admin_votings.scss";
|
@@ -0,0 +1 @@
|
|
1
|
+
@import "stylesheets/decidim/votings/admin/votings";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/in-person-vote";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/voting-description-cell";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/polling_officer_zone/edit-closure";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/polling_officer_zone/in-person-vote";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/polling_officer_zone/new-closure";
|
@@ -0,0 +1 @@
|
|
1
|
+
import "src/decidim/votings/polling_officer_zone/sign-closure";
|
File without changes
|
data/app/{assets/images/decidim/votings/icon.svg → packs/images/decidim/votings/decidim_votings.svg}
RENAMED
File without changes
|
@@ -1,16 +1,14 @@
|
|
1
|
-
|
1
|
+
import { Client } from "@codegram/decidim-bulletin_board";
|
2
2
|
|
3
3
|
$(() => {
|
4
|
-
const { Client } = decidimBulletinBoard;
|
5
4
|
const $form = $("form.step");
|
6
|
-
const $pendingAction = $form.find("#pending_action")
|
5
|
+
const $pendingAction = $form.find("#pending_action");
|
7
6
|
const bulletinBoardClient = new Client({
|
8
7
|
apiEndpointUrl: $pendingAction.data("apiEndpointUrl")
|
9
8
|
});
|
10
|
-
const messageId = $pendingAction.data("messageId")
|
9
|
+
const messageId = $pendingAction.data("messageId");
|
11
10
|
|
12
11
|
bulletinBoardClient.waitForPendingMessageToBeProcessed(messageId).then(() => {
|
13
|
-
$form.submit
|
12
|
+
$form.trigger("submit");
|
14
13
|
});
|
15
14
|
});
|
16
|
-
|
File without changes
|
@@ -0,0 +1,145 @@
|
|
1
|
+
/**
|
2
|
+
* This file is responsible to get LogEntries
|
3
|
+
* for an election for the election log.
|
4
|
+
*/
|
5
|
+
import { Client, MessageParser } from "@codegram/decidim-bulletin_board";
|
6
|
+
|
7
|
+
$(async () => {
|
8
|
+
// UI Elements
|
9
|
+
const $electionLog = $(".election-log");
|
10
|
+
const $createElectionStep = $electionLog.find("#create-election-step")
|
11
|
+
const $keyCeremonyStep = $electionLog.find("#key-ceremony-step")
|
12
|
+
const $voteStep = $electionLog.find("#vote-step")
|
13
|
+
const $tallyStep = $electionLog.find("#tally-step")
|
14
|
+
const $resultStep = $electionLog.find("#results-step")
|
15
|
+
|
16
|
+
// Data
|
17
|
+
const authorityPublicKeyJSON = JSON.stringify($electionLog.data("authorityPublicKey"))
|
18
|
+
const bulletinBoardClient = new Client({
|
19
|
+
apiEndpointUrl: $electionLog.data("apiEndpointUrl")
|
20
|
+
});
|
21
|
+
const electionUniqueId = `${$electionLog.data("authoritySlug")}.${$electionLog.data("electionId")}`
|
22
|
+
const parser = new MessageParser({ authorityPublicKeyJSON })
|
23
|
+
const logEntries = await bulletinBoardClient.getElectionLogEntries({electionUniqueId: electionUniqueId, types: ["create_election", "start_key_ceremony", "end_key_ceremony", "start_vote", "end_vote", "start_tally", "end_tally", "publish_results"]});
|
24
|
+
|
25
|
+
// Functions to be used for each step
|
26
|
+
|
27
|
+
// adds the `iat` of the message to the UI
|
28
|
+
const setMessageTime = async (logEntryStep, uiStep) => {
|
29
|
+
if (!logEntryStep.signedData) {
|
30
|
+
uiStep.find(".time").html("")
|
31
|
+
return
|
32
|
+
}
|
33
|
+
|
34
|
+
const parsedData = await parser.parse(logEntryStep)
|
35
|
+
const messageTime = new Date(parsedData.decodedData.iat * 1000)
|
36
|
+
const year = messageTime.toDateString()
|
37
|
+
const time = messageTime.toLocaleTimeString()
|
38
|
+
|
39
|
+
uiStep.find(".time").html(`${year} ${time}`)
|
40
|
+
}
|
41
|
+
|
42
|
+
// adds the chained Hash of the message to the UI
|
43
|
+
const addChainedHash = (logEntryStep, uiStep) => {
|
44
|
+
uiStep.find(".card__footer--transparent").removeClass("hide")
|
45
|
+
uiStep.find(".chained-hash").html(logEntryStep.chainedHash)
|
46
|
+
}
|
47
|
+
|
48
|
+
// finds the logEntry for each step
|
49
|
+
const getLogEntryByMessageId = (step) => {
|
50
|
+
return logEntries.find((logEntry) => logEntry.messageId.includes(step))
|
51
|
+
}
|
52
|
+
|
53
|
+
// CREATE ELECTION STEP
|
54
|
+
const createElectionLogEntry = getLogEntryByMessageId("create_election")
|
55
|
+
if (createElectionLogEntry) {
|
56
|
+
$createElectionStep.find(".no-election-created").addClass("hide")
|
57
|
+
$createElectionStep.find(".election-created").removeClass("hide")
|
58
|
+
|
59
|
+
await setMessageTime(createElectionLogEntry, $createElectionStep)
|
60
|
+
|
61
|
+
addChainedHash(createElectionLogEntry, $createElectionStep)
|
62
|
+
}
|
63
|
+
|
64
|
+
// KEY CEREMONY STEP
|
65
|
+
const startKeyCeremonyLogEntry = getLogEntryByMessageId("start_key_ceremony")
|
66
|
+
const endKeyCeremonyLogEntry = getLogEntryByMessageId("end_key_ceremony")
|
67
|
+
|
68
|
+
if (startKeyCeremonyLogEntry && !endKeyCeremonyLogEntry) {
|
69
|
+
$keyCeremonyStep.find(".key-ceremony-not-started").addClass("hide")
|
70
|
+
$keyCeremonyStep.find(".card__text").removeClass("hide")
|
71
|
+
|
72
|
+
await setMessageTime(startKeyCeremonyLogEntry, $keyCeremonyStep)
|
73
|
+
|
74
|
+
$keyCeremonyStep.find(".key-ceremony-started").removeClass("hide")
|
75
|
+
addChainedHash(startKeyCeremonyLogEntry, $keyCeremonyStep)
|
76
|
+
} else if (endKeyCeremonyLogEntry) {
|
77
|
+
$keyCeremonyStep.find(".key-ceremony-not-started").addClass("hide")
|
78
|
+
$keyCeremonyStep.find(".card__text").removeClass("hide")
|
79
|
+
|
80
|
+
await setMessageTime(endKeyCeremonyLogEntry, $keyCeremonyStep)
|
81
|
+
|
82
|
+
$keyCeremonyStep.find(".key-ceremony-started").addClass("hide")
|
83
|
+
$keyCeremonyStep.find(".key-ceremony-completed").removeClass("hide")
|
84
|
+
addChainedHash(endKeyCeremonyLogEntry, $keyCeremonyStep)
|
85
|
+
}
|
86
|
+
|
87
|
+
// VOTING STEP
|
88
|
+
const startVoteLogEntry = getLogEntryByMessageId("start_vote")
|
89
|
+
const endVoteLogEntry = getLogEntryByMessageId("end_vote")
|
90
|
+
|
91
|
+
if (startVoteLogEntry && !endVoteLogEntry) {
|
92
|
+
$voteStep.find(".vote-not-started").addClass("hide")
|
93
|
+
$voteStep.find(".card__text").removeClass("hide")
|
94
|
+
|
95
|
+
await setMessageTime(startVoteLogEntry, $voteStep)
|
96
|
+
|
97
|
+
$voteStep.find(".vote-started").removeClass("hide")
|
98
|
+
addChainedHash(startVoteLogEntry, $voteStep)
|
99
|
+
} else if (endVoteLogEntry) {
|
100
|
+
$voteStep.find(".vote-not-started").addClass("hide")
|
101
|
+
$voteStep.find(".card__text").removeClass("hide")
|
102
|
+
|
103
|
+
await setMessageTime(endVoteLogEntry, $voteStep)
|
104
|
+
|
105
|
+
$voteStep.find(".vote-started").addClass("hide")
|
106
|
+
$voteStep.find(".vote-completed").removeClass("hide")
|
107
|
+
addChainedHash(endVoteLogEntry, $voteStep)
|
108
|
+
}
|
109
|
+
|
110
|
+
// TALLY STEP
|
111
|
+
const startTallyLogEntry = getLogEntryByMessageId("start_tally")
|
112
|
+
const endTallyLogEntry = getLogEntryByMessageId("end_tally")
|
113
|
+
|
114
|
+
if (startTallyLogEntry && !endTallyLogEntry) {
|
115
|
+
$tallyStep.find(".tally-not-started").addClass("hide")
|
116
|
+
$tallyStep.find(".card__text").removeClass("hide")
|
117
|
+
|
118
|
+
await setMessageTime(startTallyLogEntry, $tallyStep)
|
119
|
+
|
120
|
+
$tallyStep.find(".tally-started").removeClass("hide")
|
121
|
+
addChainedHash(startTallyLogEntry, $tallyStep)
|
122
|
+
} else if (endTallyLogEntry) {
|
123
|
+
$tallyStep.find(".tally-not-started").addClass("hide")
|
124
|
+
$tallyStep.find(".card__text").removeClass("hide")
|
125
|
+
|
126
|
+
await setMessageTime(endTallyLogEntry, $tallyStep)
|
127
|
+
|
128
|
+
$tallyStep.find(".tally-started").addClass("hide")
|
129
|
+
$tallyStep.find(".tally-completed").removeClass("hide")
|
130
|
+
addChainedHash(endTallyLogEntry, $tallyStep)
|
131
|
+
}
|
132
|
+
|
133
|
+
// RESULTS STEP
|
134
|
+
const resultsLogEntry = getLogEntryByMessageId("publish_results")
|
135
|
+
|
136
|
+
if (resultsLogEntry) {
|
137
|
+
$resultStep.find(".results-not-published").addClass("hide")
|
138
|
+
$resultStep.find(".card__text").removeClass("hide")
|
139
|
+
|
140
|
+
await setMessageTime(resultsLogEntry, $resultStep)
|
141
|
+
|
142
|
+
$resultStep.find(".results-published").removeClass("hide")
|
143
|
+
addChainedHash(resultsLogEntry, $resultStep)
|
144
|
+
}
|
145
|
+
});
|
@@ -1,4 +1,12 @@
|
|
1
|
-
|
1
|
+
import {
|
2
|
+
KeyCeremonyComponent,
|
3
|
+
MessageIdentifier,
|
4
|
+
IdentificationKeys,
|
5
|
+
MESSAGE_RECEIVED
|
6
|
+
} from "@codegram/decidim-bulletin_board";
|
7
|
+
|
8
|
+
import { TrusteeWrapperAdapter as DummyTrusteeWrapperAdapter } from "@codegram/voting_schemes-dummy";
|
9
|
+
import { TrusteeWrapperAdapter as ElectionGuardTrusteeWrapperAdapter } from "@codegram/voting_schemes-electionguard";
|
2
10
|
|
3
11
|
/**
|
4
12
|
* This file is responsible to generate election keys,
|
@@ -6,15 +14,8 @@
|
|
6
14
|
* update the election bulletin board status
|
7
15
|
*/
|
8
16
|
$(() => {
|
9
|
-
const {
|
10
|
-
KeyCeremonyComponent,
|
11
|
-
MessageIdentifier,
|
12
|
-
IdentificationKeys,
|
13
|
-
MESSAGE_RECEIVED
|
14
|
-
} = window.decidimBulletinBoard;
|
15
|
-
|
16
17
|
// UI Elements
|
17
|
-
const $keyCeremony = $(".
|
18
|
+
const $keyCeremony = $(".trustee-step");
|
18
19
|
const $startButton = $keyCeremony.find(".start");
|
19
20
|
const $backupModal = $("#show-backup-modal");
|
20
21
|
const $backupButton = $backupModal.find(".download-election-keys");
|
@@ -24,35 +25,72 @@ $(() => {
|
|
24
25
|
const getStepRow = (step) => {
|
25
26
|
return $(`#${step.replace(".", "-")}`);
|
26
27
|
};
|
28
|
+
const TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS = 2;
|
27
29
|
|
28
30
|
// Data
|
29
31
|
const bulletinBoardClientParams = {
|
30
32
|
apiEndpointUrl: $keyCeremony.data("apiEndpointUrl")
|
31
|
-
}
|
32
|
-
const electionUniqueId = `${$keyCeremony.data(
|
33
|
+
};
|
34
|
+
const electionUniqueId = `${$keyCeremony.data(
|
35
|
+
"authoritySlug"
|
36
|
+
)}.${$keyCeremony.data("electionId")}`;
|
37
|
+
const authorityPublicKeyJSON = JSON.stringify(
|
38
|
+
$keyCeremony.data("authorityPublicKey")
|
39
|
+
);
|
40
|
+
const schemeName = $keyCeremony.data("schemeName");
|
41
|
+
|
33
42
|
const trusteeContext = {
|
34
|
-
uniqueId: $keyCeremony.data("
|
43
|
+
uniqueId: $keyCeremony.data("trusteeSlug"),
|
35
44
|
publicKeyJSON: JSON.stringify($keyCeremony.data("trusteePublicKey"))
|
36
45
|
};
|
46
|
+
|
37
47
|
let currentStep = null;
|
38
48
|
const trusteeIdentificationKeys = new IdentificationKeys(
|
39
49
|
trusteeContext.uniqueId,
|
40
50
|
trusteeContext.publicKeyJSON
|
41
51
|
);
|
42
52
|
|
43
|
-
// Use the
|
44
|
-
|
45
|
-
|
46
|
-
|
53
|
+
// Use the correct trustee wrapper adapter
|
54
|
+
let trusteeWrapperAdapter = null;
|
55
|
+
|
56
|
+
if (schemeName === "dummy") {
|
57
|
+
trusteeWrapperAdapter = new DummyTrusteeWrapperAdapter({
|
58
|
+
trusteeId: trusteeContext.uniqueId
|
59
|
+
});
|
60
|
+
} else if (schemeName === "electionguard") {
|
61
|
+
trusteeWrapperAdapter = new ElectionGuardTrusteeWrapperAdapter({
|
62
|
+
trusteeId: trusteeContext.uniqueId,
|
63
|
+
workerUrl: "/assets/electionguard/webworker.js"
|
64
|
+
});
|
65
|
+
} else {
|
66
|
+
throw new Error(`Voting scheme ${schemeName} not supported.`);
|
67
|
+
}
|
68
|
+
|
69
|
+
// Use the key ceremony component and bind all UI events
|
70
|
+
const component = new KeyCeremonyComponent({
|
71
|
+
authorityPublicKeyJSON,
|
47
72
|
trusteeUniqueId: trusteeContext.uniqueId,
|
48
|
-
trusteeIdentificationKeys
|
73
|
+
trusteeIdentificationKeys,
|
74
|
+
trusteeWrapperAdapter
|
49
75
|
});
|
50
76
|
|
51
77
|
trusteeIdentificationKeys.present(async (exists) => {
|
52
78
|
if (exists) {
|
53
|
-
await
|
79
|
+
await component.setupElection({
|
80
|
+
bulletinBoardClientParams,
|
81
|
+
electionUniqueId,
|
82
|
+
authorizationExpirationTimestamp:
|
83
|
+
Math.ceil(Number(new Date()) / 1000) +
|
84
|
+
TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS * 3600
|
85
|
+
});
|
86
|
+
|
87
|
+
await component.bindEvents({
|
54
88
|
onBindRestoreButton(onEventTriggered) {
|
55
|
-
$restoreButton.on(
|
89
|
+
$restoreButton.on(
|
90
|
+
"change",
|
91
|
+
".restore-button-input",
|
92
|
+
onEventTriggered
|
93
|
+
);
|
56
94
|
},
|
57
95
|
onBindStartButton(onEventTriggered) {
|
58
96
|
$startButton.on("click", onEventTriggered);
|
@@ -65,9 +103,6 @@ $(() => {
|
|
65
103
|
$backupButton.attr("download", backupFilename);
|
66
104
|
$backupButton.on("click", onEventTriggered);
|
67
105
|
},
|
68
|
-
onSetup() {
|
69
|
-
$startButton.prop("disabled", false);
|
70
|
-
},
|
71
106
|
onEvent(event) {
|
72
107
|
let messageIdentifier = MessageIdentifier.parse(
|
73
108
|
event.message.messageId
|
@@ -121,6 +156,8 @@ $(() => {
|
|
121
156
|
$backupModal.foundation("close");
|
122
157
|
}
|
123
158
|
});
|
159
|
+
|
160
|
+
$startButton.prop("disabled", false);
|
124
161
|
}
|
125
162
|
});
|
126
163
|
});
|
@@ -1,10 +1,16 @@
|
|
1
|
-
|
1
|
+
import {
|
2
|
+
TallyComponent,
|
3
|
+
IdentificationKeys,
|
4
|
+
MessageIdentifier,
|
5
|
+
MESSAGE_RECEIVED
|
6
|
+
} from "@codegram/decidim-bulletin_board";
|
2
7
|
|
3
|
-
|
4
|
-
|
8
|
+
import { TrusteeWrapperAdapter as DummyTrusteeWrapperAdapter } from "@codegram/voting_schemes-dummy";
|
9
|
+
import { TrusteeWrapperAdapter as ElectionGuardTrusteeWrapperAdapter } from "@codegram/voting_schemes-electionguard";
|
5
10
|
|
11
|
+
$(() => {
|
6
12
|
// UI Elements
|
7
|
-
const $tally = $(".
|
13
|
+
const $tally = $(".trustee-step");
|
8
14
|
const $startButton = $tally.find(".start");
|
9
15
|
const getStepRow = (step) => {
|
10
16
|
return $(`#${step.replace(".", "-")}`);
|
@@ -12,14 +18,22 @@ $(() => {
|
|
12
18
|
const $restoreModal = $("#show-restore-modal");
|
13
19
|
const $restoreButton = $restoreModal.find(".upload-election-keys");
|
14
20
|
const $backButton = $tally.find(".back");
|
21
|
+
const TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS = 2;
|
15
22
|
|
16
23
|
// Data
|
17
24
|
const bulletinBoardClientParams = {
|
18
25
|
apiEndpointUrl: $tally.data("apiEndpointUrl")
|
19
26
|
};
|
20
|
-
const electionUniqueId = `${$tally.data("
|
27
|
+
const electionUniqueId = `${$tally.data("authoritySlug")}.${$tally.data(
|
28
|
+
"electionId"
|
29
|
+
)}`;
|
30
|
+
const authorityPublicKeyJSON = JSON.stringify(
|
31
|
+
$tally.data("authorityPublicKey")
|
32
|
+
);
|
33
|
+
const schemeName = $tally.data("schemeName");
|
34
|
+
|
21
35
|
const trusteeContext = {
|
22
|
-
uniqueId: $tally.data("
|
36
|
+
uniqueId: $tally.data("trusteeSlug"),
|
23
37
|
publicKeyJSON: JSON.stringify($tally.data("trusteePublicKey"))
|
24
38
|
};
|
25
39
|
const trusteeIdentificationKeys = new IdentificationKeys(
|
@@ -28,15 +42,39 @@ $(() => {
|
|
28
42
|
);
|
29
43
|
let currentStep = null;
|
30
44
|
|
45
|
+
// Use the correct trustee wrapper adapter
|
46
|
+
let trusteeWrapperAdapter = null;
|
47
|
+
|
48
|
+
if (schemeName === "dummy") {
|
49
|
+
trusteeWrapperAdapter = new DummyTrusteeWrapperAdapter({
|
50
|
+
trusteeId: trusteeContext.uniqueId
|
51
|
+
});
|
52
|
+
} else if (schemeName === "electionguard") {
|
53
|
+
trusteeWrapperAdapter = new ElectionGuardTrusteeWrapperAdapter({
|
54
|
+
trusteeId: trusteeContext.uniqueId,
|
55
|
+
workerUrl: "/assets/electionguard/webworker.js"
|
56
|
+
});
|
57
|
+
} else {
|
58
|
+
throw new Error(`Voting scheme ${schemeName} not supported.`);
|
59
|
+
}
|
60
|
+
|
31
61
|
// Use the tally component and bind all UI events
|
32
62
|
const component = new TallyComponent({
|
33
|
-
|
34
|
-
electionUniqueId,
|
63
|
+
authorityPublicKeyJSON,
|
35
64
|
trusteeUniqueId: trusteeContext.uniqueId,
|
36
|
-
trusteeIdentificationKeys
|
65
|
+
trusteeIdentificationKeys,
|
66
|
+
trusteeWrapperAdapter
|
37
67
|
});
|
38
68
|
|
39
69
|
const bindComponentEvents = async () => {
|
70
|
+
await component.setupElection({
|
71
|
+
bulletinBoardClientParams,
|
72
|
+
electionUniqueId,
|
73
|
+
authorizationExpirationTimestamp:
|
74
|
+
Math.ceil(Number(new Date()) / 1000) +
|
75
|
+
TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS * 3600
|
76
|
+
});
|
77
|
+
|
40
78
|
await component.bindEvents({
|
41
79
|
onEvent(event) {
|
42
80
|
let messageIdentifier = MessageIdentifier.parse(
|
@@ -56,9 +94,6 @@ $(() => {
|
|
56
94
|
}
|
57
95
|
}
|
58
96
|
},
|
59
|
-
onSetup() {
|
60
|
-
$startButton.prop("disabled", false);
|
61
|
-
},
|
62
97
|
onBindStartButton(onEventTriggered) {
|
63
98
|
$startButton.on("click", onEventTriggered);
|
64
99
|
},
|
@@ -94,6 +129,7 @@ $(() => {
|
|
94
129
|
$restoreModal.foundation("close");
|
95
130
|
}
|
96
131
|
});
|
132
|
+
$startButton.prop("disabled", false);
|
97
133
|
};
|
98
134
|
|
99
135
|
trusteeIdentificationKeys.present(async (exists) => {
|