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