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]
tabs_with_embedded_tables = (
'seat-allocation',
'list-groups',
'superregions',
'districts',
'candidates',
'party-strengths',
'statistics'
)
[docs]
def table_link(
self,
query_params: dict[str, str] | None = None
) -> str | None:
query_params = query_params or {}
if self.tab not in self.tabs_with_embedded_tables:
return None
locale = self.request.locale
if locale:
query_params['locale'] = locale
return self.request.link(
self.model, f'{self.tab}-table', query_params=query_params
)
@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
@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
[docs]
def svg_link(self) -> str:
""" Returns a link to the SVG download view. """
return self.request.link(self.model, name='{}-svg'.format(self.tab))
@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