Source code for bo4e.bo.angebot

"""
Contains Angebot class and corresponding marshmallow schema for de-/serialization
"""

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

import pydantic
from pydantic import Field

from ..enum.typ import Typ
from ..utils import postprocess_docstring
from .geschaeftsobjekt import Geschaeftsobjekt

if TYPE_CHECKING:
    from ..com.angebotsvariante import Angebotsvariante
    from ..enum.sparte import Sparte
    from .geschaeftspartner import Geschaeftspartner
    from .person import Person


[docs] @postprocess_docstring class Angebot(Geschaeftsobjekt): """ Mit diesem BO kann ein Versorgungsangebot zur Strom- oder Gasversorgung oder die Teilnahme an einer Ausschreibung übertragen werden. Es können verschiedene Varianten enthalten sein (z.B. ein- und mehrjährige Laufzeit). Innerhalb jeder Variante können Teile enthalten sein, die jeweils für eine oder mehrere Marktlokationen erstellt werden. .. raw:: html <object data="../_static/images/bo4e/bo/Angebot.svg" type="image/svg+xml"></object> .. HINT:: `Angebot JSON Schema <https://json-schema.app/view/%23?url=https://raw.githubusercontent.com/BO4E/BO4E-Schemas/{__gh_version__}/src/bo4e_schemas/bo/Angebot.json>`_ """ typ: Annotated[Literal[Typ.ANGEBOT], Field(alias="_typ")] = Typ.ANGEBOT #: Eindeutige Nummer des Angebotes angebotsnummer: Optional[str] = None #: Erstellungsdatum des Angebots angebotsdatum: Optional[pydantic.AwareDatetime] = None #: Sparte, für die das Angebot abgegeben wird (Strom/Gas) sparte: Optional["Sparte"] = None #: Ersteller des Angebots angebotsgeber: Optional["Geschaeftspartner"] = None #: Empfänger des Angebots angebotsnehmer: Optional["Geschaeftspartner"] = None varianten: Optional[list["Angebotsvariante"]] = None """ Eine oder mehrere Varianten des Angebots mit den Angebotsteilen; Ein Angebot besteht mindestens aus einer Variante.""" anfragereferenz: Optional[str] = None """ Referenz auf eine Anfrage oder Ausschreibung; Kann dem Empfänger des Angebotes bei Zuordnung des Angebotes zur Anfrage bzw. Ausschreibung helfen.""" #: Bis zu diesem Zeitpunkt (Tag/Uhrzeit) inklusive gilt das Angebot bindefrist: Optional[pydantic.AwareDatetime] = None #: Person, die als Angebotsnehmer das Angebot angenommen hat unterzeichner_angebotsnehmer: Optional["Person"] = None #: Person, die als Angebotsgeber das Angebots ausgestellt hat unterzeichner_angebotsgeber: Optional["Person"] = None