Source code for bo4e.com.angebotsvariante

"""
Contains Angebotsvariante and corresponding marshmallow schema for de-/serialization
"""

# pylint: disable=too-few-public-methods
# pylint: disable=no-name-in-module
from typing import TYPE_CHECKING, Optional

import pydantic

from ..utils import postprocess_docstring
from .com import COM

if TYPE_CHECKING:
    from ..enum.angebotsstatus import Angebotsstatus
    from .angebotsteil import Angebotsteil
    from .betrag import Betrag
    from .menge import Menge


[docs] @postprocess_docstring class Angebotsvariante(COM): """ Führt die verschiedenen Ausprägungen der Angebotsberechnung auf .. raw:: html <object data="../_static/images/bo4e/com/Angebotsvariante.svg" type="image/svg+xml"></object> .. HINT:: `Angebotsvariante JSON Schema <https://json-schema.app/view/%23?url=https://raw.githubusercontent.com/BO4E/BO4E-Schemas/{__gh_version__}/src/bo4e_schemas/com/Angebotsvariante.json>`_ """ #: Gibt den Status eines Angebotes an. angebotsstatus: Optional["Angebotsstatus"] = None #: Datum der Erstellung der Angebotsvariante erstellungsdatum: Optional[pydantic.AwareDatetime] = None #: Bis zu diesem Zeitpunkt gilt die Angebotsvariante bindefrist: Optional[pydantic.AwareDatetime] = None teile: Optional[list["Angebotsteil"]] = None """ Angebotsteile werden im einfachsten Fall für eine Marktlokation oder Lieferstellenadresse erzeugt. Hier werden die Mengen und Gesamtkosten aller Angebotspositionen zusammengefasst. Eine Variante besteht mindestens aus einem Angebotsteil. """ #: Aufsummierte Wirkarbeitsmenge aller Angebotsteile gesamtmenge: Optional["Menge"] = None # todo: write a validator for this: https://github.com/Hochfrequenz/BO4E-python/issues/320 #: Aufsummierte Kosten aller Angebotsteile gesamtkosten: Optional["Betrag"] = None