Source code for election_day.layouts.election_compound

from __future__ import annotations

from functools import cached_property
from onegov.core.utils import normalize_for_url
from onegov.election_day import _
from onegov.election_day.layouts.detail import DetailLayout
from onegov.election_day.utils import pdf_filename
from onegov.election_day.utils import svg_filename


from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from onegov.election_day.models import ElectionCompound
    from onegov.election_day.models.election_compound.mixins import ResultRow
    from onegov.election_day.models.election_compound.mixins import TotalRow
    from onegov.election_day.request import ElectionDayRequest

    from .election import NestedMenu


[docs] class ElectionCompoundLayout(DetailLayout):
[docs] model: ElectionCompound
def __init__( self, model: ElectionCompound, request: ElectionDayRequest, tab: str | None = None ) -> None: super().__init__(model, request)
[docs] self.tab = tab
[docs] tabs_with_embedded_tables = ( 'seat-allocation', 'list-groups', 'superregions', 'districts', 'candidates', 'party-strengths', 'statistics' )
[docs] majorz = False
[docs] proporz = True
[docs] type = 'compound'
@cached_property
[docs] def all_tabs(self) -> tuple[str, ...]: """ Return the tabs in order of their appearance. """ result = [ 'seat-allocation', 'list-groups', 'superregions', 'districts', 'candidates', 'party-strengths', 'parties-panachage', 'statistics', 'data' ] if self.model.horizontal_party_strengths: result.remove('party-strengths') result.insert(1, 'party-strengths') return tuple(result)
@cached_property
[docs] def results(self) -> list[ResultRow]: return self.model.results
@cached_property
[docs] def totals(self) -> TotalRow: return self.model.totals
@cached_property
[docs] def has_districts(self) -> bool: if not self.principal.has_districts: return False if self.model.domain_elections == 'municipality': return False return True
@cached_property
[docs] def has_superregions(self) -> bool: return ( self.principal.has_superregions and self.model.domain_elections == 'region' )
[docs] def label(self, value: str) -> str: if value == 'district': if self.model.domain_elections == 'region': return self.principal.label('region') if self.model.domain_elections == 'municipality': return _('Municipality') if value == 'districts': if self.model.domain_elections == 'region': return self.principal.label('regions') if self.model.domain_elections == 'municipality': return _('Municipalities') return self.principal.label(value)
[docs] def title(self, tab: str | None = None) -> str: tab = self.tab if tab is None else tab if tab == 'seat-allocation': return _('Seat allocation') if tab == 'list-groups': return _('List groups') if tab == 'superregions': return self.label('superregions') if tab == 'districts': return self.label('districts') if tab == 'candidates': return _('Elected candidates') if tab == 'party-strengths': return _('Party strengths') if tab == 'parties-panachage': return _('Panachage') if tab == 'data': return _('Downloads') if tab == 'statistics': return _('Election statistics') return ''
[docs] def tab_visible(self, tab: str | None) -> bool: if not self.has_results: return False if tab == 'superregions': return self.has_superregions if tab == 'seat-allocation': return ( self.model.show_seat_allocation is True and self.has_party_results ) if tab == 'list-groups': return ( self.model.show_list_groups is True and self.model.pukelsheim is True and self.has_party_results ) if tab == 'party-strengths': return ( self.model.show_party_strengths is True and self.has_party_results ) if tab == 'parties-panachage': return ( self.model.show_party_panachage is True and self.has_party_panachage_results ) return True
@cached_property
[docs] def has_party_results(self) -> bool: return self.model.has_party_results
@cached_property
[docs] def has_party_panachage_results(self) -> bool: return self.model.has_party_panachage_results
@cached_property
[docs] def visible(self) -> bool: return self.tab_visible(self.tab)
@cached_property
[docs] def main_view(self) -> str: for tab in self.all_tabs: if self.tab_visible(tab): return self.request.link(self.model, tab) return self.request.link(self.model, 'districts')
@cached_property
[docs] def menu(self) -> NestedMenu: return [ ( self.title(tab), self.request.link(self.model, tab), self.tab == tab, [] ) for tab in self.all_tabs if self.tab_visible(tab) ]
@cached_property
[docs] def pdf_path(self) -> str | None: """ Returns the path to the PDF file or None, if it is not available. """ assert self.request.locale path = 'pdf/{}'.format( pdf_filename( self.model, self.request.locale, last_modified=self.last_modified ) ) filestorage = self.request.app.filestorage assert filestorage is not None if filestorage.exists(path): return path return None
@cached_property
[docs] def svg_path(self) -> str | None: """ Returns the path to the SVG or None, if it is not available. """ assert self.request.locale path = 'svg/{}'.format( svg_filename( self.model, self.tab, self.request.locale, last_modified=self.last_modified ) ) filestorage = self.request.app.filestorage assert filestorage is not None if filestorage.exists(path): return path return None
@cached_property @cached_property
[docs] def svg_name(self) -> str: """ Returns a nice to read SVG filename. """ return '{}.svg'.format( normalize_for_url( '{}-{}'.format( self.model.id, self.request.translate(self.title() or '') ) ) )
@property
[docs] def summarize(self) -> bool: return False
@cached_property
[docs] def related_compounds(self) -> list[tuple[str | None, str]]: result_set = {r.target for r in self.model.related_compounds} result = sorted(result_set, key=lambda x: x.date, reverse=True) return [(e.title, self.request.link(e)) for e in result]