Source code for election_day.formats.exports.election.internal_majorz

from __future__ import annotations

from collections import OrderedDict
from onegov.election_day.models import Candidate
from onegov.election_day.models import CandidateResult
from onegov.election_day.models import Election
from onegov.election_day.models import ElectionResult
from sqlalchemy.orm import object_session


from typing import Any
from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from collections.abc import Collection


[docs] def export_election_internal_majorz( election: Election, locales: Collection[str] ) -> list[dict[str, Any]]: """ Returns all data connected to this election as list with dicts. This is meant as a base for json/csv/excel exports. The result is therefore a flat list of dictionaries with repeating values to avoid the nesting of values. Each record in the resulting list is a single candidate result for each political entity. Party results are not included in the export (since they are not really connected with the lists). """ session = object_session(election) ids = session.query(ElectionResult.id) ids = ids.filter(ElectionResult.election_id == election.id) results = session.query( CandidateResult.votes, ElectionResult.superregion, ElectionResult.district, ElectionResult.name, ElectionResult.entity_id, ElectionResult.counted, ElectionResult.eligible_voters, ElectionResult.expats, ElectionResult.received_ballots, ElectionResult.blank_ballots, ElectionResult.invalid_ballots, ElectionResult.unaccounted_ballots, ElectionResult.accounted_ballots, ElectionResult.blank_votes, ElectionResult.invalid_votes, ElectionResult.accounted_votes, Candidate.family_name, Candidate.first_name, Candidate.candidate_id, Candidate.elected, Candidate.party, Candidate.gender, Candidate.year_of_birth, ) results = results.outerjoin(CandidateResult.candidate) results = results.outerjoin(CandidateResult.election_result) results = results.outerjoin(Candidate.election) results = results.filter(CandidateResult.election_result_id.in_(ids)) results = results.order_by( ElectionResult.district, ElectionResult.name, Candidate.family_name, Candidate.first_name ) titles = election.title_translations or {} short_titles = election.short_title_translations or {} rows: list[dict[str, Any]] = [] for result in results: row: dict[str, Any] = OrderedDict() row['election_id'] = election.id for locale in locales: title = titles.get(locale, '') or '' row[f'election_title_{locale}'] = title.strip() for locale in locales: title = short_titles.get(locale, '') or '' row[f'election_short_title_{locale}'] = title.strip() row['election_date'] = election.date.isoformat() row['election_domain'] = election.domain row['election_type'] = election.type row['election_mandates'] = election.number_of_mandates row['election_absolute_majority'] = election.absolute_majority row['election_status'] = election.status or 'unknown' row['entity_superregion'] = result.superregion or '' row['entity_district'] = result.district or '' row['entity_name'] = result.name row['entity_id'] = result.entity_id row['entity_counted'] = result.counted row['entity_eligible_voters'] = result.eligible_voters row['entity_expats'] = result.expats row['entity_received_ballots'] = result.received_ballots row['entity_blank_ballots'] = result.blank_ballots row['entity_invalid_ballots'] = result.invalid_ballots row['entity_unaccounted_ballots'] = result.unaccounted_ballots row['entity_accounted_ballots'] = result.accounted_ballots row['entity_blank_votes'] = result.blank_votes row['entity_invalid_votes'] = result.invalid_votes row['entity_accounted_votes'] = result.accounted_votes row['candidate_family_name'] = result.family_name row['candidate_first_name'] = result.first_name row['candidate_id'] = result.candidate_id row['candidate_elected'] = result.elected row['candidate_party'] = result.party row['candidate_party_color'] = election.colors.get(result.party, '') row['candidate_gender'] = result.gender or '' row['candidate_year_of_birth'] = result.year_of_birth or '' row['candidate_votes'] = result.votes rows.append(row) return rows