Source code for page.model

""" 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)