|
| 1 | +""" |
| 2 | +Contains Zaehlzeitdefinition class |
| 3 | +""" |
| 4 | + |
| 5 | +# pylint: disable=unused-argument |
| 6 | +# pylint: disable=no-name-in-module |
| 7 | +from typing import TYPE_CHECKING, Annotated, Literal, Optional |
| 8 | + |
| 9 | +from pydantic import Field |
| 10 | + |
| 11 | +from ..enum.botyp import BoTyp |
| 12 | +from ..utils import postprocess_docstring |
| 13 | +from .geschaeftsobjekt import Geschaeftsobjekt |
| 14 | + |
| 15 | +if TYPE_CHECKING: |
| 16 | + from ..com.umschaltzeit import Umschaltzeit |
| 17 | + from ..enum.wiederholungstyp import Wiederholungstyp |
| 18 | + |
| 19 | +# pylint: disable=too-many-instance-attributes, too-few-public-methods |
| 20 | + |
| 21 | + |
| 22 | +@postprocess_docstring |
| 23 | +class Zaehlzeitdefinition(Geschaeftsobjekt): |
| 24 | + """ |
| 25 | + Beinhaltet Informationen zu welchen Zeiten welche Register zählen. |
| 26 | +
|
| 27 | + .. raw:: html |
| 28 | +
|
| 29 | + <object data="../_static/images/bo4e/bo/Zaehlzeitdefinition.svg" type="image/svg+xml"></object> |
| 30 | +
|
| 31 | + .. HINT:: |
| 32 | + `Zaehlzeitdefinition JSON Schema <https://json-schema.app/view/%23?url=https://raw.githubusercontent.com/BO4E/BO4E-Schemas/{__gh_version__}/src/bo4e_schemas/bo/Zaehlzeitdefinition.json>`_ |
| 33 | +
|
| 34 | + """ |
| 35 | + |
| 36 | + typ: Annotated[Literal[BoTyp.ZAEHLZEITDEFINITION], Field(alias="_typ")] = BoTyp.ZAEHLZEITDEFINITION |
| 37 | + |
| 38 | + wiederholend: Optional["Wiederholungstyp"] = None |
| 39 | + """Dieses Feld gibt an, an welchen Tagen das Schaltschema gilt, das durch die Umschaltzeiten definiert ist.""" |
| 40 | + umschaltzeiten: Optional[list["Umschaltzeit"]] = None |
| 41 | + """ |
| 42 | + Die einzelnen Umschaltzeiten in dieser Liste definieren, zu welchen Uhrzeiten welches Register zählt. |
| 43 | +
|
| 44 | + Die Liste füllt stets einen ganzen Tag vollständig und überlappungsfrei aus. Die jeweilige Umschaltzeit in jedem |
| 45 | + Objekt der Liste ergibt (wenn der Größe nach sortiert) ein entsprechendes Schema, wobei die untere Grenze (inklusiv) |
| 46 | + als 00:00 Uhr und die obere Grenze (exklusiv) als 24:00 Uhr definiert ist. |
| 47 | +
|
| 48 | + Anmerkung: Die Umschaltzeiten sollten sich natürlich niemals doppeln. |
| 49 | + """ |
0 commit comments