""" A OneGov Page is an Adjacency List used to represent pages with any kind
of content in a hierarchy.
See also: `<https://docs.sqlalchemy.org/en/rel_0_9/orm/self_referential.html>`_
"""
from __future__ import annotations
from sqlalchemy import func
from sqlalchemy.ext.hybrid import hybrid_property
from onegov.core.orm.abstract import AdjacencyList
from onegov.core.orm.mixins import ContentMixin
from onegov.core.orm.mixins import TimestampMixin
from onegov.core.orm.mixins import UTCPublicationMixin
from onegov.file import MultiAssociatedFiles
from typing import TYPE_CHECKING
if TYPE_CHECKING:
from collections.abc import Iterator
from sqlalchemy import Column
from sqlalchemy.orm import relationship
[docs]
class Page(AdjacencyList, ContentMixin, TimestampMixin,
UTCPublicationMixin, MultiAssociatedFiles):
""" Defines a generic page. """
[docs]
__tablename__ = 'pages'
if TYPE_CHECKING:
# we override these relationships to be more specific
[docs]
parent: relationship[Page | None]
children: relationship[list[Page]]
@property
def root(self) -> Page: ...
@property
def ancestors(self) -> Iterator[Page]: ...
# HACK: Workaround for hybrid_property not working until SQLAlchemy 2.0
published_or_created: Column[bool]
else:
@hybrid_property
def published_or_created(self):
return self.publication_start or self.created
@published_or_created.expression # type:ignore[no-redef]
def published_or_created(cls):
return func.coalesce(Page.publication_start, Page.created)