Source code for agency.models.membership

from __future__ import annotations

from onegov.core.orm.mixins import dict_property
from onegov.core.orm.mixins import meta_property
from onegov.org.models.extensions import AccessExtension
from onegov.org.models.extensions import PublicationExtension
from onegov.people import AgencyMembership


from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from onegov.agency.models import ExtendedAgency
    from onegov.agency.models import ExtendedPerson
    from sqlalchemy.orm import relationship


[docs] class ExtendedAgencyMembership(AgencyMembership, AccessExtension, PublicationExtension): """ An extended version of the standard membership from onegov.people. """
[docs] __mapper_args__ = {'polymorphic_identity': 'extended'}
[docs] es_type_name = 'extended_membership'
@property
[docs] def es_public(self) -> bool: # type:ignore[override] if self.agency: if self.agency.meta.get('access', 'public') != 'public': return False if not self.agency.published: return False if self.person: if self.person.meta.get('access', 'public') != 'public': return False if not self.person.published: return False return self.access == 'public'
# Todo: It is very unclear how this should be used. In the PDF rendering, # it is placed a middle column with 0.5 cm after the title. # On the agency, it is placed after the membership title, so not a prefix # but rather a suffix and it looks. For 0.5cm, the form should validate the # length of this, otherwise people complain about weird pdf #: The prefix character.
[docs] prefix: dict_property[str | None] = meta_property()
#: A note to the membership.
[docs] note: dict_property[str | None] = meta_property()
#: An addition to the membership.
[docs] addition: dict_property[str | None] = meta_property()
if TYPE_CHECKING: # NOTE: We only relate extended versions
[docs] agency: relationship[ExtendedAgency]
person: relationship[ExtendedPerson]