reflex/pynecone/components/navigation/link.py
2023-05-11 18:41:42 -07:00

42 lines
1.1 KiB
Python

"""A link component."""
from pynecone.components.component import Component
from pynecone.components.libs.chakra import ChakraComponent
from pynecone.components.navigation.nextlink import NextLink
from pynecone.vars import Var
class Link(ChakraComponent):
"""Link to another page."""
tag = "Link"
# The rel.
rel: Var[str]
# The page to link to.
href: Var[str]
# The text to display.
text: Var[str]
# What the link renders too.
as_: Var[str] = "span" # type: ignore
# If true, the link will open in new tab.
is_external: Var[bool]
@classmethod
def create(cls, *children, **props) -> Component:
"""Create a NextJS link component, wrapping a Chakra link component.
Args:
*children: The children to pass to the component.
**props: The attributes to pass to the component.
Returns:
The component.
"""
kwargs = {"href": props.pop("href") if "href" in props else "#"}
return NextLink.create(super().create(*children, **props), **kwargs)