decidim-elections 0.27.9 → 0.28.0.rc4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +60 -3
- data/app/cells/decidim/elections/content_blocks/related_elections_cell.rb +13 -0
- data/app/cells/decidim/elections/election_cell.rb +7 -2
- data/app/cells/decidim/elections/election_g_cell.rb +23 -0
- data/app/cells/decidim/elections/election_metadata_cell.rb +57 -0
- data/app/cells/decidim/elections/election_preview/show.erb +24 -24
- data/app/cells/decidim/elections/election_results/progress_bar.erb +6 -7
- data/app/cells/decidim/elections/election_results/show.erb +36 -33
- data/app/cells/decidim/elections/election_s_cell.rb +10 -0
- data/app/cells/decidim/elections/election_vote_cta/show.erb +14 -26
- data/app/cells/decidim/elections/election_vote_cta_cell.rb +0 -9
- data/app/cells/decidim/elections/highlighted_elections_for_component/show.erb +18 -0
- data/app/cells/decidim/elections/highlighted_elections_for_component_cell.rb +50 -0
- data/app/cells/decidim/elections/remaining_time_callout/show.erb +1 -3
- data/app/cells/decidim/elections/voting_step_navigation/show.erb +21 -25
- data/app/cells/decidim/elections/voting_step_navigation_cell.rb +2 -2
- data/app/cells/decidim/votings/content_block_cell.rb +5 -1
- data/app/cells/decidim/votings/content_blocks/hero_cell.rb +53 -0
- data/app/cells/decidim/votings/content_blocks/hero_settings_form_cell.rb +15 -0
- data/app/cells/decidim/votings/content_blocks/highlighted_votings_cell.rb +12 -21
- data/app/cells/decidim/votings/content_blocks/highlighted_votings_settings_form/show.erb +1 -1
- data/app/cells/decidim/votings/content_blocks/main_data_cell.rb +34 -0
- data/app/cells/decidim/votings/content_blocks/metrics_cell.rb +17 -0
- data/app/cells/decidim/votings/content_blocks/polling_stations/show.erb +21 -0
- data/app/cells/decidim/votings/content_blocks/polling_stations_cell.rb +31 -0
- data/app/cells/decidim/votings/content_blocks/statistics_cell.rb +18 -0
- data/app/cells/decidim/votings/polling_officers/polling_officers_picker/show.erb +14 -13
- data/app/cells/decidim/votings/polling_officers/polling_officers_picker_cell.rb +19 -16
- data/app/cells/decidim/votings/polling_station_closure_certificate/show.erb +5 -7
- data/app/cells/decidim/votings/polling_station_closure_recount/show.erb +55 -59
- data/app/cells/decidim/votings/voting_cell.rb +7 -2
- data/app/cells/decidim/votings/voting_dropdown_metadata_cell.rb +19 -0
- data/app/cells/decidim/votings/voting_g_cell.rb +19 -0
- data/app/cells/decidim/votings/voting_map/show.erb +16 -0
- data/app/cells/decidim/votings/voting_map_cell.rb +28 -0
- data/app/cells/decidim/votings/voting_metadata_cell.rb +66 -0
- data/app/cells/decidim/votings/voting_s_cell.rb +10 -0
- data/app/commands/decidim/elections/admin/add_user_as_trustee.rb +5 -5
- data/app/commands/decidim/elections/admin/create_answer.rb +0 -1
- data/app/commands/decidim/elections/admin/create_election.rb +0 -1
- data/app/commands/decidim/elections/admin/destroy_answer.rb +0 -1
- data/app/commands/decidim/elections/admin/destroy_election.rb +0 -1
- data/app/commands/decidim/elections/admin/end_vote.rb +2 -2
- data/app/commands/decidim/elections/admin/import_proposals_to_elections.rb +1 -1
- data/app/commands/decidim/elections/admin/publish_election.rb +1 -1
- data/app/commands/decidim/elections/admin/publish_results.rb +2 -2
- data/app/commands/decidim/elections/admin/report_missing_trustee.rb +2 -2
- data/app/commands/decidim/elections/admin/setup_election.rb +2 -2
- data/app/commands/decidim/elections/admin/start_key_ceremony.rb +2 -2
- data/app/commands/decidim/elections/admin/start_tally.rb +2 -2
- data/app/commands/decidim/elections/admin/start_vote.rb +2 -2
- data/app/commands/decidim/elections/admin/unpublish_election.rb +1 -1
- data/app/commands/decidim/elections/admin/update_answer.rb +0 -1
- data/app/commands/decidim/elections/admin/update_answer_selection.rb +1 -1
- data/app/commands/decidim/elections/admin/update_election.rb +0 -1
- data/app/commands/decidim/elections/trustee_zone/update_election_bulletin_board_status.rb +3 -3
- data/app/commands/decidim/elections/voter/cast_vote.rb +1 -1
- data/app/commands/decidim/elections/voter/update_vote_status.rb +2 -2
- data/app/commands/decidim/votings/admin/create_ballot_style.rb +1 -1
- data/app/commands/decidim/votings/admin/create_monitoring_committee_member.rb +4 -4
- data/app/commands/decidim/votings/admin/create_polling_officer.rb +4 -4
- data/app/commands/decidim/votings/admin/create_polling_station.rb +1 -1
- data/app/commands/decidim/votings/admin/create_voting.rb +1 -1
- data/app/commands/decidim/votings/admin/destroy_ballot_style.rb +1 -1
- data/app/commands/decidim/votings/admin/destroy_monitoring_committee_member.rb +1 -1
- data/app/commands/decidim/votings/admin/destroy_polling_officer.rb +1 -1
- data/app/commands/decidim/votings/admin/manage_polling_station.rb +1 -1
- data/app/commands/decidim/votings/admin/monitoring_committee_validate_polling_station_closure.rb +1 -1
- data/app/commands/decidim/votings/admin/update_ballot_style.rb +1 -1
- data/app/commands/decidim/votings/admin/update_voting.rb +1 -1
- data/app/commands/decidim/votings/census/admin/create_dataset.rb +2 -2
- data/app/commands/decidim/votings/census/admin/create_datum.rb +3 -3
- data/app/commands/decidim/votings/census/admin/destroy_dataset.rb +1 -1
- data/app/commands/decidim/votings/census/admin/increment_dataset_processed_rows.rb +1 -1
- data/app/commands/decidim/votings/census/admin/launch_access_codes_generation.rb +1 -1
- data/app/commands/decidim/votings/census/admin/update_dataset.rb +1 -1
- data/app/commands/decidim/votings/certify_polling_station_closure.rb +1 -2
- data/app/commands/decidim/votings/create_polling_station_closure.rb +1 -1
- data/app/commands/decidim/votings/create_polling_station_results.rb +1 -1
- data/app/commands/decidim/votings/send_access_code.rb +5 -1
- data/app/commands/decidim/votings/sign_polling_station_closure.rb +2 -2
- data/app/commands/decidim/votings/voter/in_person_vote.rb +1 -1
- data/app/constraints/decidim/votings/current_voting.rb +1 -1
- data/app/controllers/concerns/decidim/elections/content_security_policy.rb +23 -0
- data/app/controllers/concerns/decidim/elections/has_vote_flow.rb +2 -2
- data/app/controllers/concerns/decidim/votings/admin/voting_admin.rb +1 -1
- data/app/controllers/concerns/decidim/votings/needs_voting.rb +1 -1
- data/app/controllers/decidim/elections/admin/answers_controller.rb +9 -10
- data/app/controllers/decidim/elections/admin/application_controller.rb +1 -0
- data/app/controllers/decidim/elections/admin/elections_controller.rb +7 -7
- data/app/controllers/decidim/elections/admin/feedback_forms_controller.rb +2 -2
- data/app/controllers/decidim/elections/admin/proposals_imports_controller.rb +3 -3
- data/app/controllers/decidim/elections/admin/questions_controller.rb +7 -7
- data/app/controllers/decidim/elections/admin/steps_controller.rb +4 -4
- data/app/controllers/decidim/elections/admin/trustees_participatory_spaces_controller.rb +2 -2
- data/app/controllers/decidim/elections/application_controller.rb +1 -0
- data/app/controllers/decidim/elections/elections_controller.rb +5 -2
- data/app/controllers/decidim/elections/trustee_zone/application_controller.rb +1 -0
- data/app/controllers/decidim/elections/trustee_zone/elections_controller.rb +2 -2
- data/app/controllers/decidim/elections/trustee_zone/trustees_controller.rb +3 -3
- data/app/controllers/decidim/elections/votes_controller.rb +19 -13
- data/app/controllers/decidim/votings/admin/monitoring_committee_election_results_controller.rb +11 -3
- data/app/controllers/decidim/votings/admin/monitoring_committee_members_controller.rb +3 -3
- data/app/controllers/decidim/votings/admin/monitoring_committee_polling_station_closures_controller.rb +3 -3
- data/app/controllers/decidim/votings/admin/polling_officers_controller.rb +3 -3
- data/app/controllers/decidim/votings/admin/polling_stations_controller.rb +3 -4
- data/app/controllers/decidim/votings/admin/voting_attachment_collections_controller.rb +5 -0
- data/app/controllers/decidim/votings/admin/voting_attachments_controller.rb +5 -0
- data/app/controllers/decidim/votings/admin/voting_publications_controller.rb +25 -0
- data/app/controllers/decidim/votings/admin/votings_controller.rb +2 -26
- data/app/controllers/decidim/votings/admin/votings_landing_page_content_blocks_controller.rb +1 -5
- data/app/controllers/decidim/votings/admin/votings_landing_page_controller.rb +4 -7
- data/app/controllers/decidim/votings/census/admin/census_controller.rb +2 -2
- data/app/controllers/decidim/votings/polling_officer_zone/closures_controller.rb +12 -12
- data/app/controllers/decidim/votings/polling_officer_zone/in_person_votes_controller.rb +17 -10
- data/app/controllers/decidim/votings/polling_officer_zone/polling_officers_controller.rb +1 -1
- data/app/controllers/decidim/votings/votings_controller.rb +7 -9
- data/app/events/decidim/elections/election_published_event.rb +1 -1
- data/app/events/decidim/elections/trustees/notify_new_trustee_event.rb +1 -1
- data/app/events/decidim/elections/trustees/notify_trustee_new_election_event.rb +1 -1
- data/app/events/decidim/elections/votes/vote_accepted_event.rb +1 -1
- data/app/events/decidim/votings/polling_officers/polling_station_assigned_event.rb +1 -1
- data/app/forms/decidim/elections/admin/answer_form.rb +1 -1
- data/app/forms/decidim/elections/admin/election_form.rb +1 -1
- data/app/forms/decidim/votings/admin/publish_results_form.rb +5 -5
- data/app/forms/decidim/votings/admin/voting_form.rb +1 -1
- data/app/forms/decidim/votings/admin/{polling_officer_form.rb → voting_user_role_form.rb} +1 -1
- data/app/forms/decidim/votings/census/frontend_fields.rb +1 -1
- data/app/forms/decidim/votings/census/in_person_fields.rb +8 -4
- data/app/forms/decidim/votings/closure_result_form.rb +2 -2
- data/app/helpers/decidim/elections/admin/trustees_participatory_spaces_helper.rb +4 -2
- data/app/helpers/decidim/elections/application_helper.rb +8 -0
- data/app/helpers/decidim/votings/map_helper.rb +22 -0
- data/app/helpers/decidim/votings/votings_helper.rb +33 -0
- data/app/jobs/decidim/votings/census/admin/create_datum_job.rb +1 -1
- data/app/jobs/decidim/votings/census/admin/generate_access_codes_job.rb +2 -2
- data/app/mailers/decidim/votings/access_code_mailer.rb +1 -1
- data/app/mailers/decidim/votings/census/export_mailer.rb +1 -1
- data/app/models/decidim/elections/trustee.rb +2 -2
- data/app/models/decidim/votings/ballot_style.rb +1 -1
- data/app/models/decidim/votings/polling_officer.rb +2 -2
- data/app/models/decidim/votings/polling_station.rb +1 -1
- data/app/packs/entrypoints/decidim_elections.js +12 -0
- data/app/packs/entrypoints/decidim_elections_admin.js +6 -0
- data/app/packs/entrypoints/decidim_votings.js +11 -0
- data/app/packs/entrypoints/decidim_votings_admin.js +10 -0
- data/app/packs/src/decidim/elections/admin/pending_action.js +10 -7
- data/app/packs/src/decidim/elections/admin/trustees_process.js +107 -104
- data/app/packs/src/decidim/elections/admin/vote_statistics.js +6 -3
- data/app/packs/src/decidim/elections/broken_promises_handler.js +9 -7
- data/app/packs/src/decidim/elections/election_log.js +126 -128
- data/app/packs/src/decidim/elections/trustee/key_ceremony.js +138 -139
- data/app/packs/src/decidim/elections/trustee/tally.js +122 -118
- data/app/packs/src/decidim/elections/trustee/trustee_zone.js +9 -7
- data/app/packs/src/decidim/elections/voter/casting-vote.js +9 -7
- data/app/packs/src/decidim/elections/voter/new-vote.js +92 -71
- data/app/packs/src/decidim/elections/voter/setup-preview.js +0 -4
- data/app/packs/src/decidim/elections/voter/setup-vote.js +0 -4
- data/app/packs/src/decidim/elections/voter/verify-vote.js +11 -6
- data/app/packs/src/decidim/elections/voter/vote_questions.component.js +74 -28
- data/app/packs/src/decidim/votings/admin/polling_officers_picker.js +16 -31
- data/app/packs/src/decidim/votings/admin/polling_stations_form.js +4 -1
- data/app/packs/src/decidim/votings/admin/{polling_officers_form.js → voting_user_role_form.js} +1 -1
- data/app/packs/src/decidim/votings/in-person-vote.js +4 -4
- data/app/packs/src/decidim/votings/polling_officer_zone/edit-closure.js +4 -4
- data/app/packs/src/decidim/votings/polling_officer_zone/in-person-vote.js +1 -1
- data/app/packs/src/decidim/votings/polling_officer_zone/new-closure.js +6 -8
- data/app/packs/stylesheets/decidim/elections/elections.scss +200 -6
- data/app/packs/stylesheets/decidim/votings/admin/votings/_ballot-styles.scss +3 -3
- data/app/packs/stylesheets/decidim/votings/admin/votings/_monitoring-committee-polling-station-closures.scss +2 -2
- data/app/packs/stylesheets/decidim/votings/admin/votings/_results.scss +1 -1
- data/app/packs/stylesheets/decidim/votings/admin/votings.scss +20 -0
- data/app/packs/stylesheets/decidim/votings/votings.scss +53 -2
- data/app/permissions/decidim/votings/admin/permissions.rb +2 -2
- data/app/presenters/decidim/elections/admin_log/election_presenter.rb +2 -2
- data/app/presenters/decidim/elections/admin_log/trustee_presenter.rb +2 -2
- data/app/presenters/decidim/elections/trustee_presenter.rb +1 -1
- data/app/presenters/decidim/votings/admin_log/ballot_style_presenter.rb +2 -2
- data/app/presenters/decidim/votings/admin_log/monitoring_committee_member_presenter.rb +2 -2
- data/app/presenters/decidim/votings/admin_log/polling_officer_presenter.rb +2 -2
- data/app/presenters/decidim/votings/admin_log/polling_station_presenter.rb +2 -2
- data/app/presenters/decidim/votings/admin_log/voting_presenter.rb +2 -2
- data/app/presenters/decidim/votings/census/admin_log/dataset_presenter.rb +2 -2
- data/app/presenters/decidim/votings/voting_stats_presenter.rb +3 -42
- data/app/services/decidim/votings/census/access_codes_exporter.rb +1 -1
- data/app/services/decidim/votings/census_vote_flow.rb +3 -3
- data/app/views/decidim/elections/admin/answers/_form.html.erb +16 -18
- data/app/views/decidim/elections/admin/answers/edit.html.erb +21 -5
- data/app/views/decidim/elections/admin/answers/index.html.erb +33 -18
- data/app/views/decidim/elections/admin/answers/new.html.erb +21 -5
- data/app/views/decidim/elections/admin/elections/_form.html.erb +20 -19
- data/app/views/decidim/elections/admin/elections/edit.html.erb +16 -6
- data/app/views/decidim/elections/admin/elections/index.html.erb +72 -70
- data/app/views/decidim/elections/admin/elections/new.html.erb +16 -6
- data/app/views/decidim/elections/admin/proposals_imports/new.html.erb +36 -21
- data/app/views/decidim/elections/admin/questions/_form.html.erb +18 -20
- data/app/views/decidim/elections/admin/questions/edit.html.erb +20 -6
- data/app/views/decidim/elections/admin/questions/index.html.erb +50 -49
- data/app/views/decidim/elections/admin/questions/new.html.erb +20 -5
- data/app/views/decidim/elections/admin/steps/_create_election.html.erb +41 -36
- data/app/views/decidim/elections/admin/steps/_created.html.erb +2 -2
- data/app/views/decidim/elections/admin/steps/_key_ceremony.html.erb +7 -7
- data/app/views/decidim/elections/admin/steps/_key_ceremony_ended.html.erb +2 -2
- data/app/views/decidim/elections/admin/steps/_results_published.html.erb +4 -4
- data/app/views/decidim/elections/admin/steps/_tally_ended.html.erb +4 -4
- data/app/views/decidim/elections/admin/steps/_tally_started.html.erb +11 -11
- data/app/views/decidim/elections/admin/steps/_vote.html.erb +3 -3
- data/app/views/decidim/elections/admin/steps/_vote_ended.html.erb +2 -2
- data/app/views/decidim/elections/admin/steps/_vote_stats.html.erb +2 -2
- data/app/views/decidim/elections/admin/steps/index.html.erb +44 -37
- data/app/views/decidim/elections/admin/trustees_participatory_spaces/_form.html.erb +10 -14
- data/app/views/decidim/elections/admin/trustees_participatory_spaces/index.html.erb +57 -60
- data/app/views/decidim/elections/admin/trustees_participatory_spaces/new.html.erb +16 -5
- data/app/views/decidim/elections/elections/_elections.html.erb +9 -16
- data/app/views/decidim/elections/elections/election_log.html.erb +171 -179
- data/app/views/decidim/elections/elections/index.html.erb +18 -21
- data/app/views/decidim/elections/elections/index.js.erb +0 -5
- data/app/views/decidim/elections/elections/show.html.erb +63 -39
- data/app/views/decidim/elections/shared/_broken_promises_modal.html.erb +18 -27
- data/app/views/decidim/elections/trustee_zone/elections/_backup_modal.html.erb +10 -20
- data/app/views/decidim/elections/trustee_zone/elections/_key_ceremony_steps.html.erb +32 -27
- data/app/views/decidim/elections/trustee_zone/elections/_restore_modal.html.erb +11 -21
- data/app/views/decidim/elections/trustee_zone/elections/_tally_started_steps.html.erb +46 -41
- data/app/views/decidim/elections/trustee_zone/elections/show.html.erb +4 -6
- data/app/views/decidim/elections/trustee_zone/trustees/_no_public_keys.html.erb +30 -0
- data/app/views/decidim/elections/trustee_zone/trustees/_public_keys.html.erb +17 -0
- data/app/views/decidim/elections/trustee_zone/trustees/_table.html.erb +28 -0
- data/app/views/decidim/elections/trustee_zone/trustees/show.html.erb +21 -96
- data/app/views/decidim/elections/votes/_new_ballot_decision_step.html.erb +22 -26
- data/app/views/decidim/elections/votes/_new_confirm_step.html.erb +59 -47
- data/app/views/decidim/elections/votes/_new_encrypting_step.html.erb +8 -19
- data/app/views/decidim/elections/votes/_new_question.html.erb +12 -28
- data/app/views/decidim/elections/votes/_new_question_modal.html.erb +20 -23
- data/app/views/decidim/elections/votes/_onboarding_modal.html.erb +14 -22
- data/app/views/decidim/elections/votes/_show_casted.html.erb +28 -30
- data/app/views/decidim/elections/votes/_show_casting.html.erb +12 -19
- data/app/views/decidim/elections/votes/_show_failed.html.erb +20 -17
- data/app/views/decidim/elections/votes/new.html.erb +78 -61
- data/app/views/decidim/elections/votes/show.html.erb +12 -11
- data/app/views/decidim/elections/votes/verify.html.erb +40 -61
- data/app/views/decidim/votings/admin/ballot_styles/_form.html.erb +19 -19
- data/app/views/decidim/votings/admin/ballot_styles/edit.html.erb +16 -6
- data/app/views/decidim/votings/admin/ballot_styles/index.html.erb +50 -54
- data/app/views/decidim/votings/admin/ballot_styles/new.html.erb +16 -6
- data/app/views/decidim/votings/admin/monitoring_committee_election_results/_results.html.erb +43 -46
- data/app/views/decidim/votings/admin/monitoring_committee_election_results/index.html.erb +23 -25
- data/app/views/decidim/votings/admin/monitoring_committee_election_results/show.html.erb +5 -5
- data/app/views/decidim/votings/admin/monitoring_committee_members/_form.html.erb +19 -20
- data/app/views/decidim/votings/admin/monitoring_committee_members/index.html.erb +32 -34
- data/app/views/decidim/votings/admin/monitoring_committee_members/new.html.erb +17 -6
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/_closure_certificate_results.erb +1 -1
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/_closures.html.erb +53 -56
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/_elections.html.erb +22 -25
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/edit.html.erb +12 -11
- data/app/views/decidim/votings/admin/monitoring_committee_polling_station_closures/show.html.erb +1 -1
- data/app/views/decidim/votings/admin/monitoring_committee_verify_elections/index.html.erb +37 -39
- data/app/views/decidim/votings/admin/polling_officers/_form.html.erb +19 -20
- data/app/views/decidim/votings/admin/polling_officers/index.html.erb +40 -41
- data/app/views/decidim/votings/admin/polling_officers/new.html.erb +17 -6
- data/app/views/decidim/votings/admin/polling_stations/_form.html.erb +25 -31
- data/app/views/decidim/votings/admin/polling_stations/edit.html.erb +17 -6
- data/app/views/decidim/votings/admin/polling_stations/index.html.erb +46 -47
- data/app/views/decidim/votings/admin/polling_stations/new.html.erb +17 -6
- data/app/views/decidim/votings/admin/votings/_form.html.erb +49 -52
- data/app/views/decidim/votings/admin/votings/edit.html.erb +35 -28
- data/app/views/decidim/votings/admin/votings/index.html.erb +58 -82
- data/app/views/decidim/votings/admin/votings/new.html.erb +16 -9
- data/app/views/decidim/votings/census/admin/census/_creating_data.html.erb +4 -4
- data/app/views/decidim/votings/census/admin/census/_export_codes.html.erb +3 -3
- data/app/views/decidim/votings/census/admin/census/_generate_codes.html.erb +8 -8
- data/app/views/decidim/votings/census/admin/census/_new_census.html.erb +8 -7
- data/app/views/decidim/votings/census/admin/census/_upload_info.html.erb +5 -5
- data/app/views/decidim/votings/census/admin/census/show.html.erb +7 -7
- data/app/views/decidim/votings/polling_officer_zone/closures/_answer_results_form_fields.html.erb +2 -3
- data/app/views/decidim/votings/polling_officer_zone/closures/_ballot_results_form_fields.html.erb +24 -35
- data/app/views/decidim/votings/polling_officer_zone/closures/_certify_form.html.erb +5 -9
- data/app/views/decidim/votings/polling_officer_zone/closures/_modal_ballots_count_error.html.erb +34 -48
- data/app/views/decidim/votings/polling_officer_zone/closures/_modal_ballots_results_count_error.html.erb +18 -18
- data/app/views/decidim/votings/polling_officer_zone/closures/_question_results_form_fields.html.erb +12 -17
- data/app/views/decidim/votings/polling_officer_zone/closures/_sign_form.html.erb +34 -49
- data/app/views/decidim/votings/polling_officer_zone/closures/edit.html.erb +50 -37
- data/app/views/decidim/votings/polling_officer_zone/closures/new.html.erb +57 -51
- data/app/views/decidim/votings/polling_officer_zone/closures/show.html.erb +44 -34
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/_complete_voting.html.erb +40 -57
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/_in_person_form.html.erb +34 -47
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/_verify_document.html.erb +19 -22
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/new.html.erb +12 -12
- data/app/views/decidim/votings/polling_officer_zone/in_person_votes/show.html.erb +22 -21
- data/app/views/decidim/votings/polling_officer_zone/polling_officers/_polling_station.html.erb +34 -41
- data/app/views/decidim/votings/polling_officer_zone/polling_officers/index.html.erb +9 -5
- data/app/views/decidim/votings/votings/_access_code_modal.html.erb +26 -31
- data/app/views/decidim/votings/votings/_check_fields.html.erb +19 -28
- data/app/views/decidim/votings/votings/_polling_officers_picker.html.erb +4 -0
- data/app/views/decidim/votings/votings/_votings.html.erb +5 -11
- data/app/views/decidim/votings/votings/check_census.html.erb +53 -53
- data/app/views/decidim/votings/votings/elections_log.html.erb +25 -22
- data/app/views/decidim/votings/votings/index.html.erb +24 -25
- data/app/views/decidim/votings/votings/index.js.erb +0 -5
- data/app/views/decidim/votings/votings/login.html.erb +51 -44
- data/app/views/decidim/votings/votings/show.html.erb +5 -7
- data/app/views/layouts/decidim/admin/voting.html.erb +11 -11
- data/app/views/layouts/decidim/admin/votings.html.erb +16 -0
- data/app/views/layouts/decidim/votings.html.erb +10 -14
- data/config/assets.rb +3 -28
- data/config/locales/ar.yml +0 -6
- data/config/locales/bg.yml +0 -1431
- data/config/locales/ca.yml +169 -223
- data/config/locales/cs.yml +157 -210
- data/config/locales/de.yml +161 -215
- data/config/locales/el.yml +164 -108
- data/config/locales/en.yml +183 -237
- data/config/locales/es-MX.yml +164 -218
- data/config/locales/es-PY.yml +163 -217
- data/config/locales/es.yml +168 -222
- data/config/locales/eu.yml +165 -222
- data/config/locales/fi-plain.yml +154 -208
- data/config/locales/fi.yml +162 -216
- data/config/locales/fr-CA.yml +168 -223
- data/config/locales/fr.yml +171 -226
- data/config/locales/ga-IE.yml +0 -40
- data/config/locales/gl.yml +2 -79
- data/config/locales/hu.yml +0 -62
- data/config/locales/it.yml +6 -243
- data/config/locales/ja.yml +173 -227
- data/config/locales/lt.yml +135 -204
- data/config/locales/lv.yml +0 -34
- data/config/locales/nl.yml +2 -211
- data/config/locales/no.yml +1 -131
- data/config/locales/pl.yml +3 -407
- data/config/locales/pt-BR.yml +4 -374
- data/config/locales/pt.yml +4 -245
- data/config/locales/ro-RO.yml +2 -143
- data/config/locales/ru.yml +0 -5
- data/config/locales/sk.yml +0 -5
- data/config/locales/sv.yml +12 -109
- data/config/locales/tr-TR.yml +58 -126
- data/config/locales/uk.yml +0 -5
- data/config/locales/zh-CN.yml +1 -68
- data/config/locales/zh-TW.yml +84 -166
- data/db/migrate/20210310120708_add_followable_counter_cache_to_votings.rb +2 -6
- data/lib/decidim/api/election_type.rb +1 -1
- data/lib/decidim/api/elections_type.rb +1 -1
- data/lib/decidim/elections/admin_engine.rb +4 -19
- data/lib/decidim/elections/component.rb +4 -452
- data/lib/decidim/elections/engine.rb +23 -1
- data/lib/decidim/elections/menu.rb +39 -0
- data/lib/decidim/elections/seeds.rb +435 -0
- data/lib/decidim/elections/test/factories.rb +22 -21
- data/lib/decidim/elections/trustee_zone_engine.rb +3 -7
- data/lib/decidim/elections/version.rb +1 -1
- data/lib/decidim/elections.rb +6 -0
- data/lib/decidim/votings/admin_engine.rb +16 -122
- data/lib/decidim/votings/census_admin_engine.rb +4 -8
- data/lib/decidim/votings/census_menu.rb +18 -0
- data/lib/decidim/votings/content_blocks/registry_manager.rb +88 -0
- data/lib/decidim/votings/engine.rb +12 -88
- data/lib/decidim/votings/menu.rb +164 -0
- data/lib/decidim/votings/participatory_space.rb +6 -190
- data/lib/decidim/votings/polling_officer_zone_engine.rb +3 -7
- data/lib/decidim/votings/polling_officer_zone_menu.rb +17 -0
- data/lib/decidim/votings/query_extensions.rb +4 -4
- data/lib/decidim/votings/seeds.rb +197 -0
- data/lib/decidim/votings/test/factories.rb +29 -13
- data/lib/decidim/votings/voting_serializer.rb +1 -1
- data/lib/tasks/decidim_elections.rake +2 -2
- metadata +76 -125
- data/app/cells/decidim/elections/election_m/data.erb +0 -19
- data/app/cells/decidim/elections/election_m/footer.erb +0 -5
- data/app/cells/decidim/elections/election_m/tags.erb +0 -3
- data/app/cells/decidim/elections/election_m_cell.rb +0 -96
- data/app/cells/decidim/elections/election_results/blank_votes.erb +0 -7
- data/app/cells/decidim/votings/content_blocks/highlighted_votings/show.erb +0 -30
- data/app/cells/decidim/votings/content_blocks/landing_page/attachments_and_folders_cell.rb +0 -22
- data/app/cells/decidim/votings/content_blocks/landing_page/description/show.erb +0 -15
- data/app/cells/decidim/votings/content_blocks/landing_page/description_cell.rb +0 -25
- data/app/cells/decidim/votings/content_blocks/landing_page/elections/show.erb +0 -15
- data/app/cells/decidim/votings/content_blocks/landing_page/elections/single.erb +0 -11
- data/app/cells/decidim/votings/content_blocks/landing_page/elections_cell.rb +0 -47
- data/app/cells/decidim/votings/content_blocks/landing_page/header/show.erb +0 -29
- data/app/cells/decidim/votings/content_blocks/landing_page/header_cell.rb +0 -108
- data/app/cells/decidim/votings/content_blocks/landing_page/header_settings_form_cell.rb +0 -17
- data/app/cells/decidim/votings/content_blocks/landing_page/metrics/show.erb +0 -12
- data/app/cells/decidim/votings/content_blocks/landing_page/metrics_cell.rb +0 -19
- data/app/cells/decidim/votings/content_blocks/landing_page/polling_stations/address.erb +0 -14
- data/app/cells/decidim/votings/content_blocks/landing_page/polling_stations/map.erb +0 -18
- data/app/cells/decidim/votings/content_blocks/landing_page/polling_stations/show.erb +0 -25
- data/app/cells/decidim/votings/content_blocks/landing_page/polling_stations_cell.rb +0 -56
- data/app/cells/decidim/votings/content_blocks/landing_page/statistics_cell.rb +0 -24
- data/app/cells/decidim/votings/content_blocks/landing_page/timeline/show.erb +0 -7
- data/app/cells/decidim/votings/content_blocks/landing_page/timeline_cell.rb +0 -17
- data/app/cells/decidim/votings/polling_officers/polling_officers_picker/polling_officers.erb +0 -12
- data/app/cells/decidim/votings/voting_m/data.erb +0 -21
- data/app/cells/decidim/votings/voting_m/footer.erb +0 -5
- data/app/cells/decidim/votings/voting_m_cell.rb +0 -94
- data/app/commands/decidim/votings/admin/publish_voting.rb +0 -40
- data/app/commands/decidim/votings/admin/unpublish_voting.rb +0 -40
- data/app/forms/decidim/votings/admin/monitoring_committee_member_form.rb +0 -27
- data/app/helpers/decidim/votings/admin/polling_officers_picker_helper.rb +0 -29
- data/app/packs/entrypoints/decidim_elections_admin_pending_action.js +0 -1
- data/app/packs/entrypoints/decidim_elections_admin_trustees_process.js +0 -1
- data/app/packs/entrypoints/decidim_elections_admin_vote_statistics.js +0 -1
- data/app/packs/entrypoints/decidim_elections_election_log.js +0 -1
- data/app/packs/entrypoints/decidim_elections_onboarding.js +0 -1
- data/app/packs/entrypoints/decidim_elections_trustee_key_ceremony.js +0 -1
- data/app/packs/entrypoints/decidim_elections_trustee_tally_started.js +0 -1
- data/app/packs/entrypoints/decidim_elections_trustee_trustee_zone.js +0 -1
- data/app/packs/entrypoints/decidim_elections_trustee_zone.js +0 -1
- data/app/packs/entrypoints/decidim_elections_trustee_zone.scss +0 -1
- data/app/packs/entrypoints/decidim_elections_voter_casting-vote.js +0 -1
- data/app/packs/entrypoints/decidim_elections_voter_new-vote.js +0 -1
- data/app/packs/entrypoints/decidim_elections_voter_setup-preview.js +0 -1
- data/app/packs/entrypoints/decidim_elections_voter_setup-vote.js +0 -1
- data/app/packs/entrypoints/decidim_elections_voter_verify-vote.js +0 -1
- data/app/packs/entrypoints/decidim_votings_admin_monitoring_committee_members_form.js +0 -1
- data/app/packs/entrypoints/decidim_votings_admin_polling_officers_form.js +0 -1
- data/app/packs/entrypoints/decidim_votings_admin_polling_officers_picker.js +0 -1
- data/app/packs/entrypoints/decidim_votings_admin_polling_stations_form.js +0 -1
- data/app/packs/entrypoints/decidim_votings_admin_update_census_dataset_status.js +0 -1
- data/app/packs/entrypoints/decidim_votings_admin_votings.js +0 -1
- data/app/packs/entrypoints/decidim_votings_admin_votings.scss +0 -1
- data/app/packs/entrypoints/decidim_votings_in-person-vote.js +0 -1
- data/app/packs/entrypoints/decidim_votings_voting-description-cell.js +0 -1
- data/app/packs/entrypoints/decidim_votings_voting_polling_officer_zone-edit-closure.js +0 -1
- data/app/packs/entrypoints/decidim_votings_voting_polling_officer_zone-in-person-vote.js +0 -1
- data/app/packs/entrypoints/decidim_votings_voting_polling_officer_zone-new-closure.js +0 -1
- data/app/packs/entrypoints/decidim_votings_voting_polling_officer_zone-sign-closure.js +0 -1
- data/app/packs/src/decidim/elections/onboarding.js +0 -5
- data/app/packs/src/decidim/votings/admin/monitoring_committee_members_form.js +0 -35
- data/app/packs/src/decidim/votings/voting-description-cell.js +0 -34
- data/app/packs/stylesheets/decidim/elections/focus/_accordion.scss +0 -36
- data/app/packs/stylesheets/decidim/elections/focus/_evote.scss +0 -344
- data/app/packs/stylesheets/decidim/elections/focus/_focus.scss +0 -128
- data/app/packs/stylesheets/decidim/elections/trustee_zone.scss +0 -24
- data/app/packs/stylesheets/decidim/votings/votings/_polling-stations-cell.scss +0 -6
- data/app/packs/stylesheets/decidim/votings/votings/_voting-description-cell.scss +0 -29
- data/app/views/decidim/elections/admin/answers/proposals_picker.html.erb +0 -1
- data/app/views/decidim/elections/elections/_count.html.erb +0 -1
- data/app/views/decidim/elections/elections/_election.html.erb +0 -1
- data/app/views/decidim/elections/elections/_filters.html.erb +0 -25
- data/app/views/decidim/elections/elections/_filters_small_view.html.erb +0 -18
- data/app/views/decidim/elections/votes/_focus_header.html.erb +0 -8
- data/app/views/decidim/elections/votes/_new_confirm_step_footer.html.erb +0 -23
- data/app/views/decidim/votings/admin/votings/polling_officers_picker.html.erb +0 -2
- data/app/views/decidim/votings/votings/_count.html.erb +0 -1
- data/app/views/decidim/votings/votings/_filters.html.erb +0 -25
- data/app/views/decidim/votings/votings/_filters_small_view.html.erb +0 -23
- data/app/views/decidim/votings/votings/_promoted_voting.html.erb +0 -27
- data/app/views/layouts/decidim/_election_votes_header.html.erb +0 -13
- data/app/views/layouts/decidim/election_votes.html.erb +0 -27
- data/app/views/layouts/decidim/voting_landing.html.erb +0 -13
- data/config/locales/he-IL.yml +0 -1
- data/db/seeds/Exampledocument.pdf +0 -0
- data/db/seeds/city.jpeg +0 -0
- data/db/seeds/city2.jpeg +0 -0
- data/decidim-elections.gemspec +0 -37
- data/lib/decidim/elections/seeds/city.jpeg +0 -0
- data/lib/decidim/votings/test/capybara_polling_officers_picker.rb +0 -49
- /data/app/cells/decidim/votings/content_blocks/{landing_page/header_settings_form → hero_settings_form}/show.erb +0 -0
@@ -6,156 +6,154 @@ import { Client, MessageParser } from "@decidim/decidim-bulletin_board";
|
|
6
6
|
|
7
7
|
$(async () => {
|
8
8
|
// UI Elements
|
9
|
-
const $electionLog = $("
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
9
|
+
const $electionLog = $("#election-log");
|
10
|
+
|
11
|
+
if ($electionLog.length) {
|
12
|
+
const $createElectionStep = $electionLog.find("#create-election-step");
|
13
|
+
const $keyCeremonyStep = $electionLog.find("#key-ceremony-step");
|
14
|
+
const $voteStep = $electionLog.find("#vote-step");
|
15
|
+
const $tallyStep = $electionLog.find("#tally-step");
|
16
|
+
const $resultStep = $electionLog.find("#results-step");
|
17
|
+
|
18
|
+
// Data
|
19
|
+
const authorityPublicKeyJSON = JSON.stringify(
|
20
|
+
$electionLog.data("authorityPublicKey")
|
21
|
+
);
|
22
|
+
const bulletinBoardClient = new Client({
|
23
|
+
apiEndpointUrl: $electionLog.data("apiEndpointUrl")
|
24
|
+
});
|
25
|
+
const electionUniqueId = `${$electionLog.data(
|
26
|
+
"authoritySlug"
|
27
|
+
)}.${$electionLog.data("electionId")}`;
|
28
|
+
const parser = new MessageParser({ authorityPublicKeyJSON });
|
29
|
+
const logEntries = await bulletinBoardClient.getElectionLogEntries({
|
30
|
+
electionUniqueId: electionUniqueId,
|
31
|
+
types: [
|
32
|
+
"create_election",
|
33
|
+
"start_key_ceremony",
|
34
|
+
"end_key_ceremony",
|
35
|
+
"start_vote",
|
36
|
+
"end_vote",
|
37
|
+
"start_tally",
|
38
|
+
"end_tally",
|
39
|
+
"publish_results"
|
40
|
+
]
|
41
|
+
});
|
42
|
+
|
43
|
+
// Functions to be used for each step
|
44
|
+
|
45
|
+
// adds the `iat` of the message to the UI
|
46
|
+
const setMessageTime = async (logEntryStep, uiStep) => {
|
47
|
+
if (!logEntryStep.signedData) {
|
48
|
+
uiStep.find("[data-time]").html("");
|
49
|
+
return;
|
50
|
+
}
|
51
|
+
|
52
|
+
const parsedData = await parser.parse(logEntryStep);
|
53
|
+
const messageTime = new Date(parsedData.decodedData.iat * 1000);
|
54
|
+
const year = messageTime.toDateString();
|
55
|
+
const time = messageTime.toLocaleTimeString();
|
56
|
+
|
57
|
+
uiStep.find("[data-time]").html(`${year} ${time}`);
|
58
|
+
};
|
59
|
+
|
60
|
+
// adds the chained Hash of the message to the UI
|
61
|
+
const addChainedHash = (logEntryStep, uiStep) => {
|
62
|
+
const $hash = uiStep.find("[data-chained-hash]");
|
63
|
+
|
64
|
+
$hash.parent().attr("hidden", false);
|
65
|
+
$hash.html(logEntryStep.chainedHash);
|
66
|
+
};
|
67
|
+
|
68
|
+
// finds the logEntry for each step
|
69
|
+
const getLogEntryByMessageId = (step) => {
|
70
|
+
return logEntries.find((logEntry) => logEntry.messageId.includes(step));
|
71
|
+
};
|
72
|
+
|
73
|
+
// CREATE ELECTION STEP
|
74
|
+
const createElectionLogEntry = getLogEntryByMessageId("create_election");
|
75
|
+
if (createElectionLogEntry) {
|
76
|
+
$createElectionStep.find("[data-no-election-created]").attr("hidden", true);
|
77
|
+
$createElectionStep.find("[data-election-created]").attr("hidden", false);
|
78
|
+
|
79
|
+
await setMessageTime(createElectionLogEntry, $createElectionStep);
|
80
|
+
|
81
|
+
addChainedHash(createElectionLogEntry, $createElectionStep);
|
48
82
|
}
|
49
83
|
|
50
|
-
|
51
|
-
const
|
52
|
-
const
|
53
|
-
const time = messageTime.toLocaleTimeString();
|
84
|
+
// KEY CEREMONY STEP
|
85
|
+
const startKeyCeremonyLogEntry = getLogEntryByMessageId("start_key_ceremony");
|
86
|
+
const endKeyCeremonyLogEntry = getLogEntryByMessageId("end_key_ceremony");
|
54
87
|
|
55
|
-
|
56
|
-
|
88
|
+
if (startKeyCeremonyLogEntry && !endKeyCeremonyLogEntry) {
|
89
|
+
$keyCeremonyStep.find("[data-key-ceremony-not-started]").attr("hidden", true);
|
57
90
|
|
58
|
-
|
59
|
-
const addChainedHash = (logEntryStep, uiStep) => {
|
60
|
-
uiStep.find(".card__footer--transparent").removeClass("hide");
|
61
|
-
uiStep.find(".chained-hash").html(logEntryStep.chainedHash);
|
62
|
-
};
|
91
|
+
await setMessageTime(startKeyCeremonyLogEntry, $keyCeremonyStep);
|
63
92
|
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
93
|
+
$keyCeremonyStep.find("[data-key-ceremony-started]").attr("hidden", false);
|
94
|
+
addChainedHash(startKeyCeremonyLogEntry, $keyCeremonyStep);
|
95
|
+
} else if (endKeyCeremonyLogEntry) {
|
96
|
+
$keyCeremonyStep.find("[data-key-ceremony-not-started]").attr("hidden", true);
|
68
97
|
|
69
|
-
|
70
|
-
const createElectionLogEntry = getLogEntryByMessageId("create_election");
|
71
|
-
if (createElectionLogEntry) {
|
72
|
-
$createElectionStep.find(".no-election-created").addClass("hide");
|
73
|
-
$createElectionStep.find(".election-created").removeClass("hide");
|
98
|
+
await setMessageTime(endKeyCeremonyLogEntry, $keyCeremonyStep);
|
74
99
|
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
// KEY CEREMONY STEP
|
81
|
-
const startKeyCeremonyLogEntry = getLogEntryByMessageId("start_key_ceremony");
|
82
|
-
const endKeyCeremonyLogEntry = getLogEntryByMessageId("end_key_ceremony");
|
83
|
-
|
84
|
-
if (startKeyCeremonyLogEntry && !endKeyCeremonyLogEntry) {
|
85
|
-
$keyCeremonyStep.find(".key-ceremony-not-started").addClass("hide");
|
86
|
-
$keyCeremonyStep.find(".card__text").removeClass("hide");
|
87
|
-
|
88
|
-
await setMessageTime(startKeyCeremonyLogEntry, $keyCeremonyStep);
|
89
|
-
|
90
|
-
$keyCeremonyStep.find(".key-ceremony-started").removeClass("hide");
|
91
|
-
addChainedHash(startKeyCeremonyLogEntry, $keyCeremonyStep);
|
92
|
-
} else if (endKeyCeremonyLogEntry) {
|
93
|
-
$keyCeremonyStep.find(".key-ceremony-not-started").addClass("hide");
|
94
|
-
$keyCeremonyStep.find(".card__text").removeClass("hide");
|
95
|
-
|
96
|
-
await setMessageTime(endKeyCeremonyLogEntry, $keyCeremonyStep);
|
97
|
-
|
98
|
-
$keyCeremonyStep.find(".key-ceremony-started").addClass("hide");
|
99
|
-
$keyCeremonyStep.find(".key-ceremony-completed").removeClass("hide");
|
100
|
-
addChainedHash(endKeyCeremonyLogEntry, $keyCeremonyStep);
|
101
|
-
}
|
100
|
+
$keyCeremonyStep.find("[data-key-ceremony-started]").attr("hidden", true);
|
101
|
+
$keyCeremonyStep.find("[data-key-ceremony-completed]").attr("hidden", false);
|
102
|
+
addChainedHash(endKeyCeremonyLogEntry, $keyCeremonyStep);
|
103
|
+
}
|
102
104
|
|
103
|
-
|
104
|
-
|
105
|
-
|
105
|
+
// VOTING STEP
|
106
|
+
const startVoteLogEntry = getLogEntryByMessageId("start_vote");
|
107
|
+
const endVoteLogEntry = getLogEntryByMessageId("end_vote");
|
106
108
|
|
107
|
-
|
108
|
-
|
109
|
-
$voteStep.find(".card__text").removeClass("hide");
|
109
|
+
if (startVoteLogEntry && !endVoteLogEntry) {
|
110
|
+
$voteStep.find("[data-vote-not-started]").attr("hidden", true);
|
110
111
|
|
111
|
-
|
112
|
+
await setMessageTime(startVoteLogEntry, $voteStep);
|
112
113
|
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
$voteStep.find(".card__text").removeClass("hide");
|
114
|
+
$voteStep.find("[data-vote-started]").attr("hidden", false);
|
115
|
+
addChainedHash(startVoteLogEntry, $voteStep);
|
116
|
+
} else if (endVoteLogEntry) {
|
117
|
+
$voteStep.find("[data-vote-not-started]").attr("hidden", true);
|
118
118
|
|
119
|
-
|
119
|
+
await setMessageTime(endVoteLogEntry, $voteStep);
|
120
120
|
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
121
|
+
$voteStep.find("[data-vote-started]").attr("hidden", true);
|
122
|
+
$voteStep.find("[data-vote-completed]").attr("hidden", false);
|
123
|
+
addChainedHash(endVoteLogEntry, $voteStep);
|
124
|
+
}
|
125
125
|
|
126
|
-
|
127
|
-
|
128
|
-
|
126
|
+
// TALLY STEP
|
127
|
+
const startTallyLogEntry = getLogEntryByMessageId("start_tally");
|
128
|
+
const endTallyLogEntry = getLogEntryByMessageId("end_tally");
|
129
129
|
|
130
|
-
|
131
|
-
|
132
|
-
$tallyStep.find(".card__text").removeClass("hide");
|
130
|
+
if (startTallyLogEntry && !endTallyLogEntry) {
|
131
|
+
$tallyStep.find("[data-tally-not-started]").attr("hidden", true);
|
133
132
|
|
134
|
-
|
133
|
+
await setMessageTime(startTallyLogEntry, $tallyStep);
|
135
134
|
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
$tallyStep.find(".card__text").removeClass("hide");
|
135
|
+
$tallyStep.find("[data-tally-started]").attr("hidden", false);
|
136
|
+
addChainedHash(startTallyLogEntry, $tallyStep);
|
137
|
+
} else if (endTallyLogEntry) {
|
138
|
+
$tallyStep.find("[data-tally-not-started]").attr("hidden", true);
|
141
139
|
|
142
|
-
|
140
|
+
await setMessageTime(endTallyLogEntry, $tallyStep);
|
143
141
|
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
142
|
+
$tallyStep.find("[data-tally-started]").attr("hidden", true);
|
143
|
+
$tallyStep.find("[data-tally-completed]").attr("hidden", false);
|
144
|
+
addChainedHash(endTallyLogEntry, $tallyStep);
|
145
|
+
}
|
148
146
|
|
149
|
-
|
150
|
-
|
147
|
+
// RESULTS STEP
|
148
|
+
const resultsLogEntry = getLogEntryByMessageId("publish_results");
|
151
149
|
|
152
|
-
|
153
|
-
|
154
|
-
$resultStep.find(".card__text").removeClass("hide");
|
150
|
+
if (resultsLogEntry) {
|
151
|
+
$resultStep.find("[data-results-not-published]").attr("hidden", true);
|
155
152
|
|
156
|
-
|
153
|
+
await setMessageTime(resultsLogEntry, $resultStep);
|
157
154
|
|
158
|
-
|
159
|
-
|
155
|
+
$resultStep.find("[data-results-published]").attr("hidden", false);
|
156
|
+
addChainedHash(resultsLogEntry, $resultStep);
|
157
|
+
}
|
160
158
|
}
|
161
159
|
});
|
@@ -18,149 +18,148 @@ import { TrusteeWrapperAdapter as ElectionGuardTrusteeWrapperAdapter } from "@de
|
|
18
18
|
*/
|
19
19
|
$(() => {
|
20
20
|
// UI Elements
|
21
|
-
const $keyCeremony = $("
|
22
|
-
const
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
});
|
63
|
-
} else if (schemeName === "electionguard") {
|
64
|
-
trusteeWrapperAdapter = new ElectionGuardTrusteeWrapperAdapter({
|
65
|
-
trusteeId: trusteeContext.uniqueId,
|
66
|
-
workerUrl: "/assets/electionguard/webworker.js"
|
67
|
-
});
|
68
|
-
} else {
|
69
|
-
throw new Error(`Voting scheme ${schemeName} not supported.`);
|
70
|
-
}
|
71
|
-
|
72
|
-
// Use the key ceremony component and bind all UI events
|
73
|
-
const component = new KeyCeremonyComponent({
|
74
|
-
authorityPublicKeyJSON,
|
75
|
-
trusteeUniqueId: trusteeContext.uniqueId,
|
76
|
-
trusteeIdentificationKeys,
|
77
|
-
trusteeWrapperAdapter
|
78
|
-
});
|
79
|
-
|
80
|
-
trusteeIdentificationKeys.present(async (exists) => {
|
81
|
-
if (exists) {
|
82
|
-
await component.setupElection({
|
83
|
-
bulletinBoardClientParams,
|
84
|
-
electionUniqueId,
|
85
|
-
authorizationExpirationTimestamp:
|
86
|
-
Math.ceil(Number(new Date()) / 1000) +
|
87
|
-
TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS * 3600
|
21
|
+
const $keyCeremony = $("#trustee-step");
|
22
|
+
const trusteeStep = $keyCeremony.data("currentStep")
|
23
|
+
|
24
|
+
if ($keyCeremony.length && trusteeStep === "key_ceremony") {
|
25
|
+
const $startButton = $keyCeremony.find("#start");
|
26
|
+
const $backButton = $keyCeremony.find("#back");
|
27
|
+
|
28
|
+
const getStepRow = (step) => {
|
29
|
+
return $(`#${step.replace(".", "-")}`);
|
30
|
+
};
|
31
|
+
const TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS = 2;
|
32
|
+
|
33
|
+
// Data
|
34
|
+
const bulletinBoardClientParams = {
|
35
|
+
apiEndpointUrl: $keyCeremony.data("apiEndpointUrl")
|
36
|
+
};
|
37
|
+
const electionUniqueId = `${$keyCeremony.data(
|
38
|
+
"authoritySlug"
|
39
|
+
)}.${$keyCeremony.data("electionId")}`;
|
40
|
+
const authorityPublicKeyJSON = JSON.stringify(
|
41
|
+
$keyCeremony.data("authorityPublicKey")
|
42
|
+
);
|
43
|
+
const schemeName = $keyCeremony.data("schemeName");
|
44
|
+
|
45
|
+
const trusteeContext = {
|
46
|
+
uniqueId: $keyCeremony.data("trusteeSlug"),
|
47
|
+
publicKeyJSON: JSON.stringify($keyCeremony.data("trusteePublicKey"))
|
48
|
+
};
|
49
|
+
|
50
|
+
let currentStep = null;
|
51
|
+
const trusteeIdentificationKeys = new IdentificationKeys(
|
52
|
+
trusteeContext.uniqueId,
|
53
|
+
trusteeContext.publicKeyJSON
|
54
|
+
);
|
55
|
+
|
56
|
+
// Use the correct trustee wrapper adapter
|
57
|
+
let trusteeWrapperAdapter = null;
|
58
|
+
|
59
|
+
if (schemeName === "dummy") {
|
60
|
+
trusteeWrapperAdapter = new DummyTrusteeWrapperAdapter({
|
61
|
+
trusteeId: trusteeContext.uniqueId
|
88
62
|
});
|
63
|
+
} else if (schemeName === "electionguard") {
|
64
|
+
trusteeWrapperAdapter = new ElectionGuardTrusteeWrapperAdapter({
|
65
|
+
trusteeId: trusteeContext.uniqueId,
|
66
|
+
workerUrl: "/assets/electionguard/webworker.js"
|
67
|
+
});
|
68
|
+
} else {
|
69
|
+
throw new Error(`Voting scheme ${schemeName} not supported.`);
|
70
|
+
}
|
89
71
|
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
},
|
98
|
-
onBindStartButton(onEventTriggered) {
|
99
|
-
$startButton.on("click", onEventTriggered);
|
100
|
-
},
|
101
|
-
onBindBackupButton(backupData, backupFilename, onEventTriggered) {
|
102
|
-
$backupButton.attr(
|
103
|
-
"href",
|
104
|
-
`data:text/plain;charset=utf-8,${backupData}`
|
105
|
-
);
|
106
|
-
$backupButton.attr("download", backupFilename);
|
107
|
-
$backupButton.on("click", onEventTriggered);
|
108
|
-
},
|
109
|
-
onEvent(event) {
|
110
|
-
let messageIdentifier = MessageIdentifier.parse(
|
111
|
-
event.message.messageId
|
112
|
-
);
|
113
|
-
|
114
|
-
if (event.type === MESSAGE_RECEIVED) {
|
115
|
-
if (currentStep && currentStep !== messageIdentifier.typeSubtype) {
|
116
|
-
const $previousStep = getStepRow(currentStep);
|
117
|
-
$previousStep.attr("data-step-status", "completed");
|
118
|
-
}
|
119
|
-
currentStep = messageIdentifier.typeSubtype;
|
72
|
+
// Use the key ceremony component and bind all UI events
|
73
|
+
const component = new KeyCeremonyComponent({
|
74
|
+
authorityPublicKeyJSON,
|
75
|
+
trusteeUniqueId: trusteeContext.uniqueId,
|
76
|
+
trusteeIdentificationKeys,
|
77
|
+
trusteeWrapperAdapter
|
78
|
+
});
|
120
79
|
|
121
|
-
|
122
|
-
|
123
|
-
|
80
|
+
trusteeIdentificationKeys.present(async (exists) => {
|
81
|
+
if (exists) {
|
82
|
+
await component.setupElection({
|
83
|
+
bulletinBoardClientParams,
|
84
|
+
electionUniqueId,
|
85
|
+
authorizationExpirationTimestamp:
|
86
|
+
Math.ceil(Number(new Date()) / 1000) +
|
87
|
+
TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS * 3600
|
88
|
+
});
|
89
|
+
|
90
|
+
await component.bindEvents({
|
91
|
+
onBindRestoreButton(onEventTriggered) {
|
92
|
+
$("#restore-button-input").on("change", onEventTriggered);
|
93
|
+
},
|
94
|
+
onBindStartButton(onEventTriggered) {
|
95
|
+
$startButton.on("click", onEventTriggered);
|
96
|
+
},
|
97
|
+
onBindBackupButton(backupData, backupFilename, onEventTriggered) {
|
98
|
+
const $backupButton = $("#download-election-keys");
|
99
|
+
|
100
|
+
$backupButton.attr(
|
101
|
+
"href",
|
102
|
+
`data:text/plain;charset=utf-8,${backupData}`
|
103
|
+
);
|
104
|
+
$backupButton.attr("download", backupFilename);
|
105
|
+
$backupButton.on("click", onEventTriggered);
|
106
|
+
},
|
107
|
+
onEvent(event) {
|
108
|
+
let messageIdentifier = MessageIdentifier.parse(
|
109
|
+
event.message.messageId
|
110
|
+
);
|
111
|
+
|
112
|
+
if (event.type === MESSAGE_RECEIVED) {
|
113
|
+
if (currentStep && currentStep !== messageIdentifier.typeSubtype) {
|
114
|
+
const $previousStep = getStepRow(currentStep);
|
115
|
+
$previousStep.attr("data-step-status", "completed");
|
116
|
+
}
|
117
|
+
currentStep = messageIdentifier.typeSubtype;
|
118
|
+
|
119
|
+
const $currentStep = getStepRow(currentStep);
|
120
|
+
if ($currentStep.data("step-status") !== "completed") {
|
121
|
+
$currentStep.attr("data-step-status", "processing");
|
122
|
+
}
|
124
123
|
}
|
124
|
+
},
|
125
|
+
onComplete() {
|
126
|
+
const $allSteps = $(".step_status");
|
127
|
+
$allSteps.attr("data-step-status", "completed");
|
128
|
+
|
129
|
+
$startButton.attr("hidden", true);
|
130
|
+
$backButton.attr("hidden", false);
|
131
|
+
|
132
|
+
$.ajax({
|
133
|
+
method: "PATCH",
|
134
|
+
url: $keyCeremony.data("updateElectionStatusUrl"),
|
135
|
+
contentType: "application/json",
|
136
|
+
data: JSON.stringify({
|
137
|
+
status: "key_ceremony"
|
138
|
+
}),
|
139
|
+
headers: {
|
140
|
+
"X-CSRF-Token": $("meta[name=csrf-token]").attr("content")
|
141
|
+
}
|
142
|
+
});
|
143
|
+
},
|
144
|
+
onStart() {
|
145
|
+
$startButton.prop("disabled", true);
|
146
|
+
},
|
147
|
+
onRestore() {
|
148
|
+
window.Decidim.currentDialogs["show-restore-modal"].close()
|
149
|
+
},
|
150
|
+
onTrusteeNeedsToBeRestored() {
|
151
|
+
window.Decidim.currentDialogs["show-restore-modal"].open()
|
152
|
+
},
|
153
|
+
onBackupNeeded() {
|
154
|
+
window.Decidim.currentDialogs["show-backup-modal"].open()
|
155
|
+
},
|
156
|
+
onBackupStarted() {
|
157
|
+
window.Decidim.currentDialogs["show-backup-modal"].close()
|
125
158
|
}
|
126
|
-
}
|
127
|
-
onRestore() {
|
128
|
-
$restoreModal.foundation("close");
|
129
|
-
},
|
130
|
-
onComplete() {
|
131
|
-
const $allSteps = $(".step_status");
|
132
|
-
$allSteps.attr("data-step-status", "completed");
|
133
|
-
|
134
|
-
$startButton.addClass("hide");
|
135
|
-
$backButton.removeClass("hide");
|
136
|
-
|
137
|
-
$.ajax({
|
138
|
-
method: "PATCH",
|
139
|
-
url: $keyCeremony.data("updateElectionStatusUrl"),
|
140
|
-
contentType: "application/json",
|
141
|
-
data: JSON.stringify({
|
142
|
-
status: "key_ceremony"
|
143
|
-
}),
|
144
|
-
headers: {
|
145
|
-
"X-CSRF-Token": $("meta[name=csrf-token]").attr("content")
|
146
|
-
}
|
147
|
-
});
|
148
|
-
},
|
149
|
-
onStart() {
|
150
|
-
$startButton.prop("disabled", true);
|
151
|
-
},
|
152
|
-
onTrusteeNeedsToBeRestored() {
|
153
|
-
$restoreModal.foundation("open");
|
154
|
-
},
|
155
|
-
onBackupNeeded() {
|
156
|
-
$backupModal.foundation("open");
|
157
|
-
},
|
158
|
-
onBackupStarted() {
|
159
|
-
$backupModal.foundation("close");
|
160
|
-
}
|
161
|
-
});
|
159
|
+
});
|
162
160
|
|
163
|
-
|
164
|
-
|
165
|
-
|
161
|
+
$startButton.prop("disabled", false);
|
162
|
+
}
|
163
|
+
});
|
164
|
+
}
|
166
165
|
});
|