from __future__ import annotations
from datetime import date
from datetime import datetime
from onegov.core.utils import append_query_param
from sedate import to_timezone
from sedate import utcnow
from sqlalchemy import Column
from sqlalchemy import Time
from onegov.core.orm.mixins import content_property
from onegov.core.orm.mixins import dict_property
from typing import TYPE_CHECKING
if TYPE_CHECKING:
from datetime import time
from onegov.landsgemeinde.models import Assembly
from sqlalchemy.orm import relationship
[docs]
class StartTimeMixin:
#: The local start time
[docs]
start_time: Column[time | None] = Column(Time, nullable=True)
[docs]
def start(self) -> None:
self.start_time = to_timezone(utcnow(), 'Europe/Zurich').time()
[docs]
class TimestampedVideoMixin(StartTimeMixin):
if TYPE_CHECKING:
# forward declare required attributes
[docs]
assembly: Assembly | relationship[Assembly]
#: The manual video timestamp of this agenda item
[docs]
video_timestamp: dict_property[str | None] = content_property()
@property
[docs]
def calculated_timestamp(self) -> str | None:
from onegov.landsgemeinde.utils import seconds_to_timestamp
if not self.start_time or not self.assembly.start_time:
return None
seconds = (
datetime.combine(date.today(), self.start_time)
- datetime.combine(date.today(), self.assembly.start_time)
).seconds
return seconds_to_timestamp(seconds)
@property
[docs]
def video_url(self) -> str | None:
from onegov.landsgemeinde.utils import timestamp_to_seconds
video_url_base = self.assembly.video_url
if not video_url_base:
return None
if self.video_timestamp:
seconds = timestamp_to_seconds(self.video_timestamp)
if seconds:
return append_query_param(
video_url_base, 'start', str(seconds)
)
calculated_timestamp = self.calculated_timestamp
if calculated_timestamp:
seconds = timestamp_to_seconds(calculated_timestamp)
if seconds:
return append_query_param(
video_url_base, 'start', str(seconds)
)
return video_url_base