Source code for ooodev.format.inner.direct.structs.table_border_distances_struct

# region Import
from __future__ import annotations
from typing import Any, Tuple, Type, cast, overload, TypeVar

from ooo.dyn.table.table_border_distances import TableBorderDistances

from ooodev.exceptions import ex as mEx
from ooodev.format.inner.common.props.struct_table_border_distances_props import StructTableBorderDistancesProps
from ooodev.format.inner.direct.structs.struct_base import StructBase
from ooodev.format.inner.kind.format_kind import FormatKind
from ooodev.units.unit_convert import UnitConvert
from ooodev.units.unit_mm import UnitMM
from ooodev.units.unit_obj import UnitT
from ooodev.utils import props as mProps

# endregion Import

_TTableBorderDistancesStruct = TypeVar("_TTableBorderDistancesStruct", bound="TableBorderDistancesStruct")


[docs]class TableBorderDistancesStruct(StructBase): """ Crop struct. Any properties starting with ``prop_`` set or get current instance values. All methods starting with ``fmt_`` can be used to chain together Border Table properties. .. versionadded:: 0.9.0 """ # region init
[docs] def __init__( self, *, left: float | UnitT = 0.0, right: float | UnitT = 0.0, top: float | UnitT = 0.0, bottom: float | UnitT = 0.0, all: float | UnitT | None = None, ) -> None: """ Constructor Args: left (float, UnitT, optional): Specifies left distance in ``mm`` units or :ref:`proto_unit_obj`. Default ``0.0``. right (float, UnitT, optional): Specifies right distance in ``mm`` units or :ref:`proto_unit_obj`. Default ``0.0``. top (float, UnitT, optional): Specifies top distance in ``mm`` units or :ref:`proto_unit_obj`. Default ``0.0``. bottom (float, UnitT, optional): Specifies bottom distance in ``mm`` units or :ref:`proto_unit_obj`. Default ``0.0``. all (float, UnitT, optional): Specifies ``left``, ``right``, ``top``, and ``bottom`` in ``mm`` units or :ref:`proto_unit_obj`. If set all other parameters are ignored. """ super().__init__() if all is not None: self.prop_left = all self.prop_right = all self.prop_top = all self.prop_bottom = all else: self.prop_left = left self.prop_right = right self.prop_top = top self.prop_bottom = bottom
# endregion init # region internal methods def _get_property_name(self) -> str: try: return self._property_name except AttributeError: self._property_name = "TableBorderDistances" return self._property_name # endregion internal methods # region dunder methods def __eq__(self, oth: object) -> bool: obj2 = None if isinstance(oth, TableBorderDistancesStruct): obj2 = oth.get_uno_struct() if getattr(oth, "typeName", None) == "com.sun.star.table.TableBorderDistances": obj2 = cast(TableBorderDistances, oth) if obj2: obj1 = self.get_uno_struct() return ( obj1.TopDistance == obj1.TopDistance and obj1.IsTopDistanceValid == obj1.IsTopDistanceValid and obj1.BottomDistance == obj1.BottomDistance and obj1.IsBottomDistanceValid == obj1.IsBottomDistanceValid and obj1.LeftDistance == obj1.LeftDistance and obj1.IsLeftDistanceValid == obj1.IsLeftDistanceValid and obj1.RightDistance == obj1.RightDistance and obj1.IsRightDistanceValid == obj1.IsRightDistanceValid ) return NotImplemented # endregion dunder methods # region methods
[docs] def get_uno_struct(self) -> TableBorderDistances: """ Gets UNO ``TableBorderDistances`` from instance. Returns: TableBorderDistances: ``TableBorderDistances`` instance """ return TableBorderDistances( TopDistance=self._get(self._props.top), IsTopDistanceValid=self._get(self._props.valid_top), BottomDistance=self._get(self._props.bottom), IsBottomDistanceValid=self._get(self._props.valid_bottom), LeftDistance=self._get(self._props.left), IsLeftDistanceValid=self._get(self._props.valid_left), RightDistance=self._get(self._props.right), IsRightDistanceValid=self._get(self._props.valid_right), )
# endregion methods # region overrides methods def _supported_services(self) -> Tuple[str, ...]: try: return self._supported_services_values except AttributeError: self._supported_services_values = ("com.sun.star.text.TextTable",) return self._supported_services_values # region apply() @overload def apply(self, obj: Any) -> None: # type: ignore ...
[docs] def apply(self, obj: Any, **kwargs) -> None: """ Applies tab properties to ``obj`` Args: obj (object): UNO object. Returns: None: """ if not mProps.Props.has(obj, self._get_property_name()): self._print_not_valid_srv("apply") return grad = self.get_uno_struct() props = {self._get_property_name(): grad} super().apply(obj=obj, override_dv=props)
# endregion apply() # endregion overrides methods # region static methods # region from_uno_struct() @overload @classmethod def from_uno_struct( cls: Type[_TTableBorderDistancesStruct], value: TableBorderDistances ) -> _TTableBorderDistancesStruct: ... @overload @classmethod def from_uno_struct( cls: Type[_TTableBorderDistancesStruct], value: TableBorderDistances, **kwargs ) -> _TTableBorderDistancesStruct: ...
[docs] @classmethod def from_uno_struct( cls: Type[_TTableBorderDistancesStruct], value: TableBorderDistances, **kwargs ) -> _TTableBorderDistancesStruct: """ Converts a ``TableBorderDistances`` instance to a ``TableBorderDistancesStruct``. Args: value (TableBorderDistances): UNO ``TableBorderDistances``. Returns: TableBorderDistancesStruct: ``TableBorderDistancesStruct`` set with ``TableBorderDistances`` properties. """ inst = cls(**kwargs) inst._set(inst._props.left, value.LeftDistance) inst._set(inst._props.right, value.RightDistance) inst._set(inst._props.top, value.TopDistance) inst._set(inst._props.bottom, value.BottomDistance) inst._set(inst._props.valid_left, value.IsLeftDistanceValid) inst._set(inst._props.valid_right, value.IsRightDistanceValid) inst._set(inst._props.valid_top, value.IsTopDistanceValid) inst._set(inst._props.valid_bottom, value.IsBottomDistanceValid) return inst
# endregion from_uno_struct() # region from_obj() @overload @classmethod def from_obj(cls: Type[_TTableBorderDistancesStruct], obj: Any) -> _TTableBorderDistancesStruct: ... @overload @classmethod def from_obj(cls: Type[_TTableBorderDistancesStruct], obj: Any, **kwargs) -> _TTableBorderDistancesStruct: ...
[docs] @classmethod def from_obj(cls: Type[_TTableBorderDistancesStruct], obj: Any, **kwargs) -> _TTableBorderDistancesStruct: """ Gets instance from object Args: obj (object): UNO object Raises: PropertyNotFoundError: If ``obj`` does not have required property Returns: TableBorderDistancesStruct: ``TableBorderDistancesStruct`` instance that represents ``obj`` crop properties. """ # sourcery skip: raise-from-previous-error # this nu is only used to get Property Name nu = cls(**kwargs) prop_name = nu._get_property_name() try: struct = cast(TableBorderDistances, mProps.Props.get(obj, prop_name)) except mEx.PropertyNotFoundError: raise mEx.PropertyNotFoundError(prop_name, f"from_obj() obj as no {prop_name} property") return cls.from_uno_struct(struct, **kwargs)
# endregion from_obj() # endregion static methods # region Style methods
[docs] def fmt_all(self: _TTableBorderDistancesStruct, value: float | UnitT) -> _TTableBorderDistancesStruct: """ Gets copy of instance with left, right, top, bottom set. Args: value (float, UnitT): Specifies crop in ``mm`` units or :ref:`proto_unit_obj`. Returns: CropStruct: Border Table """ cp = self.copy() cp.prop_top = value cp.prop_bottom = value cp.prop_left = value cp.prop_right = value return cp
[docs] def fmt_top(self: _TTableBorderDistancesStruct, value: float | UnitT) -> _TTableBorderDistancesStruct: """ Gets a copy of instance with top set. Args: value (float, UnitT): Specifies top crop in ``mm`` units or :ref:`proto_unit_obj`. Returns: CropStruct: """ cp = self.copy() cp.prop_top = value return cp
[docs] def fmt_bottom(self: _TTableBorderDistancesStruct, value: float | UnitT) -> _TTableBorderDistancesStruct: """ Gets a copy of instance with bottom set. Args: value (float, UnitT): Specifies bottom crop in ``mm`` units or :ref:`proto_unit_obj`. Returns: CropStruct: """ cp = self.copy() cp.prop_bottom = value return cp
[docs] def fmt_left(self: _TTableBorderDistancesStruct, value: float | UnitT) -> _TTableBorderDistancesStruct: """ Gets a copy of instance with left set. Args: value (float, UnitT): Specifies left crop in ``mm`` units or :ref:`proto_unit_obj`. Returns: CropStruct: """ cp = self.copy() cp.prop_left = value return cp
[docs] def fmt_right(self: _TTableBorderDistancesStruct, value: float | UnitT) -> _TTableBorderDistancesStruct: """ Gets a copy of instance with right set. Args: value (float, UnitT): Specifies right crop in ``mm`` units or :ref:`proto_unit_obj`. Returns: CropStruct: """ cp = self.copy() cp.prop_right = value return cp
# endregion Style methods # region Properties @property def prop_format_kind(self) -> FormatKind: """Gets the kind of style""" try: return self._format_kind_prop except AttributeError: self._format_kind_prop = FormatKind.STRUCT return self._format_kind_prop @property def prop_left(self) -> UnitMM: """Gets/Sets left value in ``mm`` units.""" pv = self._get(self._props.left) return UnitMM.from_mm100(pv) @prop_left.setter def prop_left(self, value: float | UnitT) -> None: try: self._set(self._props.left, value.get_value_mm100()) # type: ignore except AttributeError: self._set(self._props.left, UnitConvert.convert_mm_mm100(value)) # type: ignore self._set(self._props.valid_left, True) @property def prop_right(self) -> UnitMM: """Gets/Sets right value in ``mm`` units.""" pv = self._get(self._props.right) return UnitMM.from_mm100(pv) @prop_right.setter def prop_right(self, value: float | UnitT) -> None: try: self._set(self._props.right, value.get_value_mm100()) # type: ignore except AttributeError: self._set(self._props.right, UnitConvert.convert_mm_mm100(value)) # type: ignore self._set(self._props.valid_right, True) @property def prop_top(self) -> UnitMM: """Gets/Sets top value in ``mm`` units.""" pv = self._get(self._props.top) return UnitMM.from_mm100(pv) @prop_top.setter def prop_top(self, value: float | UnitT) -> None: try: self._set(self._props.top, value.get_value_mm100()) # type: ignore except AttributeError: self._set(self._props.top, UnitConvert.convert_mm_mm100(value)) # type: ignore self._set(self._props.valid_top, True) @property def prop_bottom(self) -> UnitMM: """Gets/Sets bottom value in ``mm`` units.""" pv = self._get(self._props.bottom) return UnitMM.from_mm100(pv) @prop_bottom.setter def prop_bottom(self, value: float | UnitT) -> None: try: self._set(self._props.bottom, value.get_value_mm100()) # type: ignore except AttributeError: self._set(self._props.bottom, UnitConvert.convert_mm_mm100(value)) # type: ignore self._set(self._props.valid_bottom, True) @property def _props(self) -> StructTableBorderDistancesProps: try: return self._props_internal_attributes except AttributeError: self._props_internal_attributes = StructTableBorderDistancesProps( left="LeftDistance", top="TopDistance", right="RightDistance", bottom="BottomDistance", valid_left="IsLeftDistanceValid", valid_top="IsTopDistanceValid", valid_right="IsRightDistanceValid", valid_bottom="IsBottomDistanceValid", ) return self._props_internal_attributes
# endregion Properties