add additional typing for calling events (#4218)
* add additional typing for calling events * simplify some code * self isn't with us * fix pyi
This commit is contained in:
parent
3eab2b6e7d
commit
fafad0e3d5
@ -38,6 +38,7 @@ from reflex.constants import (
|
|||||||
)
|
)
|
||||||
from reflex.constants.compiler import SpecialAttributes
|
from reflex.constants.compiler import SpecialAttributes
|
||||||
from reflex.event import (
|
from reflex.event import (
|
||||||
|
EventCallback,
|
||||||
EventChain,
|
EventChain,
|
||||||
EventChainVar,
|
EventChainVar,
|
||||||
EventHandler,
|
EventHandler,
|
||||||
@ -1126,6 +1127,8 @@ class Component(BaseComponent, ABC):
|
|||||||
for trigger in self.event_triggers.values():
|
for trigger in self.event_triggers.values():
|
||||||
if isinstance(trigger, EventChain):
|
if isinstance(trigger, EventChain):
|
||||||
for event in trigger.events:
|
for event in trigger.events:
|
||||||
|
if isinstance(event, EventCallback):
|
||||||
|
continue
|
||||||
if isinstance(event, EventSpec):
|
if isinstance(event, EventSpec):
|
||||||
if event.handler.state_full_name:
|
if event.handler.state_full_name:
|
||||||
return True
|
return True
|
||||||
|
126
reflex/event.py
126
reflex/event.py
@ -16,6 +16,7 @@ from typing import (
|
|||||||
Generic,
|
Generic,
|
||||||
List,
|
List,
|
||||||
Optional,
|
Optional,
|
||||||
|
Sequence,
|
||||||
Tuple,
|
Tuple,
|
||||||
Type,
|
Type,
|
||||||
TypeVar,
|
TypeVar,
|
||||||
@ -389,7 +390,9 @@ class CallableEventSpec(EventSpec):
|
|||||||
class EventChain(EventActionsMixin):
|
class EventChain(EventActionsMixin):
|
||||||
"""Container for a chain of events that will be executed in order."""
|
"""Container for a chain of events that will be executed in order."""
|
||||||
|
|
||||||
events: List[Union[EventSpec, EventVar]] = dataclasses.field(default_factory=list)
|
events: Sequence[Union[EventSpec, EventVar, EventCallback]] = dataclasses.field(
|
||||||
|
default_factory=list
|
||||||
|
)
|
||||||
|
|
||||||
args_spec: Optional[Callable] = dataclasses.field(default=None)
|
args_spec: Optional[Callable] = dataclasses.field(default=None)
|
||||||
|
|
||||||
@ -1445,13 +1448,8 @@ class LiteralEventChainVar(ArgsFunctionOperation, LiteralVar, EventChainVar):
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
G = ParamSpec("G")
|
|
||||||
|
|
||||||
IndividualEventType = Union[EventSpec, EventHandler, Callable[G, Any], Var[Any]]
|
|
||||||
|
|
||||||
EventType = Union[IndividualEventType[G], List[IndividualEventType[G]]]
|
|
||||||
|
|
||||||
P = ParamSpec("P")
|
P = ParamSpec("P")
|
||||||
|
Q = ParamSpec("Q")
|
||||||
T = TypeVar("T")
|
T = TypeVar("T")
|
||||||
V = TypeVar("V")
|
V = TypeVar("V")
|
||||||
V2 = TypeVar("V2")
|
V2 = TypeVar("V2")
|
||||||
@ -1473,55 +1471,73 @@ if sys.version_info >= (3, 10):
|
|||||||
"""
|
"""
|
||||||
self.func = func
|
self.func = func
|
||||||
|
|
||||||
|
@property
|
||||||
|
def prevent_default(self):
|
||||||
|
"""Prevent default behavior.
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
The event callback with prevent default behavior.
|
||||||
|
"""
|
||||||
|
return self
|
||||||
|
|
||||||
|
@property
|
||||||
|
def stop_propagation(self):
|
||||||
|
"""Stop event propagation.
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
The event callback with stop propagation behavior.
|
||||||
|
"""
|
||||||
|
return self
|
||||||
|
|
||||||
@overload
|
@overload
|
||||||
def __get__(
|
def __call__(
|
||||||
self: EventCallback[[V], T], instance: None, owner
|
self: EventCallback[Concatenate[V, Q], T], value: V | Var[V]
|
||||||
) -> Callable[[Union[Var[V], V]], EventSpec]: ...
|
) -> EventCallback[Q, T]: ...
|
||||||
|
|
||||||
|
@overload
|
||||||
|
def __call__(
|
||||||
|
self: EventCallback[Concatenate[V, V2, Q], T],
|
||||||
|
value: V | Var[V],
|
||||||
|
value2: V2 | Var[V2],
|
||||||
|
) -> EventCallback[Q, T]: ...
|
||||||
|
|
||||||
|
@overload
|
||||||
|
def __call__(
|
||||||
|
self: EventCallback[Concatenate[V, V2, V3, Q], T],
|
||||||
|
value: V | Var[V],
|
||||||
|
value2: V2 | Var[V2],
|
||||||
|
value3: V3 | Var[V3],
|
||||||
|
) -> EventCallback[Q, T]: ...
|
||||||
|
|
||||||
|
@overload
|
||||||
|
def __call__(
|
||||||
|
self: EventCallback[Concatenate[V, V2, V3, V4, Q], T],
|
||||||
|
value: V | Var[V],
|
||||||
|
value2: V2 | Var[V2],
|
||||||
|
value3: V3 | Var[V3],
|
||||||
|
value4: V4 | Var[V4],
|
||||||
|
) -> EventCallback[Q, T]: ...
|
||||||
|
|
||||||
|
def __call__(self, *values) -> EventCallback: # type: ignore
|
||||||
|
"""Call the function with the values.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
*values: The values to call the function with.
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
The function with the values.
|
||||||
|
"""
|
||||||
|
return self.func(*values) # type: ignore
|
||||||
|
|
||||||
@overload
|
@overload
|
||||||
def __get__(
|
def __get__(
|
||||||
self: EventCallback[[V, V2], T], instance: None, owner
|
self: EventCallback[P, T], instance: None, owner
|
||||||
) -> Callable[[Union[Var[V], V], Union[Var[V2], V2]], EventSpec]: ...
|
) -> EventCallback[P, T]: ...
|
||||||
|
|
||||||
@overload
|
|
||||||
def __get__(
|
|
||||||
self: EventCallback[[V, V2, V3], T], instance: None, owner
|
|
||||||
) -> Callable[
|
|
||||||
[Union[Var[V], V], Union[Var[V2], V2], Union[Var[V3], V3]],
|
|
||||||
EventSpec,
|
|
||||||
]: ...
|
|
||||||
|
|
||||||
@overload
|
|
||||||
def __get__(
|
|
||||||
self: EventCallback[[V, V2, V3, V4], T], instance: None, owner
|
|
||||||
) -> Callable[
|
|
||||||
[
|
|
||||||
Union[Var[V], V],
|
|
||||||
Union[Var[V2], V2],
|
|
||||||
Union[Var[V3], V3],
|
|
||||||
Union[Var[V4], V4],
|
|
||||||
],
|
|
||||||
EventSpec,
|
|
||||||
]: ...
|
|
||||||
|
|
||||||
@overload
|
|
||||||
def __get__(
|
|
||||||
self: EventCallback[[V, V2, V3, V4, V5], T], instance: None, owner
|
|
||||||
) -> Callable[
|
|
||||||
[
|
|
||||||
Union[Var[V], V],
|
|
||||||
Union[Var[V2], V2],
|
|
||||||
Union[Var[V3], V3],
|
|
||||||
Union[Var[V4], V4],
|
|
||||||
Union[Var[V5], V5],
|
|
||||||
],
|
|
||||||
EventSpec,
|
|
||||||
]: ...
|
|
||||||
|
|
||||||
@overload
|
@overload
|
||||||
def __get__(self, instance, owner) -> Callable[P, T]: ...
|
def __get__(self, instance, owner) -> Callable[P, T]: ...
|
||||||
|
|
||||||
def __get__(self, instance, owner) -> Callable:
|
def __get__(self, instance, owner) -> Callable: # type: ignore
|
||||||
"""Get the function with the instance bound to it.
|
"""Get the function with the instance bound to it.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
@ -1548,6 +1564,9 @@ if sys.version_info >= (3, 10):
|
|||||||
return func # type: ignore
|
return func # type: ignore
|
||||||
else:
|
else:
|
||||||
|
|
||||||
|
class EventCallback(Generic[P, T]):
|
||||||
|
"""A descriptor that wraps a function to be used as an event."""
|
||||||
|
|
||||||
def event_handler(func: Callable[P, T]) -> Callable[P, T]:
|
def event_handler(func: Callable[P, T]) -> Callable[P, T]:
|
||||||
"""Wrap a function to be used as an event.
|
"""Wrap a function to be used as an event.
|
||||||
|
|
||||||
@ -1560,6 +1579,17 @@ else:
|
|||||||
return func
|
return func
|
||||||
|
|
||||||
|
|
||||||
|
G = ParamSpec("G")
|
||||||
|
|
||||||
|
IndividualEventType = Union[
|
||||||
|
EventSpec, EventHandler, Callable[G, Any], EventCallback[G, Any], Var[Any]
|
||||||
|
]
|
||||||
|
|
||||||
|
ItemOrList = Union[V, List[V]]
|
||||||
|
|
||||||
|
EventType = ItemOrList[IndividualEventType[G]]
|
||||||
|
|
||||||
|
|
||||||
class EventNamespace(types.SimpleNamespace):
|
class EventNamespace(types.SimpleNamespace):
|
||||||
"""A namespace for event related classes."""
|
"""A namespace for event related classes."""
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user