Source code for bo4e.com.angebotsvariante

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

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

from pydantic import conlist

from bo4e.com.angebotsteil import Angebotsteil
from bo4e.com.betrag import Betrag
from bo4e.com.com import COM
from bo4e.com.menge import Menge
from bo4e.enum.angebotsstatus import Angebotsstatus


[docs]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/Hochfrequenz/BO4E-python/main/json_schemas/com/Angebotsvariante.json>`_ """ # required attributes #: Gibt den Status eines Angebotes an. angebotsstatus: Angebotsstatus #: Datum der Erstellung der Angebotsvariante erstellungsdatum: datetime #: Bis zu diesem Zeitpunkt gilt die Angebotsvariante bindefrist: datetime teile: conlist(Angebotsteil, min_items=1) # type: ignore[valid-type] """ 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. """ # optional attributes #: 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