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
@@ -13,131 +13,135 @@ import { TrusteeWrapperAdapter as ElectionGuardTrusteeWrapperAdapter } from "@de
|
|
13
13
|
|
14
14
|
$(() => {
|
15
15
|
// UI Elements
|
16
|
-
const $tally = $("
|
17
|
-
const
|
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
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
trusteeWrapperAdapter =
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
16
|
+
const $tally = $("#trustee-step");
|
17
|
+
const trusteeStep = $tally.data("currentStep")
|
18
|
+
|
19
|
+
if ($tally.length && trusteeStep === "tally_started") {
|
20
|
+
const $startButton = $tally.find("#start");
|
21
|
+
const $backButton = $tally.find("#back");
|
22
|
+
|
23
|
+
const getStepRow = (step) => {
|
24
|
+
return $(`#${step.replace(".", "-")}`);
|
25
|
+
};
|
26
|
+
|
27
|
+
const TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS = 2;
|
28
|
+
|
29
|
+
// Data
|
30
|
+
const bulletinBoardClientParams = {
|
31
|
+
apiEndpointUrl: $tally.data("apiEndpointUrl")
|
32
|
+
};
|
33
|
+
const electionUniqueId = `${$tally.data("authoritySlug")}.${$tally.data(
|
34
|
+
"electionId"
|
35
|
+
)}`;
|
36
|
+
const authorityPublicKeyJSON = JSON.stringify(
|
37
|
+
$tally.data("authorityPublicKey")
|
38
|
+
);
|
39
|
+
const schemeName = $tally.data("schemeName");
|
40
|
+
|
41
|
+
const trusteeContext = {
|
42
|
+
uniqueId: $tally.data("trusteeSlug"),
|
43
|
+
publicKeyJSON: JSON.stringify($tally.data("trusteePublicKey"))
|
44
|
+
};
|
45
|
+
const trusteeIdentificationKeys = new IdentificationKeys(
|
46
|
+
trusteeContext.uniqueId,
|
47
|
+
trusteeContext.publicKeyJSON
|
48
|
+
);
|
49
|
+
let currentStep = null;
|
50
|
+
|
51
|
+
// Use the correct trustee wrapper adapter
|
52
|
+
let trusteeWrapperAdapter = null;
|
53
|
+
|
54
|
+
if (schemeName === "dummy") {
|
55
|
+
trusteeWrapperAdapter = new DummyTrusteeWrapperAdapter({
|
56
|
+
trusteeId: trusteeContext.uniqueId
|
57
|
+
});
|
58
|
+
} else if (schemeName === "electionguard") {
|
59
|
+
trusteeWrapperAdapter = new ElectionGuardTrusteeWrapperAdapter({
|
60
|
+
trusteeId: trusteeContext.uniqueId,
|
61
|
+
workerUrl: "/assets/electionguard/webworker.js"
|
62
|
+
});
|
63
|
+
} else {
|
64
|
+
throw new Error(`Voting scheme ${schemeName} not supported.`);
|
65
|
+
}
|
63
66
|
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
});
|
71
|
-
|
72
|
-
const bindComponentEvents = async () => {
|
73
|
-
await component.setupElection({
|
74
|
-
bulletinBoardClientParams,
|
75
|
-
electionUniqueId,
|
76
|
-
authorizationExpirationTimestamp:
|
77
|
-
Math.ceil(Number(new Date()) / 1000) +
|
78
|
-
TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS * 3600
|
67
|
+
// Use the tally component and bind all UI events
|
68
|
+
const component = new TallyComponent({
|
69
|
+
authorityPublicKeyJSON,
|
70
|
+
trusteeUniqueId: trusteeContext.uniqueId,
|
71
|
+
trusteeIdentificationKeys,
|
72
|
+
trusteeWrapperAdapter
|
79
73
|
});
|
80
74
|
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
75
|
+
const bindComponentEvents = async () => {
|
76
|
+
await component.setupElection({
|
77
|
+
bulletinBoardClientParams,
|
78
|
+
electionUniqueId,
|
79
|
+
authorizationExpirationTimestamp:
|
80
|
+
Math.ceil(Number(new Date()) / 1000) +
|
81
|
+
TRUSTEE_AUTHORIZATION_EXPIRATION_TIME_IN_HOURS * 3600
|
82
|
+
});
|
86
83
|
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
84
|
+
await component.bindEvents({
|
85
|
+
onEvent(event) {
|
86
|
+
let messageIdentifier = MessageIdentifier.parse(
|
87
|
+
event.message.messageId
|
88
|
+
);
|
89
|
+
|
90
|
+
if (event.type === MESSAGE_RECEIVED) {
|
91
|
+
if (currentStep && currentStep !== messageIdentifier.typeSubtype) {
|
92
|
+
const $previousStep = getStepRow(currentStep);
|
93
|
+
$previousStep.attr("data-step-status", "completed");
|
94
|
+
}
|
95
|
+
currentStep = messageIdentifier.typeSubtype;
|
93
96
|
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
+
const $currentStep = getStepRow(currentStep);
|
98
|
+
if ($currentStep.data("step-status") !== "completed") {
|
99
|
+
$currentStep.attr("data-step-status", "processing");
|
100
|
+
}
|
97
101
|
}
|
102
|
+
},
|
103
|
+
onBindStartButton(onEventTriggered) {
|
104
|
+
$startButton.on("click", onEventTriggered);
|
105
|
+
},
|
106
|
+
onStart() {
|
107
|
+
$startButton.prop("disabled", true);
|
108
|
+
},
|
109
|
+
onComplete() {
|
110
|
+
const $allSteps = $(".step_status");
|
111
|
+
$allSteps.attr("data-step-status", "completed");
|
112
|
+
|
113
|
+
$startButton.attr("hidden", true);
|
114
|
+
$backButton.attr("hidden", false);
|
115
|
+
|
116
|
+
$.ajax({
|
117
|
+
method: "PATCH",
|
118
|
+
url: $tally.data("updateElectionStatusUrl"),
|
119
|
+
contentType: "application/json",
|
120
|
+
data: JSON.stringify({
|
121
|
+
status: "tally_started"
|
122
|
+
}),
|
123
|
+
headers: {
|
124
|
+
"X-CSRF-Token": $("meta[name=csrf-token]").attr("content")
|
125
|
+
}
|
126
|
+
});
|
127
|
+
},
|
128
|
+
onTrusteeNeedsToBeRestored() {
|
129
|
+
window.Decidim.currentDialogs["show-restore-modal"].open()
|
130
|
+
},
|
131
|
+
onBindRestoreButton(onEventTriggered) {
|
132
|
+
$("#restore-button-input").on("change", onEventTriggered);
|
133
|
+
},
|
134
|
+
onRestore() {
|
135
|
+
window.Decidim.currentDialogs["show-restore-modal"].close()
|
98
136
|
}
|
99
|
-
}
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
onComplete() {
|
107
|
-
const $allSteps = $(".step_status");
|
108
|
-
$allSteps.attr("data-step-status", "completed");
|
109
|
-
|
110
|
-
$startButton.addClass("hide");
|
111
|
-
$backButton.removeClass("hide");
|
112
|
-
|
113
|
-
$.ajax({
|
114
|
-
method: "PATCH",
|
115
|
-
url: $tally.data("updateElectionStatusUrl"),
|
116
|
-
contentType: "application/json",
|
117
|
-
data: JSON.stringify({
|
118
|
-
status: "tally_started"
|
119
|
-
}),
|
120
|
-
headers: {
|
121
|
-
"X-CSRF-Token": $("meta[name=csrf-token]").attr("content")
|
122
|
-
}
|
123
|
-
});
|
124
|
-
},
|
125
|
-
onTrusteeNeedsToBeRestored() {
|
126
|
-
$restoreModal.foundation("open");
|
127
|
-
},
|
128
|
-
onBindRestoreButton(onEventTriggered) {
|
129
|
-
$restoreButton.on("change", ".restore-button-input", onEventTriggered);
|
130
|
-
},
|
131
|
-
onRestore() {
|
132
|
-
$restoreModal.foundation("close");
|
137
|
+
});
|
138
|
+
$startButton.prop("disabled", false);
|
139
|
+
};
|
140
|
+
|
141
|
+
trusteeIdentificationKeys.present(async (exists) => {
|
142
|
+
if (exists) {
|
143
|
+
await bindComponentEvents();
|
133
144
|
}
|
134
145
|
});
|
135
|
-
|
136
|
-
};
|
137
|
-
|
138
|
-
trusteeIdentificationKeys.present(async (exists) => {
|
139
|
-
if (exists) {
|
140
|
-
await bindComponentEvents();
|
141
|
-
}
|
142
|
-
});
|
146
|
+
}
|
143
147
|
});
|
@@ -4,7 +4,7 @@ import { IdentificationKeys } from "@decidim/decidim-bulletin_board";
|
|
4
4
|
|
5
5
|
$(() => {
|
6
6
|
function identificationKeys() {
|
7
|
-
const $form = $("
|
7
|
+
const $form = $("#trustee_zone form");
|
8
8
|
const $trusteeSlug = $("#trustee_slug", $form);
|
9
9
|
const $trusteePublicKey = $("#trustee_public_key", $form);
|
10
10
|
|
@@ -12,8 +12,9 @@ $(() => {
|
|
12
12
|
$trusteeSlug.val(),
|
13
13
|
$trusteePublicKey.val()
|
14
14
|
);
|
15
|
+
|
15
16
|
if (!window.trusteeIdentificationKeys.browserSupport) {
|
16
|
-
$("#not_supported_browser").
|
17
|
+
$("#not_supported_browser").attr("hidden", false);
|
17
18
|
return;
|
18
19
|
}
|
19
20
|
|
@@ -28,23 +29,24 @@ $(() => {
|
|
28
29
|
$trusteePublicKey.val(
|
29
30
|
JSON.stringify(window.trusteeIdentificationKeys.publicKey)
|
30
31
|
);
|
31
|
-
$submit.
|
32
|
+
$submit.attr("hidden", false);
|
33
|
+
$generate.attr("hidden", true);
|
32
34
|
}).
|
33
35
|
catch(() => {
|
34
36
|
alert($generate.data("error"));
|
35
37
|
});
|
36
38
|
});
|
37
39
|
|
38
|
-
$("button
|
40
|
+
$("button", $submit).click(() => {
|
39
41
|
$trusteePublicKey.val("");
|
40
|
-
$submit.
|
42
|
+
$submit.attr("hidden", true);
|
41
43
|
});
|
42
44
|
|
43
45
|
$("button", $upload).click(() => {
|
44
46
|
window.trusteeIdentificationKeys.
|
45
47
|
upload().
|
46
48
|
then(() => {
|
47
|
-
$upload.
|
49
|
+
$upload.attr("hidden", true);
|
48
50
|
}).
|
49
51
|
catch((errorMessage) => {
|
50
52
|
alert($upload.data(errorMessage));
|
@@ -52,7 +54,7 @@ $(() => {
|
|
52
54
|
});
|
53
55
|
|
54
56
|
window.trusteeIdentificationKeys.present((result) => {
|
55
|
-
$upload.
|
57
|
+
$upload.attr("hidden", result);
|
56
58
|
});
|
57
59
|
}
|
58
60
|
|
@@ -4,14 +4,16 @@ import "src/decidim/elections/broken_promises_handler";
|
|
4
4
|
import { Client } from "@decidim/decidim-bulletin_board";
|
5
5
|
|
6
6
|
$(async () => {
|
7
|
-
const $castingVoteWrapper = $("
|
7
|
+
const $castingVoteWrapper = $("#casting-vote-wrapper");
|
8
8
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
9
|
+
if ($castingVoteWrapper.length) {
|
10
|
+
const bulletinBoardClient = new Client({
|
11
|
+
apiEndpointUrl: $castingVoteWrapper.data("apiEndpointUrl")
|
12
|
+
});
|
13
|
+
const messageId = $castingVoteWrapper.data("messageId");
|
13
14
|
|
14
|
-
|
15
|
+
await bulletinBoardClient.waitForPendingMessageToBeProcessed(messageId);
|
15
16
|
|
16
|
-
|
17
|
+
$("form.update_vote_status").trigger("submit");
|
18
|
+
}
|
17
19
|
});
|
@@ -1,83 +1,104 @@
|
|
1
|
+
/* eslint-disable no-inner-declarations */
|
2
|
+
/* eslint-disable require-jsdoc */
|
3
|
+
/* eslint-disable func-style */
|
1
4
|
/* eslint-disable no-console */
|
2
5
|
import VoteQuestionsComponent from "src/decidim/elections/voter/vote_questions.component";
|
3
|
-
// The voting component might come from set-preview.js or setup-vote.js, it depends if it's a preview
|
4
|
-
// so in the view template we load the component and attach it to window
|
5
|
-
const { setupVoteComponent } = window.Decidim;
|
6
6
|
|
7
7
|
$(async () => {
|
8
8
|
// UI Elements
|
9
|
-
const $voteWrapper = $("
|
10
|
-
const $ballotHash = $voteWrapper.find(".ballot-hash");
|
11
|
-
const ballotStyleId = $voteWrapper.data("ballotStyleId");
|
9
|
+
const $voteWrapper = $("#vote-wrapper");
|
12
10
|
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
11
|
+
if ($voteWrapper.length) {
|
12
|
+
const $ballotHash = $voteWrapper.find("#ballot-hash");
|
13
|
+
const ballotStyleId = $voteWrapper.data("ballotStyleId");
|
14
|
+
const isPreview = $voteWrapper.data("previewMode");
|
15
|
+
|
16
|
+
// Use the questions component
|
17
|
+
const questionsComponent = new VoteQuestionsComponent($voteWrapper);
|
18
18
|
questionsComponent.init();
|
19
|
-
});
|
20
19
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
}
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
20
|
+
// Activates the events associated to the forms after show a new step
|
21
|
+
$(document).on("on:toggle", () => questionsComponent.init());
|
22
|
+
|
23
|
+
async function setup(component) {
|
24
|
+
// Get the vote component and bind it to all UI events
|
25
|
+
const voteComponent = component($voteWrapper);
|
26
|
+
|
27
|
+
try {
|
28
|
+
await voteComponent.bindEvents({
|
29
|
+
onBindEncryptButton(onEventTriggered) {
|
30
|
+
$("[id='next-encrypting']").on("click", onEventTriggered);
|
31
|
+
},
|
32
|
+
onStart() {},
|
33
|
+
onVoteEncryption(validVoteFn) {
|
34
|
+
const getFormData = (formData) => {
|
35
|
+
return formData.serializeArray().reduce((acc, { name, value }) => {
|
36
|
+
if (!acc[name]) {
|
37
|
+
acc[name] = [];
|
38
|
+
}
|
39
|
+
acc[name] = [...acc[name], `${name}_${value}`];
|
40
|
+
return acc;
|
41
|
+
}, {});
|
42
|
+
};
|
43
|
+
const formData = getFormData($voteWrapper.find(".answer_input"));
|
44
|
+
validVoteFn(formData, ballotStyleId);
|
45
|
+
},
|
46
|
+
castOrAuditBallot({ encryptedData, encryptedDataHash }) {
|
47
|
+
$voteWrapper.find("#step-encrypting").attr("hidden", true);
|
48
|
+
$ballotHash.text(encryptedDataHash);
|
45
49
|
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
50
|
+
// show the next step
|
51
|
+
$voteWrapper.find("#step-ballot_decision").attr("hidden", false);
|
52
|
+
// simulates a toggle click, in order to update the wizard step
|
53
|
+
document.dispatchEvent(new Event("on:toggle"));
|
54
|
+
|
55
|
+
const $form = $("form.new_vote");
|
56
|
+
$("#vote_encrypted_data", $form).val(encryptedData);
|
57
|
+
$("#vote_encrypted_data_hash", $form).val(encryptedDataHash);
|
58
|
+
},
|
59
|
+
onBindAuditBallotButton(onEventTriggered) {
|
60
|
+
$("#audit_ballot").on("click", onEventTriggered);
|
61
|
+
},
|
62
|
+
onBindCastBallotButton(onEventTriggered) {
|
63
|
+
$("#cast_ballot").on("click", onEventTriggered);
|
64
|
+
},
|
65
|
+
onAuditBallot(auditedData, auditedDataFileName) {
|
66
|
+
const vote = JSON.stringify(auditedData);
|
67
|
+
const link = document.createElement("a");
|
68
|
+
$voteWrapper.find("#cast_ballot").attr("hidden", true);
|
69
|
+
$voteWrapper.find("#back").attr("hidden", false);
|
70
|
+
questionsComponent.voteCasted = true;
|
71
|
+
|
72
|
+
link.setAttribute("href", `data:text/plain;charset=utf-8,${vote}`);
|
73
|
+
link.setAttribute("download", auditedDataFileName);
|
74
|
+
document.body.appendChild(link);
|
75
|
+
link.click();
|
76
|
+
document.body.removeChild(link);
|
77
|
+
},
|
78
|
+
onAuditComplete() {
|
79
|
+
console.log("Audit completed");
|
80
|
+
},
|
81
|
+
onCastBallot() {
|
82
|
+
questionsComponent.voteCasted = true;
|
83
|
+
$("#cast_ballot").prop("disabled", true);
|
84
|
+
},
|
85
|
+
onCastComplete() {
|
86
|
+
console.log("Cast completed");
|
87
|
+
},
|
88
|
+
onInvalid() {
|
89
|
+
console.log("Something went wrong.");
|
90
|
+
}
|
91
|
+
});
|
92
|
+
} catch (error) {
|
93
|
+
console.error(error);
|
94
|
+
questionsComponent.errored();
|
95
|
+
}
|
96
|
+
}
|
62
97
|
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
document.body.removeChild(link);
|
68
|
-
},
|
69
|
-
onAuditComplete() {
|
70
|
-
console.log("Audit completed");
|
71
|
-
},
|
72
|
-
onCastBallot() {
|
73
|
-
questionsComponent.voteCasted = true;
|
74
|
-
$(".cast_ballot").prop("disabled", true);
|
75
|
-
},
|
76
|
-
onCastComplete() {
|
77
|
-
console.log("Cast completed");
|
78
|
-
},
|
79
|
-
onInvalid() {
|
80
|
-
console.log("Something went wrong.");
|
98
|
+
if (isPreview) {
|
99
|
+
import("./setup-preview").then(({ default: module }) => setup(module))
|
100
|
+
} else {
|
101
|
+
import("./setup-vote").then(({ default: module }) => setup(module))
|
81
102
|
}
|
82
|
-
}
|
103
|
+
}
|
83
104
|
});
|
@@ -4,8 +4,13 @@
|
|
4
4
|
import { Client } from "@decidim/decidim-bulletin_board";
|
5
5
|
|
6
6
|
$(() => {
|
7
|
-
const $voteVerifyWrapper = $("
|
8
|
-
|
7
|
+
const $voteVerifyWrapper = $("#verify-vote-wrapper");
|
8
|
+
|
9
|
+
if (!$voteVerifyWrapper.length) {
|
10
|
+
return
|
11
|
+
}
|
12
|
+
|
13
|
+
const $verifySubmitButton = $voteVerifyWrapper.find("[type=submit]");
|
9
14
|
|
10
15
|
let $formData = $voteVerifyWrapper.find(".vote-identifier");
|
11
16
|
|
@@ -33,11 +38,11 @@ $(() => {
|
|
33
38
|
}
|
34
39
|
|
35
40
|
function hideSuccessCallout() {
|
36
|
-
$voteVerifyWrapper.find("
|
41
|
+
$voteVerifyWrapper.find("#verify-vote-success").attr("hidden", true);
|
37
42
|
}
|
38
43
|
|
39
44
|
function hideErrorCallout() {
|
40
|
-
$voteVerifyWrapper.find("
|
45
|
+
$voteVerifyWrapper.find("#verify-vote-error").attr("hidden", true);
|
41
46
|
}
|
42
47
|
|
43
48
|
$verifySubmitButton.on("click", (event) => {
|
@@ -58,10 +63,10 @@ $(() => {
|
|
58
63
|
then((result) => {
|
59
64
|
if (result) {
|
60
65
|
hideErrorCallout();
|
61
|
-
$voteVerifyWrapper.find("
|
66
|
+
$voteVerifyWrapper.find("#verify-vote-success").attr("hidden", false);
|
62
67
|
} else {
|
63
68
|
hideSuccessCallout();
|
64
|
-
$voteVerifyWrapper.find("
|
69
|
+
$voteVerifyWrapper.find("#verify-vote-error").attr("hidden", false);
|
65
70
|
}
|
66
71
|
});
|
67
72
|
}
|