Source code for ooodev.adapter.adapter_base

from __future__ import annotations
from typing import Any, TYPE_CHECKING

# pylint: disable=unused-import, useless-import-alias
from ooodev.events.args.event_args import EventArgs
from ooodev.events.args.event_args import AbstractEvent
from ooodev.events.lo_events import Events
from ooodev.events.args.generic_args import GenericArgs
from ooodev.mock import mock_g
from ooodev.events.partial.events_partial import EventsPartial

if mock_g.DOCS_BUILDING:
    from ooodev.mock import unohelper
else:
    import unohelper

if TYPE_CHECKING:
    from ooodev.utils.type_var import EventCallback
else:
    EventCallback = Any


[docs]class AdapterBase(unohelper.Base, EventsPartial): # type: ignore """ Base Class for Listeners in the ``adapter`` name space. .. versionchanged:: 0.27.2 Now inherits from EventsPartial. """
[docs] def __init__(self, trigger_args: GenericArgs | None) -> None: """ Constructor Arguments: trigger_args (GenericArgs, Optional): Args that are passed to events when they are triggered. """ super().__init__() self.__events = Events(source=self, trigger_args=trigger_args) EventsPartial.__init__(self, events=self.__events)
def _trigger_event(self, name: str, event: Any) -> None: """ Triggers and event and wraps it in an ``EventArgs`` instance. Args: name (str): Event Name event (Any): An event instance to trigger. """ event_arg = EventArgs(self.__class__.__qualname__) event_arg.event_data = event self.trigger_event(name, event_arg) # self._events.trigger(name, event_arg) def _trigger_direct_event(self, name: str, event: AbstractEvent) -> None: """ Triggers a direct event without wrapping it in an ``EventArgs`` instance. Args: name (str): Event Name event (AbstractEvent): An event instance to trigger. """ self.trigger_event(name, event) # self._events.trigger(name, event)
[docs] def on(self, event_name: str, cb: EventCallback) -> None: """ Adds a listener for an event Args: event_name (str): Event name to add listener for. Usually the name of the method being listened to such as ``windowOpened`` cb (EventCallback): Callback event. """ self.subscribe_event(event_name, cb)
# self._events.on(event_name, cb)
[docs] def off(self, event_name: str, cb: EventCallback) -> None: """ Removes a listener for an event Args: event_name (str): Event Name cb (EventCallback): Callback event """ self.unsubscribe_event(event_name, cb)
# self._events.remove(event_name, cb)
[docs] def clear(self) -> None: """ Removes all listeners for all events .. versionadded:: 0.13.7 """ self.__events.clear()