Source code for election_day.collections.screens

from __future__ import annotations

from onegov.core.collection import Pagination
from onegov.election_day.models import Screen


from typing import Any
from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from sqlalchemy.orm import Query
    from sqlalchemy.orm import Session
    from typing import Self


[docs] class ScreenCollection(Pagination[Screen]):
[docs] page: int
def __init__(self, session: Session, page: int = 0): super().__init__(page)
[docs] self.session = session
[docs] def __eq__(self, other: object) -> bool: return isinstance(other, self.__class__) and self.page == other.page
[docs] def subset(self) -> Query[Screen]: return self.query()
@property
[docs] def page_index(self) -> int: return self.page
[docs] def page_by_index(self, index: int) -> Self: return self.__class__(self.session, index)
[docs] def query(self) -> Query[Screen]: return self.session.query(Screen).order_by(Screen.number)
[docs] def by_id(self, id: int) -> Screen | None: return self.query().filter(Screen.id == id).first()
[docs] def by_number(self, number: int) -> Screen | None: return self.query().filter(Screen.number == number).first()
[docs] def add(self, screen: Screen) -> None: self.session.add(screen) self.session.flush()
[docs] def delete(self, screen: Screen) -> None: self.session.delete(screen) self.session.flush()
[docs] def export(self) -> list[dict[str, Any]]: return [ { 'number': screen.number, 'description': screen.description, 'type': screen.type, 'structure': screen.structure, 'css': screen.css, 'group': screen.group, 'duration': screen.duration, } for screen in self.query() ]